diff options
| author | Willian Paixao <willian@ufpa.br> | 2021-12-05 19:16:34 +0100 | 
|---|---|---|
| committer | Willian Paixao <willian@ufpa.br> | 2021-12-05 19:16:34 +0100 | 
| commit | ac2e205ae9f465c27297ea542c72e8cfe4966f8c (patch) | |
| tree | 16e4d1268b2631ba7e17dcda8f366f070fbd7475 /tinyusb/src/device | |
| parent | bbd394a19aaa334a179c36cf2ed2a066f1bb312c (diff) | |
| download | Sensor-Watch-ac2e205ae9f465c27297ea542c72e8cfe4966f8c.tar.gz Sensor-Watch-ac2e205ae9f465c27297ea542c72e8cfe4966f8c.tar.bz2 Sensor-Watch-ac2e205ae9f465c27297ea542c72e8cfe4966f8c.zip | |
remove tinyusb directory
Diffstat (limited to 'tinyusb/src/device')
| -rwxr-xr-x | tinyusb/src/device/dcd.h | 181 | ||||
| -rwxr-xr-x | tinyusb/src/device/dcd_attr.h | 164 | ||||
| -rwxr-xr-x | tinyusb/src/device/usbd.c | 1353 | ||||
| -rwxr-xr-x | tinyusb/src/device/usbd.h | 783 | ||||
| -rwxr-xr-x | tinyusb/src/device/usbd_control.c | 233 | ||||
| -rwxr-xr-x | tinyusb/src/device/usbd_pvt.h | 114 | 
6 files changed, 0 insertions, 2828 deletions
| diff --git a/tinyusb/src/device/dcd.h b/tinyusb/src/device/dcd.h deleted file mode 100755 index 66767c1f..00000000 --- a/tinyusb/src/device/dcd.h +++ /dev/null @@ -1,181 +0,0 @@ -/*  - * The MIT License (MIT) - * - * Copyright (c) 2019 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. - */ - -#ifndef _TUSB_DCD_H_ -#define _TUSB_DCD_H_ - -#include "common/tusb_common.h" -#include "osal/osal.h" -#include "common/tusb_fifo.h" -#include "dcd_attr.h" - -#ifdef __cplusplus - extern "C" { -#endif - -//--------------------------------------------------------------------+ -// Configuration -//--------------------------------------------------------------------+ - -#ifndef CFG_TUD_ENDPPOINT_MAX -  #define CFG_TUD_ENDPPOINT_MAX   DCD_ATTR_ENDPOINT_MAX -#endif - -//--------------------------------------------------------------------+ -// MACRO CONSTANT TYPEDEF PROTYPES -//--------------------------------------------------------------------+ - -typedef enum -{ -  DCD_EVENT_INVALID = 0, -  DCD_EVENT_BUS_RESET, -  DCD_EVENT_UNPLUGGED, -  DCD_EVENT_SOF, -  DCD_EVENT_SUSPEND, // TODO LPM Sleep L1 support -  DCD_EVENT_RESUME, - -  DCD_EVENT_SETUP_RECEIVED, -  DCD_EVENT_XFER_COMPLETE, - -  // Not an DCD event, just a convenient way to defer ISR function -  USBD_EVENT_FUNC_CALL, - -  DCD_EVENT_COUNT -} dcd_eventid_t; - -typedef struct TU_ATTR_ALIGNED(4) -{ -  uint8_t rhport; -  uint8_t event_id; - -  union -  { -    // BUS RESET -    struct { -      tusb_speed_t speed; -    } bus_reset; - -    // SETUP_RECEIVED -    tusb_control_request_t setup_received; - -    // XFER_COMPLETE -    struct { -      uint8_t  ep_addr; -      uint8_t  result; -      uint32_t len; -    }xfer_complete; - -    // FUNC_CALL -    struct { -      void (*func) (void*); -      void* param; -    }func_call; -  }; -} dcd_event_t; - -//TU_VERIFY_STATIC(sizeof(dcd_event_t) <= 12, "size is not correct"); - -//--------------------------------------------------------------------+ -// Controller API -//--------------------------------------------------------------------+ - -// Initialize controller to device mode -void dcd_init       (uint8_t rhport); - -// Interrupt Handler -void dcd_int_handler(uint8_t rhport); - -// Enable device interrupt -void dcd_int_enable (uint8_t rhport); - -// Disable device interrupt -void dcd_int_disable(uint8_t rhport); - -// Receive Set Address request, mcu port must also include status IN response -void dcd_set_address(uint8_t rhport, uint8_t dev_addr); - -// Wake up host -void dcd_remote_wakeup(uint8_t rhport); - -// Connect by enabling internal pull-up resistor on D+/D- -void dcd_connect(uint8_t rhport) TU_ATTR_WEAK; - -// Disconnect by disabling internal pull-up resistor on D+/D- -void dcd_disconnect(uint8_t rhport) TU_ATTR_WEAK; - -//--------------------------------------------------------------------+ -// Endpoint API -//--------------------------------------------------------------------+ - -// Invoked when a control transfer's status stage is complete. -// May help DCD to prepare for next control transfer, this API is optional. -void dcd_edpt0_status_complete(uint8_t rhport, tusb_control_request_t const * request) TU_ATTR_WEAK; - -// Configure endpoint's registers according to descriptor -bool dcd_edpt_open            (uint8_t rhport, tusb_desc_endpoint_t const * desc_ep); - -// Close an endpoint. -// Since it is weak, caller must TU_ASSERT this function's existence before calling it. -void dcd_edpt_close           (uint8_t rhport, uint8_t ep_addr) TU_ATTR_WEAK; - -// Submit a transfer, When complete dcd_event_xfer_complete() is invoked to notify the stack -bool dcd_edpt_xfer            (uint8_t rhport, uint8_t ep_addr, uint8_t * buffer, uint16_t total_bytes); - -// Submit an transfer using fifo, When complete dcd_event_xfer_complete() is invoked to notify the stack -// This API is optional, may be useful for register-based for transferring data. -bool dcd_edpt_xfer_fifo       (uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16_t total_bytes) TU_ATTR_WEAK; - -// Stall endpoint -void dcd_edpt_stall           (uint8_t rhport, uint8_t ep_addr); - -// clear stall, data toggle is also reset to DATA0 -// This API never calls with control endpoints, since it is auto cleared when receiving setup packet -void dcd_edpt_clear_stall     (uint8_t rhport, uint8_t ep_addr); - -//--------------------------------------------------------------------+ -// Event API (implemented by stack) -//--------------------------------------------------------------------+ - -// Called by DCD to notify device stack -extern void dcd_event_handler(dcd_event_t const * event, bool in_isr); - -// helper to send bus signal event -extern void dcd_event_bus_signal (uint8_t rhport, dcd_eventid_t eid, bool in_isr); - -// helper to send bus reset event -extern void dcd_event_bus_reset (uint8_t rhport, tusb_speed_t speed, bool in_isr); - -// helper to send setup received -extern void dcd_event_setup_received(uint8_t rhport, uint8_t const * setup, bool in_isr); - -// helper to send transfer complete event -extern void dcd_event_xfer_complete (uint8_t rhport, uint8_t ep_addr, uint32_t xferred_bytes, uint8_t result, bool in_isr); - -#ifdef __cplusplus - } -#endif - -#endif /* _TUSB_DCD_H_ */ diff --git a/tinyusb/src/device/dcd_attr.h b/tinyusb/src/device/dcd_attr.h deleted file mode 100755 index a35fc0ac..00000000 --- a/tinyusb/src/device/dcd_attr.h +++ /dev/null @@ -1,164 +0,0 @@ -/* - * 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. - */ - -#ifndef TUSB_DCD_ATTR_H_ -#define TUSB_DCD_ATTR_H_ - -#include "tusb_option.h" - -// Attribute includes -// - ENDPOINT_MAX: max (logical) number of endpoint -// - ENDPOINT_EXCLUSIVE_NUMBER: endpoint number with different direction IN and OUT aren't allowed, -//                              e.g EP1 OUT & EP1 IN cannot exist together -// - PORT_HIGHSPEED: mask to indicate which port support highspeed mode, bit0 for port0 and so on. - -//------------- NXP -------------// -#if   TU_CHECK_MCU(LPC11UXX) || TU_CHECK_MCU(LPC13XX) || TU_CHECK_MCU(LPC15XX) -  #define DCD_ATTR_ENDPOINT_MAX   5 - -#elif TU_CHECK_MCU(LPC175X_6X) || TU_CHECK_MCU(LPC177X_8X) || TU_CHECK_MCU(LPC40XX) -  #define DCD_ATTR_ENDPOINT_MAX   16 - -#elif TU_CHECK_MCU(LPC18XX) || TU_CHECK_MCU(LPC43XX) -  // TODO USB0 has 6, USB1 has 4 -  #define DCD_ATTR_ENDPOINT_MAX   6 - -#elif TU_CHECK_MCU(LPC51UXX) -   #define DCD_ATTR_ENDPOINT_MAX   5 - -#elif TU_CHECK_MCU(LPC54XXX) -  // TODO USB0 has 5, USB1 has 6 -  #define DCD_ATTR_ENDPOINT_MAX   6 - -#elif TU_CHECK_MCU(LPC55XX) -  // TODO USB0 has 5, USB1 has 6 -  #define DCD_ATTR_ENDPOINT_MAX   6 - -#elif TU_CHECK_MCU(MIMXRT10XX) -  #define DCD_ATTR_ENDPOINT_MAX   8 - -#elif TU_CHECK_MCU(MKL25ZXX) || TU_CHECK_MCU(K32L2BXX) -  #define DCD_ATTR_ENDPOINT_MAX   16 - -//------------- Nordic -------------// -#elif TU_CHECK_MCU(NRF5X) -  // 8 CBI + 1 ISO -  #define DCD_ATTR_ENDPOINT_MAX   9 - -//------------- Microchip -------------// -#elif TU_CHECK_MCU(SAMD21) || TU_CHECK_MCU(SAMD51) || TU_CHECK_MCU(SAME5X) || \ -      TU_CHECK_MCU(SAMD11) || TU_CHECK_MCU(SAML21) || TU_CHECK_MCU(SAML22) -  #define DCD_ATTR_ENDPOINT_MAX   8 - -#elif TU_CHECK_MCU(SAMG) -  #define DCD_ATTR_ENDPOINT_MAX   6 -  #define DCD_ATTR_ENDPOINT_EXCLUSIVE_NUMBER - -#elif TU_CHECK_MCU(SAMX7X) -  #define DCD_ATTR_ENDPOINT_MAX   10 -  #define DCD_ATTR_ENDPOINT_EXCLUSIVE_NUMBER - -//------------- ST -------------// -#elif TU_CHECK_MCU(STM32F0) || TU_CHECK_MCU(STM32F1) || TU_CHECK_MCU(STM32F3) || \ -      TU_CHECK_MCU(STM32L0) || TU_CHECK_MCU(STM32L1) || TU_CHECK_MCU(STM32L4) -  // F1: F102, F103 -  // L4: L4x2, L4x3 -  #define DCD_ATTR_ENDPOINT_MAX   8 - -#elif TU_CHECK_MCU(STM32F2) || TU_CHECK_MCU(STM32F4) || TU_CHECK_MCU(STM32F3) -  // F1: F105, F107 only has 4 -  // L4: L4x5, L4x6 has 6 -  // For most mcu, FS has 4, HS has 6 -  #define DCD_ATTR_ENDPOINT_MAX   6 - -#elif TU_CHECK_MCU(STM32F7) -  // FS has 6, HS has 9 -  #define DCD_ATTR_ENDPOINT_MAX   9 - -#elif TU_CHECK_MCU(STM32H7) -  #define DCD_ATTR_ENDPOINT_MAX   9 - -//------------- Sony -------------// -#elif TU_CHECK_MCU(CXD56) -  #define DCD_ATTR_ENDPOINT_MAX   7 -  #define DCD_ATTR_ENDPOINT_EXCLUSIVE_NUMBER - -//------------- TI -------------// -#elif TU_CHECK_MCU(MSP430x5xx) -  #define DCD_ATTR_ENDPOINT_MAX   8 - -//------------- ValentyUSB -------------// -#elif TU_CHECK_MCU(VALENTYUSB_EPTRI) -  #define DCD_ATTR_ENDPOINT_MAX   16 - -//------------- Nuvoton -------------// -#elif TU_CHECK_MCU(NUC121) || TU_CHECK_MCU(NUC126) -  #define DCD_ATTR_ENDPOINT_MAX   8 - -#elif TU_CHECK_MCU(NUC120) -  #define DCD_ATTR_ENDPOINT_MAX   6 - -#elif TU_CHECK_MCU(NUC505) -  #define DCD_ATTR_ENDPOINT_MAX   12 - -//------------- Espressif -------------// -#elif TU_CHECK_MCU(ESP32S2) || TU_CHECK_MCU(ESP32S3) -  #define DCD_ATTR_ENDPOINT_MAX   6 - -//------------- Dialog -------------// -#elif TU_CHECK_MCU(DA1469X) -  #define DCD_ATTR_ENDPOINT_MAX   4 - -//------------- Raspberry Pi -------------// -#elif TU_CHECK_MCU(RP2040) -  #define DCD_ATTR_ENDPOINT_MAX   16 - -//------------- Silabs -------------// -#elif TU_CHECK_MCU(EFM32GG) || TU_CHECK_MCU(EFM32GG11) || TU_CHECK_MCU(EFM32GG12) -  #define DCD_ATTR_ENDPOINT_MAX   7 - -//------------- Renesas -------------// -#elif TU_CHECK_MCU(RX63X) || TU_CHECK_MCU(RX65X) || TU_CHECK_MCU(RX72N) -  #define DCD_ATTR_ENDPOINT_MAX   10 - -//#elif TU_CHECK_MCU(MM32F327X) -//  #define DCD_ATTR_ENDPOINT_MAX not known yet - -//------------- GigaDevice -------------// -#elif TU_CHECK_MCU(GD32VF103) -  #define DCD_ATTR_ENDPOINT_MAX   4 - -#else -  #warning "DCD_ATTR_ENDPOINT_MAX is not defined for this MCU, default to 8" -  #define DCD_ATTR_ENDPOINT_MAX   8 -#endif - -// Default to fullspeed if not defined -//#ifndef PORT_HIGHSPEED -//  #define DCD_ATTR_PORT_HIGHSPEED 0x00 -//#endif - -#endif diff --git a/tinyusb/src/device/usbd.c b/tinyusb/src/device/usbd.c deleted file mode 100755 index e12dafcf..00000000 --- a/tinyusb/src/device/usbd.c +++ /dev/null @@ -1,1353 +0,0 @@ -/* - * The MIT License (MIT) - * - * Copyright (c) 2019 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. - */ - -#include "tusb_option.h" - -#if TUSB_OPT_DEVICE_ENABLED - -#include "tusb.h" -#include "device/usbd.h" -#include "device/usbd_pvt.h" -#include "device/dcd.h" - -//--------------------------------------------------------------------+ -// USBD Configuration -//--------------------------------------------------------------------+ - -// Debug level of USBD -#define USBD_DBG_LVL   2 - -#ifndef CFG_TUD_TASK_QUEUE_SZ -  #define CFG_TUD_TASK_QUEUE_SZ   16 -#endif - -//--------------------------------------------------------------------+ -// Device Data -//--------------------------------------------------------------------+ - -// Invalid driver ID in itf2drv[] ep2drv[][] mapping -enum { DRVID_INVALID = 0xFFu }; - -typedef struct -{ -  struct TU_ATTR_PACKED -  { -    volatile uint8_t connected    : 1; -    volatile uint8_t addressed    : 1; -    volatile uint8_t suspended    : 1; - -    uint8_t remote_wakeup_en      : 1; // enable/disable by host -    uint8_t remote_wakeup_support : 1; // configuration descriptor's attribute -    uint8_t self_powered          : 1; // configuration descriptor's attribute -  }; - -  volatile uint8_t cfg_num; // current active configuration (0x00 is not configured) -  uint8_t speed; - -  uint8_t itf2drv[16];     // map interface number to driver (0xff is invalid) -  uint8_t ep2drv[CFG_TUD_ENDPPOINT_MAX][2]; // map endpoint to driver ( 0xff is invalid ) - -  struct TU_ATTR_PACKED -  { -    volatile bool busy    : 1; -    volatile bool stalled : 1; -    volatile bool claimed : 1; - -    // TODO merge ep2drv here, 4-bit should be sufficient -  }ep_status[CFG_TUD_ENDPPOINT_MAX][2]; - -}usbd_device_t; - -static usbd_device_t _usbd_dev; - -//--------------------------------------------------------------------+ -// Class Driver -//--------------------------------------------------------------------+ -#if CFG_TUSB_DEBUG >= 2 -  #define DRIVER_NAME(_name)    .name = _name, -#else -  #define DRIVER_NAME(_name) -#endif - -// Built-in class drivers -static usbd_class_driver_t const _usbd_driver[] = -{ -  #if CFG_TUD_CDC -  { -    DRIVER_NAME("CDC") -    .init             = cdcd_init, -    .reset            = cdcd_reset, -    .open             = cdcd_open, -    .control_xfer_cb  = cdcd_control_xfer_cb, -    .xfer_cb          = cdcd_xfer_cb, -    .sof              = NULL -  }, -  #endif - -  #if CFG_TUD_MSC -  { -    DRIVER_NAME("MSC") -    .init             = mscd_init, -    .reset            = mscd_reset, -    .open             = mscd_open, -    .control_xfer_cb  = mscd_control_xfer_cb, -    .xfer_cb          = mscd_xfer_cb, -    .sof              = NULL -  }, -  #endif - -  #if CFG_TUD_HID -  { -    DRIVER_NAME("HID") -    .init             = hidd_init, -    .reset            = hidd_reset, -    .open             = hidd_open, -    .control_xfer_cb  = hidd_control_xfer_cb, -    .xfer_cb          = hidd_xfer_cb, -    .sof              = NULL -  }, -  #endif - -  #if CFG_TUD_AUDIO -  { -    DRIVER_NAME("AUDIO") -    .init             = audiod_init, -    .reset            = audiod_reset, -    .open             = audiod_open, -    .control_xfer_cb  = audiod_control_xfer_cb, -    .xfer_cb          = audiod_xfer_cb, -    .sof              = NULL -  }, -  #endif - -  #if CFG_TUD_MIDI -  { -    DRIVER_NAME("MIDI") -    .init             = midid_init, -    .open             = midid_open, -    .reset            = midid_reset, -    .control_xfer_cb  = midid_control_xfer_cb, -    .xfer_cb          = midid_xfer_cb, -    .sof              = NULL -  }, -  #endif - -  #if CFG_TUD_VENDOR -  { -    DRIVER_NAME("VENDOR") -    .init             = vendord_init, -    .reset            = vendord_reset, -    .open             = vendord_open, -    .control_xfer_cb  = tud_vendor_control_xfer_cb, -    .xfer_cb          = vendord_xfer_cb, -    .sof              = NULL -  }, -  #endif - -  #if CFG_TUD_USBTMC -  { -    DRIVER_NAME("TMC") -    .init             = usbtmcd_init_cb, -    .reset            = usbtmcd_reset_cb, -    .open             = usbtmcd_open_cb, -    .control_xfer_cb  = usbtmcd_control_xfer_cb, -    .xfer_cb          = usbtmcd_xfer_cb, -    .sof              = NULL -  }, -  #endif - -  #if CFG_TUD_DFU_RUNTIME -  { -    DRIVER_NAME("DFU-RUNTIME") -    .init             = dfu_rtd_init, -    .reset            = dfu_rtd_reset, -    .open             = dfu_rtd_open, -    .control_xfer_cb  = dfu_rtd_control_xfer_cb, -    .xfer_cb          = NULL, -    .sof              = NULL -  }, -  #endif - -  #if CFG_TUD_DFU -  { -    DRIVER_NAME("DFU") -    .init             = dfu_moded_init, -    .reset            = dfu_moded_reset, -    .open             = dfu_moded_open, -    .control_xfer_cb  = dfu_moded_control_xfer_cb, -    .xfer_cb          = NULL, -    .sof              = NULL -  }, -  #endif - -  #if CFG_TUD_NET -  { -    DRIVER_NAME("NET") -    .init             = netd_init, -    .reset            = netd_reset, -    .open             = netd_open, -    .control_xfer_cb  = netd_control_xfer_cb, -    .xfer_cb          = netd_xfer_cb, -    .sof              = NULL, -  }, -  #endif - -  #if CFG_TUD_BTH -  { -    DRIVER_NAME("BTH") -    .init             = btd_init, -    .reset            = btd_reset, -    .open             = btd_open, -    .control_xfer_cb  = btd_control_xfer_cb, -    .xfer_cb          = btd_xfer_cb, -    .sof              = NULL -  }, -  #endif -}; - -enum { BUILTIN_DRIVER_COUNT = TU_ARRAY_SIZE(_usbd_driver) }; - -// Additional class drivers implemented by application -static usbd_class_driver_t const * _app_driver = NULL; -static uint8_t _app_driver_count = 0; - -// virtually joins built-in and application drivers together. -// Application is positioned first to allow overwriting built-in ones. -static inline usbd_class_driver_t const * get_driver(uint8_t drvid) -{ -  // Application drivers -  if ( usbd_app_driver_get_cb ) -  { -    if ( drvid < _app_driver_count ) return &_app_driver[drvid]; -    drvid -= _app_driver_count; -  } - -  // Built-in drivers -  if (drvid < BUILTIN_DRIVER_COUNT) return &_usbd_driver[drvid]; - -  return NULL; -} - -#define TOTAL_DRIVER_COUNT    (_app_driver_count + BUILTIN_DRIVER_COUNT) - -//--------------------------------------------------------------------+ -// DCD Event -//--------------------------------------------------------------------+ - -static bool _usbd_initialized = false; - -// Event queue -// OPT_MODE_DEVICE is used by OS NONE for mutex (disable usb isr) -OSAL_QUEUE_DEF(OPT_MODE_DEVICE, _usbd_qdef, CFG_TUD_TASK_QUEUE_SZ, dcd_event_t); -static osal_queue_t _usbd_q; - -// Mutex for claiming endpoint, only needed when using with preempted RTOS -#if CFG_TUSB_OS != OPT_OS_NONE -static osal_mutex_def_t _ubsd_mutexdef; -static osal_mutex_t _usbd_mutex; -#endif - - -//--------------------------------------------------------------------+ -// Prototypes -//--------------------------------------------------------------------+ -static bool process_control_request(uint8_t rhport, tusb_control_request_t const * p_request); -static bool process_set_config(uint8_t rhport, uint8_t cfg_num); -static bool process_get_descriptor(uint8_t rhport, tusb_control_request_t const * p_request); - -// from usbd_control.c -void usbd_control_reset(void); -void usbd_control_set_request(tusb_control_request_t const *request); -void usbd_control_set_complete_callback( usbd_control_xfer_cb_t fp ); -bool usbd_control_xfer_cb (uint8_t rhport, uint8_t ep_addr, xfer_result_t event, uint32_t xferred_bytes); - - -//--------------------------------------------------------------------+ -// Debug -//--------------------------------------------------------------------+ -#if CFG_TUSB_DEBUG >= 2 -static char const* const _usbd_event_str[DCD_EVENT_COUNT] = -{ -  "Invalid"        , -  "Bus Reset"      , -  "Unplugged"      , -  "SOF"            , -  "Suspend"        , -  "Resume"         , -  "Setup Received" , -  "Xfer Complete"  , -  "Func Call" -}; - -static char const* const _tusb_std_request_str[] = -{ -  "Get Status"        , -  "Clear Feature"     , -  "Reserved"          , -  "Set Feature"       , -  "Reserved"          , -  "Set Address"       , -  "Get Descriptor"    , -  "Set Descriptor"    , -  "Get Configuration" , -  "Set Configuration" , -  "Get Interface"     , -  "Set Interface"     , -  "Synch Frame" -}; - -static char const* const _tusb_speed_str[] = { "Full", "Low", "High" }; - -// for usbd_control to print the name of control complete driver -void usbd_driver_print_control_complete_name(usbd_control_xfer_cb_t callback) -{ -  for (uint8_t i = 0; i < TOTAL_DRIVER_COUNT; i++) -  { -    usbd_class_driver_t const * driver = get_driver(i); -    if ( driver->control_xfer_cb == callback ) -    { -      TU_LOG2("  %s control complete\r\n", driver->name); -      return; -    } -  } -} - -#endif - -//--------------------------------------------------------------------+ -// Application API -//--------------------------------------------------------------------+ -tusb_speed_t tud_speed_get(void) -{ -  return (tusb_speed_t) _usbd_dev.speed; -} - -bool tud_connected(void) -{ -  return _usbd_dev.connected; -} - -bool tud_mounted(void) -{ -  return _usbd_dev.cfg_num ? true : false; -} - -bool tud_suspended(void) -{ -  return _usbd_dev.suspended; -} - -bool tud_remote_wakeup(void) -{ -  // only wake up host if this feature is supported and enabled and we are suspended -  TU_VERIFY (_usbd_dev.suspended && _usbd_dev.remote_wakeup_support && _usbd_dev.remote_wakeup_en ); -  dcd_remote_wakeup(TUD_OPT_RHPORT); -  return true; -} - -bool tud_disconnect(void) -{ -  TU_VERIFY(dcd_disconnect); -  dcd_disconnect(TUD_OPT_RHPORT); -  return true; -} - -bool tud_connect(void) -{ -  TU_VERIFY(dcd_connect); -  dcd_connect(TUD_OPT_RHPORT); -  return true; -} - -//--------------------------------------------------------------------+ -// USBD Task -//--------------------------------------------------------------------+ -bool tud_inited(void) -{ -  return _usbd_initialized; -} - -bool tud_init (uint8_t rhport) -{ -  // skip if already initialized -  if (_usbd_initialized) return _usbd_initialized; - -  TU_LOG2("USBD init\r\n"); - -  tu_varclr(&_usbd_dev); - -#if CFG_TUSB_OS != OPT_OS_NONE -  // Init device mutex -  _usbd_mutex = osal_mutex_create(&_ubsd_mutexdef); -  TU_ASSERT(_usbd_mutex); -#endif - -  // Init device queue & task -  _usbd_q = osal_queue_create(&_usbd_qdef); -  TU_ASSERT(_usbd_q); - -  // Get application driver if available -  if ( usbd_app_driver_get_cb ) -  { -    _app_driver = usbd_app_driver_get_cb(&_app_driver_count); -  } - -  // Init class drivers -  for (uint8_t i = 0; i < TOTAL_DRIVER_COUNT; i++) -  { -    usbd_class_driver_t const * driver = get_driver(i); -    TU_LOG2("%s init\r\n", driver->name); -    driver->init(); -  } - -  // Init device controller driver -  dcd_init(rhport); -  dcd_int_enable(rhport); - -  _usbd_initialized = true; - -  return true; -} - -static void usbd_reset(uint8_t rhport) -{ -  tu_varclr(&_usbd_dev); - -  memset(_usbd_dev.itf2drv, DRVID_INVALID, sizeof(_usbd_dev.itf2drv)); // invalid mapping -  memset(_usbd_dev.ep2drv , DRVID_INVALID, sizeof(_usbd_dev.ep2drv )); // invalid mapping - -  usbd_control_reset(); - -  for ( uint8_t i = 0; i < TOTAL_DRIVER_COUNT; i++ ) -  { -    get_driver(i)->reset(rhport); -  } -} - -bool tud_task_event_ready(void) -{ -  // Skip if stack is not initialized -  if ( !tusb_inited() ) return false; - -  return !osal_queue_empty(_usbd_q); -} - -/* USB Device Driver task - * This top level thread manages all device controller event and delegates events to class-specific drivers. - * This should be called periodically within the mainloop or rtos thread. - * -   @code -    int main(void) -    { -      application_init(); -      tusb_init(); - -      while(1) // the mainloop -      { -        application_code(); -        tud_task(); // tinyusb device task -      } -    } -    @endcode - */ -void tud_task (void) -{ -  // Skip if stack is not initialized -  if ( !tusb_inited() ) return; - -  // Loop until there is no more events in the queue -  while (1) -  { -    dcd_event_t event; - -    if ( !osal_queue_receive(_usbd_q, &event) ) return; - -#if CFG_TUSB_DEBUG >= 2 -    if (event.event_id == DCD_EVENT_SETUP_RECEIVED) TU_LOG2("\r\n"); // extra line for setup -    TU_LOG2("USBD %s ", event.event_id < DCD_EVENT_COUNT ? _usbd_event_str[event.event_id] : "CORRUPTED"); -#endif - -    switch ( event.event_id ) -    { -      case DCD_EVENT_BUS_RESET: -        TU_LOG2(": %s Speed\r\n", _tusb_speed_str[event.bus_reset.speed]); -        usbd_reset(event.rhport); -        _usbd_dev.speed = event.bus_reset.speed; -      break; - -      case DCD_EVENT_UNPLUGGED: -        TU_LOG2("\r\n"); -        usbd_reset(event.rhport); - -        // invoke callback -        if (tud_umount_cb) tud_umount_cb(); -      break; - -      case DCD_EVENT_SETUP_RECEIVED: -        TU_LOG2_VAR(&event.setup_received); -        TU_LOG2("\r\n"); - -        // Mark as connected after receiving 1st setup packet. -        // But it is easier to set it every time instead of wasting time to check then set -        _usbd_dev.connected = 1; - -        // mark both in & out control as free -        _usbd_dev.ep_status[0][TUSB_DIR_OUT].busy = false; -        _usbd_dev.ep_status[0][TUSB_DIR_OUT].claimed = 0; -        _usbd_dev.ep_status[0][TUSB_DIR_IN ].busy = false; -        _usbd_dev.ep_status[0][TUSB_DIR_IN ].claimed = 0; - -        // Process control request -        if ( !process_control_request(event.rhport, &event.setup_received) ) -        { -          TU_LOG2("  Stall EP0\r\n"); -          // Failed -> stall both control endpoint IN and OUT -          dcd_edpt_stall(event.rhport, 0); -          dcd_edpt_stall(event.rhport, 0 | TUSB_DIR_IN_MASK); -        } -      break; - -      case DCD_EVENT_XFER_COMPLETE: -      { -        // Invoke the class callback associated with the endpoint address -        uint8_t const ep_addr = event.xfer_complete.ep_addr; -        uint8_t const epnum   = tu_edpt_number(ep_addr); -        uint8_t const ep_dir  = tu_edpt_dir(ep_addr); - -        TU_LOG2("on EP %02X with %u bytes\r\n", ep_addr, (unsigned int) event.xfer_complete.len); - -        _usbd_dev.ep_status[epnum][ep_dir].busy = false; -        _usbd_dev.ep_status[epnum][ep_dir].claimed = 0; - -        if ( 0 == epnum ) -        { -          usbd_control_xfer_cb(event.rhport, ep_addr, (xfer_result_t)event.xfer_complete.result, event.xfer_complete.len); -        } -        else -        { -          usbd_class_driver_t const * driver = get_driver( _usbd_dev.ep2drv[epnum][ep_dir] ); -          TU_ASSERT(driver, ); - -          TU_LOG2("  %s xfer callback\r\n", driver->name); -          driver->xfer_cb(event.rhport, ep_addr, (xfer_result_t)event.xfer_complete.result, event.xfer_complete.len); -        } -      } -      break; - -      case DCD_EVENT_SUSPEND: -        // NOTE: When plugging/unplugging device, the D+/D- state are unstable and -        // can accidentally meet the SUSPEND condition ( Bus Idle for 3ms ), which result in a series of event -        // e.g suspend -> resume -> unplug/plug. Skip suspend/resume if not connected -        if ( _usbd_dev.connected ) -        { -          TU_LOG2(": Remote Wakeup = %u\r\n", _usbd_dev.remote_wakeup_en); -          if (tud_suspend_cb) tud_suspend_cb(_usbd_dev.remote_wakeup_en); -        }else -        { -          TU_LOG2(" Skipped\r\n"); -        } -      break; - -      case DCD_EVENT_RESUME: -        if ( _usbd_dev.connected ) -        { -          TU_LOG2("\r\n"); -          if (tud_resume_cb) tud_resume_cb(); -        }else -        { -          TU_LOG2(" Skipped\r\n"); -        } -      break; - -      case DCD_EVENT_SOF: -        TU_LOG2("\r\n"); -        for ( uint8_t i = 0; i < TOTAL_DRIVER_COUNT; i++ ) -        { -          usbd_class_driver_t const * driver = get_driver(i); -          if ( driver->sof ) driver->sof(event.rhport); -        } -      break; - -      case USBD_EVENT_FUNC_CALL: -        TU_LOG2("\r\n"); -        if ( event.func_call.func ) event.func_call.func(event.func_call.param); -      break; - -      default: -        TU_BREAKPOINT(); -      break; -    } -  } -} - -//--------------------------------------------------------------------+ -// Control Request Parser & Handling -//--------------------------------------------------------------------+ - -// Helper to invoke class driver control request handler -static bool invoke_class_control(uint8_t rhport, usbd_class_driver_t const * driver, tusb_control_request_t const * request) -{ -  usbd_control_set_complete_callback(driver->control_xfer_cb); -  TU_LOG2("  %s control request\r\n", driver->name); -  return driver->control_xfer_cb(rhport, CONTROL_STAGE_SETUP, request); -} - -// This handles the actual request and its response. -// return false will cause its caller to stall control endpoint -static bool process_control_request(uint8_t rhport, tusb_control_request_t const * p_request) -{ -  usbd_control_set_complete_callback(NULL); - -  TU_ASSERT(p_request->bmRequestType_bit.type < TUSB_REQ_TYPE_INVALID); - -  // Vendor request -  if ( p_request->bmRequestType_bit.type == TUSB_REQ_TYPE_VENDOR ) -  { -    TU_VERIFY(tud_vendor_control_xfer_cb); - -    usbd_control_set_complete_callback(tud_vendor_control_xfer_cb); -    return tud_vendor_control_xfer_cb(rhport, CONTROL_STAGE_SETUP, p_request); -  } - -#if CFG_TUSB_DEBUG >= 2 -  if (TUSB_REQ_TYPE_STANDARD == p_request->bmRequestType_bit.type && p_request->bRequest <= TUSB_REQ_SYNCH_FRAME) -  { -    TU_LOG2("  %s", _tusb_std_request_str[p_request->bRequest]); -    if (TUSB_REQ_GET_DESCRIPTOR != p_request->bRequest) TU_LOG2("\r\n"); -  } -#endif - -  switch ( p_request->bmRequestType_bit.recipient ) -  { -    //------------- Device Requests e.g in enumeration -------------// -    case TUSB_REQ_RCPT_DEVICE: -      if ( TUSB_REQ_TYPE_CLASS == p_request->bmRequestType_bit.type ) -      { -        uint8_t const itf = tu_u16_low(p_request->wIndex); -        TU_VERIFY(itf < TU_ARRAY_SIZE(_usbd_dev.itf2drv)); - -        usbd_class_driver_t const * driver = get_driver(_usbd_dev.itf2drv[itf]); -        TU_VERIFY(driver); - -        // forward to class driver: "non-STD request to Interface" -        return invoke_class_control(rhport, driver, p_request); -      } - -      if ( TUSB_REQ_TYPE_STANDARD != p_request->bmRequestType_bit.type ) -      { -        // Non standard request is not supported -        TU_BREAKPOINT(); -        return false; -      } - -      switch ( p_request->bRequest ) -      { -        case TUSB_REQ_SET_ADDRESS: -          // Depending on mcu, status phase could be sent either before or after changing device address, -          // or even require stack to not response with status at all -          // Therefore DCD must take full responsibility to response and include zlp status packet if needed. -          usbd_control_set_request(p_request); // set request since DCD has no access to tud_control_status() API -          dcd_set_address(rhport, (uint8_t) p_request->wValue); -          // skip tud_control_status() -          _usbd_dev.addressed = 1; -        break; - -        case TUSB_REQ_GET_CONFIGURATION: -        { -          uint8_t cfg_num = _usbd_dev.cfg_num; -          tud_control_xfer(rhport, p_request, &cfg_num, 1); -        } -        break; - -        case TUSB_REQ_SET_CONFIGURATION: -        { -          uint8_t const cfg_num = (uint8_t) p_request->wValue; - -          if ( !_usbd_dev.cfg_num && cfg_num ) TU_ASSERT( process_set_config(rhport, cfg_num) ); -          _usbd_dev.cfg_num = cfg_num; - -          tud_control_status(rhport, p_request); -        } -        break; - -        case TUSB_REQ_GET_DESCRIPTOR: -          TU_VERIFY( process_get_descriptor(rhport, p_request) ); -        break; - -        case TUSB_REQ_SET_FEATURE: -          // Only support remote wakeup for device feature -          TU_VERIFY(TUSB_REQ_FEATURE_REMOTE_WAKEUP == p_request->wValue); - -          TU_LOG(USBD_DBG_LVL, "    Enable Remote Wakeup\r\n"); - -          // Host may enable remote wake up before suspending especially HID device -          _usbd_dev.remote_wakeup_en = true; -          tud_control_status(rhport, p_request); -        break; - -        case TUSB_REQ_CLEAR_FEATURE: -          // Only support remote wakeup for device feature -          TU_VERIFY(TUSB_REQ_FEATURE_REMOTE_WAKEUP == p_request->wValue); - -          TU_LOG(USBD_DBG_LVL, "    Disable Remote Wakeup\r\n"); - -          // Host may disable remote wake up after resuming -          _usbd_dev.remote_wakeup_en = false; -          tud_control_status(rhport, p_request); -        break; - -        case TUSB_REQ_GET_STATUS: -        { -          // Device status bit mask -          // - Bit 0: Self Powered -          // - Bit 1: Remote Wakeup enabled -          uint16_t status = (_usbd_dev.self_powered ? 1 : 0) | (_usbd_dev.remote_wakeup_en ? 2 : 0); -          tud_control_xfer(rhport, p_request, &status, 2); -        } -        break; - -        // Unknown/Unsupported request -        default: TU_BREAKPOINT(); return false; -      } -    break; - -    //------------- Class/Interface Specific Request -------------// -    case TUSB_REQ_RCPT_INTERFACE: -    { -      uint8_t const itf = tu_u16_low(p_request->wIndex); -      TU_VERIFY(itf < TU_ARRAY_SIZE(_usbd_dev.itf2drv)); - -      usbd_class_driver_t const * driver = get_driver(_usbd_dev.itf2drv[itf]); -      TU_VERIFY(driver); - -      // all requests to Interface (STD or Class) is forwarded to class driver. -      // notable requests are: GET HID REPORT DESCRIPTOR, SET_INTERFACE, GET_INTERFACE -      if ( !invoke_class_control(rhport, driver, p_request) ) -      { -        // For GET_INTERFACE and SET_INTERFACE, it is mandatory to respond even if the class -        // driver doesn't use alternate settings or implement this -        TU_VERIFY(TUSB_REQ_TYPE_STANDARD == p_request->bmRequestType_bit.type); - -        if (TUSB_REQ_GET_INTERFACE == p_request->bRequest) -        { -          uint8_t alternate = 0; -          tud_control_xfer(rhport, p_request, &alternate, 1); -        }else if (TUSB_REQ_SET_INTERFACE == p_request->bRequest) -        { -          tud_control_status(rhport, p_request); -        } else -        { -          return false; -        } -      } -    } -    break; - -    //------------- Endpoint Request -------------// -    case TUSB_REQ_RCPT_ENDPOINT: -    { -      uint8_t const ep_addr = tu_u16_low(p_request->wIndex); -      uint8_t const ep_num  = tu_edpt_number(ep_addr); -      uint8_t const ep_dir  = tu_edpt_dir(ep_addr); - -      TU_ASSERT(ep_num < TU_ARRAY_SIZE(_usbd_dev.ep2drv) ); - -      usbd_class_driver_t const * driver = get_driver(_usbd_dev.ep2drv[ep_num][ep_dir]); - -      if ( TUSB_REQ_TYPE_STANDARD != p_request->bmRequestType_bit.type ) -      { -        // Forward class request to its driver -        TU_VERIFY(driver); -        return invoke_class_control(rhport, driver, p_request); -      } -      else -      { -        // Handle STD request to endpoint -        switch ( p_request->bRequest ) -        { -          case TUSB_REQ_GET_STATUS: -          { -            uint16_t status = usbd_edpt_stalled(rhport, ep_addr) ? 0x0001 : 0x0000; -            tud_control_xfer(rhport, p_request, &status, 2); -          } -          break; - -          case TUSB_REQ_CLEAR_FEATURE: -          case TUSB_REQ_SET_FEATURE: -          { -            if ( TUSB_REQ_FEATURE_EDPT_HALT == p_request->wValue ) -            { -              if ( TUSB_REQ_CLEAR_FEATURE ==  p_request->bRequest ) -              { -                usbd_edpt_clear_stall(rhport, ep_addr); -              }else -              { -                usbd_edpt_stall(rhport, ep_addr); -              } -            } - -            if (driver) -            { -              // Some classes such as USBTMC needs to clear/re-init its buffer when receiving CLEAR_FEATURE request -              // We will also forward std request targeted endpoint to class drivers as well - -              // STD request must always be ACKed regardless of driver returned value -              // Also clear complete callback if driver set since it can also stall the request. -              (void) invoke_class_control(rhport, driver, p_request); -              usbd_control_set_complete_callback(NULL); - -              // skip ZLP status if driver already did that -              if ( !_usbd_dev.ep_status[0][TUSB_DIR_IN].busy ) tud_control_status(rhport, p_request); -            } -          } -          break; - -          // Unknown/Unsupported request -          default: TU_BREAKPOINT(); return false; -        } -      } -    } -    break; - -    // Unknown recipient -    default: TU_BREAKPOINT(); return false; -  } - -  return true; -} - -// Process Set Configure Request -// This function parse configuration descriptor & open drivers accordingly -static bool process_set_config(uint8_t rhport, uint8_t cfg_num) -{ -  tusb_desc_configuration_t const * desc_cfg = (tusb_desc_configuration_t const *) tud_descriptor_configuration_cb(cfg_num-1); // index is cfg_num-1 -  TU_ASSERT(desc_cfg != NULL && desc_cfg->bDescriptorType == TUSB_DESC_CONFIGURATION); - -  // Parse configuration descriptor -  _usbd_dev.remote_wakeup_support = (desc_cfg->bmAttributes & TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP) ? 1 : 0; -  _usbd_dev.self_powered = (desc_cfg->bmAttributes & TUSB_DESC_CONFIG_ATT_SELF_POWERED) ? 1 : 0; - -  // Parse interface descriptor -  uint8_t const * p_desc   = ((uint8_t const*) desc_cfg) + sizeof(tusb_desc_configuration_t); -  uint8_t const * desc_end = ((uint8_t const*) desc_cfg) + tu_le16toh(desc_cfg->wTotalLength); - -  while( p_desc < desc_end ) -  { -    tusb_desc_interface_assoc_t const * desc_iad = NULL; - -    // Class will always starts with Interface Association (if any) and then Interface descriptor -    if ( TUSB_DESC_INTERFACE_ASSOCIATION == tu_desc_type(p_desc) ) -    { -      desc_iad = (tusb_desc_interface_assoc_t const *) p_desc; -      p_desc = tu_desc_next(p_desc); // next to Interface -    } - -    TU_ASSERT( TUSB_DESC_INTERFACE == tu_desc_type(p_desc) ); - -    tusb_desc_interface_t const * desc_itf = (tusb_desc_interface_t const*) p_desc; -    uint16_t const remaining_len = desc_end-p_desc; - -    // Interface number must not be used already -    TU_ASSERT(DRVID_INVALID == _usbd_dev.itf2drv[desc_itf->bInterfaceNumber]); - -    // TODO usbd can calculate the total length used for driver --> driver open() does not need to calculate it -    // uint16_t const drv_len = tu_desc_get_interface_total_len(desc_itf, desc_iad ? desc_iad->bInterfaceCount : 1, desc_end-p_desc); - -    // Find driver for this interface -    uint8_t drv_id; -    for (drv_id = 0; drv_id < TOTAL_DRIVER_COUNT; drv_id++) -    { -      usbd_class_driver_t const *driver = get_driver(drv_id); -      uint16_t const drv_len = driver->open(rhport, desc_itf, remaining_len); - -      if ( drv_len > 0 ) -      { -        // Open successfully, check if length is correct -        TU_ASSERT( sizeof(tusb_desc_interface_t) <= drv_len && drv_len <= remaining_len); - -        TU_LOG2("  %s opened\r\n", driver->name); - -        // bind interface to found driver -        _usbd_dev.itf2drv[desc_itf->bInterfaceNumber] = drv_id; - -        // If using IAD, bind all interfaces to the same driver -        if (desc_iad) -        { -          // IAD's first interface number and class should match with opened interface -          TU_ASSERT(desc_iad->bFirstInterface == desc_itf->bInterfaceNumber && -                    desc_iad->bFunctionClass  == desc_itf->bInterfaceClass); - -          for(uint8_t i=1; i<desc_iad->bInterfaceCount; i++) -          { -            _usbd_dev.itf2drv[desc_itf->bInterfaceNumber+i] = drv_id; -          } -        } - -        // bind all endpoints to found driver -        tu_edpt_bind_driver(_usbd_dev.ep2drv, desc_itf, drv_len, drv_id); - -        p_desc += drv_len; // next interface - -        break; // exit driver find loop -      } -    } - -    // Failed if cannot find supported driver -    TU_ASSERT(drv_id < TOTAL_DRIVER_COUNT); -  } - -  // invoke callback -  if (tud_mount_cb) tud_mount_cb(); - -  return true; -} - -// return descriptor's buffer and update desc_len -static bool process_get_descriptor(uint8_t rhport, tusb_control_request_t const * p_request) -{ -  tusb_desc_type_t const desc_type = (tusb_desc_type_t) tu_u16_high(p_request->wValue); -  uint8_t const desc_index = tu_u16_low( p_request->wValue ); - -  switch(desc_type) -  { -    case TUSB_DESC_DEVICE: -    { -      TU_LOG2(" Device\r\n"); - -      uint16_t len = sizeof(tusb_desc_device_t); - -      // Only send up to EP0 Packet Size if not addressed -      // This only happens with the very first get device descriptor and EP0 size = 8 or 16. -      if ((CFG_TUD_ENDPOINT0_SIZE < sizeof(tusb_desc_device_t)) && !_usbd_dev.addressed) -      { -        len = CFG_TUD_ENDPOINT0_SIZE; - -        // Hack here: we modify the request length to prevent usbd_control response with zlp -        ((tusb_control_request_t*) p_request)->wLength = CFG_TUD_ENDPOINT0_SIZE; -      } - -      return tud_control_xfer(rhport, p_request, (void*) tud_descriptor_device_cb(), len); -    } -    break; - -    case TUSB_DESC_BOS: -    { -      TU_LOG2(" BOS\r\n"); - -      // requested by host if USB > 2.0 ( i.e 2.1 or 3.x ) -      if (!tud_descriptor_bos_cb) return false; - -      tusb_desc_bos_t const* desc_bos = (tusb_desc_bos_t const*) tud_descriptor_bos_cb(); - -      // Use offsetof to avoid pointer to the odd/misaligned address -      uint16_t const total_len = tu_le16toh( tu_unaligned_read16((uint8_t*) desc_bos + offsetof(tusb_desc_bos_t, wTotalLength)) ); - -      return tud_control_xfer(rhport, p_request, (void*) desc_bos, total_len); -    } -    break; - -    case TUSB_DESC_CONFIGURATION: -    { -      TU_LOG2(" Configuration[%u]\r\n", desc_index); - -      tusb_desc_configuration_t const* desc_config = (tusb_desc_configuration_t const*) tud_descriptor_configuration_cb(desc_index); -      TU_ASSERT(desc_config); - -      // Use offsetof to avoid pointer to the odd/misaligned address -      uint16_t const total_len = tu_le16toh( tu_unaligned_read16((uint8_t*) desc_config + offsetof(tusb_desc_configuration_t, wTotalLength)) ); - -      return tud_control_xfer(rhport, p_request, (void*) desc_config, total_len); -    } -    break; - -    case TUSB_DESC_STRING: -    { -      TU_LOG2(" String[%u]\r\n", desc_index); - -      // String Descriptor always uses the desc set from user -      uint8_t const* desc_str = (uint8_t const*) tud_descriptor_string_cb(desc_index, p_request->wIndex); -      TU_VERIFY(desc_str); - -      // first byte of descriptor is its size -      return tud_control_xfer(rhport, p_request, (void*) desc_str, desc_str[0]); -    } -    break; - -    case TUSB_DESC_DEVICE_QUALIFIER: -      TU_LOG2(" Device Qualifier\r\n"); - -      // Host sends this request to ask why our device with USB BCD from 2.0 -      // but is running at Full/Low Speed. If not highspeed capable stall this request, -      // otherwise return the descriptor that could work in highspeed mode -      if ( tud_descriptor_device_qualifier_cb ) -      { -        uint8_t const* desc_qualifier = tud_descriptor_device_qualifier_cb(); -        TU_ASSERT(desc_qualifier); - -        // first byte of descriptor is its size -        return tud_control_xfer(rhport, p_request, (void*) desc_qualifier, desc_qualifier[0]); -      }else -      { -        return false; -      } -    break; - -    case TUSB_DESC_OTHER_SPEED_CONFIG: -      TU_LOG2(" Other Speed Configuration\r\n"); - -      // After Device Qualifier descriptor is received host will ask for this descriptor -      return false; // not supported -    break; - -    default: return false; -  } -} - -//--------------------------------------------------------------------+ -// DCD Event Handler -//--------------------------------------------------------------------+ -void dcd_event_handler(dcd_event_t const * event, bool in_isr) -{ -  switch (event->event_id) -  { -    case DCD_EVENT_UNPLUGGED: -      // UNPLUGGED event can be bouncing, only processing if we are currently connected -      if ( _usbd_dev.connected ) -      { -        _usbd_dev.connected  = 0; -        _usbd_dev.addressed  = 0; -        _usbd_dev.cfg_num    = 0; -        _usbd_dev.suspended  = 0; -        osal_queue_send(_usbd_q, event, in_isr); -      } -    break; - -    case DCD_EVENT_SUSPEND: -      // NOTE: When plugging/unplugging device, the D+/D- state are unstable and -      // can accidentally meet the SUSPEND condition ( Bus Idle for 3ms ). -      // In addition, some MCUs such as SAMD or boards that haven no VBUS detection cannot distinguish -      // suspended vs disconnected. We will skip handling SUSPEND/RESUME event if not currently connected -      if ( _usbd_dev.connected ) -      { -        _usbd_dev.suspended = 1; -        osal_queue_send(_usbd_q, event, in_isr); -      } -    break; - -    case DCD_EVENT_RESUME: -      // skip event if not connected (especially required for SAMD) -      if ( _usbd_dev.connected ) -      { -        _usbd_dev.suspended = 0; -        osal_queue_send(_usbd_q, event, in_isr); -      } -    break; - -    case DCD_EVENT_SOF: -      // Some MCUs after running dcd_remote_wakeup() does not have way to detect the end of remote wakeup -      // which last 1-15 ms. DCD can use SOF as a clear indicator that bus is back to operational -      if ( _usbd_dev.suspended ) -      { -        _usbd_dev.suspended = 0; -        dcd_event_t const event_resume = { .rhport = event->rhport, .event_id = DCD_EVENT_RESUME }; -        osal_queue_send(_usbd_q, &event_resume, in_isr); -      } -    break; - -    default: -      osal_queue_send(_usbd_q, event, in_isr); -    break; -  } -} - -void dcd_event_bus_signal (uint8_t rhport, dcd_eventid_t eid, bool in_isr) -{ -  dcd_event_t event = { .rhport = rhport, .event_id = eid }; -  dcd_event_handler(&event, in_isr); -} - -void dcd_event_bus_reset (uint8_t rhport, tusb_speed_t speed, bool in_isr) -{ -  dcd_event_t event = { .rhport = rhport, .event_id = DCD_EVENT_BUS_RESET }; -  event.bus_reset.speed = speed; -  dcd_event_handler(&event, in_isr); -} - -void dcd_event_setup_received(uint8_t rhport, uint8_t const * setup, bool in_isr) -{ -  dcd_event_t event = { .rhport = rhport, .event_id = DCD_EVENT_SETUP_RECEIVED }; -  memcpy(&event.setup_received, setup, 8); - -  dcd_event_handler(&event, in_isr); -} - -void dcd_event_xfer_complete (uint8_t rhport, uint8_t ep_addr, uint32_t xferred_bytes, uint8_t result, bool in_isr) -{ -  dcd_event_t event = { .rhport = rhport, .event_id = DCD_EVENT_XFER_COMPLETE }; - -  event.xfer_complete.ep_addr = ep_addr; -  event.xfer_complete.len     = xferred_bytes; -  event.xfer_complete.result  = result; - -  dcd_event_handler(&event, in_isr); -} - -//--------------------------------------------------------------------+ -// USBD API For Class Driver -//--------------------------------------------------------------------+ - -// Parse consecutive endpoint descriptors (IN & OUT) -bool usbd_open_edpt_pair(uint8_t rhport, uint8_t const* p_desc, uint8_t ep_count, uint8_t xfer_type, uint8_t* ep_out, uint8_t* ep_in) -{ -  for(int i=0; i<ep_count; i++) -  { -    tusb_desc_endpoint_t const * desc_ep = (tusb_desc_endpoint_t const *) p_desc; - -    TU_ASSERT(TUSB_DESC_ENDPOINT == desc_ep->bDescriptorType && xfer_type == desc_ep->bmAttributes.xfer); -    TU_ASSERT(usbd_edpt_open(rhport, desc_ep)); - -    if ( tu_edpt_dir(desc_ep->bEndpointAddress) == TUSB_DIR_IN ) -    { -      (*ep_in) = desc_ep->bEndpointAddress; -    }else -    { -      (*ep_out) = desc_ep->bEndpointAddress; -    } - -    p_desc = tu_desc_next(p_desc); -  } - -  return true; -} - -// Helper to defer an isr function -void usbd_defer_func(osal_task_func_t func, void* param, bool in_isr) -{ -  dcd_event_t event = -  { -      .rhport   = 0, -      .event_id = USBD_EVENT_FUNC_CALL, -  }; - -  event.func_call.func  = func; -  event.func_call.param = param; - -  dcd_event_handler(&event, in_isr); -} - -//--------------------------------------------------------------------+ -// USBD Endpoint API -//--------------------------------------------------------------------+ - -bool usbd_edpt_open(uint8_t rhport, tusb_desc_endpoint_t const * desc_ep) -{ -  TU_ASSERT(tu_edpt_number(desc_ep->bEndpointAddress) < CFG_TUD_ENDPPOINT_MAX); -  TU_ASSERT(tu_edpt_validate(desc_ep, (tusb_speed_t) _usbd_dev.speed)); - -  return dcd_edpt_open(rhport, desc_ep); -} - -bool usbd_edpt_claim(uint8_t rhport, uint8_t ep_addr) -{ -  (void) rhport; - -  // TODO add this check later, also make sure we don't starve an out endpoint while suspending -  // TU_VERIFY(tud_ready()); - -  uint8_t const epnum = tu_edpt_number(ep_addr); -  uint8_t const dir   = tu_edpt_dir(ep_addr); - -#if CFG_TUSB_OS != OPT_OS_NONE -  // pre-check to help reducing mutex lock -  TU_VERIFY((_usbd_dev.ep_status[epnum][dir].busy == 0) && (_usbd_dev.ep_status[epnum][dir].claimed == 0)); -  osal_mutex_lock(_usbd_mutex, OSAL_TIMEOUT_WAIT_FOREVER); -#endif - -  // can only claim the endpoint if it is not busy and not claimed yet. -  bool const ret = (_usbd_dev.ep_status[epnum][dir].busy == 0) && (_usbd_dev.ep_status[epnum][dir].claimed == 0); -  if (ret) -  { -    _usbd_dev.ep_status[epnum][dir].claimed = 1; -  } - -#if CFG_TUSB_OS != OPT_OS_NONE -  osal_mutex_unlock(_usbd_mutex); -#endif - -  return ret; -} - -bool usbd_edpt_release(uint8_t rhport, uint8_t ep_addr) -{ -  (void) rhport; - -  uint8_t const epnum = tu_edpt_number(ep_addr); -  uint8_t const dir   = tu_edpt_dir(ep_addr); - -#if CFG_TUSB_OS != OPT_OS_NONE -  osal_mutex_lock(_usbd_mutex, OSAL_TIMEOUT_WAIT_FOREVER); -#endif - -  // can only release the endpoint if it is claimed and not busy -  bool const ret = (_usbd_dev.ep_status[epnum][dir].busy == 0) && (_usbd_dev.ep_status[epnum][dir].claimed == 1); -  if (ret) -  { -    _usbd_dev.ep_status[epnum][dir].claimed = 0; -  } - -#if CFG_TUSB_OS != OPT_OS_NONE -  osal_mutex_unlock(_usbd_mutex); -#endif - -  return ret; -} - -bool usbd_edpt_xfer(uint8_t rhport, uint8_t ep_addr, uint8_t * buffer, uint16_t total_bytes) -{ -  uint8_t const epnum = tu_edpt_number(ep_addr); -  uint8_t const dir   = tu_edpt_dir(ep_addr); - -  // TODO skip ready() check for now since enumeration also use this API -  // TU_VERIFY(tud_ready()); - -  TU_LOG2("  Queue EP %02X with %u bytes ...\r\n", ep_addr, total_bytes); - -  // Attempt to transfer on a busy endpoint, sound like an race condition ! -  TU_ASSERT(_usbd_dev.ep_status[epnum][dir].busy == 0); - -  // Set busy first since the actual transfer can be complete before dcd_edpt_xfer() -  // could return and USBD task can preempt and clear the busy -  _usbd_dev.ep_status[epnum][dir].busy = true; - -  if ( dcd_edpt_xfer(rhport, ep_addr, buffer, total_bytes) ) -  { -    return true; -  }else -  { -    // DCD error, mark endpoint as ready to allow next transfer -    _usbd_dev.ep_status[epnum][dir].busy = false; -    _usbd_dev.ep_status[epnum][dir].claimed = 0; -    TU_LOG2("FAILED\r\n"); -    TU_BREAKPOINT(); -    return false; -  } -} - -// The number of bytes has to be given explicitly to allow more flexible control of how many -// bytes should be written and second to keep the return value free to give back a boolean -// success message. If total_bytes is too big, the FIFO will copy only what is available -// into the USB buffer! -bool usbd_edpt_xfer_fifo(uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16_t total_bytes) -{ -  uint8_t const epnum = tu_edpt_number(ep_addr); -  uint8_t const dir   = tu_edpt_dir(ep_addr); - -  TU_LOG2("  Queue ISO EP %02X with %u bytes ... ", ep_addr, total_bytes); - -  // Attempt to transfer on a busy endpoint, sound like an race condition ! -  TU_ASSERT(_usbd_dev.ep_status[epnum][dir].busy == 0); - -  // Set busy first since the actual transfer can be complete before dcd_edpt_xfer() could return -  // and usbd task can preempt and clear the busy -  _usbd_dev.ep_status[epnum][dir].busy = true; - -  if (dcd_edpt_xfer_fifo(rhport, ep_addr, ff, total_bytes)) -  { -    TU_LOG2("OK\r\n"); -    return true; -  }else -  { -    // DCD error, mark endpoint as ready to allow next transfer -    _usbd_dev.ep_status[epnum][dir].busy = false; -    _usbd_dev.ep_status[epnum][dir].claimed = 0; -    TU_LOG2("failed\r\n"); -    TU_BREAKPOINT(); -    return false; -  } -} - -bool usbd_edpt_busy(uint8_t rhport, uint8_t ep_addr) -{ -  (void) rhport; - -  uint8_t const epnum = tu_edpt_number(ep_addr); -  uint8_t const dir   = tu_edpt_dir(ep_addr); - -  return _usbd_dev.ep_status[epnum][dir].busy; -} - -void usbd_edpt_stall(uint8_t rhport, uint8_t ep_addr) -{ -  TU_LOG(USBD_DBG_LVL, "    Stall EP %02X", ep_addr); - -  uint8_t const epnum = tu_edpt_number(ep_addr); -  uint8_t const dir   = tu_edpt_dir(ep_addr); - -  dcd_edpt_stall(rhport, ep_addr); -  _usbd_dev.ep_status[epnum][dir].stalled = true; -  _usbd_dev.ep_status[epnum][dir].busy = true; -} - -void usbd_edpt_clear_stall(uint8_t rhport, uint8_t ep_addr) -{ -  TU_LOG(USBD_DBG_LVL, "    Clear Stall EP %02X", ep_addr); - -  uint8_t const epnum = tu_edpt_number(ep_addr); -  uint8_t const dir   = tu_edpt_dir(ep_addr); - - -  dcd_edpt_clear_stall(rhport, ep_addr); -  _usbd_dev.ep_status[epnum][dir].stalled = false; -  _usbd_dev.ep_status[epnum][dir].busy = false; -} - -bool usbd_edpt_stalled(uint8_t rhport, uint8_t ep_addr) -{ -  (void) rhport; - -  uint8_t const epnum = tu_edpt_number(ep_addr); -  uint8_t const dir   = tu_edpt_dir(ep_addr); - -  return _usbd_dev.ep_status[epnum][dir].stalled; -} - -/** - * usbd_edpt_close will disable an endpoint. - * - * In progress transfers on this EP may be delivered after this call. - * - */ -void usbd_edpt_close(uint8_t rhport, uint8_t ep_addr) -{ -  TU_ASSERT(dcd_edpt_close, /**/); -  TU_LOG2("  CLOSING Endpoint: 0x%02X\r\n", ep_addr); - -  dcd_edpt_close(rhport, ep_addr); - -  return; -} - -#endif diff --git a/tinyusb/src/device/usbd.h b/tinyusb/src/device/usbd.h deleted file mode 100755 index c85616c9..00000000 --- a/tinyusb/src/device/usbd.h +++ /dev/null @@ -1,783 +0,0 @@ -/* - * The MIT License (MIT) - * - * Copyright (c) 2019 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. - */ - -#ifndef _TUSB_USBD_H_ -#define _TUSB_USBD_H_ - -#include "common/tusb_common.h" - -#ifdef __cplusplus -extern "C" { -#endif - -//--------------------------------------------------------------------+ -// Application API -//--------------------------------------------------------------------+ - -// Init device stack -bool tud_init (uint8_t rhport); - -// Check if device stack is already initialized -bool tud_inited(void); - -// Task function should be called in main/rtos loop -void tud_task (void); - -// Check if there is pending events need proccessing by tud_task() -bool tud_task_event_ready(void); - -// Interrupt handler, name alias to DCD -extern void dcd_int_handler(uint8_t rhport); -#define tud_int_handler   dcd_int_handler - -// Get current bus speed -tusb_speed_t tud_speed_get(void); - -// Check if device is connected (may not mounted/configured yet) -// True if just got out of Bus Reset and received the very first data from host -bool tud_connected(void); - -// Check if device is connected and configured -bool tud_mounted(void); - -// Check if device is suspended -bool tud_suspended(void); - -// Check if device is ready to transfer -TU_ATTR_ALWAYS_INLINE static inline -bool tud_ready(void) -{ -  return tud_mounted() && !tud_suspended(); -} - -// Remote wake up host, only if suspended and enabled by host -bool tud_remote_wakeup(void); - -// Enable pull-up resistor on D+ D- -// Return false on unsupported MCUs -bool tud_disconnect(void); - -// Disable pull-up resistor on D+ D- -// Return false on unsupported MCUs -bool tud_connect(void); - -// Carry out Data and Status stage of control transfer -// - If len = 0, it is equivalent to sending status only -// - If len > wLength : it will be truncated -bool tud_control_xfer(uint8_t rhport, tusb_control_request_t const * request, void* buffer, uint16_t len); - -// Send STATUS (zero length) packet -bool tud_control_status(uint8_t rhport, tusb_control_request_t const * request); - -//--------------------------------------------------------------------+ -// Application Callbacks (WEAK is optional) -//--------------------------------------------------------------------+ - -// Invoked when received GET DEVICE DESCRIPTOR request -// Application return pointer to descriptor -uint8_t const * tud_descriptor_device_cb(void); - -// Invoked when received GET CONFIGURATION DESCRIPTOR request -// Application return pointer to descriptor, whose contents must exist long enough for transfer to complete -uint8_t const * tud_descriptor_configuration_cb(uint8_t index); - -// Invoked when received GET STRING DESCRIPTOR request -// Application return pointer to descriptor, whose contents must exist long enough for transfer to complete -uint16_t const* tud_descriptor_string_cb(uint8_t index, uint16_t langid); - -// Invoked when received GET BOS DESCRIPTOR request -// Application return pointer to descriptor -TU_ATTR_WEAK uint8_t const * tud_descriptor_bos_cb(void); - -// Invoked when received GET DEVICE QUALIFIER DESCRIPTOR request -// Application return pointer to descriptor, whose contents must exist long enough for transfer to complete -TU_ATTR_WEAK uint8_t const* tud_descriptor_device_qualifier_cb(void); - -// Invoked when device is mounted (configured) -TU_ATTR_WEAK void tud_mount_cb(void); - -// Invoked when device is unmounted -TU_ATTR_WEAK void tud_umount_cb(void); - -// Invoked when usb bus is suspended -// Within 7ms, device must draw an average of current less than 2.5 mA from bus -TU_ATTR_WEAK void tud_suspend_cb(bool remote_wakeup_en); - -// Invoked when usb bus is resumed -TU_ATTR_WEAK void tud_resume_cb(void); - -// Invoked when received control request with VENDOR TYPE -TU_ATTR_WEAK bool tud_vendor_control_xfer_cb(uint8_t rhport, uint8_t stage, tusb_control_request_t const * request); - -//--------------------------------------------------------------------+ -// Binary Device Object Store (BOS) Descriptor Templates -//--------------------------------------------------------------------+ - -#define TUD_BOS_DESC_LEN      5 - -// total length, number of device caps -#define TUD_BOS_DESCRIPTOR(_total_len, _caps_num) \ -  5, TUSB_DESC_BOS, U16_TO_U8S_LE(_total_len), _caps_num - -// Device Capability Platform 128-bit UUID + Data -#define TUD_BOS_PLATFORM_DESCRIPTOR(...) \ -  4+TU_ARGS_NUM(__VA_ARGS__), TUSB_DESC_DEVICE_CAPABILITY, DEVICE_CAPABILITY_PLATFORM, 0x00, __VA_ARGS__ - -//------------- WebUSB BOS Platform -------------// - -// Descriptor Length -#define TUD_BOS_WEBUSB_DESC_LEN         24 - -// Vendor Code, iLandingPage -#define TUD_BOS_WEBUSB_DESCRIPTOR(_vendor_code, _ipage) \ -  TUD_BOS_PLATFORM_DESCRIPTOR(TUD_BOS_WEBUSB_UUID, U16_TO_U8S_LE(0x0100), _vendor_code, _ipage) - -#define TUD_BOS_WEBUSB_UUID   \ -  0x38, 0xB6, 0x08, 0x34, 0xA9, 0x09, 0xA0, 0x47, \ -  0x8B, 0xFD, 0xA0, 0x76, 0x88, 0x15, 0xB6, 0x65 - -//------------- Microsoft OS 2.0 Platform -------------// -#define TUD_BOS_MICROSOFT_OS_DESC_LEN   28 - -// Total Length of descriptor set, vendor code -#define TUD_BOS_MS_OS_20_DESCRIPTOR(_desc_set_len, _vendor_code) \ -  TUD_BOS_PLATFORM_DESCRIPTOR(TUD_BOS_MS_OS_20_UUID, U32_TO_U8S_LE(0x06030000), U16_TO_U8S_LE(_desc_set_len), _vendor_code, 0) - -#define TUD_BOS_MS_OS_20_UUID \ -    0xDF, 0x60, 0xDD, 0xD8, 0x89, 0x45, 0xC7, 0x4C, \ -  0x9C, 0xD2, 0x65, 0x9D, 0x9E, 0x64, 0x8A, 0x9F - -//--------------------------------------------------------------------+ -// Configuration & Interface Descriptor Templates -//--------------------------------------------------------------------+ - -//------------- Configuration -------------// -#define TUD_CONFIG_DESC_LEN   (9) - -// Config number, interface count, string index, total length, attribute, power in mA -#define TUD_CONFIG_DESCRIPTOR(config_num, _itfcount, _stridx, _total_len, _attribute, _power_ma) \ -  9, TUSB_DESC_CONFIGURATION, U16_TO_U8S_LE(_total_len), _itfcount, config_num, _stridx, TU_BIT(7) | _attribute, (_power_ma)/2 - -//------------- CDC -------------// - -// Length of template descriptor: 66 bytes -#define TUD_CDC_DESC_LEN  (8+9+5+5+4+5+7+9+7+7) - -// CDC Descriptor Template -// Interface number, string index, EP notification address and size, EP data address (out, in) and size. -#define TUD_CDC_DESCRIPTOR(_itfnum, _stridx, _ep_notif, _ep_notif_size, _epout, _epin, _epsize) \ -  /* Interface Associate */\ -  8, TUSB_DESC_INTERFACE_ASSOCIATION, _itfnum, 2, TUSB_CLASS_CDC, CDC_COMM_SUBCLASS_ABSTRACT_CONTROL_MODEL, CDC_COMM_PROTOCOL_NONE, 0,\ -  /* CDC Control Interface */\ -  9, TUSB_DESC_INTERFACE, _itfnum, 0, 1, TUSB_CLASS_CDC, CDC_COMM_SUBCLASS_ABSTRACT_CONTROL_MODEL, CDC_COMM_PROTOCOL_NONE, _stridx,\ -  /* CDC Header */\ -  5, TUSB_DESC_CS_INTERFACE, CDC_FUNC_DESC_HEADER, U16_TO_U8S_LE(0x0120),\ -  /* CDC Call */\ -  5, TUSB_DESC_CS_INTERFACE, CDC_FUNC_DESC_CALL_MANAGEMENT, 0, (uint8_t)((_itfnum) + 1),\ -  /* CDC ACM: support line request */\ -  4, TUSB_DESC_CS_INTERFACE, CDC_FUNC_DESC_ABSTRACT_CONTROL_MANAGEMENT, 2,\ -  /* CDC Union */\ -  5, TUSB_DESC_CS_INTERFACE, CDC_FUNC_DESC_UNION, _itfnum, (uint8_t)((_itfnum) + 1),\ -  /* Endpoint Notification */\ -  7, TUSB_DESC_ENDPOINT, _ep_notif, TUSB_XFER_INTERRUPT, U16_TO_U8S_LE(_ep_notif_size), 16,\ -  /* CDC Data Interface */\ -  9, TUSB_DESC_INTERFACE, (uint8_t)((_itfnum)+1), 0, 2, TUSB_CLASS_CDC_DATA, 0, 0, 0,\ -  /* Endpoint Out */\ -  7, TUSB_DESC_ENDPOINT, _epout, TUSB_XFER_BULK, U16_TO_U8S_LE(_epsize), 0,\ -  /* Endpoint In */\ -  7, TUSB_DESC_ENDPOINT, _epin, TUSB_XFER_BULK, U16_TO_U8S_LE(_epsize), 0 - -//------------- MSC -------------// - -// Length of template descriptor: 23 bytes -#define TUD_MSC_DESC_LEN    (9 + 7 + 7) - -// Interface number, string index, EP Out & EP In address, EP size -#define TUD_MSC_DESCRIPTOR(_itfnum, _stridx, _epout, _epin, _epsize) \ -  /* Interface */\ -  9, TUSB_DESC_INTERFACE, _itfnum, 0, 2, TUSB_CLASS_MSC, MSC_SUBCLASS_SCSI, MSC_PROTOCOL_BOT, _stridx,\ -  /* Endpoint Out */\ -  7, TUSB_DESC_ENDPOINT, _epout, TUSB_XFER_BULK, U16_TO_U8S_LE(_epsize), 0,\ -  /* Endpoint In */\ -  7, TUSB_DESC_ENDPOINT, _epin, TUSB_XFER_BULK, U16_TO_U8S_LE(_epsize), 0 - -//------------- HID -------------// - -// Length of template descriptor: 25 bytes -#define TUD_HID_DESC_LEN    (9 + 9 + 7) - -// HID Input only descriptor -// Interface number, string index, protocol, report descriptor len, EP In address, size & polling interval -#define TUD_HID_DESCRIPTOR(_itfnum, _stridx, _boot_protocol, _report_desc_len, _epin, _epsize, _ep_interval) \ -  /* Interface */\ -  9, TUSB_DESC_INTERFACE, _itfnum, 0, 1, TUSB_CLASS_HID, (uint8_t)((_boot_protocol) ? (uint8_t)HID_SUBCLASS_BOOT : 0), _boot_protocol, _stridx,\ -  /* HID descriptor */\ -  9, HID_DESC_TYPE_HID, U16_TO_U8S_LE(0x0111), 0, 1, HID_DESC_TYPE_REPORT, U16_TO_U8S_LE(_report_desc_len),\ -  /* Endpoint In */\ -  7, TUSB_DESC_ENDPOINT, _epin, TUSB_XFER_INTERRUPT, U16_TO_U8S_LE(_epsize), _ep_interval - -// Length of template descriptor: 32 bytes -#define TUD_HID_INOUT_DESC_LEN    (9 + 9 + 7 + 7) - -// HID Input & Output descriptor -// Interface number, string index, protocol, report descriptor len, EP OUT & IN address, size & polling interval -#define TUD_HID_INOUT_DESCRIPTOR(_itfnum, _stridx, _boot_protocol, _report_desc_len, _epout, _epin, _epsize, _ep_interval) \ -  /* Interface */\ -  9, TUSB_DESC_INTERFACE, _itfnum, 0, 2, TUSB_CLASS_HID, (uint8_t)((_boot_protocol) ? (uint8_t)HID_SUBCLASS_BOOT : 0), _boot_protocol, _stridx,\ -  /* HID descriptor */\ -  9, HID_DESC_TYPE_HID, U16_TO_U8S_LE(0x0111), 0, 1, HID_DESC_TYPE_REPORT, U16_TO_U8S_LE(_report_desc_len),\ -  /* Endpoint Out */\ -  7, TUSB_DESC_ENDPOINT, _epout, TUSB_XFER_INTERRUPT, U16_TO_U8S_LE(_epsize), _ep_interval, \ -  /* Endpoint In */\ -  7, TUSB_DESC_ENDPOINT, _epin, TUSB_XFER_INTERRUPT, U16_TO_U8S_LE(_epsize), _ep_interval - -//------------- MIDI -------------// -// MIDI v1.0 is based on Audio v1.0 - -#define TUD_MIDI_DESC_HEAD_LEN (9 + 9 + 9 + 7) -#define TUD_MIDI_DESC_HEAD(_itfnum,  _stridx, _numcables) \ -  /* Audio Control (AC) Interface */\ -  9, TUSB_DESC_INTERFACE, _itfnum, 0, 0, TUSB_CLASS_AUDIO, AUDIO_SUBCLASS_CONTROL, AUDIO_FUNC_PROTOCOL_CODE_UNDEF, _stridx,\ -  /* AC Header */\ -  9, TUSB_DESC_CS_INTERFACE, AUDIO_CS_AC_INTERFACE_HEADER, U16_TO_U8S_LE(0x0100), U16_TO_U8S_LE(0x0009), 1, (uint8_t)((_itfnum) + 1),\ -  /* MIDI Streaming (MS) Interface */\ -  9, TUSB_DESC_INTERFACE, (uint8_t)((_itfnum) + 1), 0, 2, TUSB_CLASS_AUDIO, AUDIO_SUBCLASS_MIDI_STREAMING, AUDIO_FUNC_PROTOCOL_CODE_UNDEF, 0,\ -  /* MS Header */\ -  7, TUSB_DESC_CS_INTERFACE, MIDI_CS_INTERFACE_HEADER, U16_TO_U8S_LE(0x0100), U16_TO_U8S_LE(7 + (_numcables) * TUD_MIDI_DESC_JACK_LEN) - -#define TUD_MIDI_JACKID_IN_EMB(_cablenum) \ -  (uint8_t)(((_cablenum) - 1) * 4 + 1) - -#define TUD_MIDI_JACKID_IN_EXT(_cablenum) \ -  (uint8_t)(((_cablenum) - 1) * 4 + 2) - -#define TUD_MIDI_JACKID_OUT_EMB(_cablenum) \ -  (uint8_t)(((_cablenum) - 1) * 4 + 3) - -#define TUD_MIDI_JACKID_OUT_EXT(_cablenum) \ -  (uint8_t)(((_cablenum) - 1) * 4 + 4) - -#define TUD_MIDI_DESC_JACK_LEN (6 + 6 + 9 + 9) -#define TUD_MIDI_DESC_JACK(_cablenum) \ -  /* MS In Jack (Embedded) */\ -  6, TUSB_DESC_CS_INTERFACE, MIDI_CS_INTERFACE_IN_JACK, MIDI_JACK_EMBEDDED, TUD_MIDI_JACKID_IN_EMB(_cablenum), 0,\ -  /* MS In Jack (External) */\ -  6, TUSB_DESC_CS_INTERFACE, MIDI_CS_INTERFACE_IN_JACK, MIDI_JACK_EXTERNAL, TUD_MIDI_JACKID_IN_EXT(_cablenum), 0,\ -  /* MS Out Jack (Embedded), connected to In Jack External */\ -  9, TUSB_DESC_CS_INTERFACE, MIDI_CS_INTERFACE_OUT_JACK, MIDI_JACK_EMBEDDED, TUD_MIDI_JACKID_OUT_EMB(_cablenum), 1, TUD_MIDI_JACKID_IN_EXT(_cablenum), 1, 0,\ -  /* MS Out Jack (External), connected to In Jack Embedded */\ -  9, TUSB_DESC_CS_INTERFACE, MIDI_CS_INTERFACE_OUT_JACK, MIDI_JACK_EXTERNAL, TUD_MIDI_JACKID_OUT_EXT(_cablenum), 1, TUD_MIDI_JACKID_IN_EMB(_cablenum), 1, 0 - -#define TUD_MIDI_DESC_EP_LEN(_numcables) (9 + 4 + (_numcables)) -#define TUD_MIDI_DESC_EP(_epout, _epsize, _numcables) \ -  /* Endpoint: Note Audio v1.0's endpoint has 9 bytes instead of 7 */\ -  9, TUSB_DESC_ENDPOINT, _epout, TUSB_XFER_BULK, U16_TO_U8S_LE(_epsize), 0, 0, 0, \ -  /* MS Endpoint (connected to embedded jack) */\ -  (uint8_t)(4 + (_numcables)), TUSB_DESC_CS_ENDPOINT, MIDI_CS_ENDPOINT_GENERAL, _numcables - -// Length of template descriptor (88 bytes) -#define TUD_MIDI_DESC_LEN (TUD_MIDI_DESC_HEAD_LEN + TUD_MIDI_DESC_JACK_LEN + TUD_MIDI_DESC_EP_LEN(1) * 2) - -// MIDI simple descriptor -// - 1 Embedded Jack In connected to 1 External Jack Out -// - 1 Embedded Jack out connected to 1 External Jack In -#define TUD_MIDI_DESCRIPTOR(_itfnum, _stridx, _epout, _epin, _epsize) \ -  TUD_MIDI_DESC_HEAD(_itfnum, _stridx, 1),\ -  TUD_MIDI_DESC_JACK(1),\ -  TUD_MIDI_DESC_EP(_epout, _epsize, 1),\ -  TUD_MIDI_JACKID_IN_EMB(1),\ -  TUD_MIDI_DESC_EP(_epin, _epsize, 1),\ -  TUD_MIDI_JACKID_OUT_EMB(1) - -//------------- AUDIO -------------// - -/* Standard Interface Association Descriptor (IAD) */ -#define TUD_AUDIO_DESC_IAD_LEN 8 -#define TUD_AUDIO_DESC_IAD(_firstitfs, _nitfs, _stridx) \ -  TUD_AUDIO_DESC_IAD_LEN, TUSB_DESC_INTERFACE_ASSOCIATION, _firstitfs, _nitfs, TUSB_CLASS_AUDIO, AUDIO_FUNCTION_SUBCLASS_UNDEFINED, AUDIO_FUNC_PROTOCOL_CODE_V2, _stridx - -/* Standard AC Interface Descriptor(4.7.1) */ -#define TUD_AUDIO_DESC_STD_AC_LEN 9 -#define TUD_AUDIO_DESC_STD_AC(_itfnum, _nEPs, _stridx) /* _nEPs is 0 or 1 */\ -  TUD_AUDIO_DESC_STD_AC_LEN, TUSB_DESC_INTERFACE, _itfnum, /* fixed to zero */ 0x00, _nEPs, TUSB_CLASS_AUDIO, AUDIO_SUBCLASS_CONTROL, AUDIO_INT_PROTOCOL_CODE_V2, _stridx - -/* Class-Specific AC Interface Header Descriptor(4.7.2) */ -#define TUD_AUDIO_DESC_CS_AC_LEN 9 -#define TUD_AUDIO_DESC_CS_AC(_bcdADC, _category, _totallen, _ctrl) /* _bcdADC : Audio Device Class Specification Release Number in Binary-Coded Decimal, _category : see audio_function_t, _totallen : Total number of bytes returned for the class-specific AudioControl interface i.e. Clock Source, Unit and Terminal descriptors - Do not include TUD_AUDIO_DESC_CS_AC_LEN, we already do this here*/ \ -  TUD_AUDIO_DESC_CS_AC_LEN, TUSB_DESC_CS_INTERFACE, AUDIO_CS_AC_INTERFACE_HEADER, U16_TO_U8S_LE(_bcdADC), _category, U16_TO_U8S_LE(_totallen + TUD_AUDIO_DESC_CS_AC_LEN), _ctrl - -/* Clock Source Descriptor(4.7.2.1) */ -#define TUD_AUDIO_DESC_CLK_SRC_LEN 8 -#define TUD_AUDIO_DESC_CLK_SRC(_clkid, _attr, _ctrl, _assocTerm, _stridx) \ -  TUD_AUDIO_DESC_CLK_SRC_LEN, TUSB_DESC_CS_INTERFACE, AUDIO_CS_AC_INTERFACE_CLOCK_SOURCE, _clkid, _attr, _ctrl, _assocTerm, _stridx - -/* Input Terminal Descriptor(4.7.2.4) */ -#define TUD_AUDIO_DESC_INPUT_TERM_LEN 17 -#define TUD_AUDIO_DESC_INPUT_TERM(_termid, _termtype, _assocTerm, _clkid, _nchannelslogical, _channelcfg, _idxchannelnames, _ctrl, _stridx) \ -  TUD_AUDIO_DESC_INPUT_TERM_LEN, TUSB_DESC_CS_INTERFACE, AUDIO_CS_AC_INTERFACE_INPUT_TERMINAL, _termid, U16_TO_U8S_LE(_termtype), _assocTerm, _clkid, _nchannelslogical, U32_TO_U8S_LE(_channelcfg), _idxchannelnames, U16_TO_U8S_LE(_ctrl), _stridx - -/* Output Terminal Descriptor(4.7.2.5) */ -#define TUD_AUDIO_DESC_OUTPUT_TERM_LEN 12 -#define TUD_AUDIO_DESC_OUTPUT_TERM(_termid, _termtype, _assocTerm, _srcid, _clkid, _ctrl, _stridx) \ -  TUD_AUDIO_DESC_OUTPUT_TERM_LEN, TUSB_DESC_CS_INTERFACE, AUDIO_CS_AC_INTERFACE_OUTPUT_TERMINAL, _termid, U16_TO_U8S_LE(_termtype), _assocTerm, _srcid, _clkid, U16_TO_U8S_LE(_ctrl), _stridx - -/* Feature Unit Descriptor(4.7.2.8) */ -// 1 - Channel -#define TUD_AUDIO_DESC_FEATURE_UNIT_ONE_CHANNEL_LEN 6+(1+1)*4 -#define TUD_AUDIO_DESC_FEATURE_UNIT_ONE_CHANNEL(_unitid, _srcid, _ctrlch0master, _ctrlch1, _stridx) \ -  TUD_AUDIO_DESC_FEATURE_UNIT_ONE_CHANNEL_LEN, TUSB_DESC_CS_INTERFACE, AUDIO_CS_AC_INTERFACE_FEATURE_UNIT, _unitid, _srcid, U32_TO_U8S_LE(_ctrlch0master), U32_TO_U8S_LE(_ctrlch1), _stridx - -// 2 - Channels -#define TUD_AUDIO_DESC_FEATURE_UNIT_TWO_CHANNEL_LEN (6+(2+1)*4) -#define TUD_AUDIO_DESC_FEATURE_UNIT_TWO_CHANNEL(_unitid, _srcid, _ctrlch0master, _ctrlch1, _ctrlch2, _stridx) \ -		TUD_AUDIO_DESC_FEATURE_UNIT_TWO_CHANNEL_LEN, TUSB_DESC_CS_INTERFACE, AUDIO_CS_AC_INTERFACE_FEATURE_UNIT, _unitid, _srcid, U32_TO_U8S_LE(_ctrlch0master), U32_TO_U8S_LE(_ctrlch1), U32_TO_U8S_LE(_ctrlch2), _stridx -// 4 - Channels -#define TUD_AUDIO_DESC_FEATURE_UNIT_FOUR_CHANNEL_LEN (6+(4+1)*4) -#define TUD_AUDIO_DESC_FEATURE_UNIT_FOUR_CHANNEL(_unitid, _srcid, _ctrlch0master, _ctrlch1, _ctrlch2, _ctrlch3, _ctrlch4, _stridx) \ -                    TUD_AUDIO_DESC_FEATURE_UNIT_FOUR_CHANNEL_LEN, TUSB_DESC_CS_INTERFACE, AUDIO_CS_AC_INTERFACE_FEATURE_UNIT, _unitid, _srcid, U32_TO_U8S_LE(_ctrlch0master), U32_TO_U8S_LE(_ctrlch1), U32_TO_U8S_LE(_ctrlch2), U32_TO_U8S_LE(_ctrlch3), U32_TO_U8S_LE(_ctrlch4), _stridx - -// For more channels, add definitions here - -/* Standard AS Interface Descriptor(4.9.1) */ -#define TUD_AUDIO_DESC_STD_AS_INT_LEN 9 -#define TUD_AUDIO_DESC_STD_AS_INT(_itfnum, _altset, _nEPs, _stridx) \ -  TUD_AUDIO_DESC_STD_AS_INT_LEN, TUSB_DESC_INTERFACE, _itfnum, _altset, _nEPs, TUSB_CLASS_AUDIO, AUDIO_SUBCLASS_STREAMING, AUDIO_INT_PROTOCOL_CODE_V2, _stridx - -/* Class-Specific AS Interface Descriptor(4.9.2) */ -#define TUD_AUDIO_DESC_CS_AS_INT_LEN 16 -#define TUD_AUDIO_DESC_CS_AS_INT(_termid, _ctrl, _formattype, _formats, _nchannelsphysical, _channelcfg, _stridx) \ -  TUD_AUDIO_DESC_CS_AS_INT_LEN, TUSB_DESC_CS_INTERFACE, AUDIO_CS_AS_INTERFACE_AS_GENERAL, _termid, _ctrl, _formattype, U32_TO_U8S_LE(_formats), _nchannelsphysical, U32_TO_U8S_LE(_channelcfg), _stridx - -/* Type I Format Type Descriptor(2.3.1.6 - Audio Formats) */ -#define TUD_AUDIO_DESC_TYPE_I_FORMAT_LEN 6 -#define TUD_AUDIO_DESC_TYPE_I_FORMAT(_subslotsize, _bitresolution) /* _subslotsize is number of bytes per sample (i.e. subslot) and can be 1,2,3, or 4 */\ -  TUD_AUDIO_DESC_TYPE_I_FORMAT_LEN, TUSB_DESC_CS_INTERFACE, AUDIO_CS_AS_INTERFACE_FORMAT_TYPE, AUDIO_FORMAT_TYPE_I, _subslotsize, _bitresolution - -/* Standard AS Isochronous Audio Data Endpoint Descriptor(4.10.1.1) */ -#define TUD_AUDIO_DESC_STD_AS_ISO_EP_LEN 7 -#define TUD_AUDIO_DESC_STD_AS_ISO_EP(_ep, _attr, _maxEPsize, _interval) \ -  TUD_AUDIO_DESC_STD_AS_ISO_EP_LEN, TUSB_DESC_ENDPOINT, _ep, _attr, U16_TO_U8S_LE(_maxEPsize), _interval - -/* Class-Specific AS Isochronous Audio Data Endpoint Descriptor(4.10.1.2) */ -#define TUD_AUDIO_DESC_CS_AS_ISO_EP_LEN 8 -#define TUD_AUDIO_DESC_CS_AS_ISO_EP(_attr, _ctrl, _lockdelayunit, _lockdelay) \ -  TUD_AUDIO_DESC_CS_AS_ISO_EP_LEN, TUSB_DESC_CS_ENDPOINT, AUDIO_CS_EP_SUBTYPE_GENERAL, _attr, _ctrl, _lockdelayunit, U16_TO_U8S_LE(_lockdelay) - -/* Standard AS Isochronous Feedback Endpoint Descriptor(4.10.2.1) */ -#define TUD_AUDIO_DESC_STD_AS_ISO_FB_EP_LEN 7 -#define TUD_AUDIO_DESC_STD_AS_ISO_FB_EP(_ep, _interval) \ -  TUD_AUDIO_DESC_STD_AS_ISO_FB_EP_LEN, TUSB_DESC_ENDPOINT, _ep, (TUSB_XFER_ISOCHRONOUS | TUSB_ISO_EP_ATT_NO_SYNC | TUSB_ISO_EP_ATT_EXPLICIT_FB), U16_TO_U8S_LE(4), _interval - -// AUDIO simple descriptor (UAC2) for 1 microphone input -// - 1 Input Terminal, 1 Feature Unit (Mute and Volume Control), 1 Output Terminal, 1 Clock Source - -#define TUD_AUDIO_MIC_ONE_CH_DESC_LEN (TUD_AUDIO_DESC_IAD_LEN\ -  + TUD_AUDIO_DESC_STD_AC_LEN\ -  + TUD_AUDIO_DESC_CS_AC_LEN\ -  + TUD_AUDIO_DESC_CLK_SRC_LEN\ -  + TUD_AUDIO_DESC_INPUT_TERM_LEN\ -  + TUD_AUDIO_DESC_OUTPUT_TERM_LEN\ -  + TUD_AUDIO_DESC_FEATURE_UNIT_ONE_CHANNEL_LEN\ -  + TUD_AUDIO_DESC_STD_AS_INT_LEN\ -  + TUD_AUDIO_DESC_STD_AS_INT_LEN\ -  + TUD_AUDIO_DESC_CS_AS_INT_LEN\ -  + TUD_AUDIO_DESC_TYPE_I_FORMAT_LEN\ -  + TUD_AUDIO_DESC_STD_AS_ISO_EP_LEN\ -  + TUD_AUDIO_DESC_CS_AS_ISO_EP_LEN) - -#define TUD_AUDIO_MIC_ONE_CH_DESC_N_AS_INT 1 	// Number of AS interfaces - -#define TUD_AUDIO_MIC_ONE_CH_DESCRIPTOR(_itfnum, _stridx, _nBytesPerSample, _nBitsUsedPerSample, _epin, _epsize) \ -  /* Standard Interface Association Descriptor (IAD) */\ -  TUD_AUDIO_DESC_IAD(/*_firstitfs*/ _itfnum, /*_nitfs*/ 0x02, /*_stridx*/ 0x00),\ -  /* Standard AC Interface Descriptor(4.7.1) */\ -  TUD_AUDIO_DESC_STD_AC(/*_itfnum*/ _itfnum, /*_nEPs*/ 0x00, /*_stridx*/ _stridx),\ -  /* Class-Specific AC Interface Header Descriptor(4.7.2) */\ -  TUD_AUDIO_DESC_CS_AC(/*_bcdADC*/ 0x0200, /*_category*/ AUDIO_FUNC_MICROPHONE, /*_totallen*/ TUD_AUDIO_DESC_CLK_SRC_LEN+TUD_AUDIO_DESC_INPUT_TERM_LEN+TUD_AUDIO_DESC_OUTPUT_TERM_LEN+TUD_AUDIO_DESC_FEATURE_UNIT_ONE_CHANNEL_LEN, /*_ctrl*/ AUDIO_CS_AS_INTERFACE_CTRL_LATENCY_POS),\ -  /* Clock Source Descriptor(4.7.2.1) */\ -  TUD_AUDIO_DESC_CLK_SRC(/*_clkid*/ 0x04, /*_attr*/ AUDIO_CLOCK_SOURCE_ATT_INT_FIX_CLK, /*_ctrl*/ (AUDIO_CTRL_R << AUDIO_CLOCK_SOURCE_CTRL_CLK_FRQ_POS), /*_assocTerm*/ 0x01,  /*_stridx*/ 0x00),\ -  /* Input Terminal Descriptor(4.7.2.4) */\ -  TUD_AUDIO_DESC_INPUT_TERM(/*_termid*/ 0x01, /*_termtype*/ AUDIO_TERM_TYPE_IN_GENERIC_MIC, /*_assocTerm*/ 0x03, /*_clkid*/ 0x04, /*_nchannelslogical*/ 0x01, /*_channelcfg*/ AUDIO_CHANNEL_CONFIG_NON_PREDEFINED, /*_idxchannelnames*/ 0x00, /*_ctrl*/ AUDIO_CTRL_R << AUDIO_IN_TERM_CTRL_CONNECTOR_POS, /*_stridx*/ 0x00),\ -  /* Output Terminal Descriptor(4.7.2.5) */\ -  TUD_AUDIO_DESC_OUTPUT_TERM(/*_termid*/ 0x03, /*_termtype*/ AUDIO_TERM_TYPE_USB_STREAMING, /*_assocTerm*/ 0x01, /*_srcid*/ 0x02, /*_clkid*/ 0x04, /*_ctrl*/ 0x0000, /*_stridx*/ 0x00),\ -  /* Feature Unit Descriptor(4.7.2.8) */\ -  TUD_AUDIO_DESC_FEATURE_UNIT_ONE_CHANNEL(/*_unitid*/ 0x02, /*_srcid*/ 0x01, /*_ctrlch0master*/ AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_MUTE_POS | AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_VOLUME_POS, /*_ctrlch1*/ AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_MUTE_POS | AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_VOLUME_POS, /*_stridx*/ 0x00),\ -  /* Standard AS Interface Descriptor(4.9.1) */\ -  /* Interface 1, Alternate 0 - default alternate setting with 0 bandwidth */\ -  TUD_AUDIO_DESC_STD_AS_INT(/*_itfnum*/ (uint8_t)((_itfnum)+1), /*_altset*/ 0x00, /*_nEPs*/ 0x00, /*_stridx*/ 0x00),\ -  /* Standard AS Interface Descriptor(4.9.1) */\ -  /* Interface 1, Alternate 1 - alternate interface for data streaming */\ -  TUD_AUDIO_DESC_STD_AS_INT(/*_itfnum*/ (uint8_t)((_itfnum)+1), /*_altset*/ 0x01, /*_nEPs*/ 0x01, /*_stridx*/ 0x00),\ -  /* Class-Specific AS Interface Descriptor(4.9.2) */\ -  TUD_AUDIO_DESC_CS_AS_INT(/*_termid*/ 0x03, /*_ctrl*/ AUDIO_CTRL_NONE, /*_formattype*/ AUDIO_FORMAT_TYPE_I, /*_formats*/ AUDIO_DATA_FORMAT_TYPE_I_PCM, /*_nchannelsphysical*/ 0x01, /*_channelcfg*/ AUDIO_CHANNEL_CONFIG_NON_PREDEFINED, /*_stridx*/ 0x00),\ -  /* Type I Format Type Descriptor(2.3.1.6 - Audio Formats) */\ -  TUD_AUDIO_DESC_TYPE_I_FORMAT(_nBytesPerSample, _nBitsUsedPerSample),\ -  /* Standard AS Isochronous Audio Data Endpoint Descriptor(4.10.1.1) */\ -  TUD_AUDIO_DESC_STD_AS_ISO_EP(/*_ep*/ _epin, /*_attr*/ (TUSB_XFER_ISOCHRONOUS | TUSB_ISO_EP_ATT_ASYNCHRONOUS | TUSB_ISO_EP_ATT_DATA), /*_maxEPsize*/ _epsize, /*_interval*/ (CFG_TUSB_RHPORT0_MODE & OPT_MODE_HIGH_SPEED) ? 0x04 : 0x01),\ -  /* Class-Specific AS Isochronous Audio Data Endpoint Descriptor(4.10.1.2) */\ -  TUD_AUDIO_DESC_CS_AS_ISO_EP(/*_attr*/ AUDIO_CS_AS_ISO_DATA_EP_ATT_NON_MAX_PACKETS_OK, /*_ctrl*/ AUDIO_CTRL_NONE, /*_lockdelayunit*/ AUDIO_CS_AS_ISO_DATA_EP_LOCK_DELAY_UNIT_UNDEFINED, /*_lockdelay*/ 0x0000) - -// AUDIO simple descriptor (UAC2) for 4 microphone input -// - 1 Input Terminal, 1 Feature Unit (Mute and Volume Control), 1 Output Terminal, 1 Clock Source - -#define TUD_AUDIO_MIC_FOUR_CH_DESC_LEN (TUD_AUDIO_DESC_IAD_LEN\ -  + TUD_AUDIO_DESC_STD_AC_LEN\ -  + TUD_AUDIO_DESC_CS_AC_LEN\ -  + TUD_AUDIO_DESC_CLK_SRC_LEN\ -  + TUD_AUDIO_DESC_INPUT_TERM_LEN\ -  + TUD_AUDIO_DESC_OUTPUT_TERM_LEN\ -  + TUD_AUDIO_DESC_FEATURE_UNIT_FOUR_CHANNEL_LEN\ -  + TUD_AUDIO_DESC_STD_AS_INT_LEN\ -  + TUD_AUDIO_DESC_STD_AS_INT_LEN\ -  + TUD_AUDIO_DESC_CS_AS_INT_LEN\ -  + TUD_AUDIO_DESC_TYPE_I_FORMAT_LEN\ -  + TUD_AUDIO_DESC_STD_AS_ISO_EP_LEN\ -  + TUD_AUDIO_DESC_CS_AS_ISO_EP_LEN) - -#define TUD_AUDIO_MIC_FOUR_CH_DESC_N_AS_INT 1   // Number of AS interfaces - -#define TUD_AUDIO_MIC_FOUR_CH_DESCRIPTOR(_itfnum, _stridx, _nBytesPerSample, _nBitsUsedPerSample, _epin, _epsize) \ -  /* Standard Interface Association Descriptor (IAD) */\ -  TUD_AUDIO_DESC_IAD(/*_firstitfs*/ _itfnum, /*_nitfs*/ 0x02, /*_stridx*/ 0x00),\ -  /* Standard AC Interface Descriptor(4.7.1) */\ -  TUD_AUDIO_DESC_STD_AC(/*_itfnum*/ _itfnum, /*_nEPs*/ 0x00, /*_stridx*/ _stridx),\ -  /* Class-Specific AC Interface Header Descriptor(4.7.2) */\ -  TUD_AUDIO_DESC_CS_AC(/*_bcdADC*/ 0x0200, /*_category*/ AUDIO_FUNC_MICROPHONE, /*_totallen*/ TUD_AUDIO_DESC_CLK_SRC_LEN+TUD_AUDIO_DESC_INPUT_TERM_LEN+TUD_AUDIO_DESC_OUTPUT_TERM_LEN+TUD_AUDIO_DESC_FEATURE_UNIT_FOUR_CHANNEL_LEN, /*_ctrl*/ AUDIO_CS_AS_INTERFACE_CTRL_LATENCY_POS),\ -  /* Clock Source Descriptor(4.7.2.1) */\ -  TUD_AUDIO_DESC_CLK_SRC(/*_clkid*/ 0x04, /*_attr*/ AUDIO_CLOCK_SOURCE_ATT_INT_FIX_CLK, /*_ctrl*/ (AUDIO_CTRL_R << AUDIO_CLOCK_SOURCE_CTRL_CLK_FRQ_POS), /*_assocTerm*/ 0x01,  /*_stridx*/ 0x00),\ -  /* Input Terminal Descriptor(4.7.2.4) */\ -  TUD_AUDIO_DESC_INPUT_TERM(/*_termid*/ 0x01, /*_termtype*/ AUDIO_TERM_TYPE_IN_GENERIC_MIC, /*_assocTerm*/ 0x03, /*_clkid*/ 0x04, /*_nchannelslogical*/ 0x04, /*_channelcfg*/ AUDIO_CHANNEL_CONFIG_NON_PREDEFINED, /*_idxchannelnames*/ 0x00, /*_ctrl*/ AUDIO_CTRL_R << AUDIO_IN_TERM_CTRL_CONNECTOR_POS, /*_stridx*/ 0x00),\ -  /* Output Terminal Descriptor(4.7.2.5) */\ -  TUD_AUDIO_DESC_OUTPUT_TERM(/*_termid*/ 0x03, /*_termtype*/ AUDIO_TERM_TYPE_USB_STREAMING, /*_assocTerm*/ 0x01, /*_srcid*/ 0x02, /*_clkid*/ 0x04, /*_ctrl*/ 0x0000, /*_stridx*/ 0x00),\ -  /* Feature Unit Descriptor(4.7.2.8) */\ -  TUD_AUDIO_DESC_FEATURE_UNIT_FOUR_CHANNEL(/*_unitid*/ 0x02, /*_srcid*/ 0x01, /*_ctrlch0master*/ AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_MUTE_POS | AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_VOLUME_POS, /*_ctrlch1*/ AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_MUTE_POS | AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_VOLUME_POS, /*_ctrlch2*/ AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_MUTE_POS | AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_VOLUME_POS, /*_ctrlch3*/ AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_MUTE_POS | AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_VOLUME_POS, /*_ctrlch4*/ AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_MUTE_POS | AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_VOLUME_POS, /*_stridx*/ 0x00),\ -  /* Standard AS Interface Descriptor(4.9.1) */\ -  /* Interface 1, Alternate 0 - default alternate setting with 0 bandwidth */\ -  TUD_AUDIO_DESC_STD_AS_INT(/*_itfnum*/ (uint8_t)((_itfnum)+1), /*_altset*/ 0x00, /*_nEPs*/ 0x00, /*_stridx*/ 0x00),\ -  /* Standard AS Interface Descriptor(4.9.1) */\ -  /* Interface 1, Alternate 1 - alternate interface for data streaming */\ -  TUD_AUDIO_DESC_STD_AS_INT(/*_itfnum*/ (uint8_t)((_itfnum)+1), /*_altset*/ 0x01, /*_nEPs*/ 0x01, /*_stridx*/ 0x00),\ -  /* Class-Specific AS Interface Descriptor(4.9.2) */\ -  TUD_AUDIO_DESC_CS_AS_INT(/*_termid*/ 0x03, /*_ctrl*/ AUDIO_CTRL_NONE, /*_formattype*/ AUDIO_FORMAT_TYPE_I, /*_formats*/ AUDIO_DATA_FORMAT_TYPE_I_PCM, /*_nchannelsphysical*/ 0x04, /*_channelcfg*/ AUDIO_CHANNEL_CONFIG_NON_PREDEFINED, /*_stridx*/ 0x00),\ -  /* Type I Format Type Descriptor(2.3.1.6 - Audio Formats) */\ -  TUD_AUDIO_DESC_TYPE_I_FORMAT(_nBytesPerSample, _nBitsUsedPerSample),\ -  /* Standard AS Isochronous Audio Data Endpoint Descriptor(4.10.1.1) */\ -  TUD_AUDIO_DESC_STD_AS_ISO_EP(/*_ep*/ _epin, /*_attr*/ (TUSB_XFER_ISOCHRONOUS | TUSB_ISO_EP_ATT_ASYNCHRONOUS | TUSB_ISO_EP_ATT_DATA), /*_maxEPsize*/ _epsize, /*_interval*/ (CFG_TUSB_RHPORT0_MODE & OPT_MODE_HIGH_SPEED) ? 0x04 : 0x01),\ -  /* Class-Specific AS Isochronous Audio Data Endpoint Descriptor(4.10.1.2) */\ -  TUD_AUDIO_DESC_CS_AS_ISO_EP(/*_attr*/ AUDIO_CS_AS_ISO_DATA_EP_ATT_NON_MAX_PACKETS_OK, /*_ctrl*/ AUDIO_CTRL_NONE, /*_lockdelayunit*/ AUDIO_CS_AS_ISO_DATA_EP_LOCK_DELAY_UNIT_UNDEFINED, /*_lockdelay*/ 0x0000) - -// AUDIO simple descriptor (UAC2) for mono speaker -// - 1 Input Terminal, 2 Feature Unit (Mute and Volume Control), 3 Output Terminal, 4 Clock Source - -#define TUD_AUDIO_SPEAKER_MONO_FB_DESC_LEN (TUD_AUDIO_DESC_IAD_LEN\ -  + TUD_AUDIO_DESC_STD_AC_LEN\ -  + TUD_AUDIO_DESC_CS_AC_LEN\ -  + TUD_AUDIO_DESC_CLK_SRC_LEN\ -  + TUD_AUDIO_DESC_INPUT_TERM_LEN\ -  + TUD_AUDIO_DESC_OUTPUT_TERM_LEN\ -  + TUD_AUDIO_DESC_FEATURE_UNIT_ONE_CHANNEL_LEN\ -  + TUD_AUDIO_DESC_STD_AS_INT_LEN\ -  + TUD_AUDIO_DESC_STD_AS_INT_LEN\ -  + TUD_AUDIO_DESC_CS_AS_INT_LEN\ -  + TUD_AUDIO_DESC_TYPE_I_FORMAT_LEN\ -  + TUD_AUDIO_DESC_STD_AS_ISO_EP_LEN\ -  + TUD_AUDIO_DESC_CS_AS_ISO_EP_LEN\ -  + TUD_AUDIO_DESC_STD_AS_ISO_FB_EP_LEN) - -#define TUD_AUDIO_SPEAKER_MONO_FB_DESCRIPTOR(_itfnum, _stridx, _nBytesPerSample, _nBitsUsedPerSample, _epout, _epsize, _epfb) \ -  /* Standard Interface Association Descriptor (IAD) */\ -  TUD_AUDIO_DESC_IAD(/*_firstitfs*/ _itfnum, /*_nitfs*/ 0x02, /*_stridx*/ 0x00),\ -  /* Standard AC Interface Descriptor(4.7.1) */\ -  TUD_AUDIO_DESC_STD_AC(/*_itfnum*/ _itfnum, /*_nEPs*/ 0x00, /*_stridx*/ _stridx),\ -  /* Class-Specific AC Interface Header Descriptor(4.7.2) */\ -  TUD_AUDIO_DESC_CS_AC(/*_bcdADC*/ 0x0200, /*_category*/ AUDIO_FUNC_DESKTOP_SPEAKER, /*_totallen*/ TUD_AUDIO_DESC_CLK_SRC_LEN+TUD_AUDIO_DESC_INPUT_TERM_LEN+TUD_AUDIO_DESC_OUTPUT_TERM_LEN+TUD_AUDIO_DESC_FEATURE_UNIT_ONE_CHANNEL_LEN, /*_ctrl*/ AUDIO_CS_AS_INTERFACE_CTRL_LATENCY_POS),\ -  /* Clock Source Descriptor(4.7.2.1) */\ -  TUD_AUDIO_DESC_CLK_SRC(/*_clkid*/ 0x04, /*_attr*/ AUDIO_CLOCK_SOURCE_ATT_INT_FIX_CLK, /*_ctrl*/ (AUDIO_CTRL_R << AUDIO_CLOCK_SOURCE_CTRL_CLK_FRQ_POS), /*_assocTerm*/ 0x01,  /*_stridx*/ 0x00),\ -  /* Input Terminal Descriptor(4.7.2.4) */\ -  TUD_AUDIO_DESC_INPUT_TERM(/*_termid*/ 0x01, /*_termtype*/ AUDIO_TERM_TYPE_USB_STREAMING, /*_assocTerm*/ 0x00, /*_clkid*/ 0x04, /*_nchannelslogical*/ 0x01, /*_channelcfg*/ AUDIO_CHANNEL_CONFIG_NON_PREDEFINED, /*_idxchannelnames*/ 0x00, /*_ctrl*/ 0 * (AUDIO_CTRL_R << AUDIO_IN_TERM_CTRL_CONNECTOR_POS), /*_stridx*/ 0x00),\ -  /* Output Terminal Descriptor(4.7.2.5) */\ -  TUD_AUDIO_DESC_OUTPUT_TERM(/*_termid*/ 0x03, /*_termtype*/ AUDIO_TERM_TYPE_OUT_DESKTOP_SPEAKER, /*_assocTerm*/ 0x01, /*_srcid*/ 0x02, /*_clkid*/ 0x04, /*_ctrl*/ 0x0000, /*_stridx*/ 0x00),\ -  /* Feature Unit Descriptor(4.7.2.8) */\ -  TUD_AUDIO_DESC_FEATURE_UNIT_ONE_CHANNEL(/*_unitid*/ 0x02, /*_srcid*/ 0x01, /*_ctrlch0master*/ 0 * (AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_MUTE_POS | AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_VOLUME_POS), /*_ctrlch1*/ 0 * (AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_MUTE_POS | AUDIO_CTRL_RW << AUDIO_FEATURE_UNIT_CTRL_VOLUME_POS), /*_stridx*/ 0x00),\ -  /* Standard AS Interface Descriptor(4.9.1) */\ -  /* Interface 1, Alternate 0 - default alternate setting with 0 bandwidth */\ -  TUD_AUDIO_DESC_STD_AS_INT(/*_itfnum*/ (uint8_t)((_itfnum) + 1), /*_altset*/ 0x00, /*_nEPs*/ 0x00, /*_stridx*/ 0x00),\ -  /* Standard AS Interface Descriptor(4.9.1) */\ -  /* Interface 1, Alternate 1 - alternate interface for data streaming */\ -  TUD_AUDIO_DESC_STD_AS_INT(/*_itfnum*/ (uint8_t)((_itfnum) + 1), /*_altset*/ 0x01, /*_nEPs*/ 0x02, /*_stridx*/ 0x00),\ -  /* Class-Specific AS Interface Descriptor(4.9.2) */\ -  TUD_AUDIO_DESC_CS_AS_INT(/*_termid*/ 0x01, /*_ctrl*/ AUDIO_CTRL_NONE, /*_formattype*/ AUDIO_FORMAT_TYPE_I, /*_formats*/ AUDIO_DATA_FORMAT_TYPE_I_PCM, /*_nchannelsphysical*/ 0x01, /*_channelcfg*/ AUDIO_CHANNEL_CONFIG_NON_PREDEFINED, /*_stridx*/ 0x00),\ -  /* Type I Format Type Descriptor(2.3.1.6 - Audio Formats) */\ -  TUD_AUDIO_DESC_TYPE_I_FORMAT(_nBytesPerSample, _nBitsUsedPerSample),\ -  /* Standard AS Isochronous Audio Data Endpoint Descriptor(4.10.1.1) */\ -  TUD_AUDIO_DESC_STD_AS_ISO_EP(/*_ep*/ _epout, /*_attr*/ (TUSB_XFER_ISOCHRONOUS | TUSB_ISO_EP_ATT_ASYNCHRONOUS | TUSB_ISO_EP_ATT_DATA), /*_maxEPsize*/ _epsize, /*_interval*/ (CFG_TUSB_RHPORT0_MODE & OPT_MODE_HIGH_SPEED) ? 0x04 : 0x01),\ -  /* Class-Specific AS Isochronous Audio Data Endpoint Descriptor(4.10.1.2) */\ -  TUD_AUDIO_DESC_CS_AS_ISO_EP(/*_attr*/ AUDIO_CS_AS_ISO_DATA_EP_ATT_NON_MAX_PACKETS_OK, /*_ctrl*/ AUDIO_CTRL_NONE, /*_lockdelayunit*/ AUDIO_CS_AS_ISO_DATA_EP_LOCK_DELAY_UNIT_UNDEFINED, /*_lockdelay*/ 0x0000),\ -  /* Standard AS Isochronous Feedback Endpoint Descriptor(4.10.2.1) */\ -  TUD_AUDIO_DESC_STD_AS_ISO_FB_EP(/*_ep*/ _epfb, /*_interval*/ 1)\ - -//   Calculate wMaxPacketSize of Endpoints -#define TUD_AUDIO_EP_SIZE(_maxFrequency, _nBytesPerSample, _nChannels) \ -    ((((_maxFrequency + ((CFG_TUSB_RHPORT0_MODE & OPT_MODE_HIGH_SPEED) ? 7999 : 999)) / ((CFG_TUSB_RHPORT0_MODE & OPT_MODE_HIGH_SPEED) ? 8000 : 1000)) + 1) * _nBytesPerSample * _nChannels) - - -//------------- TUD_USBTMC/USB488 -------------// -#define TUD_USBTMC_APP_CLASS    (TUSB_CLASS_APPLICATION_SPECIFIC) -#define TUD_USBTMC_APP_SUBCLASS 0x03u - -#define TUD_USBTMC_PROTOCOL_STD    0x00u -#define TUD_USBTMC_PROTOCOL_USB488 0x01u - -//   Interface number, number of endpoints, EP string index, USB_TMC_PROTOCOL*, bulk-out endpoint ID, -//   bulk-in endpoint ID -#define TUD_USBTMC_IF_DESCRIPTOR(_itfnum, _bNumEndpoints, _stridx, _itfProtocol) \ -  /* Interface */ \ -  0x09, TUSB_DESC_INTERFACE, _itfnum, 0x00, _bNumEndpoints, TUD_USBTMC_APP_CLASS, TUD_USBTMC_APP_SUBCLASS, _itfProtocol, _stridx - -#define TUD_USBTMC_IF_DESCRIPTOR_LEN 9u - -#define TUD_USBTMC_BULK_DESCRIPTORS(_epout, _epin, _bulk_epsize) \ -  /* Endpoint Out */ \ -  7, TUSB_DESC_ENDPOINT, _epout, TUSB_XFER_BULK, U16_TO_U8S_LE(_bulk_epsize), 0u, \ -  /* Endpoint In */ \ -  7, TUSB_DESC_ENDPOINT, _epin, TUSB_XFER_BULK, U16_TO_U8S_LE(_bulk_epsize), 0u - -#define TUD_USBTMC_BULK_DESCRIPTORS_LEN (7u+7u) - -/* optional interrupt endpoint */ \ -// _int_pollingInterval : for LS/FS, expressed in frames (1ms each). 16 may be a good number? -#define TUD_USBTMC_INT_DESCRIPTOR(_ep_interrupt, _ep_interrupt_size, _int_pollingInterval ) \ -  7, TUSB_DESC_ENDPOINT, _ep_interrupt, TUSB_XFER_INTERRUPT, U16_TO_U8S_LE(_ep_interrupt_size), 0x16 - -#define TUD_USBTMC_INT_DESCRIPTOR_LEN (7u) - - -//------------- Vendor -------------// -#define TUD_VENDOR_DESC_LEN  (9+7+7) - -// Interface number, string index, EP Out & IN address, EP size -#define TUD_VENDOR_DESCRIPTOR(_itfnum, _stridx, _epout, _epin, _epsize) \ -  /* Interface */\ -  9, TUSB_DESC_INTERFACE, _itfnum, 0, 2, TUSB_CLASS_VENDOR_SPECIFIC, 0x00, 0x00, _stridx,\ -  /* Endpoint Out */\ -  7, TUSB_DESC_ENDPOINT, _epout, TUSB_XFER_BULK, U16_TO_U8S_LE(_epsize), 0,\ -  /* Endpoint In */\ -  7, TUSB_DESC_ENDPOINT, _epin, TUSB_XFER_BULK, U16_TO_U8S_LE(_epsize), 0 - -//------------- DFU Runtime -------------// -#define TUD_DFU_APP_CLASS    (TUSB_CLASS_APPLICATION_SPECIFIC) -#define TUD_DFU_APP_SUBCLASS (APP_SUBCLASS_DFU_RUNTIME) - -// Length of template descriptr: 18 bytes -#define TUD_DFU_RT_DESC_LEN (9 + 9) - -// DFU runtime descriptor -// Interface number, string index, attributes, detach timeout, transfer size -#define TUD_DFU_RT_DESCRIPTOR(_itfnum, _stridx, _attr, _timeout, _xfer_size) \ -  /* Interface */ \ -  9, TUSB_DESC_INTERFACE, _itfnum, 0, 0, TUD_DFU_APP_CLASS, TUD_DFU_APP_SUBCLASS, DFU_PROTOCOL_RT, _stridx, \ -  /* Function */ \ -  9, DFU_DESC_FUNCTIONAL, _attr, U16_TO_U8S_LE(_timeout), U16_TO_U8S_LE(_xfer_size), U16_TO_U8S_LE(0x0101) - -// Length of template descriptor: 9 bytes + number of alternatives * 9 -#define TUD_DFU_DESC_LEN(_alt_count)    (9 + (_alt_count) * 9) - -// Interface number, Alternate count, starting string index, attributes, detach timeout, transfer size -// Note: Alternate count must be numberic or macro, string index is increased by one for each Alt interface -#define TUD_DFU_DESCRIPTOR(_itfnum, _alt_count, _stridx, _attr, _timeout, _xfer_size) \ -  TU_XSTRCAT(_TUD_DFU_ALT_,_alt_count)(_itfnum, 0, _stridx), \ -  /* Function */ \ -  9, DFU_DESC_FUNCTIONAL, _attr, U16_TO_U8S_LE(_timeout), U16_TO_U8S_LE(_xfer_size), U16_TO_U8S_LE(0x0101) - -#define _TUD_DFU_ALT(_itfnum, _alt, _stridx) \ -  /* Interface */ \ -  9, TUSB_DESC_INTERFACE, _itfnum, _alt, 0, TUD_DFU_APP_CLASS, TUD_DFU_APP_SUBCLASS, DFU_PROTOCOL_DFU, _stridx - -#define _TUD_DFU_ALT_1(_itfnum, _alt_count, _stridx) \ -  _TUD_DFU_ALT(_itfnum, _alt_count, _stridx) - -#define _TUD_DFU_ALT_2(_itfnum, _alt_count, _stridx) \ -  _TUD_DFU_ALT(_itfnum, _alt_count, _stridx),      \ -  _TUD_DFU_ALT_1(_itfnum, _alt_count+1, _stridx+1) - -#define _TUD_DFU_ALT_3(_itfnum, _alt_count, _stridx) \ -  _TUD_DFU_ALT(_itfnum, _alt_count, _stridx),      \ -  _TUD_DFU_ALT_2(_itfnum, _alt_count+1, _stridx+1) - -#define _TUD_DFU_ALT_4(_itfnum, _alt_count, _stridx) \ -  _TUD_DFU_ALT(_itfnum, _alt_count, _stridx),      \ -  _TUD_DFU_ALT_3(_itfnum, _alt_count+1, _stridx+1) - -#define _TUD_DFU_ALT_5(_itfnum, _alt_count, _stridx) \ -  _TUD_DFU_ALT(_itfnum, _alt_count, _stridx),      \ -  _TUD_DFU_ALT_4(_itfnum, _alt_count+1, _stridx+1) - -#define _TUD_DFU_ALT_6(_itfnum, _alt_count, _stridx) \ -  _TUD_DFU_ALT(_itfnum, _alt_count, _stridx),      \ -  _TUD_DFU_ALT_5(_itfnum, _alt_count+1, _stridx+1) - -#define _TUD_DFU_ALT_7(_itfnum, _alt_count, _stridx) \ -  _TUD_DFU_ALT(_itfnum, _alt_count, _stridx),      \ -  _TUD_DFU_ALT_6(_itfnum, _alt_count+1, _stridx+1) - -#define _TUD_DFU_ALT_8(_itfnum, _alt_count, _stridx) \ -  _TUD_DFU_ALT(_itfnum, _alt_count, _stridx),      \ -  _TUD_DFU_ALT_7(_itfnum, _alt_count+1, _stridx+1) - - -//------------- CDC-ECM -------------// - -// Length of template descriptor: 71 bytes -#define TUD_CDC_ECM_DESC_LEN  (8+9+5+5+13+7+9+9+7+7) - -// CDC-ECM Descriptor Template -// Interface number, description string index, MAC address string index, EP notification address and size, EP data address (out, in), and size, max segment size. -#define TUD_CDC_ECM_DESCRIPTOR(_itfnum, _desc_stridx, _mac_stridx, _ep_notif, _ep_notif_size, _epout, _epin, _epsize, _maxsegmentsize) \ -  /* Interface Association */\ -  8, TUSB_DESC_INTERFACE_ASSOCIATION, _itfnum, 2, TUSB_CLASS_CDC, CDC_COMM_SUBCLASS_ETHERNET_CONTROL_MODEL, 0, 0,\ -  /* CDC Control Interface */\ -  9, TUSB_DESC_INTERFACE, _itfnum, 0, 1, TUSB_CLASS_CDC, CDC_COMM_SUBCLASS_ETHERNET_CONTROL_MODEL, 0, _desc_stridx,\ -  /* CDC-ECM Header */\ -  5, TUSB_DESC_CS_INTERFACE, CDC_FUNC_DESC_HEADER, U16_TO_U8S_LE(0x0120),\ -  /* CDC-ECM Union */\ -  5, TUSB_DESC_CS_INTERFACE, CDC_FUNC_DESC_UNION, _itfnum, (uint8_t)((_itfnum) + 1),\ -  /* CDC-ECM Functional Descriptor */\ -  13, TUSB_DESC_CS_INTERFACE, CDC_FUNC_DESC_ETHERNET_NETWORKING, _mac_stridx, 0, 0, 0, 0, U16_TO_U8S_LE(_maxsegmentsize), U16_TO_U8S_LE(0), 0,\ -  /* Endpoint Notification */\ -  7, TUSB_DESC_ENDPOINT, _ep_notif, TUSB_XFER_INTERRUPT, U16_TO_U8S_LE(_ep_notif_size), 1,\ -  /* CDC Data Interface (default inactive) */\ -  9, TUSB_DESC_INTERFACE, (uint8_t)((_itfnum)+1), 0, 0, TUSB_CLASS_CDC_DATA, 0, 0, 0,\ -  /* CDC Data Interface (alternative active) */\ -  9, TUSB_DESC_INTERFACE, (uint8_t)((_itfnum)+1), 1, 2, TUSB_CLASS_CDC_DATA, 0, 0, 0,\ -  /* Endpoint In */\ -  7, TUSB_DESC_ENDPOINT, _epin, TUSB_XFER_BULK, U16_TO_U8S_LE(_epsize), 0,\ -  /* Endpoint Out */\ -  7, TUSB_DESC_ENDPOINT, _epout, TUSB_XFER_BULK, U16_TO_U8S_LE(_epsize), 0 - - -//------------- RNDIS -------------// - -#if 0 -/* Windows XP */ -#define TUD_RNDIS_ITF_CLASS    TUSB_CLASS_CDC -#define TUD_RNDIS_ITF_SUBCLASS CDC_COMM_SUBCLASS_ABSTRACT_CONTROL_MODEL -#define TUD_RNDIS_ITF_PROTOCOL 0xFF /* CDC_COMM_PROTOCOL_MICROSOFT_RNDIS */ -#else -/* Windows 7+ */ -#define TUD_RNDIS_ITF_CLASS    TUSB_CLASS_WIRELESS_CONTROLLER -#define TUD_RNDIS_ITF_SUBCLASS 0x01 -#define TUD_RNDIS_ITF_PROTOCOL 0x03 -#endif - -// Length of template descriptor: 66 bytes -#define TUD_RNDIS_DESC_LEN  (8+9+5+5+4+5+7+9+7+7) - -// RNDIS Descriptor Template -// Interface number, string index, EP notification address and size, EP data address (out, in) and size. -#define TUD_RNDIS_DESCRIPTOR(_itfnum, _stridx, _ep_notif, _ep_notif_size, _epout, _epin, _epsize) \ -  /* Interface Association */\ -  8, TUSB_DESC_INTERFACE_ASSOCIATION, _itfnum, 2, TUD_RNDIS_ITF_CLASS, TUD_RNDIS_ITF_SUBCLASS, TUD_RNDIS_ITF_PROTOCOL, 0,\ -  /* CDC Control Interface */\ -  9, TUSB_DESC_INTERFACE, _itfnum, 0, 1, TUD_RNDIS_ITF_CLASS, TUD_RNDIS_ITF_SUBCLASS, TUD_RNDIS_ITF_PROTOCOL, _stridx,\ -  /* CDC-ACM Header */\ -  5, TUSB_DESC_CS_INTERFACE, CDC_FUNC_DESC_HEADER, U16_TO_U8S_LE(0x0110),\ -  /* CDC Call Management */\ -  5, TUSB_DESC_CS_INTERFACE, CDC_FUNC_DESC_CALL_MANAGEMENT, 0, (uint8_t)((_itfnum) + 1),\ -  /* ACM */\ -  4, TUSB_DESC_CS_INTERFACE, CDC_FUNC_DESC_ABSTRACT_CONTROL_MANAGEMENT, 0,\ -  /* CDC Union */\ -  5, TUSB_DESC_CS_INTERFACE, CDC_FUNC_DESC_UNION, _itfnum, (uint8_t)((_itfnum) + 1),\ -  /* Endpoint Notification */\ -  7, TUSB_DESC_ENDPOINT, _ep_notif, TUSB_XFER_INTERRUPT, U16_TO_U8S_LE(_ep_notif_size), 1,\ -  /* CDC Data Interface */\ -  9, TUSB_DESC_INTERFACE, (uint8_t)((_itfnum)+1), 0, 2, TUSB_CLASS_CDC_DATA, 0, 0, 0,\ -  /* Endpoint In */\ -  7, TUSB_DESC_ENDPOINT, _epin, TUSB_XFER_BULK, U16_TO_U8S_LE(_epsize), 0,\ -  /* Endpoint Out */\ -  7, TUSB_DESC_ENDPOINT, _epout, TUSB_XFER_BULK, U16_TO_U8S_LE(_epsize), 0 - -//------------- BT Radio -------------// -#define TUD_BT_APP_CLASS                    (TUSB_CLASS_WIRELESS_CONTROLLER) -#define TUD_BT_APP_SUBCLASS                 0x01 -#define TUD_BT_PROTOCOL_PRIMARY_CONTROLLER  0x01 -#define TUD_BT_PROTOCOL_AMP_CONTROLLER      0x02 - -#ifndef CFG_TUD_BTH_ISO_ALT_COUNT -#define CFG_TUD_BTH_ISO_ALT_COUNT 0 -#endif - -// Length of template descriptor: 30 bytes + number of ISO alternatives * 23 -#define TUD_BTH_DESC_LEN (9 + 7 + 7 + 7 + (CFG_TUD_BTH_ISO_ALT_COUNT) * (9 + 7 + 7)) - -/* Primary Interface */ -#define TUD_BTH_PRI_ITF(_itfnum, _stridx, _ep_evt, _ep_evt_size, _ep_evt_interval, _ep_in, _ep_out, _ep_size) \ -  9, TUSB_DESC_INTERFACE, _itfnum, _stridx, 3, TUD_BT_APP_CLASS, TUD_BT_APP_SUBCLASS, TUD_BT_PROTOCOL_PRIMARY_CONTROLLER, 0, \ -  /* Endpoint In for events */ \ -  7, TUSB_DESC_ENDPOINT, _ep_evt, TUSB_XFER_INTERRUPT, U16_TO_U8S_LE(_ep_evt_size), _ep_evt_interval, \ -  /* Endpoint In for ACL data */ \ -  7, TUSB_DESC_ENDPOINT, _ep_in, TUSB_XFER_BULK, U16_TO_U8S_LE(_ep_size), 1, \ -  /* Endpoint Out for ACL data */ \ -  7, TUSB_DESC_ENDPOINT, _ep_out, TUSB_XFER_BULK, U16_TO_U8S_LE(_ep_size), 1 - -#define TUD_BTH_ISO_ITF(_itfnum, _alt, _ep_in, _ep_out, _n) ,\ -  /* Interface with 2 endpoints */ \ -  9, TUSB_DESC_INTERFACE, _itfnum, _alt, 2, TUD_BT_APP_CLASS, TUD_BT_APP_SUBCLASS, TUD_BT_PROTOCOL_PRIMARY_CONTROLLER, 0, \ -  /* Isochronous endpoints */ \ -  7, TUSB_DESC_ENDPOINT, _ep_in, TUSB_XFER_ISOCHRONOUS, U16_TO_U8S_LE(_n), 1, \ -  7, TUSB_DESC_ENDPOINT, _ep_out, TUSB_XFER_ISOCHRONOUS, U16_TO_U8S_LE(_n), 1 - -#define _FIRST(a, ...) a -#define _REST(a, ...) __VA_ARGS__ - -#define TUD_BTH_ISO_ITF_0(_itfnum, ...) -#define TUD_BTH_ISO_ITF_1(_itfnum, _ep_in, _ep_out, ...) TUD_BTH_ISO_ITF(_itfnum, (CFG_TUD_BTH_ISO_ALT_COUNT) - 1, _ep_in, _ep_out, _FIRST(__VA_ARGS__)) -#define TUD_BTH_ISO_ITF_2(_itfnum, _ep_in, _ep_out, ...) TUD_BTH_ISO_ITF(_itfnum, (CFG_TUD_BTH_ISO_ALT_COUNT) - 2, _ep_in, _ep_out, _FIRST(__VA_ARGS__)) \ -  TUD_BTH_ISO_ITF_1(_itfnum, _ep_in, _ep_out, _REST(__VA_ARGS__)) -#define TUD_BTH_ISO_ITF_3(_itfnum, _ep_in, _ep_out, ...) TUD_BTH_ISO_ITF(_itfnum, (CFG_TUD_BTH_ISO_ALT_COUNT) - 3, _ep_in, _ep_out, _FIRST(__VA_ARGS__)) \ -  TUD_BTH_ISO_ITF_2(_itfnum, _ep_in, _ep_out, _REST(__VA_ARGS__)) -#define TUD_BTH_ISO_ITF_4(_itfnum, _ep_in, _ep_out, ...) TUD_BTH_ISO_ITF(_itfnum, (CFG_TUD_BTH_ISO_ALT_COUNT) - 4, _ep_in, _ep_out, _FIRST(__VA_ARGS__)) \ -  TUD_BTH_ISO_ITF_3(_itfnum, _ep_in, _ep_out, _REST(__VA_ARGS__)) -#define TUD_BTH_ISO_ITF_5(_itfnum, _ep_in, _ep_out, ...) TUD_BTH_ISO_ITF(_itfnum, (CFG_TUD_BTH_ISO_ALT_COUNT) - 5, _ep_in, _ep_out, _FIRST(__VA_ARGS__)) \ -  TUD_BTH_ISO_ITF_4(_itfnum, _ep_in, _ep_out, _REST(__VA_ARGS__)) -#define TUD_BTH_ISO_ITF_6(_itfnum, _ep_in, _ep_out, ...) TUD_BTH_ISO_ITF(_itfnum, (CFG_TUD_BTH_ISO_ALT_COUNT) - 6, _ep_in, _ep_out, _FIRST(__VA_ARGS__)) \ -  TUD_BTH_ISO_ITF_5(_itfnum, _ep_in, _ep_out, _REST(__VA_ARGS__)) - -#define TUD_BTH_ISO_ITFS(_itfnum, _ep_in, _ep_out, ...) \ -  TU_XSTRCAT(TUD_BTH_ISO_ITF_, CFG_TUD_BTH_ISO_ALT_COUNT)(_itfnum, _ep_in, _ep_out, __VA_ARGS__) - -// BT Primary controller descriptor -// Interface number, string index, attributes, event endpoint, event endpoint size, interval, data in, data out, data endpoint size, iso endpoint sizes -#define TUD_BTH_DESCRIPTOR(_itfnum, _stridx, _ep_evt, _ep_evt_size, _ep_evt_interval, _ep_in, _ep_out, _ep_size,...) \ -  TUD_BTH_PRI_ITF(_itfnum, _stridx, _ep_evt, _ep_evt_size, _ep_evt_interval, _ep_in, _ep_out, _ep_size) \ -  TUD_BTH_ISO_ITFS(_itfnum + 1, _ep_in + 1, _ep_out + 1, __VA_ARGS__) - -#ifdef __cplusplus -} -#endif - -#endif /* _TUSB_USBD_H_ */ - -/** @} */ diff --git a/tinyusb/src/device/usbd_control.c b/tinyusb/src/device/usbd_control.c deleted file mode 100755 index 7a824469..00000000 --- a/tinyusb/src/device/usbd_control.c +++ /dev/null @@ -1,233 +0,0 @@ -/* - * The MIT License (MIT) - * - * Copyright (c) 2019 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. - */ - -#include "tusb_option.h" - -#if TUSB_OPT_DEVICE_ENABLED - -#include "tusb.h" -#include "device/usbd_pvt.h" -#include "dcd.h" - -#if CFG_TUSB_DEBUG >= 2 -extern void usbd_driver_print_control_complete_name(usbd_control_xfer_cb_t callback); -#endif - -enum -{ -  EDPT_CTRL_OUT = 0x00, -  EDPT_CTRL_IN  = 0x80 -}; - -typedef struct -{ -  tusb_control_request_t request; - -  uint8_t* buffer; -  uint16_t data_len; -  uint16_t total_xferred; - -  usbd_control_xfer_cb_t complete_cb; -} usbd_control_xfer_t; - -static usbd_control_xfer_t _ctrl_xfer; - -CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN -static uint8_t _usbd_ctrl_buf[CFG_TUD_ENDPOINT0_SIZE]; - -//--------------------------------------------------------------------+ -// Application API -//--------------------------------------------------------------------+ - -// Queue ZLP status transaction -static inline bool _status_stage_xact(uint8_t rhport, tusb_control_request_t const * request) -{ -  // Opposite to endpoint in Data Phase -  uint8_t const ep_addr = request->bmRequestType_bit.direction ? EDPT_CTRL_OUT : EDPT_CTRL_IN; -  return usbd_edpt_xfer(rhport, ep_addr, NULL, 0); -} - -// Status phase -bool tud_control_status(uint8_t rhport, tusb_control_request_t const * request) -{ -  _ctrl_xfer.request       = (*request); -  _ctrl_xfer.buffer        = NULL; -  _ctrl_xfer.total_xferred = 0; -  _ctrl_xfer.data_len      = 0; - -  return _status_stage_xact(rhport, request); -} - -// Queue a transaction in Data Stage -// Each transaction has up to Endpoint0's max packet size. -// This function can also transfer an zero-length packet -static bool _data_stage_xact(uint8_t rhport) -{ -  uint16_t const xact_len = tu_min16(_ctrl_xfer.data_len - _ctrl_xfer.total_xferred, CFG_TUD_ENDPOINT0_SIZE); - -  uint8_t ep_addr = EDPT_CTRL_OUT; - -  if ( _ctrl_xfer.request.bmRequestType_bit.direction == TUSB_DIR_IN ) -  { -    ep_addr = EDPT_CTRL_IN; -    if ( xact_len ) memcpy(_usbd_ctrl_buf, _ctrl_xfer.buffer, xact_len); -  } - -  return usbd_edpt_xfer(rhport, ep_addr, xact_len ? _usbd_ctrl_buf : NULL, xact_len); -} - -// Transmit data to/from the control endpoint. -// If the request's wLength is zero, a status packet is sent instead. -bool tud_control_xfer(uint8_t rhport, tusb_control_request_t const * request, void* buffer, uint16_t len) -{ -  _ctrl_xfer.request       = (*request); -  _ctrl_xfer.buffer        = (uint8_t*) buffer; -  _ctrl_xfer.total_xferred = 0U; -  _ctrl_xfer.data_len      = tu_min16(len, request->wLength); - -  if (request->wLength > 0U) -  { -    if(_ctrl_xfer.data_len > 0U) -    { -      TU_ASSERT(buffer); -    } - -//    TU_LOG2("  Control total data length is %u bytes\r\n", _ctrl_xfer.data_len); - -    // Data stage -    TU_ASSERT( _data_stage_xact(rhport) ); -  } -  else -  { -    // Status stage -    TU_ASSERT( _status_stage_xact(rhport, request) ); -  } - -  return true; -} - -//--------------------------------------------------------------------+ -// USBD API -//--------------------------------------------------------------------+ - -void usbd_control_reset(void); -void usbd_control_set_request(tusb_control_request_t const *request); -void usbd_control_set_complete_callback( usbd_control_xfer_cb_t fp ); -bool usbd_control_xfer_cb (uint8_t rhport, uint8_t ep_addr, xfer_result_t event, uint32_t xferred_bytes); - -void usbd_control_reset(void) -{ -  tu_varclr(&_ctrl_xfer); -} - -// Set complete callback -void usbd_control_set_complete_callback( usbd_control_xfer_cb_t fp ) -{ -  _ctrl_xfer.complete_cb = fp; -} - -// for dcd_set_address where DCD is responsible for status response -void usbd_control_set_request(tusb_control_request_t const *request) -{ -  _ctrl_xfer.request       = (*request); -  _ctrl_xfer.buffer        = NULL; -  _ctrl_xfer.total_xferred = 0; -  _ctrl_xfer.data_len      = 0; -} - -// callback when a transaction complete on -// - DATA stage of control endpoint or -// - Status stage -bool usbd_control_xfer_cb (uint8_t rhport, uint8_t ep_addr, xfer_result_t result, uint32_t xferred_bytes) -{ -  (void) result; - -  // Endpoint Address is opposite to direction bit, this is Status Stage complete event -  if ( tu_edpt_dir(ep_addr) != _ctrl_xfer.request.bmRequestType_bit.direction ) -  { -    TU_ASSERT(0 == xferred_bytes); - -    // invoke optional dcd hook if available -    if (dcd_edpt0_status_complete) dcd_edpt0_status_complete(rhport, &_ctrl_xfer.request); - -    if (_ctrl_xfer.complete_cb) -    { -      // TODO refactor with usbd_driver_print_control_complete_name -      _ctrl_xfer.complete_cb(rhport, CONTROL_STAGE_ACK, &_ctrl_xfer.request); -    } - -    return true; -  } - -  if ( _ctrl_xfer.request.bmRequestType_bit.direction == TUSB_DIR_OUT ) -  { -    TU_VERIFY(_ctrl_xfer.buffer); -    memcpy(_ctrl_xfer.buffer, _usbd_ctrl_buf, xferred_bytes); -    TU_LOG_MEM(2, _usbd_ctrl_buf, xferred_bytes, 2); -  } - -  _ctrl_xfer.total_xferred += xferred_bytes; -  _ctrl_xfer.buffer += xferred_bytes; - -  // Data Stage is complete when all request's length are transferred or -  // a short packet is sent including zero-length packet. -  if ( (_ctrl_xfer.request.wLength == _ctrl_xfer.total_xferred) || (xferred_bytes < CFG_TUD_ENDPOINT0_SIZE) ) -  { -    // DATA stage is complete -    bool is_ok = true; - -    // invoke complete callback if set -    // callback can still stall control in status phase e.g out data does not make sense -    if ( _ctrl_xfer.complete_cb ) -    { -      #if CFG_TUSB_DEBUG >= 2 -      usbd_driver_print_control_complete_name(_ctrl_xfer.complete_cb); -      #endif - -      is_ok = _ctrl_xfer.complete_cb(rhport, CONTROL_STAGE_DATA, &_ctrl_xfer.request); -    } - -    if ( is_ok ) -    { -      // Send status -      TU_ASSERT( _status_stage_xact(rhport, &_ctrl_xfer.request) ); -    }else -    { -      // Stall both IN and OUT control endpoint -      dcd_edpt_stall(rhport, EDPT_CTRL_OUT); -      dcd_edpt_stall(rhport, EDPT_CTRL_IN); -    } -  } -  else -  { -    // More data to transfer -    TU_ASSERT( _data_stage_xact(rhport) ); -  } - -  return true; -} - -#endif diff --git a/tinyusb/src/device/usbd_pvt.h b/tinyusb/src/device/usbd_pvt.h deleted file mode 100755 index 6a4b3095..00000000 --- a/tinyusb/src/device/usbd_pvt.h +++ /dev/null @@ -1,114 +0,0 @@ -/*  - * The MIT License (MIT) - * - * Copyright (c) 2019 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. - */ -#ifndef USBD_PVT_H_ -#define USBD_PVT_H_ - -#include "osal/osal.h" -#include "common/tusb_fifo.h" - -#ifdef __cplusplus - extern "C" { -#endif - -//--------------------------------------------------------------------+ -// Class Driver API -//--------------------------------------------------------------------+ - -typedef struct -{ -  #if CFG_TUSB_DEBUG >= 2 -  char const* name; -  #endif - -  void     (* init             ) (void); -  void     (* reset            ) (uint8_t rhport); -  uint16_t (* open             ) (uint8_t rhport, tusb_desc_interface_t const * desc_intf, uint16_t max_len); -  bool     (* control_xfer_cb  ) (uint8_t rhport, uint8_t stage, tusb_control_request_t const * request); -  bool     (* xfer_cb          ) (uint8_t rhport, uint8_t ep_addr, xfer_result_t result, uint32_t xferred_bytes); -  void     (* sof              ) (uint8_t rhport); /* optional */ -} usbd_class_driver_t; - -// Invoked when initializing device stack to get additional class drivers. -// Can optionally implemented by application to extend/overwrite class driver support. -// Note: The drivers array must be accessible at all time when stack is active -usbd_class_driver_t const* usbd_app_driver_get_cb(uint8_t* driver_count) TU_ATTR_WEAK; - -typedef bool (*usbd_control_xfer_cb_t)(uint8_t rhport, uint8_t stage, tusb_control_request_t const * request); - -//--------------------------------------------------------------------+ -// USBD Endpoint API -//--------------------------------------------------------------------+ - -// Open an endpoint -bool usbd_edpt_open(uint8_t rhport, tusb_desc_endpoint_t const * desc_ep); - -// Close an endpoint -void usbd_edpt_close(uint8_t rhport, uint8_t ep_addr); - -// Submit a usb transfer -bool usbd_edpt_xfer(uint8_t rhport, uint8_t ep_addr, uint8_t * buffer, uint16_t total_bytes); - -// Submit a usb ISO transfer by use of a FIFO (ring buffer) - all bytes in FIFO get transmitted -bool usbd_edpt_xfer_fifo(uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16_t total_bytes); - -// Claim an endpoint before submitting a transfer. -// If caller does not make any transfer, it must release endpoint for others. -bool usbd_edpt_claim(uint8_t rhport, uint8_t ep_addr); - -// Release an endpoint without submitting a transfer -bool usbd_edpt_release(uint8_t rhport, uint8_t ep_addr); - -// Check if endpoint transferring is complete -bool usbd_edpt_busy(uint8_t rhport, uint8_t ep_addr); - -// Stall endpoint -void usbd_edpt_stall(uint8_t rhport, uint8_t ep_addr); - -// Clear stalled endpoint -void usbd_edpt_clear_stall(uint8_t rhport, uint8_t ep_addr); - -// Check if endpoint is stalled -bool usbd_edpt_stalled(uint8_t rhport, uint8_t ep_addr); - -TU_ATTR_ALWAYS_INLINE static inline -bool usbd_edpt_ready(uint8_t rhport, uint8_t ep_addr) -{ -  return !usbd_edpt_busy(rhport, ep_addr) && !usbd_edpt_stalled(rhport, ep_addr); -} - -/*------------------------------------------------------------------*/ -/* Helper - *------------------------------------------------------------------*/ - -bool usbd_open_edpt_pair(uint8_t rhport, uint8_t const* p_desc, uint8_t ep_count, uint8_t xfer_type, uint8_t* ep_out, uint8_t* ep_in); -void usbd_defer_func( osal_task_func_t func, void* param, bool in_isr ); - - -#ifdef __cplusplus - } -#endif - -#endif /* USBD_PVT_H_ */ | 
