diff options
-rw-r--r-- | drivers/xen/Kconfig | 2 | ||||
-rw-r--r-- | drivers/xen/xenbus/xenbus_probe.c | 12 | ||||
-rw-r--r-- | drivers/xen/xenbus/xenbus_probe.h | 6 | ||||
-rw-r--r-- | drivers/xen/xenbus/xenbus_probe_backend.c | 41 | ||||
-rw-r--r-- | drivers/xen/xenbus/xenbus_probe_frontend.c | 28 |
5 files changed, 40 insertions, 49 deletions
diff --git a/drivers/xen/Kconfig b/drivers/xen/Kconfig index 84bf17bbb1cd..554ed573c028 100644 --- a/drivers/xen/Kconfig +++ b/drivers/xen/Kconfig | |||
@@ -72,7 +72,7 @@ config XEN_SYS_HYPERVISOR | |||
72 | 72 | ||
73 | config XEN_XENBUS_FRONTEND | 73 | config XEN_XENBUS_FRONTEND |
74 | tristate | 74 | tristate |
75 | 75 | ||
76 | config XEN_PLATFORM_PCI | 76 | config XEN_PLATFORM_PCI |
77 | tristate "xen platform pci device driver" | 77 | tristate "xen platform pci device driver" |
78 | depends on XEN_PVHVM | 78 | depends on XEN_PVHVM |
diff --git a/drivers/xen/xenbus/xenbus_probe.c b/drivers/xen/xenbus/xenbus_probe.c index 811923451218..baa65e7fbbc7 100644 --- a/drivers/xen/xenbus/xenbus_probe.c +++ b/drivers/xen/xenbus/xenbus_probe.c | |||
@@ -126,9 +126,11 @@ static int talk_to_otherend(struct xenbus_device *dev) | |||
126 | 126 | ||
127 | static int watch_otherend(struct xenbus_device *dev) | 127 | static int watch_otherend(struct xenbus_device *dev) |
128 | { | 128 | { |
129 | struct xen_bus_type *bus = container_of(dev->dev.bus, struct xen_bus_type, bus); | 129 | struct xen_bus_type *bus = |
130 | container_of(dev->dev.bus, struct xen_bus_type, bus); | ||
130 | 131 | ||
131 | return xenbus_watch_pathfmt(dev, &dev->otherend_watch, bus->otherend_changed, | 132 | return xenbus_watch_pathfmt(dev, &dev->otherend_watch, |
133 | bus->otherend_changed, | ||
132 | "%s/%s", dev->otherend, "state"); | 134 | "%s/%s", dev->otherend, "state"); |
133 | } | 135 | } |
134 | 136 | ||
@@ -579,7 +581,8 @@ int xenbus_dev_suspend(struct device *dev, pm_message_t state) | |||
579 | { | 581 | { |
580 | int err = 0; | 582 | int err = 0; |
581 | struct xenbus_driver *drv; | 583 | struct xenbus_driver *drv; |
582 | struct xenbus_device *xdev = container_of(dev, struct xenbus_device, dev); | 584 | struct xenbus_device *xdev |
585 | = container_of(dev, struct xenbus_device, dev); | ||
583 | 586 | ||
584 | DPRINTK("%s", xdev->nodename); | 587 | DPRINTK("%s", xdev->nodename); |
585 | 588 | ||
@@ -599,7 +602,8 @@ int xenbus_dev_resume(struct device *dev) | |||
599 | { | 602 | { |
600 | int err; | 603 | int err; |
601 | struct xenbus_driver *drv; | 604 | struct xenbus_driver *drv; |
602 | struct xenbus_device *xdev = container_of(dev, struct xenbus_device, dev); | 605 | struct xenbus_device *xdev |
606 | = container_of(dev, struct xenbus_device, dev); | ||
603 | 607 | ||
604 | DPRINTK("%s", xdev->nodename); | 608 | DPRINTK("%s", xdev->nodename); |
605 | 609 | ||
diff --git a/drivers/xen/xenbus/xenbus_probe.h b/drivers/xen/xenbus/xenbus_probe.h index 0e5fc4c63eb2..24665812316a 100644 --- a/drivers/xen/xenbus/xenbus_probe.h +++ b/drivers/xen/xenbus/xenbus_probe.h | |||
@@ -41,8 +41,10 @@ struct xen_bus_type | |||
41 | char *root; | 41 | char *root; |
42 | unsigned int levels; | 42 | unsigned int levels; |
43 | int (*get_bus_id)(char bus_id[XEN_BUS_ID_SIZE], const char *nodename); | 43 | int (*get_bus_id)(char bus_id[XEN_BUS_ID_SIZE], const char *nodename); |
44 | int (*probe)(struct xen_bus_type *bus, const char *type, const char *dir); | 44 | int (*probe)(struct xen_bus_type *bus, const char *type, |
45 | void (*otherend_changed)(struct xenbus_watch *watch, const char **vec, unsigned int len); | 45 | const char *dir); |
46 | void (*otherend_changed)(struct xenbus_watch *watch, const char **vec, | ||
47 | unsigned int len); | ||
46 | struct bus_type bus; | 48 | struct bus_type bus; |
47 | }; | 49 | }; |
48 | 50 | ||
diff --git a/drivers/xen/xenbus/xenbus_probe_backend.c b/drivers/xen/xenbus/xenbus_probe_backend.c index 9b9dd36bb1c4..6cf467bf63ec 100644 --- a/drivers/xen/xenbus/xenbus_probe_backend.c +++ b/drivers/xen/xenbus/xenbus_probe_backend.c | |||
@@ -84,8 +84,8 @@ static int backend_bus_id(char bus_id[XEN_BUS_ID_SIZE], const char *nodename) | |||
84 | if (err) | 84 | if (err) |
85 | return err; | 85 | return err; |
86 | 86 | ||
87 | if (snprintf(bus_id, XEN_BUS_ID_SIZE, | 87 | if (snprintf(bus_id, XEN_BUS_ID_SIZE, "%.*s-%i-%s", |
88 | "%.*s-%i-%s", typelen, type, domid, devid) >= XEN_BUS_ID_SIZE) | 88 | typelen, type, domid, devid) >= XEN_BUS_ID_SIZE) |
89 | return -ENOSPC; | 89 | return -ENOSPC; |
90 | return 0; | 90 | return 0; |
91 | } | 91 | } |
@@ -147,7 +147,8 @@ static int xenbus_probe_backend_unit(struct xen_bus_type *bus, | |||
147 | } | 147 | } |
148 | 148 | ||
149 | /* backend/<typename>/<frontend-domid> */ | 149 | /* backend/<typename>/<frontend-domid> */ |
150 | static int xenbus_probe_backend(struct xen_bus_type *bus, const char *type, const char *domid) | 150 | static int xenbus_probe_backend(struct xen_bus_type *bus, const char *type, |
151 | const char *domid) | ||
151 | { | 152 | { |
152 | char *nodename; | 153 | char *nodename; |
153 | int err = 0; | 154 | int err = 0; |
@@ -188,18 +189,18 @@ static struct device_attribute xenbus_backend_dev_attrs[] = { | |||
188 | 189 | ||
189 | static struct xen_bus_type xenbus_backend = { | 190 | static struct xen_bus_type xenbus_backend = { |
190 | .root = "backend", | 191 | .root = "backend", |
191 | .levels = 3, /* backend/type/<frontend>/<id> */ | 192 | .levels = 3, /* backend/type/<frontend>/<id> */ |
192 | .get_bus_id = backend_bus_id, | 193 | .get_bus_id = backend_bus_id, |
193 | .probe = xenbus_probe_backend, | 194 | .probe = xenbus_probe_backend, |
194 | .otherend_changed = frontend_changed, | 195 | .otherend_changed = frontend_changed, |
195 | .bus = { | 196 | .bus = { |
196 | .name = "xen-backend", | 197 | .name = "xen-backend", |
197 | .match = xenbus_match, | 198 | .match = xenbus_match, |
198 | .uevent = xenbus_uevent_backend, | 199 | .uevent = xenbus_uevent_backend, |
199 | .probe = xenbus_dev_probe, | 200 | .probe = xenbus_dev_probe, |
200 | .remove = xenbus_dev_remove, | 201 | .remove = xenbus_dev_remove, |
201 | .shutdown = xenbus_dev_shutdown, | 202 | .shutdown = xenbus_dev_shutdown, |
202 | .dev_attrs = xenbus_backend_dev_attrs, | 203 | .dev_attrs = xenbus_backend_dev_attrs, |
203 | }, | 204 | }, |
204 | }; | 205 | }; |
205 | 206 | ||
@@ -221,24 +222,6 @@ static int read_frontend_details(struct xenbus_device *xendev) | |||
221 | return xenbus_read_otherend_details(xendev, "frontend-id", "frontend"); | 222 | return xenbus_read_otherend_details(xendev, "frontend-id", "frontend"); |
222 | } | 223 | } |
223 | 224 | ||
224 | //void xenbus_backend_suspend(int (*fn)(struct device *, void *)) | ||
225 | //{ | ||
226 | // DPRINTK(""); | ||
227 | // bus_for_each_dev(&xenbus_backend.bus, NULL, NULL, fn); | ||
228 | //} | ||
229 | |||
230 | //void xenbus_backend_resume(int (*fn)(struct device *, void *)) | ||
231 | //{ | ||
232 | // DPRINTK(""); | ||
233 | // bus_for_each_dev(&xenbus_backend.bus, NULL, NULL, fn); | ||
234 | //} | ||
235 | |||
236 | //int xenbus_for_each_backend(void *arg, int (*fn)(struct device *, void *)) | ||
237 | //{ | ||
238 | // return bus_for_each_dev(&xenbus_backend.bus, NULL, arg, fn); | ||
239 | //} | ||
240 | //EXPORT_SYMBOL_GPL(xenbus_for_each_backend); | ||
241 | |||
242 | int xenbus_dev_is_online(struct xenbus_device *dev) | 225 | int xenbus_dev_is_online(struct xenbus_device *dev) |
243 | { | 226 | { |
244 | int rc, val; | 227 | int rc, val; |
diff --git a/drivers/xen/xenbus/xenbus_probe_frontend.c b/drivers/xen/xenbus/xenbus_probe_frontend.c index 60c311ab3190..5bcc2d6cf129 100644 --- a/drivers/xen/xenbus/xenbus_probe_frontend.c +++ b/drivers/xen/xenbus/xenbus_probe_frontend.c | |||
@@ -46,7 +46,8 @@ static int frontend_bus_id(char bus_id[XEN_BUS_ID_SIZE], const char *nodename) | |||
46 | } | 46 | } |
47 | 47 | ||
48 | /* device/<typename>/<name> */ | 48 | /* device/<typename>/<name> */ |
49 | static int xenbus_probe_frontend(struct xen_bus_type *bus, const char *type, const char *name) | 49 | static int xenbus_probe_frontend(struct xen_bus_type *bus, const char *type, |
50 | const char *name) | ||
50 | { | 51 | { |
51 | char *nodename; | 52 | char *nodename; |
52 | int err; | 53 | int err; |
@@ -62,7 +63,8 @@ static int xenbus_probe_frontend(struct xen_bus_type *bus, const char *type, con | |||
62 | return err; | 63 | return err; |
63 | } | 64 | } |
64 | 65 | ||
65 | static int xenbus_uevent_frontend(struct device *_dev, struct kobj_uevent_env *env) | 66 | static int xenbus_uevent_frontend(struct device *_dev, |
67 | struct kobj_uevent_env *env) | ||
66 | { | 68 | { |
67 | struct xenbus_device *dev = to_xenbus_device(_dev); | 69 | struct xenbus_device *dev = to_xenbus_device(_dev); |
68 | 70 | ||
@@ -85,21 +87,21 @@ static struct device_attribute xenbus_frontend_dev_attrs[] = { | |||
85 | 87 | ||
86 | static struct xen_bus_type xenbus_frontend = { | 88 | static struct xen_bus_type xenbus_frontend = { |
87 | .root = "device", | 89 | .root = "device", |
88 | .levels = 2, /* device/type/<id> */ | 90 | .levels = 2, /* device/type/<id> */ |
89 | .get_bus_id = frontend_bus_id, | 91 | .get_bus_id = frontend_bus_id, |
90 | .probe = xenbus_probe_frontend, | 92 | .probe = xenbus_probe_frontend, |
91 | .otherend_changed = backend_changed, | 93 | .otherend_changed = backend_changed, |
92 | .bus = { | 94 | .bus = { |
93 | .name = "xen", | 95 | .name = "xen", |
94 | .match = xenbus_match, | 96 | .match = xenbus_match, |
95 | .uevent = xenbus_uevent_frontend, | 97 | .uevent = xenbus_uevent_frontend, |
96 | .probe = xenbus_dev_probe, | 98 | .probe = xenbus_dev_probe, |
97 | .remove = xenbus_dev_remove, | 99 | .remove = xenbus_dev_remove, |
98 | .shutdown = xenbus_dev_shutdown, | 100 | .shutdown = xenbus_dev_shutdown, |
99 | .dev_attrs= xenbus_frontend_dev_attrs, | 101 | .dev_attrs = xenbus_frontend_dev_attrs, |
100 | 102 | ||
101 | .suspend = xenbus_dev_suspend, | 103 | .suspend = xenbus_dev_suspend, |
102 | .resume = xenbus_dev_resume, | 104 | .resume = xenbus_dev_resume, |
103 | }, | 105 | }, |
104 | }; | 106 | }; |
105 | 107 | ||