1f17068c1SStefano Stabellini #ifndef HW_XEN_HVM_COMMON_H
2f17068c1SStefano Stabellini #define HW_XEN_HVM_COMMON_H
3f17068c1SStefano Stabellini
4*65132d39SPhilippe Mathieu-Daudé #include "qemu/queue.h"
5*65132d39SPhilippe Mathieu-Daudé #include "exec/hwaddr.h"
6f17068c1SStefano Stabellini #include "hw/xen/xen_native.h"
7*65132d39SPhilippe Mathieu-Daudé #include "hw/xen/xen_backend_ops.h"
8f17068c1SStefano Stabellini #include <xen/hvm/ioreq.h>
9f17068c1SStefano Stabellini
10b934c3faSPhilippe Mathieu-Daudé extern MemoryRegion xen_memory;
119ecdd4bfSEdgar E. Iglesias extern MemoryRegion xen_grants;
12f17068c1SStefano Stabellini extern MemoryListener xen_io_listener;
13f17068c1SStefano Stabellini extern DeviceListener xen_device_listener;
14f17068c1SStefano Stabellini
15f17068c1SStefano Stabellini //#define DEBUG_XEN_HVM
16f17068c1SStefano Stabellini
17f17068c1SStefano Stabellini #ifdef DEBUG_XEN_HVM
18f17068c1SStefano Stabellini #define DPRINTF(fmt, ...) \
19f17068c1SStefano Stabellini do { fprintf(stderr, "xen: " fmt, ## __VA_ARGS__); } while (0)
20f17068c1SStefano Stabellini #else
21f17068c1SStefano Stabellini #define DPRINTF(fmt, ...) \
22f17068c1SStefano Stabellini do { } while (0)
23f17068c1SStefano Stabellini #endif
24f17068c1SStefano Stabellini
259ecdd4bfSEdgar E. Iglesias #define XEN_GRANT_ADDR_OFF (1ULL << 63)
269ecdd4bfSEdgar E. Iglesias
xen_vcpu_eport(shared_iopage_t * shared_page,int i)27f17068c1SStefano Stabellini static inline uint32_t xen_vcpu_eport(shared_iopage_t *shared_page, int i)
28f17068c1SStefano Stabellini {
29f17068c1SStefano Stabellini return shared_page->vcpu_ioreq[i].vp_eport;
30f17068c1SStefano Stabellini }
xen_vcpu_ioreq(shared_iopage_t * shared_page,int vcpu)31f17068c1SStefano Stabellini static inline ioreq_t *xen_vcpu_ioreq(shared_iopage_t *shared_page, int vcpu)
32f17068c1SStefano Stabellini {
33f17068c1SStefano Stabellini return &shared_page->vcpu_ioreq[vcpu];
34f17068c1SStefano Stabellini }
35f17068c1SStefano Stabellini
36f17068c1SStefano Stabellini #define BUFFER_IO_MAX_DELAY 100
37f17068c1SStefano Stabellini
38f17068c1SStefano Stabellini typedef struct XenPhysmap {
39f17068c1SStefano Stabellini hwaddr start_addr;
40f17068c1SStefano Stabellini ram_addr_t size;
41f17068c1SStefano Stabellini const char *name;
42f17068c1SStefano Stabellini hwaddr phys_offset;
43f17068c1SStefano Stabellini
44f17068c1SStefano Stabellini QLIST_ENTRY(XenPhysmap) list;
45f17068c1SStefano Stabellini } XenPhysmap;
46f17068c1SStefano Stabellini
47f17068c1SStefano Stabellini typedef struct XenPciDevice {
48f17068c1SStefano Stabellini PCIDevice *pci_dev;
49f17068c1SStefano Stabellini uint32_t sbdf;
50f17068c1SStefano Stabellini QLIST_ENTRY(XenPciDevice) entry;
51f17068c1SStefano Stabellini } XenPciDevice;
52f17068c1SStefano Stabellini
53f17068c1SStefano Stabellini typedef struct XenIOState {
54f17068c1SStefano Stabellini ioservid_t ioservid;
55f17068c1SStefano Stabellini shared_iopage_t *shared_page;
56f17068c1SStefano Stabellini buffered_iopage_t *buffered_io_page;
57f17068c1SStefano Stabellini xenforeignmemory_resource_handle *fres;
58f17068c1SStefano Stabellini QEMUTimer *buffered_io_timer;
59f17068c1SStefano Stabellini CPUState **cpu_by_vcpu_id;
60f17068c1SStefano Stabellini /* the evtchn port for polling the notification, */
61f17068c1SStefano Stabellini evtchn_port_t *ioreq_local_port;
62f17068c1SStefano Stabellini /* evtchn remote and local ports for buffered io */
63f17068c1SStefano Stabellini evtchn_port_t bufioreq_remote_port;
64f17068c1SStefano Stabellini evtchn_port_t bufioreq_local_port;
65f17068c1SStefano Stabellini /* the evtchn fd for polling */
66f17068c1SStefano Stabellini xenevtchn_handle *xce_handle;
67f17068c1SStefano Stabellini /* which vcpu we are serving */
68f17068c1SStefano Stabellini int send_vcpu;
69f17068c1SStefano Stabellini
70f17068c1SStefano Stabellini struct xs_handle *xenstore;
71f17068c1SStefano Stabellini MemoryListener memory_listener;
72f17068c1SStefano Stabellini MemoryListener io_listener;
73f17068c1SStefano Stabellini QLIST_HEAD(, XenPciDevice) dev_list;
74f17068c1SStefano Stabellini DeviceListener device_listener;
75f17068c1SStefano Stabellini
76b2150e40SEdgar E. Iglesias bool has_bufioreq;
77b2150e40SEdgar E. Iglesias
78f17068c1SStefano Stabellini Notifier exit;
79f17068c1SStefano Stabellini } XenIOState;
80f17068c1SStefano Stabellini
81f17068c1SStefano Stabellini void xen_exit_notifier(Notifier *n, void *data);
82f17068c1SStefano Stabellini
83f17068c1SStefano Stabellini void xen_region_add(MemoryListener *listener, MemoryRegionSection *section);
84f17068c1SStefano Stabellini void xen_region_del(MemoryListener *listener, MemoryRegionSection *section);
85f17068c1SStefano Stabellini void xen_io_add(MemoryListener *listener, MemoryRegionSection *section);
86f17068c1SStefano Stabellini void xen_io_del(MemoryListener *listener, MemoryRegionSection *section);
87f17068c1SStefano Stabellini void xen_device_realize(DeviceListener *listener, DeviceState *dev);
88f17068c1SStefano Stabellini void xen_device_unrealize(DeviceListener *listener, DeviceState *dev);
89f17068c1SStefano Stabellini
90f17068c1SStefano Stabellini void xen_hvm_change_state_handler(void *opaque, bool running, RunState rstate);
91f17068c1SStefano Stabellini void xen_register_ioreq(XenIOState *state, unsigned int max_cpus,
92b2150e40SEdgar E. Iglesias uint8_t handle_bufioreq,
93bcb40db0SPeter Maydell const MemoryListener *xen_memory_listener);
94f17068c1SStefano Stabellini
95f17068c1SStefano Stabellini void cpu_ioreq_pio(ioreq_t *req);
96f17068c1SStefano Stabellini #endif /* HW_XEN_HVM_COMMON_H */
97