Changes in uspace/lib/usb/src/hidparser.c [60a228f:c32688d] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/lib/usb/src/hidparser.c
r60a228f rc32688d 178 178 } 179 179 memcpy(new_report_item,report_item, sizeof(usb_hid_report_item_t)); 180 /* reset local items */ 181 new_report_item->usage_minimum = 0; 182 new_report_item->usage_maximum = 0; 183 180 184 link_initialize(&(new_report_item->link)); 181 185 report_item = new_report_item; … … 501 505 usb_log_debug("\tCOUNT: %X\n", report_item->count); 502 506 usb_log_debug("\tSIZE: %X\n", report_item->size); 503 usb_log_debug("\tCONSTANT: %X\n", USB_HID_ITEM_FLAG_CONSTANT(report_item->item_flags)); 507 usb_log_debug("\tCONSTANT/VAR: %X\n", USB_HID_ITEM_FLAG_CONSTANT(report_item->item_flags)); 508 usb_log_debug("\tVARIABLE/ARRAY: %X\n", USB_HID_ITEM_FLAG_VARIABLE(report_item->item_flags)); 504 509 usb_log_debug("\tUSAGE: %X\n", report_item->usage); 505 510 usb_log_debug("\tUSAGE PAGE: %X\n", report_item->usage_page); … … 508 513 usb_log_debug("\tPHYMIN: %X\n", report_item->physical_minimum); 509 514 usb_log_debug("\tPHYMAX: %X\n", report_item->physical_maximum); 515 usb_log_debug("\tUSAGEMIN: %X\n", report_item->usage_minimum); 516 usb_log_debug("\tUSAGEMAX: %X\n", report_item->usage_maximum); 517 510 518 usb_log_debug("\n"); 511 519 … … 602 610 usb_hid_report_item_t *item; 603 611 uint8_t *keys; 612 uint8_t item_value; 604 613 size_t key_count=0; 605 614 size_t i=0; … … 607 616 608 617 // get the size of result keycodes array 609 list_item = parser->input.next; 610 while(list_item != &(parser->input)) { 611 612 item = list_get_instance(list_item, usb_hid_report_item_t, link); 613 if(item->usage_page == BAD_HACK_USAGE_PAGE) { 614 key_count += item->count; 615 } 616 617 list_item = list_item->next; 618 } 619 620 618 usb_hid_report_path_t path; 619 path.usage_page = BAD_HACK_USAGE_PAGE; 620 key_count = usb_hid_report_input_length(parser, &path); 621 621 622 if(!(keys = malloc(sizeof(uint8_t) * key_count))){ 622 623 return ENOMEM; … … 628 629 629 630 item = list_get_instance(list_item, usb_hid_report_item_t, link); 630 if(item->usage_page == BAD_HACK_USAGE_PAGE) { 631 if(!USB_HID_ITEM_FLAG_CONSTANT(item->item_flags) && 632 (item->usage_page == path.usage_page)) { 631 633 for(j=0; j<(size_t)(item->count); j++) { 632 keys[i++] = usb_hid_translate_data(item, data,j); 634 if((USB_HID_ITEM_FLAG_VARIABLE(item->item_flags) == 0) || 635 ((item->usage_minimum == 0) && (item->usage_maximum == 0))) { 636 // variable item 637 keys[i++] = usb_hid_translate_data(item, data,j); 638 } 639 else { 640 // bitmapa 641 if((item_value = usb_hid_translate_data(item, data, j)) != 0) { 642 keys[i++] = j + item->usage_minimum; 643 } 644 else { 645 keys[i++] = 0; 646 } 647 } 633 648 } 634 649 } … … 719 734 720 735 } 736 737 int usb_hid_report_input_length(const usb_hid_report_parser_t *parser, 738 const usb_hid_report_path_t *path) 739 { 740 int ret = 0; 741 link_t *item; 742 usb_hid_report_item_t *report_item; 743 744 item = (&parser->input)->next; 745 while(&parser->input != item) { 746 report_item = list_get_instance(item, usb_hid_report_item_t, link); 747 if(!USB_HID_ITEM_FLAG_CONSTANT(report_item->item_flags) && 748 (report_item->usage_page == path->usage_page)) { 749 ret += report_item->count; 750 } 751 752 item = item->next; 753 } 754 755 return ret; 756 } 757 758 759 721 760 /** 722 761 * @}
Note:
See TracChangeset
for help on using the changeset viewer.