]>
Commit | Line | Data |
---|---|---|
108f7bba PD |
1 | /* |
2 | * Copyright (c) 2018 Citrix Systems Inc. | |
3 | * | |
4 | * This work is licensed under the terms of the GNU GPL, version 2 or later. | |
5 | * See the COPYING file in the top-level directory. | |
6 | */ | |
7 | ||
8 | #ifndef HW_XEN_BUS_H | |
9 | #define HW_XEN_BUS_H | |
10 | ||
094a2239 | 11 | #include "hw/xen/xen_common.h" |
108f7bba | 12 | #include "hw/sysbus.h" |
82a29e30 | 13 | #include "qemu/notify.h" |
db1015e9 | 14 | #include "qom/object.h" |
82a29e30 PD |
15 | |
16 | typedef void (*XenWatchHandler)(void *opaque); | |
17 | ||
374752a2 | 18 | typedef struct XenWatchList XenWatchList; |
82a29e30 | 19 | typedef struct XenWatch XenWatch; |
c0b336ea | 20 | typedef struct XenEventChannel XenEventChannel; |
108f7bba | 21 | |
db1015e9 | 22 | struct XenDevice { |
108f7bba | 23 | DeviceState qdev; |
094a2239 PD |
24 | domid_t frontend_id; |
25 | char *name; | |
d198b711 PD |
26 | struct xs_handle *xsh; |
27 | XenWatchList *watch_list; | |
094a2239 PD |
28 | char *backend_path, *frontend_path; |
29 | enum xenbus_state backend_state, frontend_state; | |
30 | Notifier exit; | |
b6af8926 PD |
31 | XenWatch *backend_state_watch, *frontend_state_watch; |
32 | bool backend_online; | |
33 | XenWatch *backend_online_watch; | |
4b34b5b1 PD |
34 | xengnttab_handle *xgth; |
35 | bool feature_grant_copy; | |
3809f758 | 36 | bool inactive; |
c0b336ea | 37 | QLIST_HEAD(, XenEventChannel) event_channels; |
3809f758 | 38 | QLIST_ENTRY(XenDevice) list; |
db1015e9 EH |
39 | }; |
40 | typedef struct XenDevice XenDevice; | |
108f7bba | 41 | |
094a2239 | 42 | typedef char *(*XenDeviceGetName)(XenDevice *xendev, Error **errp); |
108f7bba | 43 | typedef void (*XenDeviceRealize)(XenDevice *xendev, Error **errp); |
82a29e30 PD |
44 | typedef void (*XenDeviceFrontendChanged)(XenDevice *xendev, |
45 | enum xenbus_state frontend_state, | |
46 | Error **errp); | |
b69c3c21 | 47 | typedef void (*XenDeviceUnrealize)(XenDevice *xendev); |
108f7bba | 48 | |
db1015e9 | 49 | struct XenDeviceClass { |
108f7bba PD |
50 | /*< private >*/ |
51 | DeviceClass parent_class; | |
52 | /*< public >*/ | |
094a2239 PD |
53 | const char *backend; |
54 | const char *device; | |
55 | XenDeviceGetName get_name; | |
108f7bba | 56 | XenDeviceRealize realize; |
82a29e30 | 57 | XenDeviceFrontendChanged frontend_changed; |
108f7bba | 58 | XenDeviceUnrealize unrealize; |
db1015e9 | 59 | }; |
108f7bba PD |
60 | |
61 | #define TYPE_XEN_DEVICE "xen-device" | |
a489d195 | 62 | OBJECT_DECLARE_TYPE(XenDevice, XenDeviceClass, XEN_DEVICE) |
108f7bba | 63 | |
db1015e9 | 64 | struct XenBus { |
108f7bba | 65 | BusState qbus; |
094a2239 PD |
66 | domid_t backend_id; |
67 | struct xs_handle *xsh; | |
374752a2 | 68 | XenWatchList *watch_list; |
c4583c8c PD |
69 | unsigned int backend_types; |
70 | XenWatch **backend_watch; | |
3809f758 | 71 | QLIST_HEAD(, XenDevice) inactive_devices; |
db1015e9 | 72 | }; |
108f7bba | 73 | |
db1015e9 | 74 | struct XenBusClass { |
108f7bba PD |
75 | /*< private >*/ |
76 | BusClass parent_class; | |
db1015e9 | 77 | }; |
108f7bba PD |
78 | |
79 | #define TYPE_XEN_BUS "xen-bus" | |
c821774a | 80 | OBJECT_DECLARE_TYPE(XenBus, XenBusClass, |
30b5707c | 81 | XEN_BUS) |
108f7bba PD |
82 | |
83 | void xen_bus_init(void); | |
84 | ||
82a29e30 PD |
85 | void xen_device_backend_set_state(XenDevice *xendev, |
86 | enum xenbus_state state); | |
87 | enum xenbus_state xen_device_backend_get_state(XenDevice *xendev); | |
88 | ||
b6af8926 PD |
89 | void xen_device_backend_printf(XenDevice *xendev, const char *key, |
90 | const char *fmt, ...) | |
9edc6313 | 91 | G_GNUC_PRINTF(3, 4); |
b6af8926 PD |
92 | void xen_device_frontend_printf(XenDevice *xendev, const char *key, |
93 | const char *fmt, ...) | |
9edc6313 | 94 | G_GNUC_PRINTF(3, 4); |
b6af8926 PD |
95 | |
96 | int xen_device_frontend_scanf(XenDevice *xendev, const char *key, | |
97 | const char *fmt, ...); | |
98 | ||
4b34b5b1 PD |
99 | void xen_device_set_max_grant_refs(XenDevice *xendev, unsigned int nr_refs, |
100 | Error **errp); | |
101 | void *xen_device_map_grant_refs(XenDevice *xendev, uint32_t *refs, | |
102 | unsigned int nr_refs, int prot, | |
103 | Error **errp); | |
104 | void xen_device_unmap_grant_refs(XenDevice *xendev, void *map, | |
105 | unsigned int nr_refs, Error **errp); | |
106 | ||
107 | typedef struct XenDeviceGrantCopySegment { | |
108 | union { | |
109 | void *virt; | |
110 | struct { | |
111 | uint32_t ref; | |
112 | off_t offset; | |
113 | } foreign; | |
114 | } source, dest; | |
115 | size_t len; | |
116 | } XenDeviceGrantCopySegment; | |
117 | ||
118 | void xen_device_copy_grant_refs(XenDevice *xendev, bool to_domain, | |
119 | XenDeviceGrantCopySegment segs[], | |
120 | unsigned int nr_segs, Error **errp); | |
121 | ||
345f42b4 | 122 | typedef bool (*XenEventHandler)(void *opaque); |
a3d669c8 PD |
123 | |
124 | XenEventChannel *xen_device_bind_event_channel(XenDevice *xendev, | |
125 | unsigned int port, | |
126 | XenEventHandler handler, | |
127 | void *opaque, Error **errp); | |
32d0b7be PD |
128 | void xen_device_set_event_channel_context(XenDevice *xendev, |
129 | XenEventChannel *channel, | |
130 | AioContext *ctx, | |
131 | Error **errp); | |
a3d669c8 PD |
132 | void xen_device_notify_event_channel(XenDevice *xendev, |
133 | XenEventChannel *channel, | |
134 | Error **errp); | |
135 | void xen_device_unbind_event_channel(XenDevice *xendev, | |
136 | XenEventChannel *channel, | |
137 | Error **errp); | |
138 | ||
108f7bba | 139 | #endif /* HW_XEN_BUS_H */ |