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