@@ -32,13 +32,13 @@ The stack supports the following MCUs:
|
|||||||
|
|
||||||
- **MicroChip:** SAMD21, SAMD51 (device only)
|
- **MicroChip:** SAMD21, SAMD51 (device only)
|
||||||
- **Nordic:** nRF52840, nRF52833
|
- **Nordic:** nRF52840, nRF52833
|
||||||
|
- **Nuvoton:** NUC120, NUC121/NUC125, NUC126, NUC505
|
||||||
- **NXP:**
|
- **NXP:**
|
||||||
- LPC Series: 11Uxx, 13xx, 175x_6x, 177x_8x, 18xx, 40xx, 43xx, 51Uxx, 54xxx, 55xx
|
- LPC Series: 11Uxx, 13xx, 175x_6x, 177x_8x, 18xx, 40xx, 43xx, 51Uxx, 54xxx, 55xx
|
||||||
- iMX RT Series: RT1011, RT1015, RT1021, RT1052, RT1062, RT1064
|
- iMX RT Series: RT1011, RT1015, RT1021, RT1052, RT1062, RT1064
|
||||||
- **Sony:** CXD56
|
- **Sony:** CXD56
|
||||||
- **ST:** STM32 series: L0, F0, F1, F2, F3, F4, F7, H7 (device only)
|
- **ST:** STM32 series: L0, F0, F1, F2, F3, F4, F7, H7 (device only)
|
||||||
- **[ValentyUSB](https://github.com/im-tomu/valentyusb)** eptri
|
- **[ValentyUSB](https://github.com/im-tomu/valentyusb)** eptri
|
||||||
- **Nuvoton:** NUC120, NUC121/NUC125, NUC126, NUC505
|
|
||||||
|
|
||||||
[Here is the list of supported Boards](docs/boards.md) that can be used with provided examples.
|
[Here is the list of supported Boards](docs/boards.md) that can be used with provided examples.
|
||||||
|
|
||||||
|
@@ -33,12 +33,6 @@
|
|||||||
nomenclature of EPA through EPL.
|
nomenclature of EPA through EPL.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
|
||||||
Note on OPT_MCU_NUC505_USB_DMA: the author suggests against using this option.
|
|
||||||
The DMA functionality of the USBD peripheral does not appear to succeed with
|
|
||||||
transfer lengths that are longer (> 64 bytes) and are not a multiple of 4.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "tusb_option.h"
|
#include "tusb_option.h"
|
||||||
|
|
||||||
#if TUSB_OPT_DEVICE_ENABLED && (CFG_TUSB_MCU == OPT_MCU_NUC505)
|
#if TUSB_OPT_DEVICE_ENABLED && (CFG_TUSB_MCU == OPT_MCU_NUC505)
|
||||||
@@ -46,6 +40,14 @@
|
|||||||
#include "device/dcd.h"
|
#include "device/dcd.h"
|
||||||
#include "NUC505Series.h"
|
#include "NUC505Series.h"
|
||||||
|
|
||||||
|
/*
|
||||||
|
The DMA functionality of the USBD peripheral does not appear to succeed with
|
||||||
|
transfer lengths that are longer (> 64 bytes) and are not a multiple of 4.
|
||||||
|
Disable for now, we could implement a walk-around if non-DMA slow the MCU down
|
||||||
|
too much.
|
||||||
|
*/
|
||||||
|
#define USE_DMA 0
|
||||||
|
|
||||||
/* rather important info unfortunately not provided by device include files */
|
/* rather important info unfortunately not provided by device include files */
|
||||||
#define USBD_BUF_SIZE 2048 /* how much USB buffer space there is */
|
#define USBD_BUF_SIZE 2048 /* how much USB buffer space there is */
|
||||||
#define USBD_MAX_DMA_LEN 0x1000 /* max bytes that can be DMAed at one time */
|
#define USBD_MAX_DMA_LEN 0x1000 /* max bytes that can be DMAed at one time */
|
||||||
@@ -217,7 +219,7 @@ static void bus_reset(void)
|
|||||||
current_dma_xfer = NULL;
|
current_dma_xfer = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef OPT_MCU_NUC505_USB_DMA
|
#if USE_DMA
|
||||||
/* this must only be called by the ISR; it does its best to share the single DMA engine across all user EPs (IN and OUT) */
|
/* this must only be called by the ISR; it does its best to share the single DMA engine across all user EPs (IN and OUT) */
|
||||||
static void service_dma(void)
|
static void service_dma(void)
|
||||||
{
|
{
|
||||||
@@ -473,7 +475,7 @@ void USBD_IRQHandler(void)
|
|||||||
|
|
||||||
if (bus_state & USBD_BUSINTSTS_DMADONEIF_Msk)
|
if (bus_state & USBD_BUSINTSTS_DMADONEIF_Msk)
|
||||||
{
|
{
|
||||||
#ifdef OPT_MCU_NUC505_USB_DMA
|
#if USE_DMA
|
||||||
if (current_dma_xfer)
|
if (current_dma_xfer)
|
||||||
{
|
{
|
||||||
current_dma_xfer->dma_requested = false;
|
current_dma_xfer->dma_requested = false;
|
||||||
@@ -607,7 +609,7 @@ void USBD_IRQHandler(void)
|
|||||||
|
|
||||||
if (out_ep)
|
if (out_ep)
|
||||||
{
|
{
|
||||||
#ifdef OPT_MCU_NUC505_USB_DMA
|
#if USE_DMA
|
||||||
xfer->dma_requested = true;
|
xfer->dma_requested = true;
|
||||||
service_dma();
|
service_dma();
|
||||||
#else
|
#else
|
||||||
|
Reference in New Issue
Block a user