2021-06-10 16:48:20 +07:00
|
|
|
/*
|
|
|
|
* The MIT License (MIT)
|
|
|
|
*
|
|
|
|
* Copyright (c) 2021, Ha Thach (tinyusb.org)
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2023-09-07 12:38:18 +07:00
|
|
|
#ifndef _TUSB_USBH_PVT_H_
|
|
|
|
#define _TUSB_USBH_PVT_H_
|
2021-06-10 16:48:20 +07:00
|
|
|
|
|
|
|
#include "osal/osal.h"
|
|
|
|
#include "common/tusb_fifo.h"
|
2022-12-22 00:34:35 +07:00
|
|
|
#include "common/tusb_private.h"
|
2021-06-10 16:48:20 +07:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2023-12-26 12:24:54 +01:00
|
|
|
#define TU_LOG_USBH(...) TU_LOG(CFG_TUH_LOG_LEVEL, __VA_ARGS__)
|
|
|
|
#define TU_LOG_MEM_USBH(...) TU_LOG_MEM(CFG_TUH_LOG_LEVEL, __VA_ARGS__)
|
|
|
|
#define TU_LOG_BUF_USBH(...) TU_LOG_BUF(CFG_TUH_LOG_LEVEL, __VA_ARGS__)
|
|
|
|
#define TU_LOG_INT_USBH(...) TU_LOG_INT(CFG_TUH_LOG_LEVEL, __VA_ARGS__)
|
|
|
|
#define TU_LOG_HEX_USBH(...) TU_LOG_HEX(CFG_TUH_LOG_LEVEL, __VA_ARGS__)
|
2023-08-02 15:34:18 +07:00
|
|
|
|
2021-06-10 16:48:20 +07:00
|
|
|
//--------------------------------------------------------------------+
|
|
|
|
// Class Driver API
|
|
|
|
//--------------------------------------------------------------------+
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char const* name;
|
2024-03-22 16:12:57 +07:00
|
|
|
bool (* const init )(void);
|
2024-03-22 11:42:33 +07:00
|
|
|
bool (* const deinit )(void);
|
2021-08-20 19:31:38 +07:00
|
|
|
bool (* const open )(uint8_t rhport, uint8_t dev_addr, tusb_desc_interface_t const * itf_desc, uint16_t max_len);
|
|
|
|
bool (* const set_config )(uint8_t dev_addr, uint8_t itf_num);
|
|
|
|
bool (* const xfer_cb )(uint8_t dev_addr, uint8_t ep_addr, xfer_result_t result, uint32_t xferred_bytes);
|
|
|
|
void (* const close )(uint8_t dev_addr);
|
2021-06-10 16:48:20 +07:00
|
|
|
} usbh_class_driver_t;
|
|
|
|
|
2023-08-15 22:51:21 +07:00
|
|
|
// Invoked when initializing host stack to get additional class drivers.
|
|
|
|
// Can be implemented by application to extend/overwrite class driver support.
|
|
|
|
// Note: The drivers array must be accessible at all time when stack is active
|
|
|
|
usbh_class_driver_t const* usbh_app_driver_get_cb(uint8_t* driver_count) TU_ATTR_WEAK;
|
|
|
|
|
2021-06-10 17:19:21 +07:00
|
|
|
// Call by class driver to tell USBH that it has complete the enumeration
|
|
|
|
void usbh_driver_set_config_complete(uint8_t dev_addr, uint8_t itf_num);
|
|
|
|
|
|
|
|
uint8_t usbh_get_rhport(uint8_t dev_addr);
|
|
|
|
|
|
|
|
uint8_t* usbh_get_enum_buf(void);
|
|
|
|
|
2022-02-23 18:42:32 +07:00
|
|
|
void usbh_int_set(bool enabled);
|
|
|
|
|
2023-09-07 12:38:18 +07:00
|
|
|
void usbh_defer_func(osal_task_func_t func, void *param, bool in_isr);
|
|
|
|
|
2021-06-10 16:48:20 +07:00
|
|
|
//--------------------------------------------------------------------+
|
|
|
|
// USBH Endpoint API
|
|
|
|
//--------------------------------------------------------------------+
|
|
|
|
|
2022-03-18 22:22:21 +07:00
|
|
|
// Submit a usb transfer with callback support, require CFG_TUH_API_EDPT_XFER
|
|
|
|
bool usbh_edpt_xfer_with_callback(uint8_t dev_addr, uint8_t ep_addr, uint8_t * buffer, uint16_t total_bytes,
|
|
|
|
tuh_xfer_cb_t complete_cb, uintptr_t user_data);
|
|
|
|
|
2025-02-17 22:40:19 +07:00
|
|
|
TU_ATTR_ALWAYS_INLINE static inline
|
|
|
|
bool usbh_edpt_xfer(uint8_t dev_addr, uint8_t ep_addr, uint8_t * buffer, uint16_t total_bytes) {
|
2022-03-18 22:22:21 +07:00
|
|
|
return usbh_edpt_xfer_with_callback(dev_addr, ep_addr, buffer, total_bytes, NULL, 0);
|
|
|
|
}
|
|
|
|
|
2021-06-10 16:48:20 +07:00
|
|
|
// Claim an endpoint before submitting a transfer.
|
|
|
|
// If caller does not make any transfer, it must release endpoint for others.
|
|
|
|
bool usbh_edpt_claim(uint8_t dev_addr, uint8_t ep_addr);
|
|
|
|
|
2022-03-10 22:22:05 +07:00
|
|
|
// Release claimed endpoint without submitting a transfer
|
2021-08-20 18:01:10 +07:00
|
|
|
bool usbh_edpt_release(uint8_t dev_addr, uint8_t ep_addr);
|
|
|
|
|
2021-06-10 17:19:21 +07:00
|
|
|
// Check if endpoint transferring is complete
|
|
|
|
bool usbh_edpt_busy(uint8_t dev_addr, uint8_t ep_addr);
|
2021-06-10 16:48:20 +07:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|