add tusbh_hid_mouse_isr & tusbh_hid_keyboard_isr callback with xfer_complete & error event
This commit is contained in:
		
							
								
								
									
										70
									
								
								tests/test/host/hid/hidh_callback.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								tests/test/host/hid/hidh_callback.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| /* | ||||
|  * tusb_callback.h | ||||
|  * | ||||
|  *  Created on: Feb 5, 2013 | ||||
|  *      Author: hathach | ||||
|  */ | ||||
|  | ||||
| /* | ||||
|  * Software License Agreement (BSD License) | ||||
|  * Copyright (c) 2012, hathach (tinyusb.org) | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without modification, | ||||
|  * are permitted provided that the following conditions are met: | ||||
|  * | ||||
|  * 1. Redistributions of source code must retain the above copyright notice, | ||||
|  *    this list of conditions and the following disclaimer. | ||||
|  * 2. Redistributions in binary form must reproduce the above copyright notice, | ||||
|  *    this list of conditions and the following disclaimer in the documentation | ||||
|  *    and/or other materials provided with the distribution. | ||||
|  * 3. The name of the author may not be used to endorse or promote products | ||||
|  *    derived from this software without specific prior written permission. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED | ||||
|  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | ||||
|  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT | ||||
|  * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | ||||
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT | ||||
|  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | ||||
|  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN | ||||
|  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING | ||||
|  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY | ||||
|  * OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This file is part of the tiny usb stack. | ||||
|  */ | ||||
|  | ||||
| /** \file | ||||
|  *  \brief TBD | ||||
|  * | ||||
|  *  \note TBD | ||||
|  */ | ||||
|  | ||||
| /** \ingroup TBD | ||||
|  *  \defgroup TBD | ||||
|  *  \brief TBD | ||||
|  * | ||||
|  *  @{ | ||||
|  */ | ||||
|  | ||||
| #ifndef _TUSB_HIDH_CALLBACK_H_ | ||||
| #define _TUSB_HIDH_CALLBACK_H_ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
|  | ||||
| #include "common/common.h" | ||||
|  | ||||
| //------------- hidh -------------// | ||||
| void tusbh_hid_keyboard_isr(uint8_t dev_addr, uint8_t instance_num, tusb_event_t event) ATTR_WEAK; | ||||
| void tusbh_hid_mouse_isr(uint8_t dev_addr, uint8_t instance_num, tusb_event_t event) ATTR_WEAK; | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|  | ||||
| #endif /* _TUSB_HIDH_CALLBACK_H_ */ | ||||
|  | ||||
| /** @} */ | ||||
| @@ -39,10 +39,12 @@ | ||||
| #include "unity.h" | ||||
| #include "type_helper.h" | ||||
| #include "errors.h" | ||||
| #include "common/common.h" | ||||
| #include "hid_host.h" | ||||
| #include "mock_osal.h" | ||||
| #include "mock_usbh.h" | ||||
| #include "mock_hcd.h" | ||||
| #include "mock_hidh_callback.h" | ||||
| #include "descriptor_test.h" | ||||
|  | ||||
| extern hidh_interface_info_t keyboard_data[TUSB_CFG_HOST_DEVICE_MAX]; | ||||
| @@ -69,11 +71,10 @@ tusb_descriptor_endpoint_t  const *p_kdb_endpoint_desc  = &desc_configuration.ke | ||||
|  | ||||
| void setUp(void) | ||||
| { | ||||
|   hidh_init(); | ||||
|   memclr_(&report, sizeof(tusb_keyboard_report_t)); | ||||
|   dev_addr = RANDOM(TUSB_CFG_HOST_DEVICE_MAX)+1; | ||||
|  | ||||
|   hidh_init(); | ||||
|  | ||||
|   p_hidh_kbd = &keyboard_data[dev_addr-1]; | ||||
|  | ||||
|   p_hidh_kbd->report_size = sizeof(tusb_keyboard_report_t); | ||||
| @@ -96,6 +97,7 @@ void test_keyboard_init(void) | ||||
|   TEST_ASSERT_MEM_ZERO(keyboard_data, sizeof(hidh_interface_info_t)*TUSB_CFG_HOST_DEVICE_MAX); | ||||
| } | ||||
|  | ||||
| //------------- is supported -------------// | ||||
| void test_keyboard_is_supported_fail_unplug(void) | ||||
| { | ||||
|   tusbh_device_get_state_IgnoreAndReturn(TUSB_DEVICE_STATE_UNPLUG); | ||||
| @@ -191,9 +193,13 @@ void test_keyboard_get_ok() | ||||
|  | ||||
| void test_keyboard_isr_event_complete(void) | ||||
| { | ||||
|   tusbh_hid_keyboard_isr_Expect(dev_addr, 0, TUSB_EVENT_XFER_COMPLETE); | ||||
|  | ||||
|   //------------- Code Under TEST -------------// | ||||
|   hidh_isr(p_hidh_kbd->pipe_hdl, TUSB_EVENT_XFER_COMPLETE); | ||||
|  | ||||
|   tusbh_device_get_state_IgnoreAndReturn(TUSB_DEVICE_STATE_CONFIGURED); | ||||
|   TEST_ASSERT_EQUAL(TUSB_INTERFACE_STATUS_COMPLETE, tusbh_hid_keyboard_status(dev_addr, 0)); | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -39,10 +39,12 @@ | ||||
| #include "unity.h" | ||||
| #include "type_helper.h" | ||||
| #include "errors.h" | ||||
| #include "common/common.h" | ||||
| #include "hid_host.h" | ||||
| #include "mock_osal.h" | ||||
| #include "mock_usbh.h" | ||||
| #include "mock_hcd.h" | ||||
| #include "mock_hidh_callback.h" | ||||
| #include "descriptor_test.h" | ||||
|  | ||||
| extern hidh_interface_info_t mouse_data[TUSB_CFG_HOST_DEVICE_MAX]; | ||||
| @@ -180,6 +182,8 @@ void test_mouse_get_ok() | ||||
|  | ||||
| void test_mouse_isr_event_complete(void) | ||||
| { | ||||
|   tusbh_hid_mouse_isr_Expect(dev_addr, 0, TUSB_EVENT_XFER_COMPLETE); | ||||
|  | ||||
|   //------------- Code Under TEST -------------// | ||||
|   hidh_isr(p_hidh_mouse->pipe_hdl, TUSB_EVENT_XFER_COMPLETE); | ||||
|  | ||||
|   | ||||
| @@ -179,7 +179,7 @@ void test_addr0_failed_dev_desc(void) | ||||
| void test_addr0_failed_set_address(void) | ||||
| { | ||||
|   osal_semaphore_wait_StubWithCallback(semaphore_wait_timeout_stub(1)); | ||||
| //  hcd_port_reset_Expect( usbh_devices[0].core_id ); | ||||
|   hcd_port_reset_Expect( usbh_devices[0].core_id ); | ||||
|   tusbh_device_mount_failed_cb_Expect(TUSB_ERROR_USBH_MOUNT_DEVICE_NOT_RESPOND, NULL); | ||||
|  | ||||
|   usbh_enumeration_task(); | ||||
| @@ -191,7 +191,7 @@ void test_addr0_failed_set_address(void) | ||||
| void test_enum_failed_get_full_dev_desc(void) | ||||
| { | ||||
|   osal_semaphore_wait_StubWithCallback(semaphore_wait_timeout_stub(2)); | ||||
| //  hcd_port_reset_Expect( usbh_devices[0].core_id ); | ||||
|   hcd_port_reset_Expect( usbh_devices[0].core_id ); | ||||
|   hcd_pipe_control_close_ExpectAndReturn(0, TUSB_ERROR_NONE); | ||||
|  | ||||
|   osal_semaphore_reset_Expect( usbh_devices[0].control.sem_hdl ); | ||||
| @@ -211,7 +211,7 @@ void test_enum_failed_get_full_dev_desc(void) | ||||
| void test_enum_failed_get_9byte_config_desc(void) | ||||
| { | ||||
|   osal_semaphore_wait_StubWithCallback(semaphore_wait_timeout_stub(3)); | ||||
| //  hcd_port_reset_Expect( usbh_devices[0].core_id ); | ||||
|   hcd_port_reset_Expect( usbh_devices[0].core_id ); | ||||
|   hcd_pipe_control_close_ExpectAndReturn(0, TUSB_ERROR_NONE); | ||||
|   osal_semaphore_reset_Expect( usbh_devices[0].control.sem_hdl ); | ||||
|   hcd_pipe_control_open_ExpectAndReturn(1, desc_device.bMaxPacketSize0, TUSB_ERROR_NONE); | ||||
| @@ -228,7 +228,7 @@ void test_enum_failed_get_9byte_config_desc(void) | ||||
| void test_enum_failed_get_full_config_desc(void) | ||||
| { | ||||
|   osal_semaphore_wait_StubWithCallback(semaphore_wait_timeout_stub(4)); | ||||
| //  hcd_port_reset_Expect( usbh_devices[0].core_id ); | ||||
|   hcd_port_reset_Expect( usbh_devices[0].core_id ); | ||||
|   hcd_pipe_control_close_ExpectAndReturn(0, TUSB_ERROR_NONE); | ||||
|   osal_semaphore_reset_Expect( usbh_devices[0].control.sem_hdl ); | ||||
|   hcd_pipe_control_open_ExpectAndReturn(1, desc_device.bMaxPacketSize0, TUSB_ERROR_NONE); | ||||
| @@ -246,7 +246,7 @@ void class_install_expect(void) | ||||
| void test_enum_parse_config_desc(void) | ||||
| { | ||||
|   osal_semaphore_wait_StubWithCallback(semaphore_wait_timeout_stub(5)); | ||||
| //  hcd_port_reset_Expect( usbh_devices[0].core_id ); | ||||
|   hcd_port_reset_Expect( usbh_devices[0].core_id ); | ||||
|   hcd_pipe_control_close_ExpectAndReturn(0, TUSB_ERROR_NONE); | ||||
|   osal_semaphore_reset_Expect( usbh_devices[0].control.sem_hdl ); | ||||
|   hcd_pipe_control_open_ExpectAndReturn(1, desc_device.bMaxPacketSize0, TUSB_ERROR_NONE); | ||||
| @@ -262,7 +262,7 @@ void test_enum_parse_config_desc(void) | ||||
| void test_enum_set_configure(void) | ||||
| { | ||||
|   osal_semaphore_wait_StubWithCallback(semaphore_wait_timeout_stub(6)); | ||||
| //  hcd_port_reset_Expect( usbh_devices[0].core_id ); | ||||
|   hcd_port_reset_Expect( usbh_devices[0].core_id ); | ||||
|   hcd_pipe_control_close_ExpectAndReturn(0, TUSB_ERROR_NONE); | ||||
|   osal_semaphore_reset_Expect( usbh_devices[0].control.sem_hdl ); | ||||
|   hcd_pipe_control_open_ExpectAndReturn(1, desc_device.bMaxPacketSize0, TUSB_ERROR_NONE); | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* | ||||
|  * tusb_callback.h | ||||
|  * hidh_callback.h | ||||
|  * | ||||
|  *  Created on: Feb 5, 2013 | ||||
|  *      Author: hathach | ||||
| @@ -63,9 +63,6 @@ uint8_t      tusbh_device_attached_cb (tusb_descriptor_device_t const *p_desc_de | ||||
| void         tusbh_device_mount_succeed_cb (uint8_t dev_addr) ATTR_WEAK; | ||||
| void         tusbh_device_mount_failed_cb(tusb_error_t error, tusb_descriptor_device_t const *p_desc_device) ATTR_WEAK; | ||||
|  | ||||
| //------------- hidh -------------// | ||||
| void tusbh_hid_keyboard_isr(uint8_t dev_addr, tusb_event_t event); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 hathach
					hathach