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