Changeset 64861b8 in mainline for uspace/app
- Timestamp:
- 2011-01-21T12:26:09Z (15 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- e8ad0de
- Parents:
- b65ca41d (diff), 96b0faef (diff)
 Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
 Use the(diff)links above to see all the changes relative to each parent.
- Location:
- uspace/app
- Files:
- 
      - 4 edited
 
 - 
          
  usbinfo/dump.c (modified) (5 diffs)
- 
          
  usbinfo/info.c (modified) (3 diffs)
- 
          
  usbinfo/usbinfo.h (modified) (1 diff)
- 
          
  virtusbkbd/keys.h (modified) (1 diff)
 
Legend:
- Unmodified
- Added
- Removed
- 
      uspace/app/usbinfo/dump.crb65ca41d r64861b8 43 43 #include <usb/usb.h> 44 44 #include <usb/descriptor.h> 45 #include <usb/debug.h> 46 #include <usb/classes/classes.h> 45 47 46 48 #include "usbinfo.h" … … 50 52 #define BYTES_PER_LINE 12 51 53 52 #define BCD_INT(a) (((unsigned int)(a)) / 256)53 #define BCD_FRAC(a) (((unsigned int)(a)) % 256)54 54 55 #define BCD_FMT "%x.%x" 56 #define BCD_ARGS(a) BCD_INT((a)), BCD_FRAC((a)) 55 static const char *get_indent(size_t level) 56 { 57 static const char *indents[] = { 58 INDENT, 59 INDENT INDENT, 60 INDENT INDENT INDENT, 61 INDENT INDENT INDENT INDENT, 62 INDENT INDENT INDENT INDENT INDENT 63 }; 64 static size_t indents_count = sizeof(indents)/sizeof(indents[0]); 65 if (level >= indents_count) { 66 return indents[indents_count - 1]; 67 } 68 return indents[level]; 69 } 57 70 58 void dump_buffer(const char *msg, const uint8_t *buffer, size_t length) 71 void dump_buffer(const char *msg, size_t indent, 72 const uint8_t *buffer, size_t length) 59 73 { 60 printf("%s\n", msg); 74 if (msg != NULL) { 75 printf("%s\n", msg); 76 } 61 77 62 78 size_t i; 79 if (length > 0) { 80 printf("%s", get_indent(indent)); 81 } 63 82 for (i = 0; i < length; i++) { 64 printf(" 83 printf("0x%02X", buffer[i]); 65 84 if (((i > 0) && (((i+1) % BYTES_PER_LINE) == 0)) 66 85 || (i + 1 == length)) { 67 86 printf("\n"); 87 if (i + 1 < length) { 88 printf("%s", get_indent(indent)); 89 } 90 } else { 91 printf(" "); 68 92 } 69 93 } 94 } 95 96 void dump_usb_descriptor(uint8_t *descriptor, size_t size) 97 { 98 usb_dump_standard_descriptor(stdout, get_indent(0), "\n", 99 descriptor, size); 70 100 } 71 101 … … 83 113 } 84 114 85 void dump_standard_device_descriptor(usb_standard_device_descriptor_t *d)86 {87 printf("Standard device descriptor:\n");88 89 printf(INDENT "bLength = %d\n", d->length);90 printf(INDENT "bDescriptorType = 0x%02x\n", d->descriptor_type);91 printf(INDENT "bcdUSB = %d (" BCD_FMT ")\n", d->usb_spec_version,92 BCD_ARGS(d->usb_spec_version));93 printf(INDENT "bDeviceClass = 0x%02x\n", d->device_class);94 printf(INDENT "bDeviceSubClass = 0x%02x\n", d->device_subclass);95 printf(INDENT "bDeviceProtocol = 0x%02x\n", d->device_protocol);96 printf(INDENT "bMaxPacketSize0 = %d\n", d->max_packet_size);97 printf(INDENT "idVendor = %d\n", d->vendor_id);98 printf(INDENT "idProduct = %d\n", d->product_id);99 printf(INDENT "bcdDevice = %d\n", d->device_version);100 printf(INDENT "iManufacturer = %d\n", d->str_manufacturer);101 printf(INDENT "iProduct = %d\n", d->str_product);102 printf(INDENT "iSerialNumber = %d\n", d->str_serial_number);103 printf(INDENT "bNumConfigurations = %d\n", d->configuration_count);104 }105 106 void dump_standard_configuration_descriptor(107 int index, usb_standard_configuration_descriptor_t *d)108 {109 bool self_powered = d->attributes & 64;110 bool remote_wakeup = d->attributes & 32;111 112 printf("Standard configuration descriptor #%d\n", index);113 printf(INDENT "bLength = %d\n", d->length);114 printf(INDENT "bDescriptorType = 0x%02x\n", d->descriptor_type);115 printf(INDENT "wTotalLength = %d\n", d->total_length);116 printf(INDENT "bNumInterfaces = %d\n", d->interface_count);117 printf(INDENT "bConfigurationValue = %d\n", d->configuration_number);118 printf(INDENT "iConfiguration = %d\n", d->str_configuration);119 printf(INDENT "bmAttributes = %d [%s%s%s]\n", d->attributes,120 self_powered ? "self-powered" : "",121 (self_powered & remote_wakeup) ? ", " : "",122 remote_wakeup ? "remote-wakeup" : "");123 printf(INDENT "MaxPower = %d (%dmA)\n", d->max_power,124 2 * d->max_power);125 // printf(INDENT " = %d\n", d->);126 }127 128 115 static void dump_tree_descriptor(uint8_t *descriptor, size_t depth) 129 116 { 130 117 if (descriptor == NULL) { 131 118 return; 132 }133 while (depth > 0) {134 printf(" ");135 depth--;136 119 } 137 120 int type = (int) *(descriptor + 1); … … 151 134 #undef _TYPE 152 135 } 153 printf("0x%02x (%s)\n", type, name); 136 printf("%s%s (0x%02X):\n", get_indent(depth), name, type); 137 usb_dump_standard_descriptor(stdout, get_indent(depth), "\n", 138 descriptor, descriptor[0]); 154 139 } 155 140 … … 172 157 uint8_t *ptr = data->data; 173 158 printf("Descriptor tree:\n"); 174 dump_tree_internal(parser, data, ptr, 1);159 dump_tree_internal(parser, data, ptr, 0); 175 160 } 176 161 
- 
      uspace/app/usbinfo/info.crb65ca41d r64861b8 72 72 return rc; 73 73 } 74 dump_ standard_device_descriptor(&device_descriptor);74 dump_usb_descriptor((uint8_t *)&device_descriptor, sizeof(device_descriptor)); 75 75 76 76 /* … … 91 91 return rc; 92 92 } 93 dump_standard_configuration_descriptor(config_index, 94 &config_descriptor); 93 //dump_standard_configuration_descriptor(config_index, &config_descriptor); 95 94 96 95 void *full_config_descriptor = malloc(config_descriptor.total_length); … … 109 108 return rc; 110 109 } 111 dump_buffer("Full configuration descriptor:",112 full_config_descriptor, config_descriptor.total_length);113 110 114 111 dump_descriptor_tree(full_config_descriptor, 
- 
      uspace/app/usbinfo/usbinfo.hrb65ca41d r64861b8 44 44 #define NAME "usbinfo" 45 45 46 void dump_buffer(const char *, const uint8_t *, size_t);46 void dump_buffer(const char *, size_t, const uint8_t *, size_t); 47 47 void dump_match_ids(match_id_list_t *matches); 48 void dump_standard_device_descriptor(usb_standard_device_descriptor_t *); 49 void dump_standard_configuration_descriptor(int, 50 usb_standard_configuration_descriptor_t *); 48 void dump_usb_descriptor(uint8_t *, size_t); 51 49 int dump_device(int, usb_address_t); 52 50 void dump_descriptor_tree(uint8_t *, size_t); 
- 
      uspace/app/virtusbkbd/keys.hrb65ca41d r64861b8 40 40 41 41 /** Maximum number of keys that can be pressed simultaneously. */ 42 #define KB_MAX_KEYS_AT_ONCE 442 #define KB_MAX_KEYS_AT_ONCE 6 43 43 44 44 /** Key code type. */ 
  Note:
 See   TracChangeset
 for help on using the changeset viewer.
  
