Changes in uspace/lib/usbdev/src/altiface.c [160b75e:6e3c005] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/lib/usbdev/src/altiface.c
r160b75e r6e3c005 48 48 * @return Number of alternate interfaces for @p interface_no interface. 49 49 */ 50 size_t usb_interface_count_alternates( uint8_t *config_descr,50 size_t usb_interface_count_alternates(const uint8_t *config_descr, 51 51 size_t config_descr_size, uint8_t interface_no) 52 52 { … … 54 54 assert(config_descr_size > 0); 55 55 56 usb_dp_parser_t dp_parser = {56 const usb_dp_parser_t dp_parser = { 57 57 .nesting = usb_dp_standard_descriptor_nesting 58 58 }; 59 usb_dp_parser_data_t dp_data = {59 const usb_dp_parser_data_t dp_data = { 60 60 .data = config_descr, 61 61 .size = config_descr_size, … … 65 65 size_t alternate_count = 0; 66 66 67 uint8_t *iface_ptr = usb_dp_get_nested_descriptor(&dp_parser,68 &dp_data, config_descr);67 const void *iface_ptr = 68 usb_dp_get_nested_descriptor(&dp_parser, &dp_data, config_descr); 69 69 while (iface_ptr != NULL) { 70 usb_standard_interface_descriptor_t *iface 71 = (usb_standard_interface_descriptor_t *) iface_ptr; 72 if (iface->descriptor_type == USB_DESCTYPE_INTERFACE) { 73 if (iface->interface_number == interface_no) { 74 alternate_count++; 75 } 70 const usb_standard_interface_descriptor_t *iface = iface_ptr; 71 if (iface->descriptor_type == USB_DESCTYPE_INTERFACE 72 && iface->interface_number == interface_no) { 73 ++alternate_count; 76 74 } 77 75 iface_ptr = usb_dp_get_sibling_descriptor(&dp_parser, &dp_data, … … 82 80 } 83 81 84 /** Create alternate interface representation structure.82 /** Initialize alternate interface representation structure. 85 83 * 84 * @param[in] alternates Pointer to allocated structure. 86 85 * @param[in] config_descr Configuration descriptor. 87 86 * @param[in] config_descr_size Size of configuration descriptor. 88 87 * @param[in] interface_number Interface number. 89 * @param[out] alternates_ptr Where to store pointer to allocated structure.90 88 * @return Error code. 91 89 */ 92 int usb_alternate_interfaces_create(uint8_t *config_descr, 93 size_t config_descr_size, int interface_number, 94 usb_alternate_interfaces_t **alternates_ptr) 90 int usb_alternate_interfaces_init(usb_alternate_interfaces_t *alternates, 91 const uint8_t *config_descr, size_t config_descr_size, int interface_number) 95 92 { 96 assert(alternates _ptr!= NULL);93 assert(alternates != NULL); 97 94 assert(config_descr != NULL); 98 95 assert(config_descr_size > 0); 99 96 97 alternates->alternatives = NULL; 98 alternates->alternative_count = 0; 99 alternates->current = 0; 100 101 /* No interfaces. */ 100 102 if (interface_number < 0) { 101 alternates_ptr = NULL;102 103 return EOK; 103 }104 105 usb_alternate_interfaces_t *alternates106 = malloc(sizeof(usb_alternate_interfaces_t));107 108 if (alternates == NULL) {109 return ENOMEM;110 104 } 111 105 112 106 alternates->alternative_count 113 107 = usb_interface_count_alternates(config_descr, config_descr_size, 114 interface_number);108 interface_number); 115 109 116 110 if (alternates->alternative_count == 0) { 117 free(alternates);118 111 return ENOENT; 119 112 } 120 113 121 alternates->alternatives = malloc(alternates->alternative_count122 *sizeof(usb_alternate_interface_descriptors_t));114 alternates->alternatives = calloc(alternates->alternative_count, 115 sizeof(usb_alternate_interface_descriptors_t)); 123 116 if (alternates->alternatives == NULL) { 124 free(alternates);125 117 return ENOMEM; 126 118 } 127 119 128 alternates->current = 0; 129 130 usb_dp_parser_t dp_parser = { 120 const usb_dp_parser_t dp_parser = { 131 121 .nesting = usb_dp_standard_descriptor_nesting 132 122 }; 133 usb_dp_parser_data_t dp_data = {123 const usb_dp_parser_data_t dp_data = { 134 124 .data = config_descr, 135 125 .size = config_descr_size, … … 137 127 }; 138 128 139 usb_alternate_interface_descriptors_t * cur_alt_iface129 usb_alternate_interface_descriptors_t *iterator 140 130 = &alternates->alternatives[0]; 141 131 142 uint8_t *iface_ptr = usb_dp_get_nested_descriptor(&dp_parser, 143 &dp_data, dp_data.data); 144 while (iface_ptr != NULL) { 145 usb_standard_interface_descriptor_t *iface 146 = (usb_standard_interface_descriptor_t *) iface_ptr; 132 const usb_alternate_interface_descriptors_t *end 133 = &alternates->alternatives[alternates->alternative_count]; 134 135 const void *iface_ptr = 136 usb_dp_get_nested_descriptor(&dp_parser, &dp_data, dp_data.data); 137 138 while (iface_ptr != NULL && iterator < end) { 139 const usb_standard_interface_descriptor_t *iface = iface_ptr; 140 147 141 if ((iface->descriptor_type != USB_DESCTYPE_INTERFACE) 148 142 || (iface->interface_number != interface_number)) { 143 /* This is not a valid alternate interface descriptor 144 * for interface with number == interface_number. */ 149 145 iface_ptr = usb_dp_get_sibling_descriptor(&dp_parser, 150 &dp_data, 151 dp_data.data, iface_ptr); 146 &dp_data, dp_data.data, iface_ptr); 152 147 continue; 153 148 } 154 149 155 cur_alt_iface->interface = iface;156 cur_alt_iface->nested_descriptors = iface_ptr + sizeof(*iface);150 iterator->interface = iface; 151 iterator->nested_descriptors = iface_ptr + sizeof(*iface); 157 152 158 153 /* Find next interface to count size of nested descriptors. */ 159 154 iface_ptr = usb_dp_get_sibling_descriptor(&dp_parser, &dp_data, 160 155 dp_data.data, iface_ptr); 161 if (iface_ptr == NULL) {162 uint8_t *next = dp_data.data + dp_data.size;163 cur_alt_iface->nested_descriptors_size164 = next - cur_alt_iface->nested_descriptors;165 } else {166 cur_alt_iface->nested_descriptors_size167 = iface_ptr - cur_alt_iface->nested_descriptors;168 }169 156 170 cur_alt_iface++; 157 const uint8_t *next = (iface_ptr == NULL) ? 158 dp_data.data + dp_data.size : iface_ptr; 159 160 iterator->nested_descriptors_size 161 = next - iterator->nested_descriptors; 162 163 ++iterator; 171 164 } 172 173 *alternates_ptr = alternates;174 165 175 166 return EOK; 176 167 } 177 168 178 169 /** Clean initialized structure. 170 * @param instance structure do deinitialize. 171 */ 172 void usb_alternate_interfaces_deinit(usb_alternate_interfaces_t *instance) 173 { 174 if (!instance) 175 return; 176 free(instance->alternatives); 177 instance->alternatives = NULL; 178 } 179 179 /** 180 180 * @}
Note:
See TracChangeset
for help on using the changeset viewer.