blob: 83e5174d902951cff64c87dfcc82f62af0b7d9b5 [file] [log] [blame]
Emil Condreaf0021db2016-10-25 08:50:09 +03001#ifndef QEMU_HW_XEN_PVDEV_H
2#define QEMU_HW_XEN_PVDEV_H
3
4#include "hw/xen/xen_common.h"
5/* ------------------------------------------------------------- */
6
7#define XEN_BUFSIZE 1024
8
Paul Durrant2d0ed5e2019-01-08 14:48:46 +00009struct XenLegacyDevice;
Emil Condreaf0021db2016-10-25 08:50:09 +030010
11/* driver uses grant tables -> open gntdev device (xendev->gnttabdev) */
12#define DEVOPS_FLAG_NEED_GNTDEV 1
13/* don't expect frontend doing correct state transitions (aka console quirk) */
14#define DEVOPS_FLAG_IGNORE_STATE 2
15
16struct XenDevOps {
17 size_t size;
18 uint32_t flags;
Paul Durrant2d0ed5e2019-01-08 14:48:46 +000019 void (*alloc)(struct XenLegacyDevice *xendev);
20 int (*init)(struct XenLegacyDevice *xendev);
21 int (*initialise)(struct XenLegacyDevice *xendev);
22 void (*connected)(struct XenLegacyDevice *xendev);
23 void (*event)(struct XenLegacyDevice *xendev);
24 void (*disconnect)(struct XenLegacyDevice *xendev);
25 int (*free)(struct XenLegacyDevice *xendev);
26 void (*backend_changed)(struct XenLegacyDevice *xendev,
27 const char *node);
28 void (*frontend_changed)(struct XenLegacyDevice *xendev,
29 const char *node);
Emil Condreaf0021db2016-10-25 08:50:09 +030030 int (*backend_register)(void);
31};
32
Paul Durrant2d0ed5e2019-01-08 14:48:46 +000033struct XenLegacyDevice {
Juergen Gross3a6c9172016-11-22 07:10:58 +010034 DeviceState qdev;
Emil Condreaf0021db2016-10-25 08:50:09 +030035 const char *type;
36 int dom;
37 int dev;
38 char name[64];
39 int debug;
40
41 enum xenbus_state be_state;
42 enum xenbus_state fe_state;
43 int online;
44 char be[XEN_BUFSIZE];
45 char *fe;
46 char *protocol;
47 int remote_port;
48 int local_port;
49
50 xenevtchn_handle *evtchndev;
51 xengnttab_handle *gnttabdev;
52
53 struct XenDevOps *ops;
Paul Durrant2d0ed5e2019-01-08 14:48:46 +000054 QTAILQ_ENTRY(XenLegacyDevice) next;
Emil Condreaf0021db2016-10-25 08:50:09 +030055};
56
57/* ------------------------------------------------------------- */
58
59/* xenstore helper functions */
60int xenstore_write_str(const char *base, const char *node, const char *val);
61int xenstore_write_int(const char *base, const char *node, int ival);
62int xenstore_write_int64(const char *base, const char *node, int64_t ival);
63char *xenstore_read_str(const char *base, const char *node);
64int xenstore_read_int(const char *base, const char *node, int *ival);
65int xenstore_read_uint64(const char *base, const char *node, uint64_t *uval);
Emil Condrea046db9b2016-10-25 08:50:10 +030066void xenstore_update(void *unused);
Emil Condreaf0021db2016-10-25 08:50:09 +030067
68const char *xenbus_strstate(enum xenbus_state state);
69
Emil Condrea49442d92016-10-25 08:50:17 +030070void xen_pv_evtchn_event(void *opaque);
Paul Durrant2d0ed5e2019-01-08 14:48:46 +000071void xen_pv_insert_xendev(struct XenLegacyDevice *xendev);
72void xen_pv_del_xendev(struct XenLegacyDevice *xendev);
73struct XenLegacyDevice *xen_pv_find_xendev(const char *type, int dom, int dev);
Emil Condrea148512e2016-10-25 08:50:12 +030074
Paul Durrant2d0ed5e2019-01-08 14:48:46 +000075void xen_pv_unbind_evtchn(struct XenLegacyDevice *xendev);
76int xen_pv_send_notify(struct XenLegacyDevice *xendev);
Emil Condrea31c17aa2016-10-25 08:50:11 +030077
Paul Durrant2d0ed5e2019-01-08 14:48:46 +000078void xen_pv_printf(struct XenLegacyDevice *xendev, int msg_level,
Emil Condreaf0021db2016-10-25 08:50:09 +030079 const char *fmt, ...) GCC_FMT_ATTR(3, 4);
80
81#endif /* QEMU_HW_XEN_PVDEV_H */