Changes in / [bfe0eb5:b53ca1e] in mainline
- Location:
- uspace/lib
- Files:
-
- 1 added
- 6 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/lib/drv/generic/remote_usbhc.c
rbfe0eb5 rb53ca1e 540 540 .endpoint = DEV_IPC_GET_ARG2(*call) 541 541 }; 542 size_t data_buffer_len = DEV_IPC_GET_ARG3(*call); 542 543 543 544 int rc; … … 546 547 void *data_buffer = NULL; 547 548 size_t setup_packet_len = 0; 548 size_t data_buffer_len = 0;549 549 550 550 rc = async_data_write_accept(&setup_packet, false, … … 554 554 return; 555 555 } 556 rc = async_data_write_accept(&data_buffer, false, 557 1, USB_MAX_PAYLOAD_SIZE, 0, &data_buffer_len); 558 if (rc != EOK) { 559 async_answer_0(callid, rc); 560 free(setup_packet); 561 return; 556 557 if (data_buffer_len > 0) { 558 rc = async_data_write_accept(&data_buffer, false, 559 1, USB_MAX_PAYLOAD_SIZE, 0, &data_buffer_len); 560 if (rc != EOK) { 561 async_answer_0(callid, rc); 562 free(setup_packet); 563 return; 564 } 562 565 } 563 566 … … 596 599 } 597 600 598 size_t data_len = DEV_IPC_GET_ARG3(*call);599 601 usb_target_t target = { 600 602 .address = DEV_IPC_GET_ARG1(*call), … … 606 608 void *setup_packet = NULL; 607 609 size_t setup_packet_len = 0; 610 size_t data_len = 0; 608 611 609 612 rc = async_data_write_accept(&setup_packet, false, -
uspace/lib/usb/Makefile
rbfe0eb5 rb53ca1e 42 42 src/pipes.c \ 43 43 src/pipesinit.c \ 44 src/pipesio.c \ 44 45 src/recognise.c \ 45 46 src/request.c \ -
uspace/lib/usb/include/usb/recognise.h
rbfe0eb5 rb53ca1e 39 39 #include <usb/usb.h> 40 40 #include <usb/pipes.h> 41 #include <ipc/devman.h> 41 42 42 43 int usb_device_create_match_ids(usb_endpoint_pipe_t *, match_id_list_t *); -
uspace/lib/usb/src/pipes.c
rbfe0eb5 rb53ca1e 31 31 */ 32 32 /** @file 33 * Communication between device drivers and host controller driver. 34 * 35 * Note on synchronousness of the operations: there is ABSOLUTELY NO 36 * guarantee that a call to particular function will not trigger a fibril 37 * switch. 38 * The initialization functions may actually involve contacting some other 39 * task, starting/ending a session might involve asynchronous IPC and since 40 * the transfer functions uses IPC, asynchronous nature of them is obvious. 41 * The pseudo synchronous versions for the transfers internally call the 42 * asynchronous ones and so fibril switch is possible in them as well. 33 * USB endpoint pipes miscellaneous functions. 43 34 */ 44 35 #include <usb/usb.h> … … 47 38 #include <assert.h> 48 39 #include <usb/usbdrv.h> 49 50 #define _PREPARE_TARGET(varname, pipe) \51 usb_target_t varname = { \52 .address = (pipe)->wire->address, \53 .endpoint = (pipe)->endpoint_no \54 }55 40 56 41 /** Initialize connection to USB device. … … 117 102 } 118 103 119 /** Initialize USB endpoint pipe.120 *121 * @param pipe Endpoint pipe to be initialized.122 * @param connection Connection to the USB device backing this pipe (the wire).123 * @param endpoint_no Endpoint number (in USB 1.1 in range 0 to 15).124 * @param transfer_type Transfer type (e.g. interrupt or bulk).125 * @param max_packet_size Maximum packet size in bytes.126 * @param direction Endpoint direction (in/out).127 * @return Error code.128 */129 int usb_endpoint_pipe_initialize(usb_endpoint_pipe_t *pipe,130 usb_device_connection_t *connection, usb_endpoint_t endpoint_no,131 usb_transfer_type_t transfer_type, size_t max_packet_size,132 usb_direction_t direction)133 {134 assert(pipe);135 assert(connection);136 137 pipe->wire = connection;138 pipe->hc_phone = -1;139 pipe->endpoint_no = endpoint_no;140 pipe->transfer_type = transfer_type;141 pipe->max_packet_size = max_packet_size;142 pipe->direction = direction;143 144 return EOK;145 }146 147 148 /** Initialize USB endpoint pipe as the default zero control pipe.149 *150 * @param pipe Endpoint pipe to be initialized.151 * @param connection Connection to the USB device backing this pipe (the wire).152 * @return Error code.153 */154 int usb_endpoint_pipe_initialize_default_control(usb_endpoint_pipe_t *pipe,155 usb_device_connection_t *connection)156 {157 assert(pipe);158 assert(connection);159 160 int rc = usb_endpoint_pipe_initialize(pipe, connection,161 0, USB_TRANSFER_CONTROL, 8, USB_DIRECTION_BOTH);162 163 return rc;164 }165 166 104 167 105 /** Start a session on the endpoint pipe. … … 224 162 } 225 163 226 227 /** Request a read (in) transfer on an endpoint pipe.228 *229 * @param[in] pipe Pipe used for the transfer.230 * @param[out] buffer Buffer where to store the data.231 * @param[in] size Size of the buffer (in bytes).232 * @param[out] size_transfered Number of bytes that were actually transfered.233 * @return Error code.234 */235 int usb_endpoint_pipe_read(usb_endpoint_pipe_t *pipe,236 void *buffer, size_t size, size_t *size_transfered)237 {238 assert(pipe);239 240 int rc;241 usb_handle_t handle;242 243 rc = usb_endpoint_pipe_async_read(pipe, buffer, size, size_transfered,244 &handle);245 if (rc != EOK) {246 return rc;247 }248 249 rc = usb_endpoint_pipe_wait_for(pipe, handle);250 return rc;251 }252 253 /** Request a write (out) transfer on an endpoint pipe.254 *255 * @param[in] pipe Pipe used for the transfer.256 * @param[in] buffer Buffer with data to transfer.257 * @param[in] size Size of the buffer (in bytes).258 * @return Error code.259 */260 int usb_endpoint_pipe_write(usb_endpoint_pipe_t *pipe,261 void *buffer, size_t size)262 {263 assert(pipe);264 265 int rc;266 usb_handle_t handle;267 268 rc = usb_endpoint_pipe_async_write(pipe, buffer, size, &handle);269 if (rc != EOK) {270 return rc;271 }272 273 rc = usb_endpoint_pipe_wait_for(pipe, handle);274 return rc;275 }276 277 278 /** Request a control read transfer on an endpoint pipe.279 *280 * This function encapsulates all three stages of a control transfer.281 *282 * @param[in] pipe Pipe used for the transfer.283 * @param[in] setup_buffer Buffer with the setup packet.284 * @param[in] setup_buffer_size Size of the setup packet (in bytes).285 * @param[out] data_buffer Buffer for incoming data.286 * @param[in] data_buffer_size Size of the buffer for incoming data (in bytes).287 * @param[out] data_transfered_size Number of bytes that were actually288 * transfered during the DATA stage.289 * @return Error code.290 */291 int usb_endpoint_pipe_control_read(usb_endpoint_pipe_t *pipe,292 void *setup_buffer, size_t setup_buffer_size,293 void *data_buffer, size_t data_buffer_size, size_t *data_transfered_size)294 {295 assert(pipe);296 297 int rc;298 usb_handle_t handle;299 300 rc = usb_endpoint_pipe_async_control_read(pipe,301 setup_buffer, setup_buffer_size,302 data_buffer, data_buffer_size, data_transfered_size,303 &handle);304 if (rc != EOK) {305 return rc;306 }307 308 rc = usb_endpoint_pipe_wait_for(pipe, handle);309 return rc;310 }311 312 313 /** Request a control write transfer on an endpoint pipe.314 *315 * This function encapsulates all three stages of a control transfer.316 *317 * @param[in] pipe Pipe used for the transfer.318 * @param[in] setup_buffer Buffer with the setup packet.319 * @param[in] setup_buffer_size Size of the setup packet (in bytes).320 * @param[in] data_buffer Buffer with data to be sent.321 * @param[in] data_buffer_size Size of the buffer with outgoing data (in bytes).322 * @return Error code.323 */324 int usb_endpoint_pipe_control_write(usb_endpoint_pipe_t *pipe,325 void *setup_buffer, size_t setup_buffer_size,326 void *data_buffer, size_t data_buffer_size)327 {328 assert(pipe);329 330 int rc;331 usb_handle_t handle;332 333 rc = usb_endpoint_pipe_async_control_write(pipe,334 setup_buffer, setup_buffer_size,335 data_buffer, data_buffer_size,336 &handle);337 if (rc != EOK) {338 return rc;339 }340 341 rc = usb_endpoint_pipe_wait_for(pipe, handle);342 return rc;343 }344 345 346 /** Request a read (in) transfer on an endpoint pipe (asynchronous version).347 *348 * @param[in] pipe Pipe used for the transfer.349 * @param[out] buffer Buffer where to store the data.350 * @param[in] size Size of the buffer (in bytes).351 * @param[out] size_transfered Number of bytes that were actually transfered.352 * @param[out] handle Handle of the transfer.353 * @return Error code.354 */355 int usb_endpoint_pipe_async_read(usb_endpoint_pipe_t *pipe,356 void *buffer, size_t size, size_t *size_transfered,357 usb_handle_t *handle)358 {359 assert(pipe);360 361 if (pipe->hc_phone < 0) {362 return EBADF;363 }364 365 if (pipe->direction != USB_DIRECTION_IN) {366 return EBADF;367 }368 369 int rc;370 _PREPARE_TARGET(target, pipe);371 372 switch (pipe->transfer_type) {373 case USB_TRANSFER_INTERRUPT:374 rc = usb_drv_async_interrupt_in(pipe->hc_phone, target,375 buffer, size, size_transfered, handle);376 break;377 case USB_TRANSFER_CONTROL:378 rc = EBADF;379 break;380 default:381 rc = ENOTSUP;382 break;383 }384 385 return rc;386 }387 388 389 /** Request a write (out) transfer on an endpoint pipe (asynchronous version).390 *391 * @param[in] pipe Pipe used for the transfer.392 * @param[in] buffer Buffer with data to transfer.393 * @param[in] size Size of the buffer (in bytes).394 * @param[out] handle Handle of the transfer.395 * @return Error code.396 */397 int usb_endpoint_pipe_async_write(usb_endpoint_pipe_t *pipe,398 void *buffer, size_t size,399 usb_handle_t *handle)400 {401 assert(pipe);402 403 if (pipe->hc_phone < 0) {404 return EBADF;405 }406 407 if (pipe->direction != USB_DIRECTION_OUT) {408 return EBADF;409 }410 411 int rc;412 _PREPARE_TARGET(target, pipe);413 414 switch (pipe->transfer_type) {415 case USB_TRANSFER_INTERRUPT:416 rc = usb_drv_async_interrupt_out(pipe->hc_phone, target,417 buffer, size, handle);418 break;419 case USB_TRANSFER_CONTROL:420 rc = EBADF;421 break;422 default:423 rc = ENOTSUP;424 break;425 }426 427 return rc;428 }429 430 431 /** Request a control read transfer on an endpoint pipe (asynchronous version).432 *433 * This function encapsulates all three stages of a control transfer.434 *435 * @param[in] pipe Pipe used for the transfer.436 * @param[in] setup_buffer Buffer with the setup packet.437 * @param[in] setup_buffer_size Size of the setup packet (in bytes).438 * @param[out] data_buffer Buffer for incoming data.439 * @param[in] data_buffer_size Size of the buffer for incoming data (in bytes).440 * @param[out] data_transfered_size Number of bytes that were actually441 * transfered during the DATA stage.442 * @param[out] handle Handle of the transfer.443 * @return Error code.444 */445 int usb_endpoint_pipe_async_control_read(usb_endpoint_pipe_t *pipe,446 void *setup_buffer, size_t setup_buffer_size,447 void *data_buffer, size_t data_buffer_size, size_t *data_transfered_size,448 usb_handle_t *handle)449 {450 assert(pipe);451 452 if (pipe->hc_phone < 0) {453 return EBADF;454 }455 456 if ((pipe->direction != USB_DIRECTION_BOTH)457 || (pipe->transfer_type != USB_TRANSFER_CONTROL)) {458 return EBADF;459 }460 461 int rc;462 _PREPARE_TARGET(target, pipe);463 464 rc = usb_drv_async_control_read(pipe->hc_phone, target,465 setup_buffer, setup_buffer_size,466 data_buffer, data_buffer_size, data_transfered_size,467 handle);468 469 return rc;470 }471 472 473 /** Request a control write transfer on an endpoint pipe (asynchronous version).474 *475 * This function encapsulates all three stages of a control transfer.476 *477 * @param[in] pipe Pipe used for the transfer.478 * @param[in] setup_buffer Buffer with the setup packet.479 * @param[in] setup_buffer_size Size of the setup packet (in bytes).480 * @param[in] data_buffer Buffer with data to be sent.481 * @param[in] data_buffer_size Size of the buffer with outgoing data (in bytes).482 * @param[out] handle Handle of the transfer.483 * @return Error code.484 */485 int usb_endpoint_pipe_async_control_write(usb_endpoint_pipe_t *pipe,486 void *setup_buffer, size_t setup_buffer_size,487 void *data_buffer, size_t data_buffer_size,488 usb_handle_t *handle)489 {490 assert(pipe);491 492 if (pipe->hc_phone < 0) {493 return EBADF;494 }495 496 if ((pipe->direction != USB_DIRECTION_BOTH)497 || (pipe->transfer_type != USB_TRANSFER_CONTROL)) {498 return EBADF;499 }500 501 int rc;502 _PREPARE_TARGET(target, pipe);503 504 rc = usb_drv_async_control_write(pipe->hc_phone, target,505 setup_buffer, setup_buffer_size,506 data_buffer, data_buffer_size,507 handle);508 509 return rc;510 }511 512 /** Wait for transfer completion.513 *514 * The function blocks the caller fibril until the transfer associated515 * with given @p handle is completed.516 *517 * @param[in] pipe Pipe the transfer executed on.518 * @param[in] handle Transfer handle.519 * @return Error code.520 */521 int usb_endpoint_pipe_wait_for(usb_endpoint_pipe_t *pipe, usb_handle_t handle)522 {523 return usb_drv_async_wait_for(handle);524 }525 526 527 164 /** 528 165 * @} -
uspace/lib/usb/src/pipesinit.c
rbfe0eb5 rb53ca1e 320 320 } 321 321 322 /** Initialize USB endpoint pipe. 323 * 324 * @param pipe Endpoint pipe to be initialized. 325 * @param connection Connection to the USB device backing this pipe (the wire). 326 * @param endpoint_no Endpoint number (in USB 1.1 in range 0 to 15). 327 * @param transfer_type Transfer type (e.g. interrupt or bulk). 328 * @param max_packet_size Maximum packet size in bytes. 329 * @param direction Endpoint direction (in/out). 330 * @return Error code. 331 */ 332 int usb_endpoint_pipe_initialize(usb_endpoint_pipe_t *pipe, 333 usb_device_connection_t *connection, usb_endpoint_t endpoint_no, 334 usb_transfer_type_t transfer_type, size_t max_packet_size, 335 usb_direction_t direction) 336 { 337 assert(pipe); 338 assert(connection); 339 340 pipe->wire = connection; 341 pipe->hc_phone = -1; 342 pipe->endpoint_no = endpoint_no; 343 pipe->transfer_type = transfer_type; 344 pipe->max_packet_size = max_packet_size; 345 pipe->direction = direction; 346 347 return EOK; 348 } 349 350 351 /** Initialize USB endpoint pipe as the default zero control pipe. 352 * 353 * @param pipe Endpoint pipe to be initialized. 354 * @param connection Connection to the USB device backing this pipe (the wire). 355 * @return Error code. 356 */ 357 int usb_endpoint_pipe_initialize_default_control(usb_endpoint_pipe_t *pipe, 358 usb_device_connection_t *connection) 359 { 360 assert(pipe); 361 assert(connection); 362 363 int rc = usb_endpoint_pipe_initialize(pipe, connection, 364 0, USB_TRANSFER_CONTROL, 8, USB_DIRECTION_BOTH); 365 366 return rc; 367 } 368 322 369 /** 323 370 * @} -
uspace/lib/usb/src/usbdrv.c
rbfe0eb5 rb53ca1e 464 464 assert(setup_packet != NULL); 465 465 assert(setup_packet_size > 0); 466 assert( buffer != NULL);467 assert(buffer_size > 0);466 assert(((buffer != NULL) && (buffer_size > 0)) 467 || ((buffer == NULL) && (buffer_size == 0))); 468 468 assert(handle != NULL); 469 469 … … 494 494 } 495 495 496 rc = async_data_write_start(phone, buffer, buffer_size); 497 if (rc != EOK) { 498 async_wait_for(transfer->request, NULL); 499 return rc; 496 if (buffer_size > 0) { 497 rc = async_data_write_start(phone, buffer, buffer_size); 498 if (rc != EOK) { 499 async_wait_for(transfer->request, NULL); 500 return rc; 501 } 500 502 } 501 503
Note:
See TracChangeset
for help on using the changeset viewer.