2020-01-14 23:30:39 -05:00
|
|
|
/*
|
|
|
|
* 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_OPTION_H_
|
|
|
|
#define _TUSB_OPTION_H_
|
|
|
|
|
|
|
|
#define TUSB_VERSION_MAJOR 0
|
2021-05-28 17:24:35 +07:00
|
|
|
#define TUSB_VERSION_MINOR 10
|
2021-06-03 01:13:22 +07:00
|
|
|
#define TUSB_VERSION_REVISION 1
|
2020-01-14 23:30:39 -05:00
|
|
|
#define TUSB_VERSION_STRING TU_STRING(TUSB_VERSION_MAJOR) "." TU_STRING(TUSB_VERSION_MINOR) "." TU_STRING(TUSB_VERSION_REVISION)
|
|
|
|
|
|
|
|
/** \defgroup group_mcu Supported MCU
|
|
|
|
* \ref CFG_TUSB_MCU must be defined to one of these
|
|
|
|
* @{ */
|
|
|
|
|
|
|
|
#define OPT_MCU_NONE 0
|
|
|
|
|
|
|
|
// LPC
|
|
|
|
#define OPT_MCU_LPC11UXX 1 ///< NXP LPC11Uxx
|
|
|
|
#define OPT_MCU_LPC13XX 2 ///< NXP LPC13xx
|
|
|
|
#define OPT_MCU_LPC15XX 3 ///< NXP LPC15xx
|
|
|
|
#define OPT_MCU_LPC175X_6X 4 ///< NXP LPC175x, LPC176x
|
|
|
|
#define OPT_MCU_LPC177X_8X 5 ///< NXP LPC177x, LPC178x
|
|
|
|
#define OPT_MCU_LPC18XX 6 ///< NXP LPC18xx
|
|
|
|
#define OPT_MCU_LPC40XX 7 ///< NXP LPC40xx
|
|
|
|
#define OPT_MCU_LPC43XX 8 ///< NXP LPC43xx
|
|
|
|
#define OPT_MCU_LPC51UXX 9 ///< NXP LPC51U6x
|
|
|
|
#define OPT_MCU_LPC54XXX 10 ///< NXP LPC54xxx
|
|
|
|
#define OPT_MCU_LPC55XX 11 ///< NXP LPC55xx
|
|
|
|
|
|
|
|
// NRF
|
|
|
|
#define OPT_MCU_NRF5X 100 ///< Nordic nRF5x series
|
|
|
|
|
|
|
|
// SAM
|
|
|
|
#define OPT_MCU_SAMD21 200 ///< MicroChip SAMD21
|
|
|
|
#define OPT_MCU_SAMD51 201 ///< MicroChip SAMD51
|
2020-08-22 18:46:19 +07:00
|
|
|
#define OPT_MCU_SAMG 202 ///< MicroChip SAMDG series
|
2021-05-26 20:29:18 +07:00
|
|
|
#define OPT_MCU_SAME5X 203 ///< MicroChip SAM E5x
|
|
|
|
#define OPT_MCU_SAMD11 204 ///< MicroChip SAMD11
|
2021-04-05 00:02:51 -04:00
|
|
|
#define OPT_MCU_SAML22 205 ///< MicroChip SAML22
|
2021-06-15 17:53:09 +02:00
|
|
|
#define OPT_MCU_SAMX7X 206 ///< MicroChip SAME70, S70, V70, V71 family
|
2021-06-11 22:50:00 +01:00
|
|
|
|
2020-01-14 23:30:39 -05:00
|
|
|
|
|
|
|
// STM32
|
|
|
|
#define OPT_MCU_STM32F0 300 ///< ST STM32F0
|
|
|
|
#define OPT_MCU_STM32F1 301 ///< ST STM32F1
|
|
|
|
#define OPT_MCU_STM32F2 302 ///< ST STM32F2
|
|
|
|
#define OPT_MCU_STM32F3 303 ///< ST STM32F3
|
|
|
|
#define OPT_MCU_STM32F4 304 ///< ST STM32F4
|
|
|
|
#define OPT_MCU_STM32F7 305 ///< ST STM32F7
|
|
|
|
#define OPT_MCU_STM32H7 306 ///< ST STM32H7
|
|
|
|
#define OPT_MCU_STM32L0 307 ///< ST STM32L0
|
|
|
|
#define OPT_MCU_STM32L1 308 ///< ST STM32L1
|
|
|
|
#define OPT_MCU_STM32L4 309 ///< ST STM32L4
|
|
|
|
|
2020-03-22 17:19:57 +07:00
|
|
|
// Sony
|
2020-01-14 23:30:39 -05:00
|
|
|
#define OPT_MCU_CXD56 400 ///< SONY CXD56
|
|
|
|
|
2020-03-22 17:19:57 +07:00
|
|
|
// TI MSP430
|
2020-04-22 19:18:03 +07:00
|
|
|
#define OPT_MCU_MSP430x5xx 500 ///< TI MSP430x5xx
|
2020-03-22 17:19:57 +07:00
|
|
|
|
2020-04-22 19:18:03 +07:00
|
|
|
// ValentyUSB eptri
|
2020-01-14 23:30:39 -05:00
|
|
|
#define OPT_MCU_VALENTYUSB_EPTRI 600 ///< Fomu eptri config
|
|
|
|
|
2020-04-22 19:18:03 +07:00
|
|
|
// NXP iMX RT
|
2020-01-14 23:30:39 -05:00
|
|
|
#define OPT_MCU_MIMXRT10XX 700 ///< NXP iMX RT10xx
|
|
|
|
|
2020-04-22 19:18:03 +07:00
|
|
|
// Nuvoton
|
2020-01-14 23:30:39 -05:00
|
|
|
#define OPT_MCU_NUC121 800
|
|
|
|
#define OPT_MCU_NUC126 801
|
2020-01-25 13:10:32 -06:00
|
|
|
#define OPT_MCU_NUC120 802
|
2020-02-07 20:11:00 -06:00
|
|
|
#define OPT_MCU_NUC505 803
|
2020-01-14 23:30:39 -05:00
|
|
|
|
2020-04-22 19:18:03 +07:00
|
|
|
// Espressif
|
2020-02-19 12:45:29 +01:00
|
|
|
#define OPT_MCU_ESP32S2 900 ///< Espressif ESP32-S2
|
2021-03-09 11:29:07 +01:00
|
|
|
#define OPT_MCU_ESP32S3 901 ///< Espressif ESP32-S3
|
2020-02-19 12:45:29 +01:00
|
|
|
|
2020-06-09 15:22:16 +02:00
|
|
|
// Dialog
|
|
|
|
#define OPT_MCU_DA1469X 1000 ///< Dialog Semiconductor DA1469x
|
|
|
|
|
2021-01-19 19:52:07 -06:00
|
|
|
// Raspberry Pi
|
|
|
|
#define OPT_MCU_RP2040 1100 ///< Raspberry Pi RP2040
|
|
|
|
|
2021-01-21 16:35:13 +07:00
|
|
|
// NXP Kinetis
|
|
|
|
#define OPT_MCU_MKL25ZXX 1200 ///< NXP MKL25Zxx
|
2020-11-27 00:49:25 +09:00
|
|
|
|
2021-03-04 23:00:48 +00:00
|
|
|
// Silabs
|
|
|
|
#define OPT_MCU_EFM32GG 1300 ///< Silabs EFM32GG
|
|
|
|
#define OPT_MCU_EFM32GG11 1301 ///< Silabs EFM32GG11
|
|
|
|
#define OPT_MCU_EFM32GG12 1302 ///< Silabs EFM32GG12
|
|
|
|
|
2021-03-24 00:53:55 +09:00
|
|
|
// Renesas RX
|
|
|
|
#define OPT_MCU_RX63X 1400 ///< Renesas RX63N/631
|
|
|
|
|
2021-06-07 18:51:44 +07:00
|
|
|
// Mind Motion
|
|
|
|
#define OPT_MCU_MM32F327X 1500 ///< Mind Motion MM32F327
|
|
|
|
|
2020-01-14 23:30:39 -05:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/** \defgroup group_supported_os Supported RTOS
|
|
|
|
* \ref CFG_TUSB_OS must be defined to one of these
|
|
|
|
* @{ */
|
2020-04-05 18:22:16 +07:00
|
|
|
#define OPT_OS_NONE 1 ///< No RTOS
|
|
|
|
#define OPT_OS_FREERTOS 2 ///< FreeRTOS
|
|
|
|
#define OPT_OS_MYNEWT 3 ///< Mynewt OS
|
|
|
|
#define OPT_OS_CUSTOM 4 ///< Custom OS is implemented by application
|
2021-01-19 19:52:07 -06:00
|
|
|
#define OPT_OS_PICO 5 ///< Raspberry Pi Pico SDK
|
2021-02-07 22:44:49 +08:00
|
|
|
#define OPT_OS_RTTHREAD 6 ///< RT-Thread
|
2020-01-14 23:30:39 -05:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
// Allow to use command line to change the config name/location
|
2020-09-26 05:40:24 +02:00
|
|
|
#ifdef CFG_TUSB_CONFIG_FILE
|
|
|
|
#include CFG_TUSB_CONFIG_FILE
|
|
|
|
#else
|
|
|
|
#include "tusb_config.h"
|
2020-01-14 23:30:39 -05:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/** \addtogroup group_configuration
|
|
|
|
* @{ */
|
|
|
|
|
2020-05-26 15:21:23 +07:00
|
|
|
|
2020-01-14 23:30:39 -05:00
|
|
|
//--------------------------------------------------------------------
|
2020-05-26 15:21:23 +07:00
|
|
|
// RootHub Mode Configuration
|
2020-06-14 18:28:45 +07:00
|
|
|
// CFG_TUSB_RHPORTx_MODE contains operation mode and speed for that port
|
2020-01-14 23:30:39 -05:00
|
|
|
//--------------------------------------------------------------------
|
2020-05-26 15:21:23 +07:00
|
|
|
|
|
|
|
// Lower 4-bit is operational mode
|
2020-01-14 23:30:39 -05:00
|
|
|
#define OPT_MODE_NONE 0x00 ///< Disabled
|
|
|
|
#define OPT_MODE_DEVICE 0x01 ///< Device Mode
|
|
|
|
#define OPT_MODE_HOST 0x02 ///< Host Mode
|
2020-05-26 15:21:23 +07:00
|
|
|
|
|
|
|
// Higher 4-bit is max operational speed (corresponding to tusb_speed_t)
|
|
|
|
#define OPT_MODE_FULL_SPEED 0x00 ///< Max Full Speed
|
|
|
|
#define OPT_MODE_LOW_SPEED 0x10 ///< Max Low Speed
|
|
|
|
#define OPT_MODE_HIGH_SPEED 0x20 ///< Max High Speed
|
|
|
|
|
2020-01-14 23:30:39 -05:00
|
|
|
|
|
|
|
#ifndef CFG_TUSB_RHPORT0_MODE
|
|
|
|
#define CFG_TUSB_RHPORT0_MODE OPT_MODE_NONE
|
|
|
|
#endif
|
|
|
|
|
2020-06-14 18:28:45 +07:00
|
|
|
|
2020-01-14 23:30:39 -05:00
|
|
|
#ifndef CFG_TUSB_RHPORT1_MODE
|
|
|
|
#define CFG_TUSB_RHPORT1_MODE OPT_MODE_NONE
|
|
|
|
#endif
|
|
|
|
|
2021-01-08 16:25:30 +07:00
|
|
|
#if (((CFG_TUSB_RHPORT0_MODE) & OPT_MODE_HOST ) && ((CFG_TUSB_RHPORT1_MODE) & OPT_MODE_HOST )) || \
|
|
|
|
(((CFG_TUSB_RHPORT0_MODE) & OPT_MODE_DEVICE) && ((CFG_TUSB_RHPORT1_MODE) & OPT_MODE_DEVICE))
|
2020-05-26 15:21:23 +07:00
|
|
|
#error "TinyUSB currently does not support same modes on more than 1 roothub port"
|
2020-01-14 23:30:39 -05:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Which roothub port is configured as host
|
2021-01-08 16:25:30 +07:00
|
|
|
#define TUH_OPT_RHPORT ( ((CFG_TUSB_RHPORT0_MODE) & OPT_MODE_HOST) ? 0 : (((CFG_TUSB_RHPORT1_MODE) & OPT_MODE_HOST) ? 1 : -1) )
|
2020-01-14 23:30:39 -05:00
|
|
|
#define TUSB_OPT_HOST_ENABLED ( TUH_OPT_RHPORT >= 0 )
|
|
|
|
|
|
|
|
// Which roothub port is configured as device
|
2021-01-08 16:25:30 +07:00
|
|
|
#define TUD_OPT_RHPORT ( ((CFG_TUSB_RHPORT0_MODE) & OPT_MODE_DEVICE) ? 0 : (((CFG_TUSB_RHPORT1_MODE) & OPT_MODE_DEVICE) ? 1 : -1) )
|
2020-01-14 23:30:39 -05:00
|
|
|
|
|
|
|
#if TUD_OPT_RHPORT == 0
|
2021-01-08 16:25:30 +07:00
|
|
|
#define TUD_OPT_HIGH_SPEED ( (CFG_TUSB_RHPORT0_MODE) & OPT_MODE_HIGH_SPEED )
|
2020-01-14 23:30:39 -05:00
|
|
|
#else
|
2021-01-08 16:25:30 +07:00
|
|
|
#define TUD_OPT_HIGH_SPEED ( (CFG_TUSB_RHPORT1_MODE) & OPT_MODE_HIGH_SPEED )
|
2020-01-14 23:30:39 -05:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#define TUSB_OPT_DEVICE_ENABLED ( TUD_OPT_RHPORT >= 0 )
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------+
|
|
|
|
// COMMON OPTIONS
|
|
|
|
//--------------------------------------------------------------------+
|
|
|
|
|
|
|
|
// Debug enable to print out error message
|
|
|
|
#ifndef CFG_TUSB_DEBUG
|
2020-10-03 09:46:22 +02:00
|
|
|
#define CFG_TUSB_DEBUG 0
|
2020-01-14 23:30:39 -05:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// place data in accessible RAM for usb controller
|
|
|
|
#ifndef CFG_TUSB_MEM_SECTION
|
2020-05-26 15:21:23 +07:00
|
|
|
#define CFG_TUSB_MEM_SECTION
|
2020-01-14 23:30:39 -05:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CFG_TUSB_MEM_ALIGN
|
2020-05-26 15:21:23 +07:00
|
|
|
#define CFG_TUSB_MEM_ALIGN TU_ATTR_ALIGNED(4)
|
2020-01-14 23:30:39 -05:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CFG_TUSB_OS
|
2020-05-26 15:21:23 +07:00
|
|
|
#define CFG_TUSB_OS OPT_OS_NONE
|
2020-01-14 23:30:39 -05:00
|
|
|
#endif
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
// DEVICE OPTIONS
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
|
|
|
|
#ifndef CFG_TUD_ENDPOINT0_SIZE
|
2020-05-26 15:21:23 +07:00
|
|
|
#define CFG_TUD_ENDPOINT0_SIZE 64
|
2020-01-14 23:30:39 -05:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CFG_TUD_CDC
|
|
|
|
#define CFG_TUD_CDC 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CFG_TUD_MSC
|
|
|
|
#define CFG_TUD_MSC 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CFG_TUD_HID
|
|
|
|
#define CFG_TUD_HID 0
|
|
|
|
#endif
|
|
|
|
|
2020-07-17 08:40:10 +02:00
|
|
|
#ifndef CFG_TUD_AUDIO
|
|
|
|
#define CFG_TUD_AUDIO 0
|
|
|
|
#endif
|
|
|
|
|
2020-01-14 23:30:39 -05:00
|
|
|
#ifndef CFG_TUD_MIDI
|
|
|
|
#define CFG_TUD_MIDI 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CFG_TUD_VENDOR
|
|
|
|
#define CFG_TUD_VENDOR 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CFG_TUD_USBTMC
|
|
|
|
#define CFG_TUD_USBTMC 0
|
|
|
|
#endif
|
|
|
|
|
2021-02-11 12:05:22 +07:00
|
|
|
#ifndef CFG_TUD_DFU_RUNTIME
|
2021-04-05 16:32:58 -04:00
|
|
|
#define CFG_TUD_DFU_RUNTIME 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef CFG_TUD_DFU_MODE
|
|
|
|
#define CFG_TUD_DFU_MODE 0
|
2020-01-14 23:30:39 -05:00
|
|
|
#endif
|
|
|
|
|
2021-03-26 15:30:43 -04:00
|
|
|
#ifndef CFG_TUD_DFU_TRANSFER_BUFFER_SIZE
|
|
|
|
#define CFG_TUD_DFU_TRANSFER_BUFFER_SIZE 64
|
2020-01-14 23:30:39 -05:00
|
|
|
#endif
|
|
|
|
|
2020-03-02 21:15:01 -06:00
|
|
|
#ifndef CFG_TUD_NET
|
|
|
|
#define CFG_TUD_NET 0
|
|
|
|
#endif
|
2020-01-14 23:30:39 -05:00
|
|
|
|
2020-05-13 17:04:10 +02:00
|
|
|
#ifndef CFG_TUD_BTH
|
|
|
|
#define CFG_TUD_BTH 0
|
|
|
|
#endif
|
|
|
|
|
2020-01-14 23:30:39 -05:00
|
|
|
//--------------------------------------------------------------------
|
|
|
|
// HOST OPTIONS
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
#if TUSB_OPT_HOST_ENABLED
|
|
|
|
#ifndef CFG_TUSB_HOST_DEVICE_MAX
|
|
|
|
#define CFG_TUSB_HOST_DEVICE_MAX 1
|
|
|
|
#warning CFG_TUSB_HOST_DEVICE_MAX is not defined, default value is 1
|
|
|
|
#endif
|
|
|
|
|
|
|
|
//------------- HUB CLASS -------------//
|
|
|
|
#if CFG_TUH_HUB && (CFG_TUSB_HOST_DEVICE_MAX == 1)
|
|
|
|
#error there is no benefit enable hub with max device is 1. Please disable hub or increase CFG_TUSB_HOST_DEVICE_MAX
|
|
|
|
#endif
|
|
|
|
|
2021-05-12 19:27:05 +07:00
|
|
|
#ifndef CFG_TUH_ENUMERATION_BUFSZIE
|
|
|
|
#define CFG_TUH_ENUMERATION_BUFSZIE 256
|
2020-01-14 23:30:39 -05:00
|
|
|
#endif
|
|
|
|
|
|
|
|
//------------- CLASS -------------//
|
|
|
|
#endif // TUSB_OPT_HOST_ENABLED
|
|
|
|
|
2021-04-06 19:32:01 +07:00
|
|
|
//--------------------------------------------------------------------+
|
|
|
|
// Port Options
|
|
|
|
// TUP for TinyUSB Port (can be renamed)
|
|
|
|
//--------------------------------------------------------------------+
|
|
|
|
|
|
|
|
// TUP_ARCH_STRICT_ALIGN if arch cannot access unaligned memory
|
|
|
|
|
2021-04-26 17:42:49 +07:00
|
|
|
|
2021-04-06 19:32:01 +07:00
|
|
|
// ARMv7+ (M3-M7, M23-M33) can access unaligned memory
|
|
|
|
#if (defined(__ARM_ARCH) && (__ARM_ARCH >= 7))
|
|
|
|
#define TUP_ARCH_STRICT_ALIGN 0
|
|
|
|
#else
|
|
|
|
#define TUP_ARCH_STRICT_ALIGN 1
|
|
|
|
#endif
|
2020-01-14 23:30:39 -05:00
|
|
|
|
2021-04-26 17:42:49 +07:00
|
|
|
// TUP_MCU_STRICT_ALIGN will overwrite TUP_ARCH_STRICT_ALIGN.
|
|
|
|
// In case TUP_MCU_STRICT_ALIGN = 1 and TUP_ARCH_STRICT_ALIGN =0, we will not reply on compiler
|
|
|
|
// to generate unaligned access code.
|
|
|
|
// LPC_IP3511 Highspeed cannot access unaligned memory on USB_RAM
|
|
|
|
#if TUD_OPT_HIGH_SPEED && (CFG_TUSB_MCU == OPT_MCU_LPC54XXX || CFG_TUSB_MCU == OPT_MCU_LPC55XX)
|
|
|
|
#define TUP_MCU_STRICT_ALIGN 1
|
|
|
|
#else
|
|
|
|
#define TUP_MCU_STRICT_ALIGN 0
|
|
|
|
#endif
|
|
|
|
|
2020-01-14 23:30:39 -05:00
|
|
|
//------------------------------------------------------------------
|
|
|
|
// Configuration Validation
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
#if CFG_TUD_ENDPOINT0_SIZE > 64
|
|
|
|
#error Control Endpoint Max Packet Size cannot be larger than 64
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* _TUSB_OPTION_H_ */
|
|
|
|
|
|
|
|
/** @} */
|