Changeset 0773396 in mainline for uspace/lib/usbhid/src/hidparser.c


Ignore:
Timestamp:
2013-12-25T13:05:25Z (10 years ago)
Author:
Martin Decky <martin@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
bc54126c
Parents:
f4a47e52 (diff), 6946f23 (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.
Message:

merge mainline changes

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/lib/usbhid/src/hidparser.c

    rf4a47e52 r0773396  
    130130    size_t size, uint8_t *report_id)
    131131{
    132         usb_hid_report_field_t *item;
    133 
    134132        usb_hid_report_description_t *report_des;
    135133        usb_hid_report_type_t type = USB_HID_REPORT_TYPE_INPUT;
     
    153151
    154152        /* 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) {
    158155
    159156                if (USB_HID_ITEM_FLAG_CONSTANT(item->item_flags) == 0) {
     
    163160                                item->value =
    164161                                        usb_hid_translate_data(item, data);
    165                
     162                               
    166163                                item->usage = USB_HID_EXTENDED_USAGE(
    167164                                    item->usages[item->value -
     
    184181                                /* variable item */
    185182                                item->value = usb_hid_translate_data(item,
    186                                     data);                             
    187                         }                       
     183                                    data);
     184                        }
    188185                }
    189186        }
     
    295292        usb_hid_report_description_t *report_des = NULL;
    296293
    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;
    303299                        break;
    304300                }
     
    351347
    352348        if (report->use_report_ids != 0) {
    353                 buffer[0] = report_id;         
     349                buffer[0] = report_id;
    354350        }
    355351
     
    362358        }
    363359
    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) {
    370362                value = usb_hid_translate_data_reverse(report_item,
    371363                    report_item->value);
     
    382374                        }
    383375                        size_t shift = 8 - offset % 8 - length;
    384                         value = value << shift;                                                 
     376                        value = value << shift;
    385377                        value = value & (((1 << length) - 1) << shift);
    386                                
     378                       
    387379                        uint8_t mask = 0;
    388380                        mask = 0xff - (((1 << length) - 1) << shift);
     
    400392
    401393                                        tmp_value = tmp_value << (offset % 8);
    402        
     394                                       
    403395                                        mask = ~(((1 << (8 - (offset % 8))) - 1)
    404396                                            << (offset % 8));
     
    413405                                        value = value & ((1 << (length -
    414406                                            ((offset + length) % 8))) - 1);
    415                                
     407                                       
    416408                                        mask = (1 << (length -
    417409                                            ((offset + length) % 8))) - 1;
Note: See TracChangeset for help on using the changeset viewer.