mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-03 15:53:54 -06:00
hw/pci-bridge: Make PCIe and CXL PXB Devices inherit from TYPE_PXB_DEV
Previously, PXB_CXL_DEVICE, PXB_PCIE_DEVICE and PXB_DEVICE all have PCI_DEVICE as their direct parent but share a common state struct PXBDev. convert_to_pxb() is used to get the PXBDev instance from which ever of these types it is called on. This patch switches to an explicit hierarchy based on shared functionality. To allow use of OBJECT_DECLARE_SIMPLE_TYPE() whilst minimizing code changes, all types are renamed to have the postfix _DEV rather than _DEVICE. The new heirarchy has PXB_CXL_DEV with parent PXB_PCIE_DEV which in turn has parent PXB_DEV which continues to have parent PCI_DEVICE. This allows simple use of PXB_DEV() etc rather than a custom function + removal of duplicated properties and moving the CXL specific elements out of struct PXBDev. Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com> Message-Id: <20230420142750.6950-3-Jonathan.Cameron@huawei.com> Reviewed-by: Thomas Huth <thuth@redhat.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
This commit is contained in:
parent
9136f661c7
commit
c28db9e000
5 changed files with 50 additions and 58 deletions
|
@ -84,7 +84,7 @@ struct PCIBridge {
|
|||
#define PCI_BRIDGE_DEV_PROP_SHPC "shpc"
|
||||
typedef struct CXLHost CXLHost;
|
||||
|
||||
struct PXBDev {
|
||||
typedef struct PXBDev {
|
||||
/*< private >*/
|
||||
PCIDevice parent_obj;
|
||||
/*< public >*/
|
||||
|
@ -92,15 +92,27 @@ struct PXBDev {
|
|||
uint8_t bus_nr;
|
||||
uint16_t numa_node;
|
||||
bool bypass_iommu;
|
||||
bool hdm_for_passthrough;
|
||||
struct cxl_dev {
|
||||
CXLHost *cxl_host_bridge; /* Pointer to a CXLHost */
|
||||
} cxl;
|
||||
};
|
||||
} PXBDev;
|
||||
|
||||
#define TYPE_PXB_CXL_DEVICE "pxb-cxl"
|
||||
DECLARE_INSTANCE_CHECKER(PXBDev, PXB_CXL_DEV,
|
||||
TYPE_PXB_CXL_DEVICE)
|
||||
typedef struct PXBPCIEDev {
|
||||
/*< private >*/
|
||||
PXBDev parent_obj;
|
||||
} PXBPCIEDev;
|
||||
|
||||
#define TYPE_PXB_DEV "pxb"
|
||||
OBJECT_DECLARE_SIMPLE_TYPE(PXBDev, PXB_DEV)
|
||||
|
||||
typedef struct PXBCXLDev {
|
||||
/*< private >*/
|
||||
PXBPCIEDev parent_obj;
|
||||
/*< public >*/
|
||||
|
||||
bool hdm_for_passthrough;
|
||||
CXLHost *cxl_host_bridge; /* Pointer to a CXLHost */
|
||||
} PXBCXLDev;
|
||||
|
||||
#define TYPE_PXB_CXL_DEV "pxb-cxl"
|
||||
OBJECT_DECLARE_SIMPLE_TYPE(PXBCXLDev, PXB_CXL_DEV)
|
||||
|
||||
int pci_bridge_ssvid_init(PCIDevice *dev, uint8_t offset,
|
||||
uint16_t svid, uint16_t ssid,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue