| 
									
										
										
										
											2023-03-17 16:12:49 +07:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2019-03-20 16:11:42 +07:00
										 |  |  |  * The MIT License (MIT) | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-05-14 11:48:05 +07:00
										 |  |  |  * Copyright (c) 2019 Ha Thach (tinyusb.org) | 
					
						
							| 
									
										
										
										
											2019-03-20 16:11:42 +07:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Permission is hereby granted, free of charge, to any person obtaining a copy | 
					
						
							|  |  |  |  * of this software and associated documentation files (the "Software"), to deal | 
					
						
							|  |  |  |  * in the Software without restriction, including without limitation the rights | 
					
						
							|  |  |  |  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | 
					
						
							|  |  |  |  * copies of the Software, and to permit persons to whom the Software is | 
					
						
							|  |  |  |  * furnished to do so, subject to the following conditions: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The above copyright notice and this permission notice shall be included in | 
					
						
							|  |  |  |  * all copies or substantial portions of the Software. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | 
					
						
							|  |  |  |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | 
					
						
							|  |  |  |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | 
					
						
							|  |  |  |  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | 
					
						
							|  |  |  |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | 
					
						
							|  |  |  |  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | 
					
						
							|  |  |  |  * THE SOFTWARE. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of the TinyUSB stack. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-24 12:35:44 +07:00
										 |  |  | #ifndef _TUSB_USBH_H_
 | 
					
						
							|  |  |  | #define _TUSB_USBH_H_
 | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  |  extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-27 18:18:30 +07:00
										 |  |  | #include "common/tusb_common.h"
 | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-25 16:15:58 +07:00
										 |  |  | #if CFG_TUH_MAX3421
 | 
					
						
							|  |  |  | #include "portable/analog/max3421/hcd_max3421.h"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-27 12:18:01 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // MACRO CONSTANT TYPEDEF
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2020-09-07 15:19:20 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-13 15:52:30 +07:00
										 |  |  | // Endpoint Bulk size depending on host mx speed
 | 
					
						
							|  |  |  | #define TUH_EPSIZE_BULK_MPS   (TUD_OPT_HIGH_SPEED ? TUSB_EPSIZE_BULK_HS : TUSB_EPSIZE_BULK_FS)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-11 21:57:55 +07:00
										 |  |  | // forward declaration
 | 
					
						
							| 
									
										
										
										
											2022-03-17 20:52:16 +07:00
										 |  |  | struct tuh_xfer_s; | 
					
						
							|  |  |  | typedef struct tuh_xfer_s tuh_xfer_t; | 
					
						
							| 
									
										
										
										
											2022-03-18 16:39:35 +07:00
										 |  |  | typedef void (*tuh_xfer_cb_t)(tuh_xfer_t* xfer); | 
					
						
							| 
									
										
										
										
											2022-03-11 21:57:55 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-19 00:43:31 +07:00
										 |  |  | // Note1: layout and order of this will be changed in near future
 | 
					
						
							| 
									
										
										
										
											2022-03-18 22:22:21 +07:00
										 |  |  | // it is advised to initialize it using member name
 | 
					
						
							| 
									
										
										
										
											2022-06-08 01:17:01 +07:00
										 |  |  | // Note2: not all field is available/meaningful in callback,
 | 
					
						
							|  |  |  | // some info is not saved by usbh to save SRAM
 | 
					
						
							| 
									
										
										
										
											2023-08-07 18:22:28 +07:00
										 |  |  | struct tuh_xfer_s { | 
					
						
							| 
									
										
										
										
											2022-03-18 13:38:30 +07:00
										 |  |  |   uint8_t daddr; | 
					
						
							| 
									
										
										
										
											2022-03-17 12:53:52 +07:00
										 |  |  |   uint8_t ep_addr; | 
					
						
							| 
									
										
										
										
											2022-11-28 23:22:10 +07:00
										 |  |  |   uint8_t TU_RESERVED;      // reserved
 | 
					
						
							| 
									
										
										
										
											2022-03-18 13:38:30 +07:00
										 |  |  |   xfer_result_t result; | 
					
						
							| 
									
										
										
										
											2022-11-28 23:22:10 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-18 22:22:21 +07:00
										 |  |  |   uint32_t actual_len;      // excluding setup packet
 | 
					
						
							| 
									
										
										
										
											2022-03-18 13:38:30 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-07 18:22:28 +07:00
										 |  |  |   union { | 
					
						
							| 
									
										
										
										
											2022-03-18 16:39:35 +07:00
										 |  |  |     tusb_control_request_t const* setup; // setup packet pointer if control transfer
 | 
					
						
							| 
									
										
										
										
											2022-11-28 23:22:10 +07:00
										 |  |  |     uint32_t buflen;                     // expected length if not control transfer (not available in callback)
 | 
					
						
							| 
									
										
										
										
											2022-03-18 13:38:30 +07:00
										 |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-18 22:22:21 +07:00
										 |  |  |   uint8_t* buffer;           // not available in callback if not control transfer
 | 
					
						
							| 
									
										
										
										
											2022-03-17 20:52:16 +07:00
										 |  |  |   tuh_xfer_cb_t complete_cb; | 
					
						
							| 
									
										
										
										
											2022-03-17 22:37:51 +07:00
										 |  |  |   uintptr_t user_data; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-18 22:22:21 +07:00
										 |  |  |   // uint32_t timeout_ms;    // place holder, not supported yet
 | 
					
						
							| 
									
										
										
										
											2022-03-11 21:57:55 +07:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2020-10-12 00:35:38 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-22 09:23:44 +07:00
										 |  |  | // Subject to change
 | 
					
						
							| 
									
										
										
										
											2023-08-07 18:22:28 +07:00
										 |  |  | typedef struct { | 
					
						
							| 
									
										
										
										
											2023-03-22 09:23:44 +07:00
										 |  |  |   uint8_t daddr; | 
					
						
							|  |  |  |   tusb_desc_interface_t desc; | 
					
						
							|  |  |  | } tuh_itf_info_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-23 16:03:40 +07:00
										 |  |  | typedef struct { | 
					
						
							|  |  |  |   uint8_t rhport; | 
					
						
							|  |  |  |   uint8_t hub_addr; | 
					
						
							|  |  |  |   uint8_t hub_port; | 
					
						
							|  |  |  |   uint8_t speed; | 
					
						
							|  |  |  | } tuh_bus_info_t; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-02 16:38:40 +07:00
										 |  |  | // ConfigID for tuh_configure()
 | 
					
						
							| 
									
										
										
										
											2023-08-07 18:22:28 +07:00
										 |  |  | enum { | 
					
						
							| 
									
										
										
										
											2024-04-02 16:38:40 +07:00
										 |  |  |   TUH_CFGID_INVALID = 0, | 
					
						
							|  |  |  |   TUH_CFGID_RPI_PIO_USB_CONFIGURATION = 100, // cfg_param: pio_usb_configuration_t
 | 
					
						
							|  |  |  |   TUH_CFGID_MAX3421 = 200, | 
					
						
							| 
									
										
										
										
											2022-06-08 01:17:01 +07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 13:16:08 +07:00
										 |  |  | typedef struct { | 
					
						
							| 
									
										
										
										
											2024-08-26 12:24:29 +07:00
										 |  |  |   uint8_t max_nak; // max NAK per endpoint per frame to save CPU/SPI bus usage
 | 
					
						
							| 
									
										
										
										
											2024-04-08 13:16:08 +07:00
										 |  |  |   uint8_t cpuctl; // R16: CPU Control Register
 | 
					
						
							|  |  |  |   uint8_t pinctl; // R17: Pin Control Register. FDUPSPI bit is ignored
 | 
					
						
							|  |  |  | } tuh_configure_max3421_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-02 16:38:40 +07:00
										 |  |  | typedef union { | 
					
						
							|  |  |  |   // For TUH_CFGID_RPI_PIO_USB_CONFIGURATION use pio_usb_configuration_t
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 13:16:08 +07:00
										 |  |  |   tuh_configure_max3421_t max3421; | 
					
						
							| 
									
										
										
										
											2024-04-02 16:38:40 +07:00
										 |  |  | } tuh_configure_param_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // APPLICATION CALLBACK
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-12 22:16:08 +07:00
										 |  |  | // Invoked when enumeration get device descriptor
 | 
					
						
							| 
									
										
										
										
											2025-03-24 22:55:04 +07:00
										 |  |  | // Device is not ready to communicate yet, application can copy the descriptor if needed
 | 
					
						
							|  |  |  | void tuh_enum_descriptor_device_cb(uint8_t daddr, const tusb_desc_device_t *desc_device); | 
					
						
							| 
									
										
										
										
											2022-08-25 15:08:00 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-12 22:16:08 +07:00
										 |  |  | // Invoked when enumeration get configuration descriptor
 | 
					
						
							| 
									
										
										
										
											2025-03-24 22:55:04 +07:00
										 |  |  | // For multi-configuration device return false to skip, true to proceed with this configuration (may not be implemented yet)
 | 
					
						
							|  |  |  | // Device is not ready to communicate yet, application can copy the descriptor if needed
 | 
					
						
							|  |  |  | bool tuh_enum_descriptor_configuration_cb(uint8_t daddr, uint8_t cfg_index, const tusb_desc_configuration_t *desc_config); | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-28 23:22:10 +07:00
										 |  |  | // Invoked when a device is mounted (configured)
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | TU_ATTR_WEAK void tuh_mount_cb (uint8_t daddr); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-28 23:22:10 +07:00
										 |  |  | // Invoked when a device failed to mount during enumeration process
 | 
					
						
							|  |  |  | // TU_ATTR_WEAK void tuh_mount_failed_cb (uint8_t daddr);
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-24 18:21:24 +07:00
										 |  |  | // Invoked when a device is unmounted (detached)
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | TU_ATTR_WEAK void tuh_umount_cb(uint8_t daddr); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-24 18:21:24 +07:00
										 |  |  | // Invoked when there is a new usb event, which need to be processed by tuh_task()/tuh_task_ext()
 | 
					
						
							| 
									
										
										
										
											2024-01-12 15:47:08 +07:00
										 |  |  | void tuh_event_hook_cb(uint8_t rhport, uint32_t eventid, bool in_isr); | 
					
						
							| 
									
										
										
										
											2023-11-24 18:21:24 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // APPLICATION API
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2020-09-05 13:57:07 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-08 01:17:01 +07:00
										 |  |  | // Configure host stack behavior with dynamic or port-specific parameters.
 | 
					
						
							|  |  |  | // Should be called before tuh_init()
 | 
					
						
							|  |  |  | // - cfg_id   : configure ID (TBD)
 | 
					
						
							|  |  |  | // - cfg_param: configure data, structure depends on the ID
 | 
					
						
							| 
									
										
										
										
											2023-08-07 18:22:28 +07:00
										 |  |  | bool tuh_configure(uint8_t rhport, uint32_t cfg_id, const void* cfg_param); | 
					
						
							| 
									
										
										
										
											2022-06-08 01:17:01 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-11 12:58:18 +07:00
										 |  |  | // New API to replace tuh_init() to init host stack on specific roothub port
 | 
					
						
							| 
									
										
										
										
											2024-10-14 18:27:52 +07:00
										 |  |  | bool tuh_rhport_init(uint8_t rhport, const tusb_rhport_init_t* rh_init); | 
					
						
							| 
									
										
										
										
											2022-06-08 01:17:01 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-05 13:57:07 +07:00
										 |  |  | // Init host stack
 | 
					
						
							| 
									
										
										
										
											2024-10-11 12:58:18 +07:00
										 |  |  | #if TUSB_VERSION_NUMBER > 2000  // 0.20.0
 | 
					
						
							| 
									
										
										
										
											2024-10-14 18:27:52 +07:00
										 |  |  | TU_ATTR_DEPRECATED("Please use tusb_init(rhport, rh_init) instead") | 
					
						
							| 
									
										
										
										
											2024-10-11 12:58:18 +07:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | TU_ATTR_ALWAYS_INLINE static inline bool tuh_init(uint8_t rhport) { | 
					
						
							|  |  |  |   const tusb_rhport_init_t rh_init = { | 
					
						
							|  |  |  |     .role = TUSB_ROLE_HOST, | 
					
						
							|  |  |  |     .speed = TUH_OPT_HIGH_SPEED ? TUSB_SPEED_HIGH : TUSB_SPEED_FULL, | 
					
						
							|  |  |  |   }; | 
					
						
							| 
									
										
										
										
											2024-10-14 18:27:52 +07:00
										 |  |  |   return tuh_rhport_init(rhport, &rh_init); | 
					
						
							| 
									
										
										
										
											2024-10-11 12:58:18 +07:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2020-09-05 13:57:07 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-22 11:42:33 +07:00
										 |  |  | // Deinit host stack on rhport
 | 
					
						
							|  |  |  | bool tuh_deinit(uint8_t rhport); | 
					
						
							| 
									
										
										
										
											2020-09-05 13:57:07 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-07 18:22:28 +07:00
										 |  |  | // Check if host stack is already initialized with any roothub ports
 | 
					
						
							| 
									
										
										
										
											2024-03-22 11:42:33 +07:00
										 |  |  | // To check if an rhport is initialized, use tuh_rhport_is_active()
 | 
					
						
							| 
									
										
										
										
											2021-05-02 01:46:22 +07:00
										 |  |  | bool tuh_inited(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-20 18:29:41 +07:00
										 |  |  | // Task function should be called in main/rtos loop, extended version of tuh_task()
 | 
					
						
							|  |  |  | // - timeout_ms: millisecond to wait, zero = no wait, 0xFFFFFFFF = wait forever
 | 
					
						
							|  |  |  | // - in_isr: if function is called in ISR
 | 
					
						
							|  |  |  | void tuh_task_ext(uint32_t timeout_ms, bool in_isr); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-05 13:57:07 +07:00
										 |  |  | // Task function should be called in main/rtos loop
 | 
					
						
							| 
									
										
										
										
											2025-03-21 00:11:18 +07:00
										 |  |  | TU_ATTR_ALWAYS_INLINE static inline void tuh_task(void) { | 
					
						
							| 
									
										
										
										
											2022-04-20 18:35:38 +07:00
										 |  |  |   tuh_task_ext(UINT32_MAX, false); | 
					
						
							| 
									
										
										
										
											2022-04-20 18:29:41 +07:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2018-12-13 14:51:37 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-22 09:23:44 +07:00
										 |  |  | // Check if there is pending events need processing by tuh_task()
 | 
					
						
							|  |  |  | bool tuh_task_event_ready(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-24 22:22:52 +07:00
										 |  |  | #ifndef _TUSB_HCD_H_
 | 
					
						
							| 
									
										
										
										
											2023-09-27 15:51:03 +07:00
										 |  |  | extern void hcd_int_handler(uint8_t rhport, bool in_isr); | 
					
						
							| 
									
										
										
										
											2022-06-24 22:22:52 +07:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-27 15:51:03 +07:00
										 |  |  | // Interrupt handler alias to HCD with in_isr as optional parameter
 | 
					
						
							| 
									
										
										
										
											2024-10-11 12:58:18 +07:00
										 |  |  | #define _tuh_int_handler_arg0()                   TU_VERIFY_STATIC(false, "tuh_int_handler() must have 1 or 2 arguments")
 | 
					
						
							|  |  |  | #define _tuh_int_handler_arg1(_rhport)            hcd_int_handler(_rhport, true)
 | 
					
						
							|  |  |  | #define _tuh_int_handler_arg2(_rhport, _in_isr)   hcd_int_handler(_rhport, _in_isr)
 | 
					
						
							| 
									
										
										
										
											2025-04-23 16:03:40 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // 1st argument is rhport (mandatory), 2nd argument in_isr (optional)
 | 
					
						
							| 
									
										
										
										
											2024-10-11 12:58:18 +07:00
										 |  |  | #define tuh_int_handler(...)   TU_FUNC_OPTIONAL_ARG(_tuh_int_handler, __VA_ARGS__)
 | 
					
						
							| 
									
										
										
										
											2019-11-21 22:20:30 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-07 18:22:28 +07:00
										 |  |  | // Check if roothub port is initialized and active as a host
 | 
					
						
							|  |  |  | bool tuh_rhport_is_active(uint8_t rhport); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Assert/de-assert Bus Reset signal to roothub port. USB specs: it should last 10-50ms
 | 
					
						
							|  |  |  | bool tuh_rhport_reset_bus(uint8_t rhport, bool active); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // Device API
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Get VID/PID of device
 | 
					
						
							| 
									
										
										
										
											2022-03-04 19:26:54 +07:00
										 |  |  | bool tuh_vid_pid_get(uint8_t daddr, uint16_t* vid, uint16_t* pid); | 
					
						
							| 
									
										
										
										
											2022-03-03 16:53:22 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-07 18:22:28 +07:00
										 |  |  | // Get speed of device
 | 
					
						
							| 
									
										
										
										
											2022-03-04 19:26:54 +07:00
										 |  |  | tusb_speed_t tuh_speed_get(uint8_t daddr); | 
					
						
							| 
									
										
										
										
											2013-03-24 15:50:49 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-24 12:30:57 +07:00
										 |  |  | // Check if device is connected and configured
 | 
					
						
							| 
									
										
										
										
											2022-03-04 19:26:54 +07:00
										 |  |  | bool tuh_mounted(uint8_t daddr); | 
					
						
							| 
									
										
										
										
											2021-08-24 12:30:57 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-17 22:40:19 +07:00
										 |  |  | // Check if device is connected which mean device has at least 1 successful transfer
 | 
					
						
							|  |  |  | // Note: It may not be addressed/configured/mounted yet
 | 
					
						
							|  |  |  | bool tuh_connected(uint8_t daddr); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-24 12:30:57 +07:00
										 |  |  | // Check if device is suspended
 | 
					
						
							| 
									
										
										
										
											2025-03-21 00:11:18 +07:00
										 |  |  | TU_ATTR_ALWAYS_INLINE static inline bool tuh_suspended(uint8_t daddr) { | 
					
						
							| 
									
										
										
										
											2021-08-24 12:30:57 +07:00
										 |  |  |   // TODO implement suspend & resume on host
 | 
					
						
							| 
									
										
										
										
											2022-03-04 19:26:54 +07:00
										 |  |  |   (void) daddr; | 
					
						
							| 
									
										
										
										
											2021-08-24 12:30:57 +07:00
										 |  |  |   return false; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2021-05-13 00:11:20 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Check if device is ready to communicate with
 | 
					
						
							| 
									
										
										
										
											2025-03-21 00:11:18 +07:00
										 |  |  | TU_ATTR_ALWAYS_INLINE static inline bool tuh_ready(uint8_t daddr) { | 
					
						
							| 
									
										
										
										
											2022-03-04 19:26:54 +07:00
										 |  |  |   return tuh_mounted(daddr) && !tuh_suspended(daddr); | 
					
						
							| 
									
										
										
										
											2021-05-13 00:11:20 +07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-23 16:03:40 +07:00
										 |  |  | // Get bus information of device
 | 
					
						
							|  |  |  | bool tuh_bus_info_get(uint8_t daddr, tuh_bus_info_t* bus_info); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-17 12:53:52 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2022-03-18 16:39:35 +07:00
										 |  |  | // Transfer API
 | 
					
						
							| 
									
										
										
										
											2022-03-17 12:53:52 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-17 21:20:20 +07:00
										 |  |  | // Submit a control transfer
 | 
					
						
							| 
									
										
										
										
											2022-03-19 00:43:31 +07:00
										 |  |  | //  - async: complete callback invoked when finished.
 | 
					
						
							|  |  |  | //  - sync : blocking if complete callback is NULL.
 | 
					
						
							| 
									
										
										
										
											2022-03-18 16:39:35 +07:00
										 |  |  | bool tuh_control_xfer(tuh_xfer_t* xfer); | 
					
						
							| 
									
										
										
										
											2022-03-11 21:57:55 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-17 21:20:20 +07:00
										 |  |  | // Submit a bulk/interrupt transfer
 | 
					
						
							| 
									
										
										
										
											2022-03-19 00:43:31 +07:00
										 |  |  | //  - async: complete callback invoked when finished.
 | 
					
						
							|  |  |  | //  - sync : blocking if complete callback is NULL.
 | 
					
						
							| 
									
										
										
										
											2022-03-18 16:39:35 +07:00
										 |  |  | bool tuh_edpt_xfer(tuh_xfer_t* xfer); | 
					
						
							| 
									
										
										
										
											2020-09-07 15:19:20 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-20 11:20:12 +07:00
										 |  |  | // Open a non-control endpoint
 | 
					
						
							|  |  |  | bool tuh_edpt_open(uint8_t daddr, tusb_desc_endpoint_t const * desc_ep); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-25 16:15:58 +07:00
										 |  |  | // Close a non-control endpoint, it will abort any pending transfer
 | 
					
						
							|  |  |  | bool tuh_edpt_close(uint8_t daddr, uint8_t ep_addr); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-20 11:20:12 +07:00
										 |  |  | // Abort a queued transfer. Note: it can only abort transfer that has not been started
 | 
					
						
							| 
									
										
										
										
											2023-07-21 19:06:36 +07:00
										 |  |  | // Return true if a queued transfer is aborted, false if there is no transfer to abort
 | 
					
						
							| 
									
										
										
										
											2023-07-20 11:20:12 +07:00
										 |  |  | bool tuh_edpt_abort_xfer(uint8_t daddr, uint8_t ep_addr); | 
					
						
							| 
									
										
										
										
											2022-03-19 00:43:31 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-24 10:41:00 +07:00
										 |  |  | // Set Address (control transfer)
 | 
					
						
							|  |  |  | bool tuh_address_set(uint8_t daddr, uint8_t new_addr, | 
					
						
							|  |  |  |                      tuh_xfer_cb_t complete_cb, uintptr_t user_data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // Set Configuration (control transfer)
 | 
					
						
							| 
									
										
										
										
											2022-03-04 21:41:27 +07:00
										 |  |  | // config_num = 0 will un-configure device. Note: config_num = config_descriptor_index + 1
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // true on success, false if there is on-going control transfer or incorrect parameters
 | 
					
						
							| 
									
										
										
										
											2023-03-21 18:13:25 +07:00
										 |  |  | // if complete_cb == NULL i.e blocking, user_data should be pointed to xfer_reuslt_t*
 | 
					
						
							| 
									
										
										
										
											2022-03-11 21:57:55 +07:00
										 |  |  | bool tuh_configuration_set(uint8_t daddr, uint8_t config_num, | 
					
						
							| 
									
										
										
										
											2022-03-17 22:37:51 +07:00
										 |  |  |                            tuh_xfer_cb_t complete_cb, uintptr_t user_data); | 
					
						
							| 
									
										
										
										
											2022-03-04 21:41:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-21 12:54:43 +07:00
										 |  |  | // Set Interface (control transfer)
 | 
					
						
							|  |  |  | // true on success, false if there is on-going control transfer or incorrect parameters
 | 
					
						
							| 
									
										
										
										
											2023-03-21 18:13:25 +07:00
										 |  |  | // if complete_cb == NULL i.e blocking, user_data should be pointed to xfer_reuslt_t*
 | 
					
						
							| 
									
										
										
										
											2023-03-21 12:54:43 +07:00
										 |  |  | bool tuh_interface_set(uint8_t daddr, uint8_t itf_num, uint8_t itf_alt, | 
					
						
							|  |  |  |                        tuh_xfer_cb_t complete_cb, uintptr_t user_data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // Descriptors Asynchronous (non-blocking)
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2022-03-04 21:41:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // Get an descriptor (control transfer)
 | 
					
						
							|  |  |  | // true on success, false if there is on-going control transfer or incorrect parameters
 | 
					
						
							| 
									
										
										
										
											2022-03-11 21:57:55 +07:00
										 |  |  | bool tuh_descriptor_get(uint8_t daddr, uint8_t type, uint8_t index, void* buffer, uint16_t len, | 
					
						
							| 
									
										
										
										
											2022-03-17 22:37:51 +07:00
										 |  |  |                         tuh_xfer_cb_t complete_cb, uintptr_t user_data); | 
					
						
							| 
									
										
										
										
											2022-03-04 21:41:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // Get device descriptor (control transfer)
 | 
					
						
							|  |  |  | // true on success, false if there is on-going control transfer or incorrect parameters
 | 
					
						
							| 
									
										
										
										
											2022-03-11 21:57:55 +07:00
										 |  |  | bool tuh_descriptor_get_device(uint8_t daddr, void* buffer, uint16_t len, | 
					
						
							| 
									
										
										
										
											2022-03-17 22:37:51 +07:00
										 |  |  |                                tuh_xfer_cb_t complete_cb, uintptr_t user_data); | 
					
						
							| 
									
										
										
										
											2022-03-04 21:41:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // Get configuration descriptor (control transfer)
 | 
					
						
							|  |  |  | // true on success, false if there is on-going control transfer or incorrect parameters
 | 
					
						
							| 
									
										
										
										
											2022-03-11 21:57:55 +07:00
										 |  |  | bool tuh_descriptor_get_configuration(uint8_t daddr, uint8_t index, void* buffer, uint16_t len, | 
					
						
							| 
									
										
										
										
											2022-03-17 22:37:51 +07:00
										 |  |  |                                       tuh_xfer_cb_t complete_cb, uintptr_t user_data); | 
					
						
							| 
									
										
										
										
											2022-03-11 21:57:55 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // Get HID report descriptor (control transfer)
 | 
					
						
							|  |  |  | // true on success, false if there is on-going control transfer or incorrect parameters
 | 
					
						
							|  |  |  | bool tuh_descriptor_get_hid_report(uint8_t daddr, uint8_t itf_num, uint8_t desc_type, uint8_t index, void* buffer, uint16_t len, | 
					
						
							| 
									
										
										
										
											2022-03-17 22:37:51 +07:00
										 |  |  |                                    tuh_xfer_cb_t complete_cb, uintptr_t user_data); | 
					
						
							| 
									
										
										
										
											2022-03-04 21:41:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // Get string descriptor (control transfer)
 | 
					
						
							|  |  |  | // true on success, false if there is on-going control transfer or incorrect parameters
 | 
					
						
							| 
									
										
										
										
											2022-03-17 22:37:51 +07:00
										 |  |  | // Blocking if complete callback is NULL, in this case 'user_data' must contain xfer_result_t variable
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | bool tuh_descriptor_get_string(uint8_t daddr, uint8_t index, uint16_t language_id, void* buffer, uint16_t len, | 
					
						
							| 
									
										
										
										
											2022-03-17 22:37:51 +07:00
										 |  |  |                                tuh_xfer_cb_t complete_cb, uintptr_t user_data); | 
					
						
							| 
									
										
										
										
											2022-03-04 21:41:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-03 23:22:23 +07:00
										 |  |  | // Get language id string descriptor (control transfer)
 | 
					
						
							|  |  |  | TU_ATTR_ALWAYS_INLINE static inline | 
					
						
							|  |  |  | bool tuh_descriptor_get_string_langid(uint8_t daddr, void* buffer, uint16_t len, | 
					
						
							|  |  |  |                                tuh_xfer_cb_t complete_cb, uintptr_t user_data) { | 
					
						
							|  |  |  |   return tuh_descriptor_get_string(daddr, 0, 0, buffer, len, complete_cb, user_data); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // Get manufacturer string descriptor (control transfer)
 | 
					
						
							|  |  |  | // true on success, false if there is on-going control transfer or incorrect parameters
 | 
					
						
							| 
									
										
										
										
											2022-03-11 21:57:55 +07:00
										 |  |  | bool tuh_descriptor_get_manufacturer_string(uint8_t daddr, uint16_t language_id, void* buffer, uint16_t len, | 
					
						
							| 
									
										
										
										
											2022-03-17 22:37:51 +07:00
										 |  |  |                                             tuh_xfer_cb_t complete_cb, uintptr_t user_data); | 
					
						
							| 
									
										
										
										
											2022-03-04 21:41:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // Get product string descriptor (control transfer)
 | 
					
						
							|  |  |  | // true on success, false if there is on-going control transfer or incorrect parameters
 | 
					
						
							| 
									
										
										
										
											2022-03-11 21:57:55 +07:00
										 |  |  | bool tuh_descriptor_get_product_string(uint8_t daddr, uint16_t language_id, void* buffer, uint16_t len, | 
					
						
							| 
									
										
										
										
											2022-03-17 22:37:51 +07:00
										 |  |  |                                        tuh_xfer_cb_t complete_cb, uintptr_t user_data); | 
					
						
							| 
									
										
										
										
											2022-03-04 22:23:56 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // Get serial string descriptor (control transfer)
 | 
					
						
							|  |  |  | // true on success, false if there is on-going control transfer or incorrect parameters
 | 
					
						
							| 
									
										
										
										
											2022-03-11 21:57:55 +07:00
										 |  |  | bool tuh_descriptor_get_serial_string(uint8_t daddr, uint16_t language_id, void* buffer, uint16_t len, | 
					
						
							| 
									
										
										
										
											2022-03-17 22:37:51 +07:00
										 |  |  |                                       tuh_xfer_cb_t complete_cb, uintptr_t user_data); | 
					
						
							| 
									
										
										
										
											2022-03-09 11:03:29 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-24 15:50:49 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // Descriptors Synchronous (blocking)
 | 
					
						
							| 
									
										
										
										
											2013-03-24 15:50:49 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2018-12-10 19:25:57 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // Sync (blocking) version of tuh_descriptor_get()
 | 
					
						
							|  |  |  | // return transfer result
 | 
					
						
							| 
									
										
										
										
											2022-03-18 13:38:30 +07:00
										 |  |  | uint8_t tuh_descriptor_get_sync(uint8_t daddr, uint8_t type, uint8_t index, void* buffer, uint16_t len); | 
					
						
							| 
									
										
										
										
											2018-12-10 19:25:57 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // Sync (blocking) version of tuh_descriptor_get_device()
 | 
					
						
							|  |  |  | // return transfer result
 | 
					
						
							| 
									
										
										
										
											2022-03-18 13:38:30 +07:00
										 |  |  | uint8_t tuh_descriptor_get_device_sync(uint8_t daddr, void* buffer, uint16_t len); | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Sync (blocking) version of tuh_descriptor_get_configuration()
 | 
					
						
							|  |  |  | // return transfer result
 | 
					
						
							| 
									
										
										
										
											2022-03-18 13:38:30 +07:00
										 |  |  | uint8_t tuh_descriptor_get_configuration_sync(uint8_t daddr, uint8_t index, void* buffer, uint16_t len); | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Sync (blocking) version of tuh_descriptor_get_hid_report()
 | 
					
						
							|  |  |  | // return transfer result
 | 
					
						
							| 
									
										
										
										
											2022-03-18 13:38:30 +07:00
										 |  |  | uint8_t tuh_descriptor_get_hid_report_sync(uint8_t daddr, uint8_t itf_num, uint8_t desc_type, uint8_t index, void* buffer, uint16_t len); | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Sync (blocking) version of tuh_descriptor_get_string()
 | 
					
						
							|  |  |  | // return transfer result
 | 
					
						
							| 
									
										
										
										
											2022-03-18 13:38:30 +07:00
										 |  |  | uint8_t tuh_descriptor_get_string_sync(uint8_t daddr, uint8_t index, uint16_t language_id, void* buffer, uint16_t len); | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-03 23:22:23 +07:00
										 |  |  | // Sync (blocking) version of tuh_descriptor_get_string_langid()
 | 
					
						
							|  |  |  | TU_ATTR_ALWAYS_INLINE static inline | 
					
						
							|  |  |  | uint8_t tuh_descriptor_get_string_langid_sync(uint8_t daddr, void* buffer, uint16_t len) { | 
					
						
							|  |  |  |   return tuh_descriptor_get_string_sync(daddr, 0, 0, buffer, len); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | // Sync (blocking) version of tuh_descriptor_get_manufacturer_string()
 | 
					
						
							|  |  |  | // return transfer result
 | 
					
						
							| 
									
										
										
										
											2022-03-18 13:38:30 +07:00
										 |  |  | uint8_t tuh_descriptor_get_manufacturer_string_sync(uint8_t daddr, uint16_t language_id, void* buffer, uint16_t len); | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Sync (blocking) version of tuh_descriptor_get_product_string()
 | 
					
						
							|  |  |  | // return transfer result
 | 
					
						
							| 
									
										
										
										
											2022-03-18 13:38:30 +07:00
										 |  |  | uint8_t tuh_descriptor_get_product_string_sync(uint8_t daddr, uint16_t language_id, void* buffer, uint16_t len); | 
					
						
							| 
									
										
										
										
											2022-03-13 17:45:46 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Sync (blocking) version of tuh_descriptor_get_serial_string()
 | 
					
						
							|  |  |  | // return transfer result
 | 
					
						
							| 
									
										
										
										
											2022-03-18 13:38:30 +07:00
										 |  |  | uint8_t tuh_descriptor_get_serial_string_sync(uint8_t daddr, uint16_t language_id, void* buffer, uint16_t len); | 
					
						
							| 
									
										
										
										
											2013-02-06 12:03:01 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-22 17:41:06 +07:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  |  } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-10 16:55:12 +07:00
										 |  |  | #endif
 |