mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-10-26 12:41:43 +01:00 
			
		
		
		
	This commit refactors the USBH and the USB Host Library in the following ways:
- USBH now presents an abstraction of an endpoint (via usbh_ep_handle_t)
    - Added separate functions to enqueue/dequeue URBs to a particular endpoint
    - USB Host Library no longer calls HCD API directly. Calls USBH endpoint API
      instead.
- Renamed "notif_cb" to "proc_req_cb" (Processing Request Callback)
    - This is to avoid confusion with FreerTOS task notifications and Host
      Library client event notifications.
    - The processing functions of each layer (i.e., "xxx_process()") request
      calls via the "proc_req_cb"
    - The main handling function (i.e., usb_host_lib_handle_events()) is
      responsible for calling the required "xxx_process()" of each layer
		
	
		
			
				
	
	
		
			89 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * SPDX-FileCopyrightText: 2015-2021 Espressif Systems (Shanghai) CO LTD
 | |
|  *
 | |
|  * SPDX-License-Identifier: Apache-2.0
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <stdlib.h>
 | |
| #include <stdint.h>
 | |
| #include "esp_err.h"
 | |
| #include "usb_private.h"
 | |
| #include "usbh.h"
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| // ------------------------------------------------------ Types --------------------------------------------------------
 | |
| 
 | |
| /**
 | |
|  * @brief Hub driver configuration
 | |
|  */
 | |
| typedef struct {
 | |
|     usb_proc_req_cb_t proc_req_cb;      /**< Processing request callback */
 | |
|     void *proc_req_cb_arg;              /**< Processing request callback argument */
 | |
| } hub_config_t;
 | |
| 
 | |
| // ---------------------------------------------- Hub Driver Functions -------------------------------------------------
 | |
| 
 | |
| /**
 | |
|  * @brief Install Hub driver
 | |
|  *
 | |
|  * Entry:
 | |
|  * - USBH must already be installed
 | |
|  * Exit:
 | |
|  * - Install Hub driver memory resources
 | |
|  * - Initializes the HCD root port
 | |
|  *
 | |
|  * @param[in] hub_config Hub driver configuration
 | |
|  * @return esp_err_t
 | |
|  */
 | |
| esp_err_t hub_install(hub_config_t *hub_config);
 | |
| 
 | |
| /**
 | |
|  * @brief Uninstall Hub driver
 | |
|  *
 | |
|  * This must be called before uninstalling the USBH
 | |
|  * Entry:
 | |
|  * - Must have stopped the root port
 | |
|  * Exit:
 | |
|  * - HCD root port deinitialized
 | |
|  *
 | |
|  * @return esp_err_t
 | |
|  */
 | |
| esp_err_t hub_uninstall(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Start the Hub driver's root port
 | |
|  *
 | |
|  * This will power the root port ON
 | |
|  *
 | |
|  * @return esp_err_t
 | |
|  */
 | |
| esp_err_t hub_root_start(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Stops the Hub driver's root port
 | |
|  *
 | |
|  * This will power OFF the root port
 | |
|  *
 | |
|  * @return esp_err_t
 | |
|  */
 | |
| esp_err_t hub_root_stop(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Hub driver's processing function
 | |
|  *
 | |
|  * Hub driver handling function that must be called repeatdly to process the Hub driver's 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_t
 | |
|  */
 | |
| esp_err_t hub_process(void);
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 |