
* Update to QEMU v9.0.0 --------- Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Fabiano Rosas <farosas@suse.de> Signed-off-by: Peter Xu <peterx@redhat.com> Signed-off-by: Thomas Huth <thuth@redhat.com> Signed-off-by: Cédric Le Goater <clg@redhat.com> Signed-off-by: Zheyu Ma <zheyuma97@gmail.com> Signed-off-by: Ido Plat <ido.plat@ibm.com> Signed-off-by: Ilya Leoshkevich <iii@linux.ibm.com> Signed-off-by: Markus Armbruster <armbru@redhat.com> Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru> Signed-off-by: David Hildenbrand <david@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com> Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com> Signed-off-by: Fiona Ebner <f.ebner@proxmox.com> Signed-off-by: Gregory Price <gregory.price@memverge.com> Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com> Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> Signed-off-by: Lorenz Brun <lorenz@brun.one> Signed-off-by: Yao Xingtao <yaoxt.fnst@fujitsu.com> Signed-off-by: Arnaud Minier <arnaud.minier@telecom-paris.fr> Signed-off-by: Inès Varhol <ines.varhol@telecom-paris.fr> Signed-off-by: BALATON Zoltan <balaton@eik.bme.hu> Signed-off-by: Igor Mammedov <imammedo@redhat.com> Signed-off-by: Akihiko Odaki <akihiko.odaki@daynix.com> Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Sven Schnelle <svens@stackframe.org> Signed-off-by: Daniel Henrique Barboza <dbarboza@ventanamicro.com> Signed-off-by: Christian Schoenebeck <qemu_oss@crudebyte.com> Signed-off-by: Jason Wang <jasowang@redhat.com> Signed-off-by: Helge Deller <deller@gmx.de> Signed-off-by: Nicholas Piggin <npiggin@gmail.com> Signed-off-by: Benjamin Gray <bgray@linux.ibm.com> Signed-off-by: Avihai Horon <avihaih@nvidia.com> Signed-off-by: Michael Tokarev <mjt@tls.msk.ru> Signed-off-by: Joonas Kankaala <joonas.a.kankaala@gmail.com> Signed-off-by: Marcin Juszkiewicz <marcin.juszkiewicz@linaro.org> Signed-off-by: Stefan Weil <sw@weilnetz.de> Signed-off-by: Zhao Liu <zhao1.liu@intel.com> Signed-off-by: Glenn Miles <milesg@linux.ibm.com> Signed-off-by: Oleg Sviridov <oleg.sviridov@red-soft.ru> Signed-off-by: Artem Chernyshev <artem.chernyshev@red-soft.ru> Signed-off-by: Yajun Wu <yajunw@nvidia.com> Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk> Signed-off-by: Pierre-Clément Tosi <ptosi@google.com> Signed-off-by: Lei Wang <lei4.wang@intel.com> Signed-off-by: Wei Wang <wei.w.wang@intel.com> Signed-off-by: Martin Hundebøll <martin@geanix.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Manos Pitsidianakis <manos.pitsidianakis@linaro.org> Signed-off-by: Wafer <wafer@jaguarmicro.com> Signed-off-by: Yuxue Liu <yuxue.liu@jaguarmicro.com> Signed-off-by: Gerd Hoffmann <kraxel@redhat.com> Signed-off-by: Nguyen Dinh Phi <phind.uet@gmail.com> Signed-off-by: Zack Buhman <zack@buhman.org> Signed-off-by: Keith Packard <keithp@keithp.com> Signed-off-by: Yuquan Wang wangyuquan1236@phytium.com.cn Signed-off-by: Matheus Tavares Bernardino <quic_mathbern@quicinc.com> Signed-off-by: Cindy Lu <lulu@redhat.com> Co-authored-by: Peter Maydell <peter.maydell@linaro.org> Co-authored-by: Fabiano Rosas <farosas@suse.de> Co-authored-by: Peter Xu <peterx@redhat.com> Co-authored-by: Thomas Huth <thuth@redhat.com> Co-authored-by: Cédric Le Goater <clg@redhat.com> Co-authored-by: Zheyu Ma <zheyuma97@gmail.com> Co-authored-by: Ido Plat <ido.plat@ibm.com> Co-authored-by: Ilya Leoshkevich <iii@linux.ibm.com> Co-authored-by: Markus Armbruster <armbru@redhat.com> Co-authored-by: Marc-André Lureau <marcandre.lureau@redhat.com> Co-authored-by: Paolo Bonzini <pbonzini@redhat.com> Co-authored-by: Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru> Co-authored-by: David Hildenbrand <david@redhat.com> Co-authored-by: Kevin Wolf <kwolf@redhat.com> Co-authored-by: Stefan Reiter <s.reiter@proxmox.com> Co-authored-by: Fiona Ebner <f.ebner@proxmox.com> Co-authored-by: Gregory Price <gregory.price@memverge.com> Co-authored-by: Lorenz Brun <lorenz@brun.one> Co-authored-by: Yao Xingtao <yaoxt.fnst@fujitsu.com> Co-authored-by: Philippe Mathieu-Daudé <philmd@linaro.org> Co-authored-by: Arnaud Minier <arnaud.minier@telecom-paris.fr> Co-authored-by: BALATON Zoltan <balaton@eik.bme.hu> Co-authored-by: Igor Mammedov <imammedo@redhat.com> Co-authored-by: Akihiko Odaki <akihiko.odaki@daynix.com> Co-authored-by: Richard Henderson <richard.henderson@linaro.org> Co-authored-by: Sven Schnelle <svens@stackframe.org> Co-authored-by: Daniel Henrique Barboza <dbarboza@ventanamicro.com> Co-authored-by: Helge Deller <deller@kernel.org> Co-authored-by: Harsh Prateek Bora <harshpb@linux.ibm.com> Co-authored-by: Benjamin Gray <bgray@linux.ibm.com> Co-authored-by: Nicholas Piggin <npiggin@gmail.com> Co-authored-by: Avihai Horon <avihaih@nvidia.com> Co-authored-by: Michael Tokarev <mjt@tls.msk.ru> Co-authored-by: Joonas Kankaala <joonas.a.kankaala@gmail.com> Co-authored-by: Marcin Juszkiewicz <marcin.juszkiewicz@linaro.org> Co-authored-by: Stefan Weil <sw@weilnetz.de> Co-authored-by: Dayu Liu <liu.dayu@zte.com.cn> Co-authored-by: Zhao Liu <zhao1.liu@intel.com> Co-authored-by: Glenn Miles <milesg@linux.vnet.ibm.com> Co-authored-by: Artem Chernyshev <artem.chernyshev@red-soft.ru> Co-authored-by: Yajun Wu <yajunw@nvidia.com> Co-authored-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk> Co-authored-by: Pierre-Clément Tosi <ptosi@google.com> Co-authored-by: Wei Wang <wei.w.wang@intel.com> Co-authored-by: Martin Hundebøll <martin@geanix.com> Co-authored-by: Michael S. Tsirkin <mst@redhat.com> Co-authored-by: Manos Pitsidianakis <manos.pitsidianakis@linaro.org> Co-authored-by: Wafer <wafer@jaguarmicro.com> Co-authored-by: lyx634449800 <yuxue.liu@jaguarmicro.com> Co-authored-by: Gerd Hoffmann <kraxel@redhat.com> Co-authored-by: Nguyen Dinh Phi <phind.uet@gmail.com> Co-authored-by: Zack Buhman <zack@buhman.org> Co-authored-by: Keith Packard <keithp@keithp.com> Co-authored-by: Yuquan Wang <wangyuquan1236@phytium.com.cn> Co-authored-by: Matheus Tavares Bernardino <quic_mathbern@quicinc.com> Co-authored-by: Cindy Lu <lulu@redhat.com>
178 lines
7.7 KiB
C
178 lines
7.7 KiB
C
/*
|
|
* constants for pcie configurations space from pci express spec.
|
|
*
|
|
* TODO:
|
|
* Those constants and macros should go to Linux pci_regs.h
|
|
* Once they're merged, they will go away.
|
|
*/
|
|
#ifndef QEMU_PCIE_REGS_H
|
|
#define QEMU_PCIE_REGS_H
|
|
|
|
|
|
/* express capability */
|
|
|
|
#define PCI_EXP_VER1_SIZEOF 0x14 /* express capability of ver. 1 */
|
|
#define PCI_EXP_VER2_SIZEOF 0x3c /* express capability of ver. 2 */
|
|
#define PCI_EXT_CAP_VER_SHIFT 16
|
|
#define PCI_EXT_CAP_NEXT_SHIFT 20
|
|
#define PCI_EXT_CAP_NEXT_MASK (0xffc << PCI_EXT_CAP_NEXT_SHIFT)
|
|
|
|
#define PCI_EXT_CAP(id, ver, next) \
|
|
((id) | \
|
|
((ver) << PCI_EXT_CAP_VER_SHIFT) | \
|
|
((next) << PCI_EXT_CAP_NEXT_SHIFT))
|
|
|
|
#define PCI_EXT_CAP_ALIGN 4
|
|
#define PCI_EXT_CAP_ALIGNUP(x) \
|
|
(((x) + PCI_EXT_CAP_ALIGN - 1) & ~(PCI_EXT_CAP_ALIGN - 1))
|
|
|
|
/* PCI_EXP_FLAGS */
|
|
#define PCI_EXP_FLAGS_VER1 1
|
|
#define PCI_EXP_FLAGS_VER2 2
|
|
#define PCI_EXP_FLAGS_IRQ_SHIFT ctz32(PCI_EXP_FLAGS_IRQ)
|
|
#define PCI_EXP_FLAGS_TYPE_SHIFT ctz32(PCI_EXP_FLAGS_TYPE)
|
|
|
|
/* PCI_EXP_LINK{CAP, STA} */
|
|
/* link speed */
|
|
typedef enum PCIExpLinkSpeed {
|
|
QEMU_PCI_EXP_LNK_2_5GT = 1,
|
|
QEMU_PCI_EXP_LNK_5GT,
|
|
QEMU_PCI_EXP_LNK_8GT,
|
|
QEMU_PCI_EXP_LNK_16GT,
|
|
QEMU_PCI_EXP_LNK_32GT,
|
|
QEMU_PCI_EXP_LNK_64GT,
|
|
} PCIExpLinkSpeed;
|
|
|
|
#define QEMU_PCI_EXP_LNKCAP_MLS(speed) (speed)
|
|
#define QEMU_PCI_EXP_LNKSTA_CLS QEMU_PCI_EXP_LNKCAP_MLS
|
|
|
|
typedef enum PCIExpLinkWidth {
|
|
QEMU_PCI_EXP_LNK_X1 = 1,
|
|
QEMU_PCI_EXP_LNK_X2 = 2,
|
|
QEMU_PCI_EXP_LNK_X4 = 4,
|
|
QEMU_PCI_EXP_LNK_X8 = 8,
|
|
QEMU_PCI_EXP_LNK_X12 = 12,
|
|
QEMU_PCI_EXP_LNK_X16 = 16,
|
|
QEMU_PCI_EXP_LNK_X32 = 32,
|
|
} PCIExpLinkWidth;
|
|
|
|
#define PCI_EXP_LNK_MLW_SHIFT ctz32(PCI_EXP_LNKCAP_MLW)
|
|
#define QEMU_PCI_EXP_LNKCAP_MLW(width) (width << PCI_EXP_LNK_MLW_SHIFT)
|
|
#define QEMU_PCI_EXP_LNKSTA_NLW QEMU_PCI_EXP_LNKCAP_MLW
|
|
|
|
/* PCI_EXP_LINKCAP */
|
|
#define PCI_EXP_LNKCAP_ASPMS_SHIFT ctz32(PCI_EXP_LNKCAP_ASPMS)
|
|
#define PCI_EXP_LNKCAP_ASPMS_0S (1 << PCI_EXP_LNKCAP_ASPMS_SHIFT)
|
|
|
|
#define PCI_EXP_LNKCAP_PN_SHIFT ctz32(PCI_EXP_LNKCAP_PN)
|
|
|
|
#define PCI_EXP_SLTCAP_PSN_SHIFT ctz32(PCI_EXP_SLTCAP_PSN)
|
|
|
|
#define PCI_EXP_SLTCTL_SUPPORTED \
|
|
(PCI_EXP_SLTCTL_ABPE | \
|
|
PCI_EXP_SLTCTL_PDCE | \
|
|
PCI_EXP_SLTCTL_CCIE | \
|
|
PCI_EXP_SLTCTL_HPIE | \
|
|
PCI_EXP_SLTCTL_AIC | \
|
|
PCI_EXP_SLTCTL_PCC | \
|
|
PCI_EXP_SLTCTL_EIC)
|
|
|
|
#define PCI_EXP_DEVCAP2_EFF 0x100000
|
|
#define PCI_EXP_DEVCAP2_EETLPP 0x200000
|
|
|
|
#define PCI_EXP_DEVCTL2_EETLPPB 0x8000
|
|
|
|
/* ARI */
|
|
#define PCI_ARI_VER 1
|
|
#define PCI_ARI_SIZEOF 8
|
|
|
|
/* AER */
|
|
#define PCI_ERR_VER 2
|
|
#define PCI_ERR_SIZEOF 0x48
|
|
|
|
#define PCI_ERR_UNC_SDN 0x00000020 /* surprise down */
|
|
#define PCI_ERR_UNC_ACSV 0x00200000 /* ACS Violation */
|
|
#define PCI_ERR_UNC_INTN 0x00400000 /* Internal Error */
|
|
#define PCI_ERR_UNC_MCBTLP 0x00800000 /* MC Blcoked TLP */
|
|
#define PCI_ERR_UNC_ATOP_EBLOCKED 0x01000000 /* atomic op egress blocked */
|
|
#define PCI_ERR_UNC_TLP_PRF_BLOCKED 0x02000000 /* TLP Prefix Blocked */
|
|
#define PCI_ERR_COR_ADV_NONFATAL 0x00002000 /* Advisory Non-Fatal */
|
|
#define PCI_ERR_COR_INTERNAL 0x00004000 /* Corrected Internal */
|
|
#define PCI_ERR_COR_HL_OVERFLOW 0x00008000 /* Header Long Overflow */
|
|
#define PCI_ERR_CAP_FEP_MASK 0x0000001f
|
|
#define PCI_ERR_CAP_MHRC 0x00000200
|
|
#define PCI_ERR_CAP_MHRE 0x00000400
|
|
#define PCI_ERR_CAP_TLP 0x00000800
|
|
|
|
#define PCI_ERR_HEADER_LOG_SIZE 16
|
|
#define PCI_ERR_TLP_PREFIX_LOG 0x38
|
|
#define PCI_ERR_TLP_PREFIX_LOG_SIZE 16
|
|
|
|
#define PCI_SEC_STATUS_RCV_SYSTEM_ERROR 0x4000
|
|
|
|
/* aer root error command/status */
|
|
#define PCI_ERR_ROOT_CMD_EN_MASK (PCI_ERR_ROOT_CMD_COR_EN | \
|
|
PCI_ERR_ROOT_CMD_NONFATAL_EN | \
|
|
PCI_ERR_ROOT_CMD_FATAL_EN)
|
|
|
|
#define PCI_ERR_ROOT_IRQ_MAX 32
|
|
#define PCI_ERR_ROOT_IRQ 0xf8000000
|
|
#define PCI_ERR_ROOT_IRQ_SHIFT ctz32(PCI_ERR_ROOT_IRQ)
|
|
#define PCI_ERR_ROOT_STATUS_REPORT_MASK (PCI_ERR_ROOT_COR_RCV | \
|
|
PCI_ERR_ROOT_MULTI_COR_RCV | \
|
|
PCI_ERR_ROOT_UNCOR_RCV | \
|
|
PCI_ERR_ROOT_MULTI_UNCOR_RCV | \
|
|
PCI_ERR_ROOT_FIRST_FATAL | \
|
|
PCI_ERR_ROOT_NONFATAL_RCV | \
|
|
PCI_ERR_ROOT_FATAL_RCV)
|
|
|
|
#define PCI_ERR_UNC_SUPPORTED (PCI_ERR_UNC_DLP | \
|
|
PCI_ERR_UNC_SDN | \
|
|
PCI_ERR_UNC_POISON_TLP | \
|
|
PCI_ERR_UNC_FCP | \
|
|
PCI_ERR_UNC_COMP_TIME | \
|
|
PCI_ERR_UNC_COMP_ABORT | \
|
|
PCI_ERR_UNC_UNX_COMP | \
|
|
PCI_ERR_UNC_RX_OVER | \
|
|
PCI_ERR_UNC_MALF_TLP | \
|
|
PCI_ERR_UNC_ECRC | \
|
|
PCI_ERR_UNC_UNSUP | \
|
|
PCI_ERR_UNC_ACSV | \
|
|
PCI_ERR_UNC_INTN | \
|
|
PCI_ERR_UNC_MCBTLP | \
|
|
PCI_ERR_UNC_ATOP_EBLOCKED | \
|
|
PCI_ERR_UNC_TLP_PRF_BLOCKED)
|
|
|
|
#define PCI_ERR_UNC_MASK_DEFAULT (PCI_ERR_UNC_INTN | \
|
|
PCI_ERR_UNC_TLP_PRF_BLOCKED)
|
|
|
|
#define PCI_ERR_UNC_SEVERITY_DEFAULT (PCI_ERR_UNC_DLP | \
|
|
PCI_ERR_UNC_SDN | \
|
|
PCI_ERR_UNC_FCP | \
|
|
PCI_ERR_UNC_RX_OVER | \
|
|
PCI_ERR_UNC_MALF_TLP | \
|
|
PCI_ERR_UNC_INTN)
|
|
|
|
#define PCI_ERR_COR_SUPPORTED (PCI_ERR_COR_RCVR | \
|
|
PCI_ERR_COR_BAD_TLP | \
|
|
PCI_ERR_COR_BAD_DLLP | \
|
|
PCI_ERR_COR_REP_ROLL | \
|
|
PCI_ERR_COR_REP_TIMER | \
|
|
PCI_ERR_COR_ADV_NONFATAL | \
|
|
PCI_ERR_COR_INTERNAL | \
|
|
PCI_ERR_COR_HL_OVERFLOW)
|
|
|
|
#define PCI_ERR_COR_MASK_DEFAULT (PCI_ERR_COR_ADV_NONFATAL | \
|
|
PCI_ERR_COR_INTERNAL | \
|
|
PCI_ERR_COR_HL_OVERFLOW)
|
|
|
|
/* ACS */
|
|
#define PCI_ACS_VER 0x1
|
|
#define PCI_ACS_SIZEOF 8
|
|
|
|
/* DOE Capability Register Fields */
|
|
#define PCI_DOE_VER 0x1
|
|
#define PCI_DOE_SIZEOF 24
|
|
|
|
#endif /* QEMU_PCIE_REGS_H */
|