Date: Mon, 2 Nov 2009 23:50:12 +0000 (UTC) From: Andrew Thompson <thompsa@FreeBSD.org> To: src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org Subject: svn commit: r198833 - head/usr.sbin/usbconfig Message-ID: <200911022350.nA2NoCcr073693@svn.freebsd.org>
next in thread | raw e-mail | index | archive | help
Author: thompsa Date: Mon Nov 2 23:50:12 2009 New Revision: 198833 URL: http://svn.freebsd.org/changeset/base/198833 Log: Add more verbose output when dumping the configuration descriptor. Submitted by: Hans Petter Selasky Modified: head/usr.sbin/usbconfig/dump.c Modified: head/usr.sbin/usbconfig/dump.c ============================================================================== --- head/usr.sbin/usbconfig/dump.c Mon Nov 2 23:30:15 2009 (r198832) +++ head/usr.sbin/usbconfig/dump.c Mon Nov 2 23:50:12 2009 (r198833) @@ -100,21 +100,66 @@ dump_field(struct libusb20_device *pdev, printf("%s%s = 0x%04x ", plevel, field, value); - if ((field[0] != 'i') || (field[1] == 'd')) { - printf("\n"); - return; - } - if (value == 0) { - printf(" <no string>\n"); - return; + if (strlen(plevel) == 8) { + /* Endpoint Descriptor */ + + if (strcmp(field, "bEndpointAddress") == 0) { + if (value & 0x80) + printf(" <IN>\n"); + else + printf(" <OUT>\n"); + return; + } + + if (strcmp(field, "bmAttributes") == 0) { + switch (value & 0x03) { + case 0: + printf(" <CONTROL>\n"); + break; + case 1: + switch (value & 0x0C) { + case 0x00: + printf(" <ISOCHRONOUS>\n"); + break; + case 0x04: + printf(" <ASYNC-ISOCHRONOUS>\n"); + break; + case 0x08: + printf(" <ADAPT-ISOCHRONOUS>\n"); + break; + default: + printf(" <SYNC-ISOCHRONOUS>\n"); + break; + } + break; + case 2: + printf(" <BULK>\n"); + break; + default: + printf(" <INTERRUPT>\n"); + break; + } + return; + } } - if (libusb20_dev_req_string_simple_sync(pdev, value, - temp_string, sizeof(temp_string))) { - printf(" <retrieving string failed>\n"); + + if ((field[0] == 'i') && (field[1] != 'd')) { + /* Indirect String Descriptor */ + if (value == 0) { + printf(" <no string>\n"); + return; + } + if (libusb20_dev_req_string_simple_sync(pdev, value, + temp_string, sizeof(temp_string))) { + printf(" <retrieving string failed>\n"); + return; + } + printf(" <%s>\n", temp_string); return; } - printf(" <%s>\n", temp_string); - return; + + /* No additional information */ + printf("\n"); } static void
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200911022350.nA2NoCcr073693>