diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/usb/core/hcd.c | 2 | ||||
-rw-r--r-- | drivers/usb/core/hcd.h | 16 | ||||
-rw-r--r-- | drivers/usb/mon/mon_main.c | 23 |
3 files changed, 21 insertions, 20 deletions
diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c index 16790ad0e2e4..e8f2b8d8f14d 100644 --- a/drivers/usb/core/hcd.c +++ b/drivers/usb/core/hcd.c | |||
@@ -793,7 +793,6 @@ static int usb_register_bus(struct usb_bus *bus) | |||
793 | up (&usb_bus_list_lock); | 793 | up (&usb_bus_list_lock); |
794 | 794 | ||
795 | usb_notify_add_bus(bus); | 795 | usb_notify_add_bus(bus); |
796 | usbmon_notify_bus_add (bus); | ||
797 | 796 | ||
798 | dev_info (bus->controller, "new USB bus registered, assigned bus number %d\n", bus->busnum); | 797 | dev_info (bus->controller, "new USB bus registered, assigned bus number %d\n", bus->busnum); |
799 | return 0; | 798 | return 0; |
@@ -821,7 +820,6 @@ static void usb_deregister_bus (struct usb_bus *bus) | |||
821 | up (&usb_bus_list_lock); | 820 | up (&usb_bus_list_lock); |
822 | 821 | ||
823 | usb_notify_remove_bus(bus); | 822 | usb_notify_remove_bus(bus); |
824 | usbmon_notify_bus_remove (bus); | ||
825 | 823 | ||
826 | clear_bit (bus->busnum, busmap.busmap); | 824 | clear_bit (bus->busnum, busmap.busmap); |
827 | 825 | ||
diff --git a/drivers/usb/core/hcd.h b/drivers/usb/core/hcd.h index cc33886260cd..a5d92943ff95 100644 --- a/drivers/usb/core/hcd.h +++ b/drivers/usb/core/hcd.h | |||
@@ -421,8 +421,6 @@ struct usb_mon_operations { | |||
421 | void (*urb_submit_error)(struct usb_bus *bus, struct urb *urb, int err); | 421 | void (*urb_submit_error)(struct usb_bus *bus, struct urb *urb, int err); |
422 | void (*urb_complete)(struct usb_bus *bus, struct urb *urb); | 422 | void (*urb_complete)(struct usb_bus *bus, struct urb *urb); |
423 | /* void (*urb_unlink)(struct usb_bus *bus, struct urb *urb); */ | 423 | /* void (*urb_unlink)(struct usb_bus *bus, struct urb *urb); */ |
424 | void (*bus_add)(struct usb_bus *bus); | ||
425 | void (*bus_remove)(struct usb_bus *bus); | ||
426 | }; | 424 | }; |
427 | 425 | ||
428 | extern struct usb_mon_operations *mon_ops; | 426 | extern struct usb_mon_operations *mon_ops; |
@@ -445,18 +443,6 @@ static inline void usbmon_urb_complete(struct usb_bus *bus, struct urb *urb) | |||
445 | if (bus->monitored) | 443 | if (bus->monitored) |
446 | (*mon_ops->urb_complete)(bus, urb); | 444 | (*mon_ops->urb_complete)(bus, urb); |
447 | } | 445 | } |
448 | |||
449 | static inline void usbmon_notify_bus_add(struct usb_bus *bus) | ||
450 | { | ||
451 | if (mon_ops) | ||
452 | (*mon_ops->bus_add)(bus); | ||
453 | } | ||
454 | |||
455 | static inline void usbmon_notify_bus_remove(struct usb_bus *bus) | ||
456 | { | ||
457 | if (mon_ops) | ||
458 | (*mon_ops->bus_remove)(bus); | ||
459 | } | ||
460 | 446 | ||
461 | int usb_mon_register(struct usb_mon_operations *ops); | 447 | int usb_mon_register(struct usb_mon_operations *ops); |
462 | void usb_mon_deregister(void); | 448 | void usb_mon_deregister(void); |
@@ -467,8 +453,6 @@ static inline void usbmon_urb_submit(struct usb_bus *bus, struct urb *urb) {} | |||
467 | static inline void usbmon_urb_submit_error(struct usb_bus *bus, struct urb *urb, | 453 | static inline void usbmon_urb_submit_error(struct usb_bus *bus, struct urb *urb, |
468 | int error) {} | 454 | int error) {} |
469 | static inline void usbmon_urb_complete(struct usb_bus *bus, struct urb *urb) {} | 455 | static inline void usbmon_urb_complete(struct usb_bus *bus, struct urb *urb) {} |
470 | static inline void usbmon_notify_bus_add(struct usb_bus *bus) {} | ||
471 | static inline void usbmon_notify_bus_remove(struct usb_bus *bus) {} | ||
472 | 456 | ||
473 | #endif /* CONFIG_USB_MON */ | 457 | #endif /* CONFIG_USB_MON */ |
474 | 458 | ||
diff --git a/drivers/usb/mon/mon_main.c b/drivers/usb/mon/mon_main.c index 508a21028db4..c34944c75047 100644 --- a/drivers/usb/mon/mon_main.c +++ b/drivers/usb/mon/mon_main.c | |||
@@ -11,6 +11,7 @@ | |||
11 | #include <linux/usb.h> | 11 | #include <linux/usb.h> |
12 | #include <linux/debugfs.h> | 12 | #include <linux/debugfs.h> |
13 | #include <linux/smp_lock.h> | 13 | #include <linux/smp_lock.h> |
14 | #include <linux/notifier.h> | ||
14 | 15 | ||
15 | #include "usb_mon.h" | 16 | #include "usb_mon.h" |
16 | #include "../core/hcd.h" | 17 | #include "../core/hcd.h" |
@@ -205,6 +206,23 @@ static void mon_bus_remove(struct usb_bus *ubus) | |||
205 | up(&mon_lock); | 206 | up(&mon_lock); |
206 | } | 207 | } |
207 | 208 | ||
209 | static int mon_notify(struct notifier_block *self, unsigned long action, | ||
210 | void *dev) | ||
211 | { | ||
212 | switch (action) { | ||
213 | case USB_BUS_ADD: | ||
214 | mon_bus_add(dev); | ||
215 | break; | ||
216 | case USB_BUS_REMOVE: | ||
217 | mon_bus_remove(dev); | ||
218 | } | ||
219 | return NOTIFY_OK; | ||
220 | } | ||
221 | |||
222 | static struct notifier_block mon_nb = { | ||
223 | .notifier_call = mon_notify, | ||
224 | }; | ||
225 | |||
208 | /* | 226 | /* |
209 | * Ops | 227 | * Ops |
210 | */ | 228 | */ |
@@ -212,8 +230,6 @@ static struct usb_mon_operations mon_ops_0 = { | |||
212 | .urb_submit = mon_submit, | 230 | .urb_submit = mon_submit, |
213 | .urb_submit_error = mon_submit_error, | 231 | .urb_submit_error = mon_submit_error, |
214 | .urb_complete = mon_complete, | 232 | .urb_complete = mon_complete, |
215 | .bus_add = mon_bus_add, | ||
216 | .bus_remove = mon_bus_remove, | ||
217 | }; | 233 | }; |
218 | 234 | ||
219 | /* | 235 | /* |
@@ -329,6 +345,8 @@ static int __init mon_init(void) | |||
329 | } | 345 | } |
330 | // MOD_INC_USE_COUNT(which_module?); | 346 | // MOD_INC_USE_COUNT(which_module?); |
331 | 347 | ||
348 | usb_register_notify(&mon_nb); | ||
349 | |||
332 | down(&usb_bus_list_lock); | 350 | down(&usb_bus_list_lock); |
333 | list_for_each_entry (ubus, &usb_bus_list, bus_list) { | 351 | list_for_each_entry (ubus, &usb_bus_list, bus_list) { |
334 | mon_bus_init(mondir, ubus); | 352 | mon_bus_init(mondir, ubus); |
@@ -342,6 +360,7 @@ static void __exit mon_exit(void) | |||
342 | struct mon_bus *mbus; | 360 | struct mon_bus *mbus; |
343 | struct list_head *p; | 361 | struct list_head *p; |
344 | 362 | ||
363 | usb_unregister_notify(&mon_nb); | ||
345 | usb_mon_deregister(); | 364 | usb_mon_deregister(); |
346 | 365 | ||
347 | down(&mon_lock); | 366 | down(&mon_lock); |