Changeset 9753220 in mainline
- Timestamp:
- 2011-01-30T23:10:57Z (14 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- fe4dd14
- Parents:
- 707ffcf
- Location:
- uspace/lib/drv
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/lib/drv/generic/remote_usbhc.c
r707ffcf r9753220 1 1 /* 2 * Copyright (c) 2010 Vojtech Horky2 * Copyright (c) 2010-2011 Vojtech Horky 3 3 * All rights reserved. 4 4 * … … 52 52 static void remote_usbhc_control_read_data(device_t *, void *, ipc_callid_t, ipc_call_t *); 53 53 static void remote_usbhc_control_read_status(device_t *, void *, ipc_callid_t, ipc_call_t *); 54 static void remote_usbhc_control_write(device_t *, void *, ipc_callid_t, ipc_call_t *); 55 static void remote_usbhc_control_read(device_t *, void *, ipc_callid_t, ipc_call_t *); 54 56 static void remote_usbhc_reserve_default_address(device_t *, void *, ipc_callid_t, ipc_call_t *); 55 57 static void remote_usbhc_release_default_address(device_t *, void *, ipc_callid_t, ipc_call_t *); … … 81 83 remote_usbhc_control_read_setup, 82 84 remote_usbhc_control_read_data, 83 remote_usbhc_control_read_status 85 remote_usbhc_control_read_status, 86 87 remote_usbhc_control_write, 88 remote_usbhc_control_read 84 89 }; 85 90 … … 95 100 ipc_callid_t caller; 96 101 void *buffer; 102 void *setup_packet; 97 103 size_t size; 98 104 } async_transaction_t; … … 297 303 trans->caller = callid; 298 304 trans->buffer = buffer; 305 trans->setup_packet = NULL; 299 306 trans->size = len; 300 307 … … 336 343 trans->caller = callid; 337 344 trans->buffer = malloc(len); 345 trans->setup_packet = NULL; 338 346 trans->size = len; 339 347 … … 391 399 trans->caller = callid; 392 400 trans->buffer = NULL; 401 trans->setup_packet = NULL; 393 402 trans->size = 0; 394 403 … … 496 505 } 497 506 507 void remote_usbhc_control_write(device_t *device, void *iface, 508 ipc_callid_t callid, ipc_call_t *call) 509 { 510 usbhc_iface_t *usb_iface = (usbhc_iface_t *) iface; 511 assert(usb_iface != NULL); 512 513 if (!usb_iface->control_write) { 514 ipc_answer_0(callid, ENOTSUP); 515 return; 516 } 517 518 usb_target_t target = { 519 .address = DEV_IPC_GET_ARG1(*call), 520 .endpoint = DEV_IPC_GET_ARG2(*call) 521 }; 522 523 int rc; 524 525 void *setup_packet = NULL; 526 void *data_buffer = NULL; 527 size_t setup_packet_len = 0; 528 size_t data_buffer_len = 0; 529 530 rc = async_data_write_accept(&setup_packet, false, 531 1, USB_MAX_PAYLOAD_SIZE, 0, &setup_packet_len); 532 if (rc != EOK) { 533 ipc_answer_0(callid, rc); 534 return; 535 } 536 rc = async_data_write_accept(&data_buffer, false, 537 1, USB_MAX_PAYLOAD_SIZE, 0, &data_buffer_len); 538 if (rc != EOK) { 539 free(setup_packet); 540 ipc_answer_0(callid, rc); 541 return; 542 } 543 544 async_transaction_t *trans = malloc(sizeof(async_transaction_t)); 545 trans->caller = callid; 546 trans->setup_packet = setup_packet; 547 trans->buffer = data_buffer; 548 trans->size = data_buffer_len; 549 550 rc = usb_iface->control_write(device, target, 551 setup_packet, setup_packet_len, 552 data_buffer, data_buffer_len, 553 callback_out, trans); 554 555 if (rc != EOK) { 556 ipc_answer_0(callid, rc); 557 free(setup_packet); 558 free(data_buffer); 559 free(trans); 560 } 561 } 562 563 564 void remote_usbhc_control_read(device_t *device, void *iface, 565 ipc_callid_t callid, ipc_call_t *call) 566 { 567 usbhc_iface_t *usb_iface = (usbhc_iface_t *) iface; 568 assert(usb_iface != NULL); 569 570 if (!usb_iface->control_read) { 571 ipc_answer_0(callid, ENOTSUP); 572 return; 573 } 574 575 size_t data_len = DEV_IPC_GET_ARG3(*call); 576 usb_target_t target = { 577 .address = DEV_IPC_GET_ARG1(*call), 578 .endpoint = DEV_IPC_GET_ARG2(*call) 579 }; 580 581 int rc; 582 583 void *setup_packet = NULL; 584 size_t setup_packet_len = 0; 585 586 rc = async_data_write_accept(&setup_packet, false, 587 1, USB_MAX_PAYLOAD_SIZE, 0, &setup_packet_len); 588 if (rc != EOK) { 589 ipc_answer_0(callid, rc); 590 return; 591 } 592 593 async_transaction_t *trans = malloc(sizeof(async_transaction_t)); 594 trans->caller = callid; 595 trans->setup_packet = setup_packet; 596 trans->buffer = malloc(data_len); 597 trans->size = data_len; 598 599 rc = usb_iface->control_read(device, target, 600 setup_packet, setup_packet_len, 601 trans->buffer, trans->size, 602 callback_in, trans); 603 604 if (rc != EOK) { 605 ipc_answer_0(callid, rc); 606 free(setup_packet); 607 free(trans->buffer); 608 free(trans); 609 } 610 } 611 498 612 499 613 -
uspace/lib/drv/include/usbhc_iface.h
r707ffcf r9753220 201 201 IPC_M_USBHC_CONTROL_READ_STATUS, 202 202 203 /** Issue control WRITE transfer. 204 * See explanation at usb_iface_funcs_t (OUT transaction) for 205 * call parameters. 206 * This call is immediately followed by two IPC data writes 207 * from the caller (setup packet and actual data). 208 */ 209 IPC_M_USBHC_CONTROL_WRITE, 210 211 /** Issue control WRITE transfer. 212 * See explanation at usb_iface_funcs_t (IN transaction) for 213 * call parameters. 214 * This call is immediately followed by IPC data read from the caller 215 * (setup packet). 216 * Actual data are retrieved through IPC_M_USBHC_GET_BUFFER. 217 */ 218 IPC_M_USBHC_CONTROL_READ, 203 219 204 220 /* IPC_M_USB_ */ … … 249 265 int (*control_read_status)(device_t *, usb_target_t, 250 266 usbhc_iface_transfer_out_callback_t, void *); 267 268 int (*control_write)(device_t *, usb_target_t, 269 void *, size_t, void *, size_t, 270 usbhc_iface_transfer_out_callback_t, void *); 271 272 int (*control_read)(device_t *, usb_target_t, 273 void *, size_t, void *, size_t, 274 usbhc_iface_transfer_in_callback_t, void *); 251 275 } usbhc_iface_t; 252 276
Note:
See TracChangeset
for help on using the changeset viewer.