158ea30f5SMarkus Armbruster #ifndef HW_XEN_LEGACY_BACKEND_H 258ea30f5SMarkus Armbruster #define HW_XEN_LEGACY_BACKEND_H 3d94f9486Saliguori 40d09e41aSPaolo Bonzini #include "hw/xen/xen_common.h" 5*b6cacfeaSDavid Woodhouse #include "hw/xen/xen_backend_ops.h" 6f0021dbaSEmil Condrea #include "hw/xen/xen_pvdev.h" 71422e32dSPaolo Bonzini #include "net/net.h" 8db1015e9SEduardo Habkost #include "qom/object.h" 9d94f9486Saliguori 10873d57abSJuergen Gross #define TYPE_XENSYSDEV "xen-sysdev" 11873d57abSJuergen Gross #define TYPE_XENSYSBUS "xen-sysbus" 123a6c9172SJuergen Gross #define TYPE_XENBACKEND "xen-backend" 133a6c9172SJuergen Gross 14694b3d28SEduardo Habkost typedef struct XenLegacyDevice XenLegacyDevice; 152211118aSEduardo Habkost DECLARE_INSTANCE_CHECKER(XenLegacyDevice, XENBACKEND, 168110fa1dSEduardo Habkost TYPE_XENBACKEND) 17873d57abSJuergen Gross 18d94f9486Saliguori /* variables */ 19d94f9486Saliguori extern struct xs_handle *xenstore; 202c8b24a3Saliguori extern const char *xen_protocol; 219432e53aSJuergen Gross extern DeviceState *xen_sysdev; 22873d57abSJuergen Gross extern BusState *xen_sysbus; 23d94f9486Saliguori 24637c53ffSJuergen Gross int xenstore_mkdir(char *path, int p); 252d0ed5e6SPaul Durrant int xenstore_write_be_str(struct XenLegacyDevice *xendev, const char *node, 262d0ed5e6SPaul Durrant const char *val); 272d0ed5e6SPaul Durrant int xenstore_write_be_int(struct XenLegacyDevice *xendev, const char *node, 282d0ed5e6SPaul Durrant int ival); 292d0ed5e6SPaul Durrant int xenstore_write_be_int64(struct XenLegacyDevice *xendev, const char *node, 302d0ed5e6SPaul Durrant int64_t ival); 312d0ed5e6SPaul Durrant char *xenstore_read_be_str(struct XenLegacyDevice *xendev, const char *node); 322d0ed5e6SPaul Durrant int xenstore_read_be_int(struct XenLegacyDevice *xendev, const char *node, 332d0ed5e6SPaul Durrant int *ival); 342d0ed5e6SPaul Durrant void xenstore_update_fe(char *watch, struct XenLegacyDevice *xendev); 35046db9beSEmil Condrea void xenstore_update_be(char *watch, char *type, int dom, 36046db9beSEmil Condrea struct XenDevOps *ops); 372d0ed5e6SPaul Durrant char *xenstore_read_fe_str(struct XenLegacyDevice *xendev, const char *node); 382d0ed5e6SPaul Durrant int xenstore_read_fe_int(struct XenLegacyDevice *xendev, const char *node, 392d0ed5e6SPaul Durrant int *ival); 402d0ed5e6SPaul Durrant int xenstore_read_fe_uint64(struct XenLegacyDevice *xendev, const char *node, 41b9730c5bSEmil Condrea uint64_t *uval); 42d94f9486Saliguori 432d0ed5e6SPaul Durrant void xen_be_check_state(struct XenLegacyDevice *xendev); 44d94f9486Saliguori 45d94f9486Saliguori /* xen backend driver bits */ 4679807f3eSDavid Woodhouse void xen_be_init(void); 47d94f9486Saliguori int xen_be_register(const char *type, struct XenDevOps *ops); 482d0ed5e6SPaul Durrant int xen_be_set_state(struct XenLegacyDevice *xendev, enum xenbus_state state); 492d0ed5e6SPaul Durrant int xen_be_bind_evtchn(struct XenLegacyDevice *xendev); 502d0ed5e6SPaul Durrant void xen_be_set_max_grant_refs(struct XenLegacyDevice *xendev, 519838824aSPaul Durrant unsigned int nr_refs); 522d0ed5e6SPaul Durrant void *xen_be_map_grant_refs(struct XenLegacyDevice *xendev, uint32_t *refs, 539838824aSPaul Durrant unsigned int nr_refs, int prot); 542d0ed5e6SPaul Durrant void xen_be_unmap_grant_refs(struct XenLegacyDevice *xendev, void *ptr, 559838824aSPaul Durrant unsigned int nr_refs); 569838824aSPaul Durrant 579838824aSPaul Durrant typedef struct XenGrantCopySegment { 589838824aSPaul Durrant union { 599838824aSPaul Durrant void *virt; 609838824aSPaul Durrant struct { 619838824aSPaul Durrant uint32_t ref; 629838824aSPaul Durrant off_t offset; 639838824aSPaul Durrant } foreign; 649838824aSPaul Durrant } source, dest; 659838824aSPaul Durrant size_t len; 669838824aSPaul Durrant } XenGrantCopySegment; 679838824aSPaul Durrant 682d0ed5e6SPaul Durrant int xen_be_copy_grant_refs(struct XenLegacyDevice *xendev, 699838824aSPaul Durrant bool to_domain, XenGrantCopySegment segs[], 709838824aSPaul Durrant unsigned int nr_segs); 719838824aSPaul Durrant 722d0ed5e6SPaul Durrant static inline void *xen_be_map_grant_ref(struct XenLegacyDevice *xendev, 739838824aSPaul Durrant uint32_t ref, int prot) 749838824aSPaul Durrant { 759838824aSPaul Durrant return xen_be_map_grant_refs(xendev, &ref, 1, prot); 769838824aSPaul Durrant } 779838824aSPaul Durrant 782d0ed5e6SPaul Durrant static inline void xen_be_unmap_grant_ref(struct XenLegacyDevice *xendev, 799838824aSPaul Durrant void *ptr) 809838824aSPaul Durrant { 819838824aSPaul Durrant return xen_be_unmap_grant_refs(xendev, ptr, 1); 829838824aSPaul Durrant } 83d94f9486Saliguori 84e57dd20bSaliguori /* actual backend drivers */ 85e57dd20bSaliguori extern struct XenDevOps xen_console_ops; /* xen_console.c */ 86e7151f83Saliguori extern struct XenDevOps xen_kbdmouse_ops; /* xen_framebuffer.c */ 87e7151f83Saliguori extern struct XenDevOps xen_framebuffer_ops; /* xen_framebuffer.c */ 8862d23efaSaliguori extern struct XenDevOps xen_blkdev_ops; /* xen_disk.c */ 89e737b6d5SStefano Stabellini #ifdef CONFIG_VIRTFS 90e737b6d5SStefano Stabellini extern struct XenDevOps xen_9pfs_ops; /* xen-9p-backend.c */ 91e737b6d5SStefano Stabellini #endif 92e613b064Saliguori extern struct XenDevOps xen_netdev_ops; /* xen_nic.c */ 93816ac92eSJuergen Gross #ifdef CONFIG_USB_LIBUSB 94816ac92eSJuergen Gross extern struct XenDevOps xen_usb_ops; /* xen-usb.c */ 95816ac92eSJuergen Gross #endif 96e7151f83Saliguori 972c8b24a3Saliguori /* configuration (aka xenbus setup) */ 9828695489SAnthony Liguori void xen_config_cleanup(void); 992c8b24a3Saliguori int xen_config_dev_blk(DriveInfo *disk); 1002c8b24a3Saliguori int xen_config_dev_nic(NICInfo *nic); 1019306acb5Saliguori int xen_config_dev_vfb(int vdev, const char *type); 1029306acb5Saliguori int xen_config_dev_vkbd(int vdev); 1039306acb5Saliguori int xen_config_dev_console(int vdev); 1042c8b24a3Saliguori 10558ea30f5SMarkus Armbruster #endif /* HW_XEN_LEGACY_BACKEND_H */ 106