pseries: Add PCI MSI/MSI-X support
[qemu/ar7.git] / hw / xen-host-pci-device.h
blob0079daca518508a31720f3575fa2ed8c589ed16a
1 #ifndef XEN_HOST_PCI_DEVICE_H
2 #define XEN_HOST_PCI_DEVICE_H
4 #include "pci.h"
6 enum {
7 XEN_HOST_PCI_REGION_TYPE_IO = 1 << 1,
8 XEN_HOST_PCI_REGION_TYPE_MEM = 1 << 2,
9 XEN_HOST_PCI_REGION_TYPE_PREFETCH = 1 << 3,
10 XEN_HOST_PCI_REGION_TYPE_MEM_64 = 1 << 4,
13 typedef struct XenHostPCIIORegion {
14 pcibus_t base_addr;
15 pcibus_t size;
16 uint8_t type;
17 uint8_t bus_flags; /* Bus-specific bits */
18 } XenHostPCIIORegion;
20 typedef struct XenHostPCIDevice {
21 uint16_t domain;
22 uint8_t bus;
23 uint8_t dev;
24 uint8_t func;
26 uint16_t vendor_id;
27 uint16_t device_id;
28 int irq;
30 XenHostPCIIORegion io_regions[PCI_NUM_REGIONS - 1];
31 XenHostPCIIORegion rom;
33 bool is_virtfn;
35 int config_fd;
36 } XenHostPCIDevice;
38 int xen_host_pci_device_get(XenHostPCIDevice *d, uint16_t domain,
39 uint8_t bus, uint8_t dev, uint8_t func);
40 void xen_host_pci_device_put(XenHostPCIDevice *pci_dev);
42 int xen_host_pci_get_byte(XenHostPCIDevice *d, int pos, uint8_t *p);
43 int xen_host_pci_get_word(XenHostPCIDevice *d, int pos, uint16_t *p);
44 int xen_host_pci_get_long(XenHostPCIDevice *d, int pos, uint32_t *p);
45 int xen_host_pci_get_block(XenHostPCIDevice *d, int pos, uint8_t *buf,
46 int len);
47 int xen_host_pci_set_byte(XenHostPCIDevice *d, int pos, uint8_t data);
48 int xen_host_pci_set_word(XenHostPCIDevice *d, int pos, uint16_t data);
49 int xen_host_pci_set_long(XenHostPCIDevice *d, int pos, uint32_t data);
50 int xen_host_pci_set_block(XenHostPCIDevice *d, int pos, uint8_t *buf,
51 int len);
53 int xen_host_pci_find_ext_cap_offset(XenHostPCIDevice *s, uint32_t cap);
55 #endif /* !XEN_HOST_PCI_DEVICE_H_ */