| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- /*
- * The MIT License (MIT)
- *
- * Copyright (c) 2019 Ha Thach (tinyusb.org),
- * Additions Copyright (c) 2020, Espressif Systems (Shanghai) PTE LTD
- *
- * 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.
- *
- */
- #pragma once
- #include "tusb_option.h"
- #include "sdkconfig.h"
- #ifdef __cplusplus
- extern "C" {
- #endif
- /* */
- /* COMMON CONFIGURATION */
- /* */
- #define CFG_TUSB_RHPORT0_MODE OPT_MODE_DEVICE
- #define CFG_TUSB_OS OPT_OS_FREERTOS
- /* USB DMA on some MCUs can only access a specific SRAM region with restriction on alignment.
- * Tinyusb use follows macros to declare transferring memory so that they can be put
- * into those specific section.
- * e.g
- * - CFG_TUSB_MEM SECTION : __attribute__ (( section(".usb_ram") ))
- * - CFG_TUSB_MEM_ALIGN : __attribute__ ((aligned(4)))
- */
- #ifndef CFG_TUSB_MEM_SECTION
- # define CFG_TUSB_MEM_SECTION
- #endif
- #ifndef CFG_TUSB_MEM_ALIGN
- # define CFG_TUSB_MEM_ALIGN TU_ATTR_ALIGNED(4)
- #endif
- /* */
- /* DRIVER CONFIGURATION */
- /* */
- #define CFG_TUD_MAINTASK_SIZE 4096
- #define CFG_TUD_ENDOINT0_SIZE 64
- // CDC FIFO size of TX and RX
- #define CFG_TUD_CDC_RX_BUFSIZE CONFIG_USB_CDC_RX_BUFSIZE
- #define CFG_TUD_CDC_TX_BUFSIZE CONFIG_USB_CDC_TX_BUFSIZE
- // MSC Buffer size of Device Mass storage:
- #define CFG_TUD_MSC_BUFSIZE CONFIG_USB_MSC_BUFSIZE
- // HID buffer size Should be sufficient to hold ID (if any) + Data
- #define CFG_TUD_HID_BUFSIZE CONFIG_USB_HID_BUFSIZE
- #define CFG_TUD_CDC CONFIG_USB_CDC_ENABLED
- #define CFG_TUD_MSC CONFIG_USB_MSC_ENABLED
- #define CFG_TUD_HID CONFIG_USB_HID_ENABLED
- #define CFG_TUD_MIDI CONFIG_USB_MIDI_ENABLED
- #define CFG_TUD_CUSTOM_CLASS CONFIG_USB_CUSTOM_CLASS_ENABLED
- /* */
- /* KCONFIG */
- /* */
- #ifndef CONFIG_USB_CDC_ENABLED
- # define CONFIG_USB_CDC_ENABLED 0
- #endif
- #ifndef CONFIG_USB_MSC_ENABLED
- # define CONFIG_USB_MSC_ENABLED 0
- #endif
- #ifndef CONFIG_USB_HID_ENABLED
- # define CONFIG_USB_HID_ENABLED 0
- #endif
- #ifndef CONFIG_USB_MIDI_ENABLED
- # define CONFIG_USB_MIDI_ENABLED 0
- #endif
- #ifndef CONFIG_USB_CUSTOM_CLASS_ENABLED
- # define CONFIG_USB_CUSTOM_CLASS_ENABLED 0
- #endif
- #ifdef __cplusplus
- }
- #endif
|