Changeset cac458f in mainline for uspace/lib/usbhid/src/hidpath.c
- Timestamp:
- 2011-06-22T01:59:39Z (14 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 41e2118
- Parents:
- 79506d6 (diff), f1fae414 (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/hidpath.c
r79506d6 rcac458f 81 81 return ENOMEM; 82 82 } 83 li st_initialize(&item->link);83 link_initialize(&item->rpath_items_link); 84 84 85 85 item->usage = usage; … … 87 87 item->flags = 0; 88 88 89 list_append (&item-> link, &usage_path->head);89 list_append (&item->rpath_items_link, &usage_path->items); 90 90 usage_path->depth++; 91 91 return EOK; … … 100 100 void usb_hid_report_remove_last_item(usb_hid_report_path_t *usage_path) 101 101 { 102 link_t *item_link; 102 103 usb_hid_report_usage_path_t *item; 103 104 104 if(!list_empty(&usage_path->head)){ 105 item = list_get_instance(usage_path->head.prev, 106 usb_hid_report_usage_path_t, link); 107 list_remove(usage_path->head.prev); 105 if(!list_empty(&usage_path->items)){ 106 item_link = list_last(&usage_path->items); 107 item = list_get_instance(item_link, 108 usb_hid_report_usage_path_t, rpath_items_link); 109 list_remove(item_link); 108 110 usage_path->depth--; 109 111 free(item); … … 122 124 usb_hid_report_usage_path_t *item; 123 125 124 if(!list_empty(&usage_path-> head)){125 item = list_get_instance( usage_path->head.prev,126 usb_hid_report_usage_path_t, link);126 if(!list_empty(&usage_path->items)){ 127 item = list_get_instance(list_last(&usage_path->items), 128 usb_hid_report_usage_path_t, rpath_items_link); 127 129 128 130 memset(item, 0, sizeof(usb_hid_report_usage_path_t)); … … 145 147 usb_hid_report_usage_path_t *item; 146 148 147 if(!list_empty(&usage_path-> head)){148 item = list_get_instance( usage_path->head.prev,149 usb_hid_report_usage_path_t,link);149 if(!list_empty(&usage_path->items)){ 150 item = list_get_instance(list_last(&usage_path->items), 151 usb_hid_report_usage_path_t, rpath_items_link); 150 152 151 153 switch(tag) { … … 173 175 usb_log_debug("\tLENGTH: %d\n", path->depth); 174 176 175 link_t *item = path->head.next;176 177 usb_hid_report_usage_path_t *path_item; 177 while(item != &path->head) { 178 179 path_item = list_get_instance(item, usb_hid_report_usage_path_t, 180 link);178 179 list_foreach(path->items, item) { 180 path_item = list_get_instance(item, usb_hid_report_usage_path_t, 181 rpath_items_link); 181 182 182 183 usb_log_debug("\tUSAGE_PAGE: %X\n", path_item->usage_page); 183 184 usb_log_debug("\tUSAGE: %X\n", path_item->usage); 184 usb_log_debug("\tFLAGS: %d\n", path_item->flags); 185 186 item = item->next; 185 usb_log_debug("\tFLAGS: %d\n", path_item->flags); 187 186 } 188 187 } … … 233 232 } 234 233 235 report_link = report_path->head.next; 236 path_link = path->head.next; 237 path_item = list_get_instance(path_link, 238 usb_hid_report_usage_path_t, link); 239 240 while(report_link != &report_path->head) { 241 report_item = list_get_instance(report_link, 242 usb_hid_report_usage_path_t, link); 234 path_link = list_first(&path->items); 235 path_item = list_get_instance(path_link, 236 usb_hid_report_usage_path_t, rpath_items_link); 237 238 list_foreach(report_path->items, report_link) { 239 report_item = list_get_instance(report_link, 240 usb_hid_report_usage_path_t, rpath_items_link); 243 241 244 if(USB_HID_SAME_USAGE_PAGE(report_item->usage_page, 242 if(USB_HID_SAME_USAGE_PAGE(report_item->usage_page, 245 243 path_item->usage_page)){ 246 244 … … 257 255 } 258 256 } 259 260 report_link = report_link->next;261 257 } 262 258 … … 273 269 case USB_HID_PATH_COMPARE_BEGIN: 274 270 275 report_link = report_path-> head.next;276 path_link = path-> head.next;271 report_link = report_path->items.head.next; 272 path_link = path->items.head.next; 277 273 278 while((report_link != &report_path-> head) &&279 (path_link != &path-> head)) {274 while((report_link != &report_path->items.head) && 275 (path_link != &path->items.head)) { 280 276 281 277 report_item = list_get_instance(report_link, 282 usb_hid_report_usage_path_t, link);278 usb_hid_report_usage_path_t, rpath_items_link); 283 279 284 280 path_item = list_get_instance(path_link, 285 usb_hid_report_usage_path_t, link);281 usb_hid_report_usage_path_t, rpath_items_link); 286 282 287 283 if(!USB_HID_SAME_USAGE_PAGE(report_item->usage_page, … … 297 293 } 298 294 299 295 } 300 296 301 297 if((((flags & USB_HID_PATH_COMPARE_BEGIN) != 0) && 302 (path_link == &path-> head)) ||303 ((report_link == &report_path-> head) &&304 (path_link == &path-> head))) {298 (path_link == &path->items.head)) || 299 ((report_link == &report_path->items.head) && 300 (path_link == &path->items.head))) { 305 301 306 302 return EOK; … … 314 310 case USB_HID_PATH_COMPARE_END: 315 311 316 report_link = report_path-> head.prev;317 path_link = path-> head.prev;318 319 if(list_empty(&path-> head)){312 report_link = report_path->items.head.prev; 313 path_link = path->items.head.prev; 314 315 if(list_empty(&path->items)){ 320 316 return EOK; 321 317 } 322 318 323 while((report_link != &report_path-> head) &&324 (path_link != &path-> head)) {319 while((report_link != &report_path->items.head) && 320 (path_link != &path->items.head)) { 325 321 326 report_item = list_get_instance(report_link, 327 usb_hid_report_usage_path_t, link);322 report_item = list_get_instance(report_link, 323 usb_hid_report_usage_path_t, rpath_items_link); 328 324 329 325 path_item = list_get_instance(path_link, 330 usb_hid_report_usage_path_t, link);326 usb_hid_report_usage_path_t, rpath_items_link); 331 327 332 328 if(!USB_HID_SAME_USAGE_PAGE(report_item->usage_page, … … 343 339 } 344 340 345 if(path_link == &path-> head) {341 if(path_link == &path->items.head) { 346 342 return EOK; 347 343 } … … 373 369 path->depth = 0; 374 370 path->report_id = 0; 375 li st_initialize(&path->link);376 list_initialize(&path-> head);371 link_initialize(&path->cpath_link); 372 list_initialize(&path->items); 377 373 return path; 378 374 } … … 388 384 void usb_hid_report_path_free(usb_hid_report_path_t *path) 389 385 { 390 while(!list_empty(&path-> head)){386 while(!list_empty(&path->items)){ 391 387 usb_hid_report_remove_last_item(path); 392 388 } 393 389 394 list_remove(&path->link);390 assert_link_not_used(&path->cpath_link); 395 391 free(path); 396 392 } … … 406 402 usb_hid_report_path_t *usage_path) 407 403 { 408 link_t *path_link;409 404 usb_hid_report_usage_path_t *path_item; 410 405 usb_hid_report_usage_path_t *new_path_item; … … 417 412 new_usage_path->report_id = usage_path->report_id; 418 413 419 if(list_empty(&usage_path-> head)){414 if(list_empty(&usage_path->items)){ 420 415 return new_usage_path; 421 416 } 422 417 423 path_link = usage_path->head.next; 424 while(path_link != &usage_path->head) { 425 path_item = list_get_instance(path_link, 426 usb_hid_report_usage_path_t, link); 418 list_foreach(usage_path->items, path_link) { 419 path_item = list_get_instance(path_link, 420 usb_hid_report_usage_path_t, rpath_items_link); 427 421 428 422 new_path_item = malloc(sizeof(usb_hid_report_usage_path_t)); … … 431 425 } 432 426 433 li st_initialize (&new_path_item->link);427 link_initialize(&new_path_item->rpath_items_link); 434 428 new_path_item->usage_page = path_item->usage_page; 435 429 new_path_item->usage = path_item->usage; 436 430 new_path_item->flags = path_item->flags; 437 431 438 list_append(&new_path_item->link, &new_usage_path->head); 432 list_append(&new_path_item->rpath_items_link, 433 &new_usage_path->items); 439 434 new_usage_path->depth++; 440 441 path_link = path_link->next;442 435 } 443 436
Note:
See TracChangeset
for help on using the changeset viewer.