| /* | 
 |  * QEMU PowerPC PowerNV Proxy PHB model | 
 |  * | 
 |  * Copyright (c) 2022, IBM Corporation. | 
 |  * | 
 |  * This code is licensed under the GPL version 2 or later. See the | 
 |  * COPYING file in the top-level directory. | 
 |  */ | 
 |  | 
 | #ifndef PCI_HOST_PNV_PHB_H | 
 | #define PCI_HOST_PNV_PHB_H | 
 |  | 
 | #include "hw/pci/pcie_host.h" | 
 | #include "hw/pci/pcie_port.h" | 
 | #include "hw/ppc/pnv.h" | 
 | #include "qom/object.h" | 
 |  | 
 | typedef struct PnvPhb4PecState PnvPhb4PecState; | 
 |  | 
 | struct PnvPHB { | 
 |     PCIExpressHost parent_obj; | 
 |  | 
 |     uint32_t chip_id; | 
 |     uint32_t phb_id; | 
 |     uint32_t version; | 
 |     char bus_path[8]; | 
 |  | 
 |     PnvChip *chip; | 
 |  | 
 |     PnvPhb4PecState *pec; | 
 |  | 
 |     /* The PHB backend (PnvPHB3, PnvPHB4 ...) being used */ | 
 |     Object *backend; | 
 | }; | 
 |  | 
 | #define TYPE_PNV_PHB "pnv-phb" | 
 | OBJECT_DECLARE_SIMPLE_TYPE(PnvPHB, PNV_PHB) | 
 |  | 
 | /* | 
 |  * PHB PCIe Root port | 
 |  */ | 
 | #define PNV_PHB3_DEVICE_ID         0x03dc | 
 | #define PNV_PHB4_DEVICE_ID         0x04c1 | 
 | #define PNV_PHB5_DEVICE_ID         0x0652 | 
 |  | 
 | typedef struct PnvPHBRootPort { | 
 |     PCIESlot parent_obj; | 
 |  | 
 |     uint32_t version; | 
 | } PnvPHBRootPort; | 
 |  | 
 | #define TYPE_PNV_PHB_ROOT_PORT "pnv-phb-root-port" | 
 | OBJECT_DECLARE_SIMPLE_TYPE(PnvPHBRootPort, PNV_PHB_ROOT_PORT) | 
 |  | 
 | #endif /* PCI_HOST_PNV_PHB_H */ |