ESPHome 2025.10.0-dev
|
#include <usb_host.h>
Public Member Functions | |
USBClient (uint16_t vid, uint16_t pid) | |
void | setup () override |
void | loop () override |
float | get_setup_priority () const override |
void | on_opened (uint8_t addr) |
void | on_removed (usb_device_handle_t handle) |
void | control_transfer_callback (const usb_transfer_t *xfer) const |
void | transfer_in (uint8_t ep_address, const transfer_cb_t &callback, uint16_t length) |
Performs a transfer input operation. | |
void | transfer_out (uint8_t ep_address, const transfer_cb_t &callback, const uint8_t *data, uint16_t length) |
Performs an output transfer operation. | |
void | dump_config () override |
void | release_trq (TransferRequest *trq) |
bool | control_transfer (uint8_t type, uint8_t request, uint16_t value, uint16_t index, const transfer_cb_t &callback, const std::vector< uint8_t > &data={}) |
![]() | |
float | get_actual_setup_priority () const |
void | set_setup_priority (float priority) |
virtual float | get_loop_priority () const |
priority of loop(). | |
void | call () |
virtual void | on_shutdown () |
virtual void | on_safe_shutdown () |
virtual bool | teardown () |
Called during teardown to allow component to gracefully finish operations. | |
virtual void | on_powerdown () |
Called after teardown is complete to power down hardware. | |
uint8_t | get_component_state () const |
void | reset_to_construction_state () |
Reset this component back to the construction state to allow setup to run again. | |
bool | is_in_loop_state () const |
Check if this component has completed setup and is in the loop state. | |
virtual void | mark_failed () |
Mark this component as failed. | |
void | mark_failed (const char *message) |
void | disable_loop () |
Disable this component's loop. | |
void | enable_loop () |
Enable this component's loop. | |
void | enable_loop_soon_any_context () |
Thread and ISR-safe version of enable_loop() that can be called from any context. | |
bool | is_failed () const |
bool | is_ready () const |
virtual bool | can_proceed () |
bool | status_has_warning () const |
bool | status_has_error () const |
void | status_set_warning (const char *message=nullptr) |
void | status_set_warning (const LogString *message) |
void | status_set_error (const char *message=nullptr) |
void | status_clear_warning () |
void | status_clear_error () |
void | status_momentary_warning (const std::string &name, uint32_t length=5000) |
void | status_momentary_error (const std::string &name, uint32_t length=5000) |
bool | has_overridden_loop () const |
void | set_component_source (const LogString *source) |
Set where this component was loaded from for some debug messages. | |
const LogString * | get_component_log_str () const |
Get the integration where this component was declared as a LogString for logging. | |
bool | should_warn_of_blocking (uint32_t blocking_time) |
Data Fields | |
LockFreeQueue< UsbEvent, USB_EVENT_QUEUE_SIZE > | event_queue |
EventPool< UsbEvent, USB_EVENT_QUEUE_SIZE > | event_pool |
Protected Member Functions | |
bool | register_ () |
TransferRequest * | get_trq_ () |
virtual void | disconnect () |
virtual void | on_connected () |
virtual void | on_disconnected () |
void | usb_task_loop () |
![]() | |
virtual void | call_loop () |
virtual void | call_setup () |
virtual void | call_dump_config () |
void | set_component_state_ (uint8_t state) |
Helper to set component state (clears state bits and sets new state) | |
void | set_interval (const std::string &name, uint32_t interval, std::function< void()> &&f) |
Set an interval function with a unique name. | |
void | set_interval (const char *name, uint32_t interval, std::function< void()> &&f) |
Set an interval function with a const char* name. | |
void | set_interval (uint32_t interval, std::function< void()> &&f) |
bool | cancel_interval (const std::string &name) |
Cancel an interval function. | |
bool | cancel_interval (const char *name) |
void | set_retry (const std::string &name, uint32_t initial_wait_time, uint8_t max_attempts, std::function< RetryResult(uint8_t)> &&f, float backoff_increase_factor=1.0f) |
Set an retry function with a unique name. | |
void | set_retry (uint32_t initial_wait_time, uint8_t max_attempts, std::function< RetryResult(uint8_t)> &&f, float backoff_increase_factor=1.0f) |
bool | cancel_retry (const std::string &name) |
Cancel a retry function. | |
void | set_timeout (const std::string &name, uint32_t timeout, std::function< void()> &&f) |
Set a timeout function with a unique name. | |
void | set_timeout (const char *name, uint32_t timeout, std::function< void()> &&f) |
Set a timeout function with a const char* name. | |
void | set_timeout (uint32_t timeout, std::function< void()> &&f) |
bool | cancel_timeout (const std::string &name) |
Cancel a timeout function. | |
bool | cancel_timeout (const char *name) |
void | defer (const std::string &name, std::function< void()> &&f) |
Defer a callback to the next loop() call. | |
void | defer (const char *name, std::function< void()> &&f) |
Defer a callback to the next loop() call with a const char* name. | |
void | defer (std::function< void()> &&f) |
Defer a callback to the next loop() call. | |
bool | cancel_defer (const std::string &name) |
Cancel a defer callback using the specified name, name must not be empty. | |
Static Protected Member Functions | |
static void | usb_task_fn (void *arg) |
Protected Attributes | |
TaskHandle_t | usb_task_handle_ {nullptr} |
usb_host_client_handle_t | handle_ {} |
usb_device_handle_t | device_handle_ {} |
int | device_addr_ {-1} |
int | state_ {USB_CLIENT_INIT} |
uint16_t | vid_ {} |
uint16_t | pid_ {} |
std::atomic< uint16_t > | trq_in_use_ |
TransferRequest | requests_ [MAX_REQUESTS] {} |
![]() | |
const LogString * | component_source_ {nullptr} |
uint16_t | warn_if_blocking_over_ {WARN_IF_BLOCKING_OVER_MS} |
Warn if blocked for this many ms (max 65.5s) | |
uint8_t | component_state_ {0x00} |
State of this component - each bit has a purpose: Bits 0-2: Component state (0x00=CONSTRUCTION, 0x01=SETUP, 0x02=LOOP, 0x03=FAILED, 0x04=LOOP_DONE) Bit 3: STATUS_LED_WARNING Bit 4: STATUS_LED_ERROR Bits 5-7: Unused - reserved for future expansion. | |
volatile bool | pending_enable_loop_ {false} |
ISR-safe flag for enable_loop_soon_any_context. | |
Definition at line 118 of file usb_host.h.
|
inline |
Definition at line 122 of file usb_host.h.
bool esphome::usb_host::USBClient::control_transfer | ( | uint8_t | type, |
uint8_t | request, | ||
uint16_t | value, | ||
uint16_t | index, | ||
const transfer_cb_t & | callback, | ||
const std::vector< uint8_t > & | data = {} ) |
Definition at line 405 of file usb_host_client.cpp.
void esphome::usb_host::USBClient::control_transfer_callback | ( | const usb_transfer_t * | xfer | ) | const |
|
protectedvirtual |
Definition at line 392 of file usb_host_client.cpp.
|
overridevirtual |
Reimplemented from esphome::Component.
Reimplemented in esphome::usb_uart::USBUartComponent.
Definition at line 517 of file usb_host_client.cpp.
|
inlineoverridevirtual |
Reimplemented from esphome::Component.
Definition at line 126 of file usb_host.h.
|
protected |
Definition at line 360 of file usb_host_client.cpp.
|
overridevirtual |
Reimplemented from esphome::Component.
Reimplemented in esphome::usb_uart::USBUartComponent.
Definition at line 220 of file usb_host_client.cpp.
|
inlineprotectedvirtual |
Reimplemented in esphome::usb_uart::USBUartTypeCdcAcm.
Definition at line 146 of file usb_host.h.
|
inlineprotectedvirtual |
Reimplemented in esphome::usb_uart::USBUartTypeCdcAcm.
Definition at line 147 of file usb_host.h.
void esphome::usb_host::USBClient::on_opened | ( | uint8_t | addr | ) |
Definition at line 304 of file usb_host_client.cpp.
void esphome::usb_host::USBClient::on_removed | ( | usb_device_handle_t | handle | ) |
Definition at line 310 of file usb_host_client.cpp.
|
protected |
void esphome::usb_host::USBClient::release_trq | ( | TransferRequest * | trq | ) |
Definition at line 530 of file usb_host_client.cpp.
|
overridevirtual |
Reimplemented from esphome::Component.
Reimplemented in esphome::usb_uart::USBUartComponent.
Definition at line 178 of file usb_host_client.cpp.
void esphome::usb_host::USBClient::transfer_in | ( | uint8_t | ep_address, |
const transfer_cb_t & | callback, | ||
uint16_t | length ) |
Performs a transfer input operation.
THREAD CONTEXT: Called from both USB task and main loop threads!
ep_address | The endpoint address. |
callback | The callback function to be called when the transfer is complete. |
length | The length of the data to be transferred. |
None. |
Definition at line 470 of file usb_host_client.cpp.
void esphome::usb_host::USBClient::transfer_out | ( | uint8_t | ep_address, |
const transfer_cb_t & | callback, | ||
const uint8_t * | data, | ||
uint16_t | length ) |
Performs an output transfer operation.
THREAD CONTEXT: Called from main loop thread only
ep_address | The endpoint address. |
callback | The callback function to be called when the transfer is complete. |
data | The data to be transferred. |
length | The length of the data to be transferred. |
None. |
Definition at line 500 of file usb_host_client.cpp.
|
staticprotected |
Definition at line 209 of file usb_host_client.cpp.
|
protected |
Definition at line 214 of file usb_host_client.cpp.
|
protected |
Definition at line 160 of file usb_host.h.
|
protected |
Definition at line 159 of file usb_host.h.
Definition at line 140 of file usb_host.h.
LockFreeQueue<UsbEvent, USB_EVENT_QUEUE_SIZE> esphome::usb_host::USBClient::event_queue |
Definition at line 139 of file usb_host.h.
|
protected |
Definition at line 158 of file usb_host.h.
|
protected |
Definition at line 163 of file usb_host.h.
|
protected |
Definition at line 170 of file usb_host.h.
|
protected |
Definition at line 161 of file usb_host.h.
|
protected |
Definition at line 169 of file usb_host.h.
|
protected |
Definition at line 156 of file usb_host.h.
|
protected |
Definition at line 162 of file usb_host.h.