xref: /openbmc/qemu/include/hw/pci/pcie_regs.h (revision 6fc69312313a2207a8fbc083658e0548746b707f)
10d09e41aSPaolo Bonzini /*
20d09e41aSPaolo Bonzini  * constants for pcie configurations space from pci express spec.
30d09e41aSPaolo Bonzini  *
40d09e41aSPaolo Bonzini  * TODO:
50d09e41aSPaolo Bonzini  * Those constants and macros should go to Linux pci_regs.h
60d09e41aSPaolo Bonzini  * Once they're merged, they will go away.
70d09e41aSPaolo Bonzini  */
80d09e41aSPaolo Bonzini #ifndef QEMU_PCIE_REGS_H
90d09e41aSPaolo Bonzini #define QEMU_PCIE_REGS_H
100d09e41aSPaolo Bonzini 
110d09e41aSPaolo Bonzini 
120d09e41aSPaolo Bonzini /* express capability */
130d09e41aSPaolo Bonzini 
146383292aSDmitry Fleytman #define PCI_EXP_VER1_SIZEOF             0x14 /* express capability of ver. 1 */
150d09e41aSPaolo Bonzini #define PCI_EXP_VER2_SIZEOF             0x3c /* express capability of ver. 2 */
160d09e41aSPaolo Bonzini #define PCI_EXT_CAP_VER_SHIFT           16
170d09e41aSPaolo Bonzini #define PCI_EXT_CAP_NEXT_SHIFT          20
180d09e41aSPaolo Bonzini #define PCI_EXT_CAP_NEXT_MASK           (0xffc << PCI_EXT_CAP_NEXT_SHIFT)
190d09e41aSPaolo Bonzini 
200d09e41aSPaolo Bonzini #define PCI_EXT_CAP(id, ver, next)                                      \
210d09e41aSPaolo Bonzini     ((id) |                                                             \
220d09e41aSPaolo Bonzini      ((ver) << PCI_EXT_CAP_VER_SHIFT) |                                 \
230d09e41aSPaolo Bonzini      ((next) << PCI_EXT_CAP_NEXT_SHIFT))
240d09e41aSPaolo Bonzini 
250d09e41aSPaolo Bonzini #define PCI_EXT_CAP_ALIGN               4
260d09e41aSPaolo Bonzini #define PCI_EXT_CAP_ALIGNUP(x)                                  \
270d09e41aSPaolo Bonzini     (((x) + PCI_EXT_CAP_ALIGN - 1) & ~(PCI_EXT_CAP_ALIGN - 1))
280d09e41aSPaolo Bonzini 
290d09e41aSPaolo Bonzini /* PCI_EXP_FLAGS */
306383292aSDmitry Fleytman #define PCI_EXP_FLAGS_VER1              1
316383292aSDmitry Fleytman #define PCI_EXP_FLAGS_VER2              2
32786a4ea8SStefan Hajnoczi #define PCI_EXP_FLAGS_IRQ_SHIFT         ctz32(PCI_EXP_FLAGS_IRQ)
33786a4ea8SStefan Hajnoczi #define PCI_EXP_FLAGS_TYPE_SHIFT        ctz32(PCI_EXP_FLAGS_TYPE)
340d09e41aSPaolo Bonzini 
350d09e41aSPaolo Bonzini /* PCI_EXP_LINK{CAP, STA} */
360d09e41aSPaolo Bonzini /* link speed */
37d96a0ac7SAlex Williamson typedef enum PCIExpLinkSpeed {
38d96a0ac7SAlex Williamson     QEMU_PCI_EXP_LNK_2_5GT = 1,
39d96a0ac7SAlex Williamson     QEMU_PCI_EXP_LNK_5GT,
40d96a0ac7SAlex Williamson     QEMU_PCI_EXP_LNK_8GT,
41d96a0ac7SAlex Williamson     QEMU_PCI_EXP_LNK_16GT,
42*c08da86dSLukas Stockner     QEMU_PCI_EXP_LNK_32GT,
43*c08da86dSLukas Stockner     QEMU_PCI_EXP_LNK_64GT,
44d96a0ac7SAlex Williamson } PCIExpLinkSpeed;
45d96a0ac7SAlex Williamson 
46d96a0ac7SAlex Williamson #define QEMU_PCI_EXP_LNKCAP_MLS(speed)  (speed)
47d96a0ac7SAlex Williamson #define QEMU_PCI_EXP_LNKSTA_CLS         QEMU_PCI_EXP_LNKCAP_MLS
48d96a0ac7SAlex Williamson 
49d96a0ac7SAlex Williamson typedef enum PCIExpLinkWidth {
50d96a0ac7SAlex Williamson     QEMU_PCI_EXP_LNK_X1 = 1,
51d96a0ac7SAlex Williamson     QEMU_PCI_EXP_LNK_X2 = 2,
52d96a0ac7SAlex Williamson     QEMU_PCI_EXP_LNK_X4 = 4,
53d96a0ac7SAlex Williamson     QEMU_PCI_EXP_LNK_X8 = 8,
54d96a0ac7SAlex Williamson     QEMU_PCI_EXP_LNK_X12 = 12,
55d96a0ac7SAlex Williamson     QEMU_PCI_EXP_LNK_X16 = 16,
56d96a0ac7SAlex Williamson     QEMU_PCI_EXP_LNK_X32 = 32,
57d96a0ac7SAlex Williamson } PCIExpLinkWidth;
580d09e41aSPaolo Bonzini 
59786a4ea8SStefan Hajnoczi #define PCI_EXP_LNK_MLW_SHIFT           ctz32(PCI_EXP_LNKCAP_MLW)
60d96a0ac7SAlex Williamson #define QEMU_PCI_EXP_LNKCAP_MLW(width)  (width << PCI_EXP_LNK_MLW_SHIFT)
61d96a0ac7SAlex Williamson #define QEMU_PCI_EXP_LNKSTA_NLW         QEMU_PCI_EXP_LNKCAP_MLW
620d09e41aSPaolo Bonzini 
630d09e41aSPaolo Bonzini /* PCI_EXP_LINKCAP */
64786a4ea8SStefan Hajnoczi #define PCI_EXP_LNKCAP_ASPMS_SHIFT      ctz32(PCI_EXP_LNKCAP_ASPMS)
650d09e41aSPaolo Bonzini #define PCI_EXP_LNKCAP_ASPMS_0S         (1 << PCI_EXP_LNKCAP_ASPMS_SHIFT)
660d09e41aSPaolo Bonzini 
67786a4ea8SStefan Hajnoczi #define PCI_EXP_LNKCAP_PN_SHIFT         ctz32(PCI_EXP_LNKCAP_PN)
680d09e41aSPaolo Bonzini 
69786a4ea8SStefan Hajnoczi #define PCI_EXP_SLTCAP_PSN_SHIFT        ctz32(PCI_EXP_SLTCAP_PSN)
700d09e41aSPaolo Bonzini 
710d09e41aSPaolo Bonzini #define PCI_EXP_SLTCTL_SUPPORTED        \
720d09e41aSPaolo Bonzini             (PCI_EXP_SLTCTL_ABPE |      \
730d09e41aSPaolo Bonzini              PCI_EXP_SLTCTL_PDCE |      \
740d09e41aSPaolo Bonzini              PCI_EXP_SLTCTL_CCIE |      \
750d09e41aSPaolo Bonzini              PCI_EXP_SLTCTL_HPIE |      \
760d09e41aSPaolo Bonzini              PCI_EXP_SLTCTL_AIC |       \
770d09e41aSPaolo Bonzini              PCI_EXP_SLTCTL_PCC |       \
780d09e41aSPaolo Bonzini              PCI_EXP_SLTCTL_EIC)
790d09e41aSPaolo Bonzini 
800d09e41aSPaolo Bonzini #define PCI_EXP_DEVCAP2_EFF             0x100000
810d09e41aSPaolo Bonzini #define PCI_EXP_DEVCAP2_EETLPP          0x200000
820d09e41aSPaolo Bonzini 
8330b04f87SChen Fan #define PCI_EXP_DEVCTL2_EETLPPB         0x8000
840d09e41aSPaolo Bonzini 
850d09e41aSPaolo Bonzini /* ARI */
860d09e41aSPaolo Bonzini #define PCI_ARI_VER                     1
870d09e41aSPaolo Bonzini #define PCI_ARI_SIZEOF                  8
880d09e41aSPaolo Bonzini 
890d09e41aSPaolo Bonzini /* AER */
900d09e41aSPaolo Bonzini #define PCI_ERR_VER                     2
910d09e41aSPaolo Bonzini #define PCI_ERR_SIZEOF                  0x48
920d09e41aSPaolo Bonzini 
930d09e41aSPaolo Bonzini #define PCI_ERR_UNC_SDN                 0x00000020      /* surprise down */
940d09e41aSPaolo Bonzini #define PCI_ERR_UNC_ACSV                0x00200000      /* ACS Violation */
950d09e41aSPaolo Bonzini #define PCI_ERR_UNC_INTN                0x00400000      /* Internal Error */
960d09e41aSPaolo Bonzini #define PCI_ERR_UNC_MCBTLP              0x00800000      /* MC Blcoked TLP */
970d09e41aSPaolo Bonzini #define PCI_ERR_UNC_ATOP_EBLOCKED       0x01000000      /* atomic op egress blocked */
980d09e41aSPaolo Bonzini #define PCI_ERR_UNC_TLP_PRF_BLOCKED     0x02000000      /* TLP Prefix Blocked */
990d09e41aSPaolo Bonzini #define PCI_ERR_COR_ADV_NONFATAL        0x00002000      /* Advisory Non-Fatal */
1000d09e41aSPaolo Bonzini #define PCI_ERR_COR_INTERNAL            0x00004000      /* Corrected Internal */
1010d09e41aSPaolo Bonzini #define PCI_ERR_COR_HL_OVERFLOW         0x00008000      /* Header Long Overflow */
1020d09e41aSPaolo Bonzini #define PCI_ERR_CAP_FEP_MASK            0x0000001f
1030d09e41aSPaolo Bonzini #define PCI_ERR_CAP_MHRC                0x00000200
1040d09e41aSPaolo Bonzini #define PCI_ERR_CAP_MHRE                0x00000400
1050d09e41aSPaolo Bonzini #define PCI_ERR_CAP_TLP                 0x00000800
1060d09e41aSPaolo Bonzini 
1070d09e41aSPaolo Bonzini #define PCI_ERR_HEADER_LOG_SIZE         16
1080d09e41aSPaolo Bonzini #define PCI_ERR_TLP_PREFIX_LOG          0x38
1090d09e41aSPaolo Bonzini #define PCI_ERR_TLP_PREFIX_LOG_SIZE     16
1100d09e41aSPaolo Bonzini 
1110d09e41aSPaolo Bonzini #define PCI_SEC_STATUS_RCV_SYSTEM_ERROR         0x4000
1120d09e41aSPaolo Bonzini 
1130d09e41aSPaolo Bonzini /* aer root error command/status */
1140d09e41aSPaolo Bonzini #define PCI_ERR_ROOT_CMD_EN_MASK        (PCI_ERR_ROOT_CMD_COR_EN |      \
1150d09e41aSPaolo Bonzini                                          PCI_ERR_ROOT_CMD_NONFATAL_EN | \
1160d09e41aSPaolo Bonzini                                          PCI_ERR_ROOT_CMD_FATAL_EN)
1170d09e41aSPaolo Bonzini 
1180d09e41aSPaolo Bonzini #define PCI_ERR_ROOT_IRQ_MAX            32
1190d09e41aSPaolo Bonzini #define PCI_ERR_ROOT_IRQ                0xf8000000
120786a4ea8SStefan Hajnoczi #define PCI_ERR_ROOT_IRQ_SHIFT          ctz32(PCI_ERR_ROOT_IRQ)
1210d09e41aSPaolo Bonzini #define PCI_ERR_ROOT_STATUS_REPORT_MASK (PCI_ERR_ROOT_COR_RCV |         \
1220d09e41aSPaolo Bonzini                                          PCI_ERR_ROOT_MULTI_COR_RCV |   \
1230d09e41aSPaolo Bonzini                                          PCI_ERR_ROOT_UNCOR_RCV |       \
1240d09e41aSPaolo Bonzini                                          PCI_ERR_ROOT_MULTI_UNCOR_RCV | \
1250d09e41aSPaolo Bonzini                                          PCI_ERR_ROOT_FIRST_FATAL |     \
1260d09e41aSPaolo Bonzini                                          PCI_ERR_ROOT_NONFATAL_RCV |    \
1270d09e41aSPaolo Bonzini                                          PCI_ERR_ROOT_FATAL_RCV)
1280d09e41aSPaolo Bonzini 
1290d09e41aSPaolo Bonzini #define PCI_ERR_UNC_SUPPORTED           (PCI_ERR_UNC_DLP |              \
1300d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_SDN |              \
1310d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_POISON_TLP |       \
1320d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_FCP |              \
1330d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_COMP_TIME |        \
1340d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_COMP_ABORT |       \
1350d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_UNX_COMP |         \
1360d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_RX_OVER |          \
1370d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_MALF_TLP |         \
1380d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_ECRC |             \
1390d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_UNSUP |            \
1400d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_ACSV |             \
1410d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_INTN |             \
1420d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_MCBTLP |           \
1430d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_ATOP_EBLOCKED |    \
1440d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_TLP_PRF_BLOCKED)
1450d09e41aSPaolo Bonzini 
146010746aeSJonathan Cameron #define PCI_ERR_UNC_MASK_DEFAULT        (PCI_ERR_UNC_INTN | \
147010746aeSJonathan Cameron                                          PCI_ERR_UNC_TLP_PRF_BLOCKED)
148010746aeSJonathan Cameron 
1490d09e41aSPaolo Bonzini #define PCI_ERR_UNC_SEVERITY_DEFAULT    (PCI_ERR_UNC_DLP |              \
1500d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_SDN |              \
1510d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_FCP |              \
1520d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_RX_OVER |          \
1530d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_MALF_TLP |         \
1540d09e41aSPaolo Bonzini                                          PCI_ERR_UNC_INTN)
1550d09e41aSPaolo Bonzini 
1560d09e41aSPaolo Bonzini #define PCI_ERR_COR_SUPPORTED           (PCI_ERR_COR_RCVR |             \
1570d09e41aSPaolo Bonzini                                          PCI_ERR_COR_BAD_TLP |          \
1580d09e41aSPaolo Bonzini                                          PCI_ERR_COR_BAD_DLLP |         \
1590d09e41aSPaolo Bonzini                                          PCI_ERR_COR_REP_ROLL |         \
1600d09e41aSPaolo Bonzini                                          PCI_ERR_COR_REP_TIMER |        \
1610d09e41aSPaolo Bonzini                                          PCI_ERR_COR_ADV_NONFATAL |     \
1620d09e41aSPaolo Bonzini                                          PCI_ERR_COR_INTERNAL |         \
1630d09e41aSPaolo Bonzini                                          PCI_ERR_COR_HL_OVERFLOW)
1640d09e41aSPaolo Bonzini 
1650d09e41aSPaolo Bonzini #define PCI_ERR_COR_MASK_DEFAULT        (PCI_ERR_COR_ADV_NONFATAL |     \
1660d09e41aSPaolo Bonzini                                          PCI_ERR_COR_INTERNAL |         \
1670d09e41aSPaolo Bonzini                                          PCI_ERR_COR_HL_OVERFLOW)
1680d09e41aSPaolo Bonzini 
169db891a9bSKnut Omang /* ACS */
170db891a9bSKnut Omang #define PCI_ACS_VER                     0x1
171db891a9bSKnut Omang #define PCI_ACS_SIZEOF                  8
172db891a9bSKnut Omang 
1735fb52f6cSHuai-Cheng Kuo /* DOE Capability Register Fields */
1745fb52f6cSHuai-Cheng Kuo #define PCI_DOE_VER                     0x1
1755fb52f6cSHuai-Cheng Kuo #define PCI_DOE_SIZEOF                  24
1765fb52f6cSHuai-Cheng Kuo 
1770d09e41aSPaolo Bonzini #endif /* QEMU_PCIE_REGS_H */
178