From 060c4b3b302f349d15db1d521e97e9b08e889c93 Mon Sep 17 00:00:00 2001 From: hathach Date: Wed, 6 Feb 2013 16:52:18 +0700 Subject: [PATCH] refractor move device_addr0 into usbh_device_pool enum_entry contains speed and enum task will not carry out disconnection clean up --- tests/test/host/test_enum_task.c | 68 +++++++++++----------- tests/test/host/test_usbh.c | 12 ++-- tinyusb/host/hcd.h | 4 +- tinyusb/host/usbh.c | 98 ++++++++++++++++++-------------- tinyusb/host/usbh_hcd.h | 19 ++----- 5 files changed, 101 insertions(+), 100 deletions(-) diff --git a/tests/test/host/test_enum_task.c b/tests/test/host/test_enum_task.c index 7bb10466e..1ca02494f 100644 --- a/tests/test/host/test_enum_task.c +++ b/tests/test/host/test_enum_task.c @@ -44,36 +44,31 @@ #include "mock_usbh_hcd.h" #include "mock_tusb_callback.h" -extern usbh_device_info_t usbh_device_info_pool[TUSB_CFG_HOST_DEVICE_MAX]; -extern usbh_device_addr0_t device_addr0; +extern usbh_device_info_t usbh_device_info_pool[TUSB_CFG_HOST_DEVICE_MAX+1]; extern uint8_t enum_data_buffer[TUSB_CFG_HOST_ENUM_BUFFER_SIZE]; - tusb_handle_device_t dev_hdl; -pipe_handle_t pipe_addr0 = 12; usbh_enumerate_t const enum_connect = { - .core_id = 0, - .hub_addr = 0, - .hub_port = 0, - .connect_status = 1 + .core_id = 0, + .hub_addr = 0, + .hub_port = 0, + .speed = TUSB_SPEED_FULL }; void queue_recv_stub (osal_queue_handle_t const queue_hdl, uint32_t *p_data, uint32_t msec, tusb_error_t *p_error, int num_call); void semaphore_wait_success_stub(osal_semaphore_handle_t const sem_hdl, uint32_t msec, tusb_error_t *p_error, int num_call); -tusb_error_t control_xfer_stub(pipe_handle_t pipe_hdl, const tusb_std_request_t * const p_request, uint8_t data[], int num_call); +tusb_error_t control_xfer_stub(uint8_t dev_addr, const tusb_std_request_t * const p_request, uint8_t data[], int num_call); void setUp(void) { - memclr_(usbh_device_info_pool, sizeof(usbh_device_info_t)*TUSB_CFG_HOST_DEVICE_MAX); + memclr_(usbh_device_info_pool, sizeof(usbh_device_info_t)*(TUSB_CFG_HOST_DEVICE_MAX+1)); osal_queue_receive_StubWithCallback(queue_recv_stub); osal_semaphore_wait_StubWithCallback(semaphore_wait_success_stub); hcd_pipe_control_xfer_StubWithCallback(control_xfer_stub); hcd_port_connect_status_ExpectAndReturn(enum_connect.core_id, true); - hcd_port_speed_ExpectAndReturn(enum_connect.core_id, TUSB_SPEED_FULL); - - hcd_addr0_open_IgnoreAndReturn(TUSB_ERROR_NONE); + hcd_pipe_control_open_ExpectAndReturn(0, 8, TUSB_ERROR_NONE); } void tearDown(void) @@ -109,7 +104,7 @@ semaphore_wait_timeout(2) semaphore_wait_timeout(3) semaphore_wait_timeout(4) -tusb_error_t control_xfer_stub(pipe_handle_t pipe_hdl, const tusb_std_request_t * const p_request, uint8_t data[], int num_call) +tusb_error_t control_xfer_stub(uint8_t dev_addr, const tusb_std_request_t * const p_request, uint8_t data[], int num_call) { switch (num_call) { @@ -171,31 +166,34 @@ void test_addr0_failed_set_address(void) TEST_ASSERT_EQUAL_MEMORY(&desc_device, enum_data_buffer, 8); } -void test_enum_task_connect(void) + + +void test_enum_failed_get_full_dev_desc(void) { + pipe_handle_t a_pipe = 0x1111; + osal_semaphore_wait_StubWithCallback(semaphore_wait_timeout_stub(2)); + + hcd_pipe_control_open_ExpectAndReturn(1, desc_device.bMaxPacketSize0, a_pipe); + tusbh_device_mount_failed_cb_Expect(TUSB_ERROR_USBH_MOUNT_DEVICE_NOT_RESPOND, NULL); + + usbh_enumeration_task(); + + TEST_ASSERT_EQUAL(TUSB_DEVICE_STATUS_ADDRESSED, usbh_device_info_pool[1].status); + TEST_ASSERT_EQUAL(TUSB_SPEED_FULL, usbh_device_info_pool[1].speed); + TEST_ASSERT_EQUAL(enum_connect.core_id, usbh_device_info_pool[1].core_id); + TEST_ASSERT_EQUAL(enum_connect.hub_addr, usbh_device_info_pool[1].hub_addr); + TEST_ASSERT_EQUAL(enum_connect.hub_port, usbh_device_info_pool[1].hub_port); +} + +void test_enum_update_new_device_info(void) +{ + TEST_IGNORE(); + + osal_semaphore_wait_StubWithCallback(semaphore_wait_timeout_stub(2)); + usbh_enumeration_task(); - TEST_ASSERT_EQUAL(TUSB_DEVICE_STATUS_ADDRESSED, usbh_device_info_pool[0].status); - TEST_ASSERT_EQUAL(TUSB_SPEED_FULL, usbh_device_info_pool[0].speed); - TEST_ASSERT_EQUAL(enum_connect.core_id, usbh_device_info_pool[0].core_id); - TEST_ASSERT_EQUAL(enum_connect.hub_addr, usbh_device_info_pool[0].hub_addr); - TEST_ASSERT_EQUAL(enum_connect.hub_port, usbh_device_info_pool[0].hub_port); // hcd_pipe_control_open_ExpectAndReturn(1, desc_device.bMaxPacketSize0, TUSB_ERROR_NONE); } - -void test_enum_task_disconnect(void) -{ - TEST_IGNORE(); -} - -void test_enum_task_connect_via_hub(void) -{ - TEST_IGNORE(); -} - -void test_enum_task_disconnect_via_hub(void) -{ - TEST_IGNORE(); -} diff --git a/tests/test/host/test_usbh.c b/tests/test/host/test_usbh.c index e0fc003ee..da435426c 100644 --- a/tests/test/host/test_usbh.c +++ b/tests/test/host/test_usbh.c @@ -42,12 +42,12 @@ #include "mock_hcd.h" #include "mock_usbh_hcd.h" -extern usbh_device_info_t usbh_device_info_pool[TUSB_CFG_HOST_DEVICE_MAX]; +extern usbh_device_info_t usbh_device_info_pool[TUSB_CFG_HOST_DEVICE_MAX+1]; tusb_handle_device_t dev_hdl; void setUp(void) { dev_hdl = 0; - memset(usbh_device_info_pool, 0, TUSB_CFG_HOST_DEVICE_MAX*sizeof(usbh_device_info_t)); + memset(usbh_device_info_pool, 0, (TUSB_CFG_HOST_DEVICE_MAX+1)*sizeof(usbh_device_info_t)); } void tearDown(void) @@ -86,8 +86,8 @@ void test_usbh_init_ok(void) { uint32_t dummy; - usbh_device_info_t device_info_zero[TUSB_CFG_HOST_DEVICE_MAX]; - memclr_(device_info_zero, sizeof(usbh_device_info_t)*TUSB_CFG_HOST_DEVICE_MAX); + usbh_device_info_t device_info_zero[TUSB_CFG_HOST_DEVICE_MAX+1]; + memclr_(device_info_zero, sizeof(usbh_device_info_t)*(TUSB_CFG_HOST_DEVICE_MAX+1)); for(uint32_t i=0; ibMaxPacketSize0 ); + + { // Get full device descriptor + // tusb_std_request_t request_device_desc = { + // .bmRequestType = { .direction = TUSB_DIR_DEV_TO_HOST, .type = TUSB_REQUEST_TYPE_STANDARD, .recipient = TUSB_REQUEST_RECIPIENT_DEVICE }, + // .bRequest = TUSB_REQUEST_GET_DESCRIPTOR, + // .wValue = (TUSB_DESC_DEVICE << 8), + // .wLength = 18 + // }; + // + // hcd_pipe_control_xfer(device_addr0.pipe_hdl, &request_device_desc, enum_data_buffer); + // osal_semaphore_wait(usbh_device_info_pool[0].sem_hdl, OSAL_TIMEOUT_NORMAL, &error); // careful of local variable without static + // TASK_ASSERT_STATUS_HANDLER(error, tusbh_device_mount_failed_cb(TUSB_ERROR_USBH_MOUNT_DEVICE_NOT_RESPOND, NULL) ); } OSAL_TASK_LOOP_END @@ -153,7 +163,7 @@ tusb_error_t usbh_init(void) { uint32_t i; - memclr_(usbh_device_info_pool, sizeof(usbh_device_info_t)*TUSB_CFG_HOST_DEVICE_MAX); + memclr_(usbh_device_info_pool, sizeof(usbh_device_info_t)*(TUSB_CFG_HOST_DEVICE_MAX+1)); for(i=0; i