blob: b12a463a3e22176caf4ecc8e84d4da231edbb96b [file] [log] [blame]
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -07001/*
2 * All the USB notify logic
3 *
4 * (C) Copyright 2005 Greg Kroah-Hartman <gregkh@suse.de>
5 *
6 * notifier functions originally based on those in kernel/sys.c
7 * but fixed up to not be so broken.
8 *
Greg Kroah-Hartmanb65fba32016-10-28 17:16:36 -04009 * Released under the GPLv2 only.
10 * SPDX-License-Identifier: GPL-2.0
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -070011 */
12
13
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -070014#include <linux/kernel.h>
Paul Gortmakerf940fcd2011-05-27 09:56:31 -040015#include <linux/export.h>
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -070016#include <linux/notifier.h>
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -070017#include <linux/usb.h>
Arjan van de Ven4186ecf2006-01-11 15:55:29 +010018#include <linux/mutex.h>
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -070019#include "usb.h"
20
Alan Sterne041c682006-03-27 01:16:30 -080021static BLOCKING_NOTIFIER_HEAD(usb_notifier_list);
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -070022
23/**
24 * usb_register_notify - register a notifier callback whenever a usb change happens
25 * @nb: pointer to the notifier block for the callback events.
26 *
27 * These changes are either USB devices or busses being added or removed.
28 */
29void usb_register_notify(struct notifier_block *nb)
30{
Alan Sterne041c682006-03-27 01:16:30 -080031 blocking_notifier_chain_register(&usb_notifier_list, nb);
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -070032}
33EXPORT_SYMBOL_GPL(usb_register_notify);
34
35/**
36 * usb_unregister_notify - unregister a notifier callback
37 * @nb: pointer to the notifier block for the callback events.
38 *
Manish Katiyarda287622007-12-15 11:01:14 +053039 * usb_register_notify() must have been previously called for this function
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -070040 * to work properly.
41 */
42void usb_unregister_notify(struct notifier_block *nb)
43{
Alan Sterne041c682006-03-27 01:16:30 -080044 blocking_notifier_chain_unregister(&usb_notifier_list, nb);
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -070045}
46EXPORT_SYMBOL_GPL(usb_unregister_notify);
47
48
49void usb_notify_add_device(struct usb_device *udev)
50{
Alan Sterne041c682006-03-27 01:16:30 -080051 blocking_notifier_call_chain(&usb_notifier_list, USB_DEVICE_ADD, udev);
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -070052}
53
54void usb_notify_remove_device(struct usb_device *udev)
55{
Alan Stern4a2a8a22006-07-01 22:05:01 -040056 /* Protect against simultaneous usbfs open */
57 mutex_lock(&usbfs_mutex);
Alan Sterne041c682006-03-27 01:16:30 -080058 blocking_notifier_call_chain(&usb_notifier_list,
59 USB_DEVICE_REMOVE, udev);
Alan Stern4a2a8a22006-07-01 22:05:01 -040060 mutex_unlock(&usbfs_mutex);
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -070061}
62
63void usb_notify_add_bus(struct usb_bus *ubus)
64{
Alan Sterne041c682006-03-27 01:16:30 -080065 blocking_notifier_call_chain(&usb_notifier_list, USB_BUS_ADD, ubus);
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -070066}
67
68void usb_notify_remove_bus(struct usb_bus *ubus)
69{
Alan Sterne041c682006-03-27 01:16:30 -080070 blocking_notifier_call_chain(&usb_notifier_list, USB_BUS_REMOVE, ubus);
Greg Kroah-Hartman3099e752005-06-20 21:15:16 -070071}