aboutsummaryrefslogtreecommitdiffstats
path: root/aer.h
blob: fa488b293dfd8617359b14697c87b05ae85bc70c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#ifndef AER_H
#define AER_H

#include <stdint.h>

#define AER_VERSION "0.1"

struct aer_error_inj
{
	int8_t bus;
	int8_t dev;
	int8_t fn;
	int32_t uncor_status;
	int32_t cor_status;
	int32_t header_log0;
	int32_t header_log1;
	int32_t header_log2;
	int32_t header_log3;
	uint16_t domain;
};

#define  PCI_ERR_UNC_TRAIN	0x00000001	/* Training */
#define  PCI_ERR_UNC_DLP	0x00000010	/* Data Link Protocol */
#define  PCI_ERR_UNC_POISON_TLP	0x00001000	/* Poisoned TLP */
#define  PCI_ERR_UNC_FCP	0x00002000	/* Flow Control Protocol */
#define  PCI_ERR_UNC_COMP_TIME	0x00004000	/* Completion Timeout */
#define  PCI_ERR_UNC_COMP_ABORT	0x00008000	/* Completer Abort */
#define  PCI_ERR_UNC_UNX_COMP	0x00010000	/* Unexpected Completion */
#define  PCI_ERR_UNC_RX_OVER	0x00020000	/* Receiver Overflow */
#define  PCI_ERR_UNC_MALF_TLP	0x00040000	/* Malformed TLP */
#define  PCI_ERR_UNC_ECRC	0x00080000	/* ECRC Error Status */
#define  PCI_ERR_UNC_UNSUP	0x00100000	/* Unsupported Request */
#define  PCI_ERR_COR_RCVR	0x00000001	/* Receiver Error Status */
#define  PCI_ERR_COR_BAD_TLP	0x00000040	/* Bad TLP Status */
#define  PCI_ERR_COR_BAD_DLLP	0x00000080	/* Bad DLLP Status */
#define  PCI_ERR_COR_REP_ROLL	0x00000100	/* REPLAY_NUM Rollover */
#define  PCI_ERR_COR_REP_TIMER	0x00001000	/* Replay Timer Timeout */

extern void init_aer(struct aer_error_inj *err);
extern void submit_aer(struct aer_error_inj *err);
extern int parse_pci_id(const char *str, struct aer_error_inj *err);
extern int parse_data(char **argv);

extern char *filename;
extern int yylineno;
extern void yyerror(char const *msg, ...);
extern int yylex(void);
extern int yyparse(void);

#endif