Changeset dd0c8a0 in mainline for uspace/lib/usbhid/src/hidparser.c
- Timestamp:
- 2013-09-29T06:56:33Z (12 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- a9bd960d
- Parents:
- 3deb0155 (diff), 13be2583 (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. - File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/lib/usbhid/src/hidparser.c
r3deb0155 rdd0c8a0 130 130 size_t size, uint8_t *report_id) 131 131 { 132 usb_hid_report_field_t *item;133 134 132 usb_hid_report_description_t *report_des; 135 133 usb_hid_report_type_t type = USB_HID_REPORT_TYPE_INPUT; … … 153 151 154 152 /* read data */ 155 list_foreach(report_des->report_items, list_item) { 156 item = list_get_instance(list_item, usb_hid_report_field_t, 157 ritems_link); 153 list_foreach(report_des->report_items, ritems_link, 154 usb_hid_report_field_t, item) { 158 155 159 156 if (USB_HID_ITEM_FLAG_CONSTANT(item->item_flags) == 0) { … … 163 160 item->value = 164 161 usb_hid_translate_data(item, data); 165 162 166 163 item->usage = USB_HID_EXTENDED_USAGE( 167 164 item->usages[item->value - … … 184 181 /* variable item */ 185 182 item->value = usb_hid_translate_data(item, 186 data); 187 } 183 data); 184 } 188 185 } 189 186 } … … 295 292 usb_hid_report_description_t *report_des = NULL; 296 293 297 list_foreach(report->reports, report_it) { 298 report_des = list_get_instance(report_it, 299 usb_hid_report_description_t, reports_link); 300 301 if ((report_des->report_id == report_id) && 302 (report_des->type == USB_HID_REPORT_TYPE_OUTPUT)) { 294 list_foreach(report->reports, reports_link, 295 usb_hid_report_description_t, rdes) { 296 if ((rdes->report_id == report_id) && 297 (rdes->type == USB_HID_REPORT_TYPE_OUTPUT)) { 298 report_des = rdes; 303 299 break; 304 300 } … … 351 347 352 348 if (report->use_report_ids != 0) { 353 buffer[0] = report_id; 349 buffer[0] = report_id; 354 350 } 355 351 … … 362 358 } 363 359 364 usb_hid_report_field_t *report_item; 365 366 list_foreach(report_des->report_items, item) { 367 report_item = list_get_instance(item, usb_hid_report_field_t, 368 ritems_link); 369 360 list_foreach(report_des->report_items, ritems_link, 361 usb_hid_report_field_t, report_item) { 370 362 value = usb_hid_translate_data_reverse(report_item, 371 363 report_item->value); … … 382 374 } 383 375 size_t shift = 8 - offset % 8 - length; 384 value = value << shift; 376 value = value << shift; 385 377 value = value & (((1 << length) - 1) << shift); 386 378 387 379 uint8_t mask = 0; 388 380 mask = 0xff - (((1 << length) - 1) << shift); … … 400 392 401 393 tmp_value = tmp_value << (offset % 8); 402 394 403 395 mask = ~(((1 << (8 - (offset % 8))) - 1) 404 396 << (offset % 8)); … … 413 405 value = value & ((1 << (length - 414 406 ((offset + length) % 8))) - 1); 415 407 416 408 mask = (1 << (length - 417 409 ((offset + length) % 8))) - 1;
Note:
See TracChangeset
for help on using the changeset viewer.