mirror of
https://github.com/espressif/esp-idf.git
synced 2025-08-09 12:35:28 +00:00
213 lines
7.4 KiB
C
213 lines
7.4 KiB
C
/*
|
|
* SPDX-FileCopyrightText: 2024-2025 Espressif Systems (Shanghai) CO LTD
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
#pragma once
|
|
|
|
#include <stdint.h>
|
|
#include "esp_err.h"
|
|
#include "usb/usb_types_stack.h"
|
|
#include "usb/usb_types_ch11.h"
|
|
#include "sdkconfig.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#if CONFIG_USB_HOST_HUB_MULTI_LEVEL
|
|
#define ENABLE_MULTIPLE_HUBS 1
|
|
#endif // CONFIG_USB_HOST_HUB_MULTI_LEVEL
|
|
|
|
typedef struct ext_port_s *ext_port_hdl_t;
|
|
|
|
// ------------------------ External Port API typedefs -------------------------
|
|
|
|
/**
|
|
* @brief External Hub Port driver
|
|
*/
|
|
typedef struct {
|
|
esp_err_t (*new)(void *port_cfg, void **port_hdl);
|
|
esp_err_t (*reset)(void *port_hdl);
|
|
esp_err_t (*recycle)(void *port_hdl);
|
|
esp_err_t (*active)(void *port_hdl);
|
|
esp_err_t (*disable)(void *port_hdl);
|
|
esp_err_t (*gone)(void *port_hdl);
|
|
esp_err_t (*del)(void *port_hdl);
|
|
esp_err_t (*get_speed)(void *por_hdl, usb_speed_t *speed);
|
|
esp_err_t (*get_status)(void *port_hdl);
|
|
esp_err_t (*set_status)(void *port_hdl, const usb_port_status_t *status);
|
|
esp_err_t (*req_process)(void *port_hdl);
|
|
} ext_port_driver_api_t;
|
|
|
|
// ------------------------------ Events ---------------------------------------
|
|
typedef enum {
|
|
EXT_PORT_CONNECTED = 0x01, /**< Port has a device connection event */
|
|
EXT_PORT_RESET_COMPLETED, /**< Port has completed the reset routine */
|
|
EXT_PORT_DISCONNECTED, /**< Port has a device disconnection event */
|
|
} ext_port_event_t;
|
|
|
|
/**
|
|
* @brief Event data object for External Port driver events
|
|
*/
|
|
typedef struct {
|
|
ext_port_event_t event;
|
|
union {
|
|
struct {
|
|
usb_device_handle_t parent_dev_hdl; /**< Ports' parent device handle */
|
|
uint8_t parent_port_num; /**< Ports' parent port number */
|
|
} connected; /**< EXT_PORT_CONNECTED event specific data */
|
|
|
|
struct {
|
|
usb_device_handle_t parent_dev_hdl; /**< Ports' parent device handle */
|
|
uint8_t parent_port_num; /**< Ports' parent port number */
|
|
} reset_completed; /**< EXT_PORT_RESET_COMPLETED event specific data */
|
|
|
|
struct {
|
|
usb_device_handle_t parent_dev_hdl; /**< Ports' parent device handle */
|
|
uint8_t parent_port_num; /**< Ports' parent port number */
|
|
} disconnected; /**< EXT_PORT_DISCONNECTED event specific data */
|
|
};
|
|
} ext_port_event_data_t;
|
|
|
|
typedef enum {
|
|
EXT_PORT_PARENT_REQ_CONTROL = 0x01, /** Port requires action from the parent Hub */
|
|
EXT_PORT_PARENT_REQ_PROC_COMPLETED /** All ports were handled */
|
|
} ext_port_parent_request_type_t;
|
|
|
|
/**
|
|
* @brief Specific data for External Port parent Hub class specific request
|
|
*/
|
|
typedef struct {
|
|
ext_port_parent_request_type_t type;
|
|
union {
|
|
struct {
|
|
usb_hub_class_request_t req;
|
|
uint8_t feature;
|
|
} control;
|
|
};
|
|
} ext_port_parent_request_data_t;
|
|
|
|
// ------------------------------ Callbacks ------------------------------------
|
|
/**
|
|
* @brief Callback used to indicate that the External Port Driver requires process callback
|
|
*
|
|
* @note For the Hub Driver only
|
|
*/
|
|
typedef void (*ext_port_cb_t)(void *user_arg);
|
|
|
|
/**
|
|
* @brief Callback used to indicate that the External Port driver has an event
|
|
*
|
|
* @note For the Hub Driver only
|
|
*/
|
|
typedef void (*ext_port_event_cb_t)(ext_port_hdl_t port_hdl, ext_port_event_data_t *event_data, void *arg);
|
|
|
|
/**
|
|
* @brief Callback used to indicate that the External Port driver requires a Hub class specific request
|
|
*/
|
|
typedef esp_err_t (*ext_port_parent_request_cb_t)(ext_port_hdl_t port_hdl, ext_port_parent_request_data_t *data, void *user_arg);
|
|
|
|
// ----------------- External Port Driver configuration ------------------------
|
|
|
|
/**
|
|
* @brief External Port driver configuration
|
|
*/
|
|
typedef struct {
|
|
ext_port_cb_t proc_req_cb; /**< External Port process callback */
|
|
void *proc_req_cb_arg; /**< External Port process callback argument */
|
|
ext_port_event_cb_t event_cb; /**< External Port event callback */
|
|
void *event_cb_arg; /**< External Port event callback argument */
|
|
ext_port_parent_request_cb_t hub_request_cb;/**< External Port Hub request callback */
|
|
void *hub_request_cb_arg; /**< External Port Hub request callback argument */
|
|
} ext_port_driver_config_t;
|
|
|
|
/**
|
|
* @brief External Port configuration
|
|
*
|
|
* Structure is used to create new port
|
|
*/
|
|
typedef struct {
|
|
void* context; /**< Ports' parent external Hub handle */
|
|
usb_device_handle_t parent_dev_hdl; /**< Ports' parent device handle */
|
|
uint8_t parent_port_num; /**< Ports' parent port number */
|
|
uint16_t port_power_delay_ms; /**< Ports' Power on time to Power Good, ms */
|
|
} ext_port_config_t;
|
|
|
|
// -------------------- External Port Processing Functions ---------------------
|
|
|
|
/**
|
|
* @brief Install the External Port Driver
|
|
*
|
|
* @note This function should only be called from the Hub Driver
|
|
*
|
|
* @param[in] config External Port Driver configuration
|
|
* @return
|
|
* - ESP_ERR_NOT_ALLOWED: The Driver was already installed
|
|
* - ESP_ERR_NO_MEM: Unable to install the Driver, no memory
|
|
* - ESP_OK: The Driver has been installed successfully
|
|
*/
|
|
esp_err_t ext_port_install(const ext_port_driver_config_t *config);
|
|
|
|
/**
|
|
* @brief Uninstall the External Port Driver
|
|
*
|
|
* @note This function should only be called from the Hub Driver
|
|
*
|
|
* @return
|
|
* - ESP_ERR_NOT_ALLOWED: The Driver was not installed
|
|
* - ESP_ERR_INVALID_STATE: The Driver has ports in the pending list and can't be uninstalled
|
|
* - ESP_OK: The Driver has been uninstall successfully
|
|
*/
|
|
esp_err_t ext_port_uninstall(void);
|
|
|
|
/**
|
|
* @brief External Port Driver's process function
|
|
*
|
|
* @note This function should only be called from the Hub Driver
|
|
*
|
|
* External Port Driver process function that must be called repeatedly to process the driver's actions and events.
|
|
* If blocking, the caller can block on the notification callback of source USB_PROC_REQ_SOURCE_HUB
|
|
* to run this function.
|
|
*
|
|
* @return
|
|
* - ESP_ERR_NOT_ALLOWED: The Driver was not installed
|
|
* - ESP_OK: The Driver processed completed
|
|
*/
|
|
esp_err_t ext_port_process(void);
|
|
|
|
/**
|
|
* @brief Returns External Port Driver's API
|
|
*
|
|
* @note This is a specific API for the External Hub Driver to handle the ports.
|
|
* @return
|
|
* - NULL: The Driver has not been installed
|
|
* - not NULL: Pointer to the External Port Driver API
|
|
*/
|
|
const ext_port_driver_api_t *ext_port_get_driver(void);
|
|
|
|
/**
|
|
* @brief Returns External Port Driver's context
|
|
*
|
|
* @param[in] port_hdl Port object handle
|
|
* @return
|
|
* - Pointer to the External Port Driver context
|
|
*/
|
|
void* ext_port_get_context(ext_port_hdl_t port_hdl);
|
|
|
|
/**
|
|
* @brief Returns External Port's port number
|
|
*
|
|
* @param[in] port_hdl Port object handle
|
|
* @param[out] port1 Port number, starting from 1
|
|
* @return
|
|
* - ESP_ERR_NOT_ALLOWED if the External Port Driver has not been installed
|
|
* - ESP_ERR_INVALID_ARG if the Port handle is NULL
|
|
* - ESP_OK if the port number was successfully returned
|
|
*/
|
|
esp_err_t ext_port_get_port_num(ext_port_hdl_t port_hdl, uint8_t *port1);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|