b8782d2a47
Add pci-bus-spapr node, that produces pci-bus. Move QPCIBusSPAPR struct declaration in its header (since it will be needed by other drivers) and introduce a setter method for drivers that do not need to allocate but have to initialize QPCIBusSPAPR. Signed-off-by: Emanuele Giuseppe Esposito <e.emanuelegiuseppe@gmail.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
42 lines
949 B
C
42 lines
949 B
C
/*
|
|
* libqos PCI bindings for SPAPR
|
|
*
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
|
* See the COPYING file in the top-level directory.
|
|
*/
|
|
|
|
#ifndef LIBQOS_PCI_SPAPR_H
|
|
#define LIBQOS_PCI_SPAPR_H
|
|
|
|
#include "libqos/malloc.h"
|
|
#include "libqos/pci.h"
|
|
#include "libqos/qgraph.h"
|
|
|
|
/* From include/hw/pci-host/spapr.h */
|
|
|
|
typedef struct QPCIWindow {
|
|
uint64_t pci_base; /* window address in PCI space */
|
|
uint64_t size; /* window size */
|
|
} QPCIWindow;
|
|
|
|
typedef struct QPCIBusSPAPR {
|
|
QOSGraphObject obj;
|
|
QPCIBus bus;
|
|
QGuestAllocator *alloc;
|
|
|
|
uint64_t buid;
|
|
|
|
uint64_t pio_cpu_base;
|
|
QPCIWindow pio;
|
|
|
|
uint64_t mmio32_cpu_base;
|
|
QPCIWindow mmio32;
|
|
} QPCIBusSPAPR;
|
|
|
|
void qpci_init_spapr(QPCIBusSPAPR *ret, QTestState *qts,
|
|
QGuestAllocator *alloc);
|
|
QPCIBus *qpci_new_spapr(QTestState *qts, QGuestAllocator *alloc);
|
|
void qpci_free_spapr(QPCIBus *bus);
|
|
|
|
#endif
|