Commit 70e90fb5 authored by Kurt Kanzenbach's avatar Kurt Kanzenbach Committed by Greg Kroah-Hartman

staging: usbip: userspace: show product name in `list -l' command

The `usbip list -l' command shows your local usb-devices.
Example:
 $ usbip list -l
 $ Local USB devices
 $ =================
 $ - busid 1-1 (13fe:1d00)
 $         1-1:1.0 -> usb-storage
 $
 $ - busid 1-2 (0409:55aa)
 $         1-2:1.0 -> hub

However this list command doesn't show which device is connected
to this busid. Therefore you have to use another tool e.g. lsusb
to determine that.

This patches adds the possibility to see which device that is.
Example:
 $ usbip list -l
 $ Local USB devices
 $ =================
 $ - busid 1-1 (13fe:1d00)
 $   Kingston Technology Company Inc. : DataTraveler 2.0 1GB/4GB Flash Drive / Patriot Xporter 4GB Flash
 $         1-1:1.0 -> usb-storage
 $
 $ - busid 1-2 (0409:55aa)
 $   NEC Corp. : Hub (0409:55aa)
 $         1-2:1.0 -> hub

If parsable is specified the info will be not printed.
Signed-off-by: default avatarKurt Kanzenbach <ly80toro@cip.cs.fau.de>
Signed-off-by: default avatarStefan Reif <ke42caxa@cip.cs.fau.de>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 80e4b943
...@@ -159,6 +159,12 @@ static void print_device(char *busid, char *vendor, char *product, ...@@ -159,6 +159,12 @@ static void print_device(char *busid, char *vendor, char *product,
printf(" - busid %s (%.4s:%.4s)\n", busid, vendor, product); printf(" - busid %s (%.4s:%.4s)\n", busid, vendor, product);
} }
static void print_product_name(char *product_name, bool parsable)
{
if (!parsable)
printf(" %s\n", product_name);
}
static void print_interface(char *busid, char *driver, bool parsable) static void print_interface(char *busid, char *driver, bool parsable)
{ {
if (parsable) if (parsable)
...@@ -189,6 +195,7 @@ static int list_devices(bool parsable) ...@@ -189,6 +195,7 @@ static int list_devices(bool parsable)
{ {
char bus_type[] = "usb"; char bus_type[] = "usb";
char busid[SYSFS_BUS_ID_SIZE]; char busid[SYSFS_BUS_ID_SIZE];
char product_name[128];
struct sysfs_bus *ubus; struct sysfs_bus *ubus;
struct sysfs_device *dev; struct sysfs_device *dev;
struct sysfs_device *intf; struct sysfs_device *intf;
...@@ -231,8 +238,13 @@ static int list_devices(bool parsable) ...@@ -231,8 +238,13 @@ static int list_devices(bool parsable)
goto err_out; goto err_out;
} }
/* get product name */
usbip_names_get_product(product_name, sizeof(product_name),
strtol(idVendor->value, NULL, 16),
strtol(idProduct->value, NULL, 16));
print_device(dev->bus_id, idVendor->value, idProduct->value, print_device(dev->bus_id, idVendor->value, idProduct->value,
parsable); parsable);
print_product_name(product_name, parsable);
for (i = 0; i < atoi(bNumIntfs->value); i++) { for (i = 0; i < atoi(bNumIntfs->value); i++) {
snprintf(busid, sizeof(busid), "%s:%.1s.%d", snprintf(busid, sizeof(busid), "%s:%.1s.%d",
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment