# This is a BitKeeper generated patch for the following project:
# Project Name: Linux kernel tree
# This patch format is intended for GNU patch command version 2.5 or higher.
# This patch includes the following deltas:
# ChangeSet 1.624 -> 1.625
# drivers/usb/core/usb.c 1.65 -> 1.66
#
# The following is the BitKeeper ChangeSet Log
# --------------------------------------------
# 02/07/05 [EMAIL PROTECTED] 1.625
# USB: added product, manufacturer, and serial driverfs files for a device
# --------------------------------------------
#
diff -Nru a/drivers/usb/core/usb.c b/drivers/usb/core/usb.c
--- a/drivers/usb/core/usb.c Sun Jul 7 12:36:10 2002
+++ b/drivers/usb/core/usb.c Sun Jul 7 12:36:10 2002
@@ -788,6 +788,70 @@
show: show_altsetting,
};
+/* product driverfs file */
+static ssize_t show_product (struct device *dev, char *buf, size_t count, loff_t off)
+{
+ struct usb_device *udev;
+ int len;
+
+ if (off)
+ return 0;
+ udev = list_entry (dev, struct usb_device, dev);
+
+ len = usb_string(udev, udev->descriptor.iProduct, buf, PAGE_SIZE);
+ buf[len] = '\n';
+ buf[len+1] = 0x00;
+ return len+1;
+}
+static struct driver_file_entry usb_product_entry = {
+ name: "product",
+ mode: S_IRUGO,
+ show: show_product,
+};
+
+/* manufacturer driverfs file */
+static ssize_t
+show_manufacturer (struct device *dev, char *buf, size_t count, loff_t off)
+{
+ struct usb_device *udev;
+ int len;
+
+ if (off)
+ return 0;
+ udev = list_entry (dev, struct usb_device, dev);
+
+ len = usb_string(udev, udev->descriptor.iManufacturer, buf, PAGE_SIZE);
+ buf[len] = '\n';
+ buf[len+1] = 0x00;
+ return len+1;
+}
+static struct driver_file_entry usb_manufacturer_entry = {
+ name: "manufacturer",
+ mode: S_IRUGO,
+ show: show_manufacturer,
+};
+
+/* serial number driverfs file */
+static ssize_t
+show_serial (struct device *dev, char *buf, size_t count, loff_t off)
+{
+ struct usb_device *udev;
+ int len;
+
+ if (off)
+ return 0;
+ udev = list_entry (dev, struct usb_device, dev);
+
+ len = usb_string(udev, udev->descriptor.iSerialNumber, buf, PAGE_SIZE);
+ buf[len] = '\n';
+ buf[len+1] = 0x00;
+ return len+1;
+}
+static struct driver_file_entry usb_serial_entry = {
+ name: "serial",
+ mode: S_IRUGO,
+ show: show_serial,
+};
/*
* This entrypoint gets called for each new device.
@@ -1319,6 +1383,12 @@
if (err)
return err;
device_create_file (&dev->dev, &usb_config_entry);
+ if (dev->descriptor.iManufacturer)
+ device_create_file (&dev->dev, &usb_manufacturer_entry);
+ if (dev->descriptor.iProduct)
+ device_create_file (&dev->dev, &usb_product_entry);
+ if (dev->descriptor.iSerialNumber)
+ device_create_file (&dev->dev, &usb_serial_entry);
/* now that the basic setup is over, add a /proc/bus/usb entry */
usbfs_add_device(dev);
-------------------------------------------------------
This sf.net email is sponsored by:ThinkGeek
We have stuff for geeks like you.
http://thinkgeek.com/sf
_______________________________________________
[EMAIL PROTECTED]
To unsubscribe, use the last form field at:
https://lists.sourceforge.net/lists/listinfo/linux-usb-devel