hathach
a1b17be681
add class flags
...
change keyboard_info_pool to keyboard_data
2013-03-24 17:29:07 +07:00
hathach
92c137243d
refractor
...
- rename usbh_device_info_pool to usbh_devices
- create a struct for control pipe in usbh_device_info_t
2013-03-24 16:44:59 +07:00
hathach
ea04815bbc
rename sem_hdl in usbh_device_info_t control_sem_hdl
2013-03-24 16:22:58 +07:00
hathach
55ce5cc4a2
add TUSB_DEVICE_STATE_INVALID_PARAMETER to tusb_device_state_t
2013-03-24 16:05:50 +07:00
hathach
439a3134b9
refractor
...
- rename tusbh_device_status_get to tusbh_device_get_state
- replace tusbh_device_status_t by tusb_device_state_t
2013-03-24 16:02:45 +07:00
hathach
ce63980386
clean up:
...
- refractor tusb_handle_device_t device_hdl to uint8_t dev_addr
add keyboard_app.c/h
2013-03-24 15:50:49 +07:00
hathach
9c5ffa9932
house keeping
2013-03-24 14:32:54 +07:00
hathach
0c5e0ef0f3
- add control_pipe_status for usbh_device_info_t to reflect the status transfer of control pipe
...
- fix bug with hcd_port_reset
+ remove regs->portsc_bit.port_enable in the wait loop as device unplugged can cause this to always fails
- correct the timeout for hcd_controll_stop/reset 16 uframes ~ 2 ms
- potentially fix bugs device unplugged when new address is not assigned
2013-03-23 18:36:43 +07:00
hathach
44e09cc397
enhance some tests
...
add test for usbh_isr error invoke
fix bug if device unplugged before is set to new address
- clean up & close control addr0 in usbh_device_unplugged_isr
2013-03-23 17:31:51 +07:00
hathach
4adfc6a6d8
change signature usbh_isr to add tusb_bus_event_t parameter
...
change singature of call_isr as well
2013-03-23 15:00:56 +07:00
hathach
e6b8166a58
house keeping
2013-03-23 14:27:32 +07:00
hathach
e14864759d
refractor
...
- rename TUSB_DEVICE_STATE_READY to TUSB_DEVICE_STATE_CONFIGURED
- move device_state to core/tusb_types.h
- remove usbh_device_hcd_data_cleaned_up_cb, hcd now set the state directly
2013-03-23 12:13:02 +07:00
hathach
d7ba86c85e
refractor
...
- rename usbh_device_info_t.status to state
- rename enum TUSB_DEVICE_STATUS_* to TUSB_DEVICE_STATE_*
2013-03-23 11:34:51 +07:00
hathach
ae9b9ead7a
continue clean up ehci
2013-03-23 10:23:37 +07:00
hathach
53a4164b39
use DO PING for highspeed out bulk
2013-03-22 21:50:07 +07:00
hathach
397d62db10
fix bug: adjust all bulk queue head from ehci_data.device
2013-03-22 21:21:00 +07:00
hathach
f6acca6664
add callback for hcd when it cleaned up all cache data for a device (previously mark as removing).
2013-03-22 18:55:45 +07:00
hathach
6b276d09bf
house keeping for pipe API test code
2013-03-22 17:45:03 +07:00
hathach
45c94c2aa9
test code clean up
2013-03-22 17:36:59 +07:00
hathach
cf98cdeaa2
refractoring test code
2013-03-22 17:34:59 +07:00
hathach
9d4327f5bd
start to clean up test code
2013-03-22 17:10:38 +07:00
hathach
dbaf6c0d30
- fix bug when unplugged unmounted-already device (mostly plugged when power on)
...
- add hal_debugger_is_attached & hal_debugger_breakpoint
- assert will suspend (place breakpoint) if the condition is failed and debugger is attached. Otherwise, a message to uart is printed
- fix get control qhd function when dev_addr is not zero (shifted 1)
- fix wrong logic for unsupported class
2013-03-22 17:08:51 +07:00
hathach
9bc30f7694
add some test for usbh_hcd integration
...
- add tests for pipe_close (while TDs are active)
- add tests for device unplugged
add tesst & implement the async_advance_isr to clean up "REMOVING" queue head
- add helper find previous qhd
- add remove qhd from async list
- add is_removing field for async advance isr to clean up
add pipe close for control pipe & bulk pipe (with tests)
add helper get qhd from pipe_handle
2013-03-13 21:42:19 +07:00
hathach
dbd3d9618d
refractor rename field inactive_next_xact of ehci_qhd_t
2013-03-13 12:29:44 +07:00
hathach
1a932e7437
refractor ehci test files
...
adding some code for async_advance_isr
add test for async_advance_isr
2013-03-13 12:25:27 +07:00
hathach
97c436a16e
add usbh_pipe_control_close (in conjunction with usbh pipe control open)
...
close control pipe when unplugged
2013-03-13 11:20:02 +07:00
hathach
97c9001d40
add hard fault handler to bsp.c
...
rename class_install_subtask to class_open_subtask
add class_close for unmount
adding code for usbh_device_unplugged_isr & invoke it in hcd_isr
2013-03-13 10:57:30 +07:00
hathach
63765b37c7
forget to add test file for ehci isr
2013-03-13 00:17:02 +07:00
hathach
79e277d323
go through all the enumeration (up to get full configuration)
...
- fix init_qhd for address 0 (clear queue head --> ehci controller halted)
- fix bug in usbh_init missing address0 for semaphore create
TUSB_CFG_DEBUG == 3: --> ATTR_ALWAYS_INLINE is null --> allow gcc to export "normal inline" function
2013-03-13 00:02:45 +07:00
hathach
80facf6f2e
add isr api for usbh_hcd
...
- void usbh_device_plugged_isr(uint8_t hostid, tusb_speed_t speed);
- void usbh_device_unplugged_isr(uint8_t hostid);
implement port_connect_status_isr
2013-03-12 16:42:19 +07:00
hathach
38ff7123b4
add semaphore reset & queue flush API for osal
...
add semaphore reset when opening control pipe
2013-03-12 00:10:52 +07:00
hathach
8eaad2326b
add semphore reset & queue flush API
...
modify test to check control pipe semaphore created with usbh_init
2013-03-11 12:00:25 +07:00
hathach
3b0b48e01a
- add test code for bulk xfer isr
...
- fix mismatch type func return
2013-03-10 19:28:38 +07:00
hathach
0e845947ce
rename
2013-03-10 18:17:57 +07:00
hathach
c1848b8114
add code for ehci interrupt handler
...
- interrupt source identifying
- for async list process
refractor control_xfer to use insert_qtd_to_qhd
- add test for control xfer interrupt processing
- add code for faking ehci controller async list scheduling & processing
- add prototype for void usbh_isr(pipe_handle_t pipe_hdl, uint8_t class_code);
2013-03-10 17:51:53 +07:00
hathach
889f267e12
rename file
2013-03-10 07:21:54 +07:00
hathach
8457585464
add class code to hcd_pipe_open to facilitate usb_complete callback
2013-03-09 21:37:49 +07:00
hathach
2364b09f80
add int_on_complete parameter to hcd_pipe_xfer for TD chain class request
...
fix control transfer request: remove get_control_request_ptr()
2013-03-09 14:19:40 +07:00
hathach
b1db85dedf
- addd p_qtd_list_tail to qhd structure for easy queue TD
...
- move control_request from ehci_data to usbh_device_info_pool
- add test for bulk transfer double (2 consecutive xfers)
- use table (array) structure for class driver, currently included
- refractor extract to function insert_qtd_to_qhd
+ init function
+ install_subtask
--> all class driver function must be declared with WEAK
2013-03-09 13:11:02 +07:00
hathach
b146730306
add test code & hcd_pipe_xfer for bulk transfer
...
- test cross 4k boundary test for bulk transfer
rename p_qtd_list to p_qtd_list_head
2013-03-07 19:54:00 +07:00
hathach
644f0d3932
make "used" member of ehci_qtd_t into reserved place of buffer[1] (with assert check in hcd init)
2013-03-07 17:59:07 +07:00
hathach
6d30ae1f32
guard check for open iso pipe
2013-03-07 16:10:16 +07:00
hathach
66586ffb08
re-layout ehci_data_t to get better memory consumption
2013-03-07 16:06:28 +07:00
hathach
ef08654e73
add prototype for hcd_pipe(control)_close
...
- update test code for enum task respectively
2013-03-06 22:41:14 +07:00
hathach
5c3bd1f8dc
add code & test for hcd_pipe_open interrupt
...
high and non-highspeed
2013-03-06 22:21:42 +07:00
hathach
7557a807a9
basically finish code for control transfer & test code
2013-03-06 16:32:01 +07:00
hathach
f38fed3529
pass test for setup TD
2013-03-06 15:39:37 +07:00
hathach
685fb97086
rename fields in ehci_qtd_t
2013-03-06 15:08:09 +07:00
hathach
959311532e
refractor
...
- rename some field in ehci_qhd/qtd_t
- code test for open pipe
2013-03-06 14:55:02 +07:00
hathach
ef1cef5019
refractor ehci_data_t
...
separate tests for pipe open & pipe xfer
2013-03-06 14:25:26 +07:00