diff options
author | Theodore Ts'o <tytso@mit.edu> | 2012-07-04 11:22:20 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2012-08-15 15:04:12 -0400 |
commit | 52d1114f461ad4d33d8bc38987b5991161712e96 (patch) | |
tree | 8bcf06e22648fa4436101f5d28e0c3e91448491b /drivers/usb/core | |
parent | 3e035335b0578f6a058aecaf817b462ec9773c24 (diff) |
usb: feed USB device information to the /dev/random driver
commit b04b3156a20d395a7faa8eed98698d1e17a36000 upstream.
Send the USB device's serial, product, and manufacturer strings to the
/dev/random driver to help seed its pools.
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Acked-by: Greg KH <greg@kroah.com>
Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/usb/core')
-rw-r--r-- | drivers/usb/core/hub.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c index 34bb059607f..3c0aa028fb3 100644 --- a/drivers/usb/core/hub.c +++ b/drivers/usb/core/hub.c | |||
@@ -24,6 +24,7 @@ | |||
24 | #include <linux/kthread.h> | 24 | #include <linux/kthread.h> |
25 | #include <linux/mutex.h> | 25 | #include <linux/mutex.h> |
26 | #include <linux/freezer.h> | 26 | #include <linux/freezer.h> |
27 | #include <linux/random.h> | ||
27 | 28 | ||
28 | #include <asm/uaccess.h> | 29 | #include <asm/uaccess.h> |
29 | #include <asm/byteorder.h> | 30 | #include <asm/byteorder.h> |
@@ -1902,6 +1903,14 @@ int usb_new_device(struct usb_device *udev) | |||
1902 | /* Tell the world! */ | 1903 | /* Tell the world! */ |
1903 | announce_device(udev); | 1904 | announce_device(udev); |
1904 | 1905 | ||
1906 | if (udev->serial) | ||
1907 | add_device_randomness(udev->serial, strlen(udev->serial)); | ||
1908 | if (udev->product) | ||
1909 | add_device_randomness(udev->product, strlen(udev->product)); | ||
1910 | if (udev->manufacturer) | ||
1911 | add_device_randomness(udev->manufacturer, | ||
1912 | strlen(udev->manufacturer)); | ||
1913 | |||
1905 | device_enable_async_suspend(&udev->dev); | 1914 | device_enable_async_suspend(&udev->dev); |
1906 | /* Register the device. The device driver is responsible | 1915 | /* Register the device. The device driver is responsible |
1907 | * for configuring the device and invoking the add-device | 1916 | * for configuring the device and invoking the add-device |