xen-hvm-common.h 2.8 KB

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