1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34#ifndef _XEN_XENBUS_H
35#define _XEN_XENBUS_H
36
37#include <linux/device.h>
38#include <linux/notifier.h>
39#include <linux/mutex.h>
40#include <linux/export.h>
41#include <linux/completion.h>
42#include <linux/init.h>
43#include <linux/slab.h>
44#include <xen/interface/xen.h>
45#include <xen/interface/grant_table.h>
46#include <xen/interface/io/xenbus.h>
47#include <xen/interface/io/xs_wire.h>
48
49
50struct xenbus_watch
51{
52 struct list_head list;
53
54
55 const char *node;
56
57
58 void (*callback)(struct xenbus_watch *,
59 const char **vec, unsigned int len);
60};
61
62
63
64struct xenbus_device {
65 const char *devicetype;
66 const char *nodename;
67 const char *otherend;
68 int otherend_id;
69 struct xenbus_watch otherend_watch;
70 struct device dev;
71 enum xenbus_state state;
72 struct completion down;
73 struct work_struct work;
74};
75
76static inline struct xenbus_device *to_xenbus_device(struct device *dev)
77{
78 return container_of(dev, struct xenbus_device, dev);
79}
80
81struct xenbus_device_id
82{
83
84 char devicetype[32];
85};
86
87
88struct xenbus_driver {
89 const struct xenbus_device_id *ids;
90 int (*probe)(struct xenbus_device *dev,
91 const struct xenbus_device_id *id);
92 void (*otherend_changed)(struct xenbus_device *dev,
93 enum xenbus_state backend_state);
94 int (*remove)(struct xenbus_device *dev);
95 int (*suspend)(struct xenbus_device *dev);
96 int (*resume)(struct xenbus_device *dev);
97 int (*uevent)(struct xenbus_device *, struct kobj_uevent_env *);
98 struct device_driver driver;
99 int (*read_otherend_details)(struct xenbus_device *dev);
100 int (*is_ready)(struct xenbus_device *dev);
101};
102
103#define DEFINE_XENBUS_DRIVER(var, drvname, methods...) \
104struct xenbus_driver var ## _driver = { \
105 .driver.name = drvname + 0 ?: var ## _ids->devicetype, \
106 .driver.owner = THIS_MODULE, \
107 .ids = var ## _ids, ## methods \
108}
109
110static inline struct xenbus_driver *to_xenbus_driver(struct device_driver *drv)
111{
112 return container_of(drv, struct xenbus_driver, driver);
113}
114
115int __must_check xenbus_register_frontend(struct xenbus_driver *);
116int __must_check xenbus_register_backend(struct xenbus_driver *);
117
118void xenbus_unregister_driver(struct xenbus_driver *drv);
119
120struct xenbus_transaction
121{
122 u32 id;
123};
124
125
126#define XBT_NIL ((struct xenbus_transaction) { 0 })
127
128char **xenbus_directory(struct xenbus_transaction t,
129 const char *dir, const char *node, unsigned int *num);
130void *xenbus_read(struct xenbus_transaction t,
131 const char *dir, const char *node, unsigned int *len);
132int xenbus_write(struct xenbus_transaction t,
133 const char *dir, const char *node, const char *string);
134int xenbus_mkdir(struct xenbus_transaction t,
135 const char *dir, const char *node);
136int xenbus_exists(struct xenbus_transaction t,
137 const char *dir, const char *node);
138int xenbus_rm(struct xenbus_transaction t, const char *dir, const char *node);
139int xenbus_transaction_start(struct xenbus_transaction *t);
140int xenbus_transaction_end(struct xenbus_transaction t, int abort);
141
142
143__scanf(4, 5)
144int xenbus_scanf(struct xenbus_transaction t,
145 const char *dir, const char *node, const char *fmt, ...);
146
147
148__printf(4, 5)
149int xenbus_printf(struct xenbus_transaction t,
150 const char *dir, const char *node, const char *fmt, ...);
151
152
153
154int xenbus_gather(struct xenbus_transaction t, const char *dir, ...);
155
156
157extern int xenstored_ready;
158int register_xenstore_notifier(struct notifier_block *nb);
159void unregister_xenstore_notifier(struct notifier_block *nb);
160
161int register_xenbus_watch(struct xenbus_watch *watch);
162void unregister_xenbus_watch(struct xenbus_watch *watch);
163void xs_suspend(void);
164void xs_resume(void);
165void xs_suspend_cancel(void);
166
167
168void *xenbus_dev_request_and_reply(struct xsd_sockmsg *msg);
169
170struct work_struct;
171
172
173void xenbus_suspend(void);
174void xenbus_resume(void);
175void xenbus_probe(struct work_struct *);
176void xenbus_suspend_cancel(void);
177
178#define XENBUS_IS_ERR_READ(str) ({ \
179 if (!IS_ERR(str) && strlen(str) == 0) { \
180 kfree(str); \
181 str = ERR_PTR(-ERANGE); \
182 } \
183 IS_ERR(str); \
184})
185
186#define XENBUS_EXIST_ERR(err) ((err) == -ENOENT || (err) == -ERANGE)
187
188int xenbus_watch_path(struct xenbus_device *dev, const char *path,
189 struct xenbus_watch *watch,
190 void (*callback)(struct xenbus_watch *,
191 const char **, unsigned int));
192__printf(4, 5)
193int xenbus_watch_pathfmt(struct xenbus_device *dev, struct xenbus_watch *watch,
194 void (*callback)(struct xenbus_watch *,
195 const char **, unsigned int),
196 const char *pathfmt, ...);
197
198int xenbus_switch_state(struct xenbus_device *dev, enum xenbus_state new_state);
199int xenbus_grant_ring(struct xenbus_device *dev, unsigned long ring_mfn);
200int xenbus_map_ring_valloc(struct xenbus_device *dev,
201 int gnt_ref, void **vaddr);
202int xenbus_map_ring(struct xenbus_device *dev, int gnt_ref,
203 grant_handle_t *handle, void *vaddr);
204
205int xenbus_unmap_ring_vfree(struct xenbus_device *dev, void *vaddr);
206int xenbus_unmap_ring(struct xenbus_device *dev,
207 grant_handle_t handle, void *vaddr);
208
209int xenbus_alloc_evtchn(struct xenbus_device *dev, int *port);
210int xenbus_free_evtchn(struct xenbus_device *dev, int port);
211
212enum xenbus_state xenbus_read_driver_state(const char *path);
213
214__printf(3, 4)
215void xenbus_dev_error(struct xenbus_device *dev, int err, const char *fmt, ...);
216__printf(3, 4)
217void xenbus_dev_fatal(struct xenbus_device *dev, int err, const char *fmt, ...);
218
219const char *xenbus_strstate(enum xenbus_state state);
220int xenbus_dev_is_online(struct xenbus_device *dev);
221int xenbus_frontend_closed(struct xenbus_device *dev);
222
223#endif
224