Changeset 466b120 in mainline
- Timestamp:
- 2011-01-16T17:57:33Z (14 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 85d0cf8, a1d12f4, f841608
- Parents:
- df175fa
- Location:
- uspace
- Files:
-
- 1 added
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/app/usbinfo/dump.c
rdf175fa r466b120 43 43 #include <usb/usb.h> 44 44 #include <usb/descriptor.h> 45 #include <usb/debug.h> 45 46 #include <usb/classes/classes.h> 46 47 … … 49 50 50 51 #define INDENT " " 51 #define PRINTLINE(indent, fmt, ...) printf("%s - " fmt, get_indent(indent), __VA_ARGS__)52 52 #define BYTES_PER_LINE 12 53 53 54 #define BCD_INT(a) (((unsigned int)(a)) / 256)55 #define BCD_FRAC(a) (((unsigned int)(a)) % 256)56 57 #define BCD_FMT "%x.%x"58 #define BCD_ARGS(a) BCD_INT((a)), BCD_FRAC((a))59 60 static void dump_descriptor_by_type(size_t, uint8_t *, size_t);61 62 typedef struct {63 int descriptor;64 void (*dump)(size_t indent, uint8_t *descriptor, size_t length);65 } descriptor_dump_t;66 67 static void dump_descriptor_device(size_t, uint8_t *, size_t);68 static void dump_descriptor_configuration(size_t, uint8_t *, size_t);69 static void dump_descriptor_interface(size_t, uint8_t *, size_t);70 static void dump_descriptor_string(size_t, uint8_t *, size_t);71 static void dump_descriptor_endpoint(size_t, uint8_t *, size_t);72 static void dump_descriptor_hid(size_t, uint8_t *, size_t);73 static void dump_descriptor_hub(size_t, uint8_t *, size_t);74 static void dump_descriptor_generic(size_t, uint8_t *, size_t);75 76 static descriptor_dump_t descriptor_dumpers[] = {77 { USB_DESCTYPE_DEVICE, dump_descriptor_device },78 { USB_DESCTYPE_CONFIGURATION, dump_descriptor_configuration },79 { USB_DESCTYPE_STRING, dump_descriptor_string },80 { USB_DESCTYPE_INTERFACE, dump_descriptor_interface },81 { USB_DESCTYPE_ENDPOINT, dump_descriptor_endpoint },82 { USB_DESCTYPE_HID, dump_descriptor_hid },83 { USB_DESCTYPE_HUB, dump_descriptor_hub },84 { -1, dump_descriptor_generic },85 { -1, NULL }86 };87 54 88 55 static const char *get_indent(size_t level) … … 127 94 } 128 95 129 void dump_descriptor_by_type(size_t indent, uint8_t *d, size_t length)130 {131 if (length < 2) {132 return;133 }134 int type = d[1];135 136 descriptor_dump_t *dumper = descriptor_dumpers;137 while (dumper->dump != NULL) {138 if ((dumper->descriptor == type) || (dumper->descriptor < 0)) {139 dumper->dump(indent, d, length);140 return;141 }142 dumper++;143 }144 }145 146 96 void dump_usb_descriptor(uint8_t *descriptor, size_t size) 147 97 { 148 dump_descriptor_by_type(0, descriptor, size); 98 usb_dump_standard_descriptor(stdout, get_indent(0), "\n", 99 descriptor, size); 149 100 } 150 151 void dump_descriptor_device(size_t indent, uint8_t *descr, size_t size)152 {153 usb_standard_device_descriptor_t *d154 = (usb_standard_device_descriptor_t *) descr;155 if (size != sizeof(*d)) {156 return;157 }158 159 PRINTLINE(indent, "bLength = %d\n", d->length);160 PRINTLINE(indent, "bDescriptorType = 0x%02x\n", d->descriptor_type);161 PRINTLINE(indent, "bcdUSB = %d (" BCD_FMT ")\n", d->usb_spec_version,162 BCD_ARGS(d->usb_spec_version));163 PRINTLINE(indent, "bDeviceClass = 0x%02x\n", d->device_class);164 PRINTLINE(indent, "bDeviceSubClass = 0x%02x\n", d->device_subclass);165 PRINTLINE(indent, "bDeviceProtocol = 0x%02x\n", d->device_protocol);166 PRINTLINE(indent, "bMaxPacketSize0 = %d\n", d->max_packet_size);167 PRINTLINE(indent, "idVendor = %d\n", d->vendor_id);168 PRINTLINE(indent, "idProduct = %d\n", d->product_id);169 PRINTLINE(indent, "bcdDevice = %d\n", d->device_version);170 PRINTLINE(indent, "iManufacturer = %d\n", d->str_manufacturer);171 PRINTLINE(indent, "iProduct = %d\n", d->str_product);172 PRINTLINE(indent, "iSerialNumber = %d\n", d->str_serial_number);173 PRINTLINE(indent, "bNumConfigurations = %d\n", d->configuration_count);174 }175 176 void dump_descriptor_configuration(size_t indent, uint8_t *descr, size_t size)177 {178 usb_standard_configuration_descriptor_t *d179 = (usb_standard_configuration_descriptor_t *) descr;180 if (size != sizeof(*d)) {181 return;182 }183 184 bool self_powered = d->attributes & 64;185 bool remote_wakeup = d->attributes & 32;186 187 PRINTLINE(indent, "bLength = %d\n", d->length);188 PRINTLINE(indent, "bDescriptorType = 0x%02x\n", d->descriptor_type);189 PRINTLINE(indent, "wTotalLength = %d\n", d->total_length);190 PRINTLINE(indent, "bNumInterfaces = %d\n", d->interface_count);191 PRINTLINE(indent, "bConfigurationValue = %d\n", d->configuration_number);192 PRINTLINE(indent, "iConfiguration = %d\n", d->str_configuration);193 PRINTLINE(indent, "bmAttributes = %d [%s%s%s]\n", d->attributes,194 self_powered ? "self-powered" : "",195 (self_powered & remote_wakeup) ? ", " : "",196 remote_wakeup ? "remote-wakeup" : "");197 PRINTLINE(indent, "MaxPower = %d (%dmA)\n", d->max_power,198 2 * d->max_power);199 }200 201 void dump_descriptor_interface(size_t indent, uint8_t *descr, size_t size)202 {203 usb_standard_interface_descriptor_t *d204 = (usb_standard_interface_descriptor_t *) descr;205 if (size != sizeof(*d)) {206 return;207 }208 209 PRINTLINE(indent, "bLength = %d\n", d->length);210 PRINTLINE(indent, "bDescriptorType = 0x%02x\n", d->descriptor_type);211 PRINTLINE(indent, "bInterfaceNumber = %d\n", d->interface_number);212 PRINTLINE(indent, "bAlternateSetting = %d\n", d->alternate_setting);213 PRINTLINE(indent, "bNumEndpoints = %d\n", d->endpoint_count);214 PRINTLINE(indent, "bInterfaceClass = %s\n", d->interface_class == 0215 ? "reserved (0)" : usb_str_class(d->interface_class));216 PRINTLINE(indent, "bInterfaceSubClass = %d\n", d->interface_subclass);217 PRINTLINE(indent, "bInterfaceProtocol = %d\n", d->interface_protocol);218 PRINTLINE(indent, "iInterface = %d\n", d->str_interface);219 }220 221 void dump_descriptor_string(size_t indent, uint8_t *descr, size_t size)222 {223 dump_descriptor_generic(indent, descr, size);224 }225 226 void dump_descriptor_endpoint(size_t indent, uint8_t *descr, size_t size)227 {228 usb_standard_endpoint_descriptor_t *d229 = (usb_standard_endpoint_descriptor_t *) descr;230 if (size != sizeof(*d)) {231 return;232 }233 234 int endpoint = d->endpoint_address & 15;235 usb_direction_t direction = d->endpoint_address & 128236 ? USB_DIRECTION_IN : USB_DIRECTION_OUT;237 238 PRINTLINE(indent, "bLength = %d\n", d->length);239 PRINTLINE(indent, "bDescriptorType = 0x%02X\n", d->descriptor_type);240 PRINTLINE(indent, "bEndpointAddress = 0x%02X [%d, %s]\n",241 d->endpoint_address, endpoint,242 direction == USB_DIRECTION_IN ? "in" : "out");243 PRINTLINE(indent, "bmAttributes = %d\n", d->attributes);244 PRINTLINE(indent, "wMaxPacketSize = %d\n", d->max_packet_size);245 PRINTLINE(indent, "bInterval = %dms\n", d->poll_interval);246 }247 248 void dump_descriptor_hid(size_t indent, uint8_t *descr, size_t size)249 {250 dump_descriptor_generic(indent, descr, size);251 }252 253 void dump_descriptor_hub(size_t indent, uint8_t *descr, size_t size)254 {255 dump_descriptor_generic(indent, descr, size);256 }257 258 void dump_descriptor_generic(size_t indent, uint8_t *descr, size_t size)259 {260 dump_buffer(NULL, indent, descr, size);261 }262 263 101 264 102 void dump_match_ids(match_id_list_t *matches) … … 297 135 } 298 136 printf("%s%s (0x%02X):\n", get_indent(depth), name, type); 299 dump_descriptor_by_type(depth, descriptor, descriptor[0]);300 137 usb_dump_standard_descriptor(stdout, get_indent(depth), "\n", 138 descriptor, descriptor[0]); 301 139 } 302 140 -
uspace/lib/usb/Makefile
rdf175fa r466b120 38 38 src/dp.c \ 39 39 src/drvpsync.c \ 40 src/dump.c \ 40 41 src/hcdhubd.c \ 41 42 src/hcdrv.c \ -
uspace/lib/usb/include/usb/debug.h
rdf175fa r466b120 35 35 #ifndef LIBUSB_DEBUG_H_ 36 36 #define LIBUSB_DEBUG_H_ 37 #include <stdio.h> 38 #include <usb/usb.h> 37 39 38 40 void usb_dprintf(const char *tag, int level, const char *format, ...); 39 41 void usb_dprintf_enable(const char *tag, int level); 40 42 43 void usb_dump_standard_descriptor(FILE *, const char *, const char *, 44 const uint8_t *, size_t); 41 45 42 46 #endif
Note:
See TracChangeset
for help on using the changeset viewer.