You've already forked dspico-usb-examples
mirror of
https://github.com/LNH-team/dspico-usb-examples.git
synced 2026-01-09 16:27:56 -08:00
84 lines
2.3 KiB
C
84 lines
2.3 KiB
C
#pragma once
|
|
#include "usb_descriptors.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
//--------------------------------------------------------------------+
|
|
// Board Specific Configuration
|
|
//--------------------------------------------------------------------+
|
|
|
|
// RHPort number used for device can be defined by board.mk, default to port 0
|
|
#ifndef BOARD_TUD_RHPORT
|
|
#define BOARD_TUD_RHPORT 0
|
|
#endif
|
|
|
|
// RHPort max operational speed can defined by board.mk
|
|
#ifndef BOARD_TUD_MAX_SPEED
|
|
#define BOARD_TUD_MAX_SPEED OPT_MODE_DEFAULT_SPEED
|
|
#endif
|
|
|
|
//--------------------------------------------------------------------
|
|
// COMMON CONFIGURATION
|
|
//--------------------------------------------------------------------
|
|
|
|
// defined by compiler flags for flexibility
|
|
#ifndef CFG_TUSB_MCU
|
|
#define CFG_TUSB_MCU OPT_MCU_DSPICO
|
|
#endif
|
|
|
|
#define TUP_DCD_ENDPOINT_MAX 16
|
|
|
|
#ifndef CFG_TUSB_OS
|
|
#define CFG_TUSB_OS OPT_OS_CUSTOM
|
|
#endif
|
|
|
|
#ifndef CFG_TUSB_DEBUG
|
|
#define CFG_TUSB_DEBUG 0
|
|
#endif
|
|
|
|
// Enable Device stack
|
|
#define CFG_TUD_ENABLED 1
|
|
|
|
// Default is max speed that hardware controller could support with on-chip PHY
|
|
#define CFG_TUD_MAX_SPEED BOARD_TUD_MAX_SPEED
|
|
|
|
/* 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 __attribute__ ((aligned(4)))
|
|
#endif
|
|
|
|
//--------------------------------------------------------------------
|
|
// DEVICE CONFIGURATION
|
|
//--------------------------------------------------------------------
|
|
|
|
#ifndef CFG_TUD_ENDPOINT0_SIZE
|
|
#define CFG_TUD_ENDPOINT0_SIZE 64
|
|
#endif
|
|
|
|
//------------- CLASS -------------//
|
|
#define CFG_TUD_VIDEO 1
|
|
|
|
// The number of video streaming interfaces
|
|
#define CFG_TUD_VIDEO_STREAMING 1
|
|
|
|
// video streaming endpoint buffer size
|
|
#define CFG_TUD_VIDEO_STREAMING_EP_BUFSIZE 512
|
|
|
|
// use bulk endpoint for streaming interface
|
|
#define CFG_TUD_VIDEO_STREAMING_BULK 0
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif |