mirror of
https://github.com/hathach/tinyusb.git
synced 2025-01-17 05:32:55 +08:00
STM32L151 portable driver adaptations
This commit is contained in:
parent
88f5c04fe0
commit
ea72d64992
@ -113,7 +113,8 @@
|
|||||||
(CFG_TUSB_MCU == OPT_MCU_STM32F0 ) || \
|
(CFG_TUSB_MCU == OPT_MCU_STM32F0 ) || \
|
||||||
(CFG_TUSB_MCU == OPT_MCU_STM32F1 && defined(STM32F1_FSDEV)) || \
|
(CFG_TUSB_MCU == OPT_MCU_STM32F1 && defined(STM32F1_FSDEV)) || \
|
||||||
(CFG_TUSB_MCU == OPT_MCU_STM32F3 ) || \
|
(CFG_TUSB_MCU == OPT_MCU_STM32F3 ) || \
|
||||||
(CFG_TUSB_MCU == OPT_MCU_STM32L0 ) \
|
(CFG_TUSB_MCU == OPT_MCU_STM32L0 ) || \
|
||||||
|
(CFG_TUSB_MCU == OPT_MCU_STM32L1 ) \
|
||||||
)
|
)
|
||||||
|
|
||||||
// In order to reduce the dependance on HAL, we undefine this.
|
// In order to reduce the dependance on HAL, we undefine this.
|
||||||
@ -273,6 +274,20 @@ void dcd_connect(uint8_t rhport)
|
|||||||
USB->BCDR |= USB_BCDR_DPPU;
|
USB->BCDR |= USB_BCDR_DPPU;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#elif defined(SYSCFG_PMC_USB_PU) // works e.g. on STM32L151
|
||||||
|
// Disable internal D+ PU
|
||||||
|
void dcd_disconnect(uint8_t rhport)
|
||||||
|
{
|
||||||
|
(void) rhport;
|
||||||
|
SYSCFG->PMC &= ~(SYSCFG_PMC_USB_PU);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Enable internal D+ PU
|
||||||
|
void dcd_connect(uint8_t rhport)
|
||||||
|
{
|
||||||
|
(void) rhport;
|
||||||
|
SYSCFG->PMC |= SYSCFG_PMC_USB_PU;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Enable device interrupt
|
// Enable device interrupt
|
||||||
@ -284,6 +299,8 @@ void dcd_int_enable (uint8_t rhport)
|
|||||||
__ISB();
|
__ISB();
|
||||||
#if CFG_TUSB_MCU == OPT_MCU_STM32F0 || CFG_TUSB_MCU == OPT_MCU_STM32L0
|
#if CFG_TUSB_MCU == OPT_MCU_STM32F0 || CFG_TUSB_MCU == OPT_MCU_STM32L0
|
||||||
NVIC_EnableIRQ(USB_IRQn);
|
NVIC_EnableIRQ(USB_IRQn);
|
||||||
|
#elif CFG_TUSB_MCU == OPT_MCU_STM32L1
|
||||||
|
NVIC_EnableIRQ(USB_LP_IRQn);
|
||||||
#elif CFG_TUSB_MCU == OPT_MCU_STM32F3
|
#elif CFG_TUSB_MCU == OPT_MCU_STM32F3
|
||||||
// Some STM32F302/F303 devices allow to remap the USB interrupt vectors from
|
// Some STM32F302/F303 devices allow to remap the USB interrupt vectors from
|
||||||
// shared USB/CAN IRQs to separate CAN and USB IRQs.
|
// shared USB/CAN IRQs to separate CAN and USB IRQs.
|
||||||
@ -318,6 +335,8 @@ void dcd_int_disable(uint8_t rhport)
|
|||||||
|
|
||||||
#if CFG_TUSB_MCU == OPT_MCU_STM32F0 || CFG_TUSB_MCU == OPT_MCU_STM32L0
|
#if CFG_TUSB_MCU == OPT_MCU_STM32F0 || CFG_TUSB_MCU == OPT_MCU_STM32L0
|
||||||
NVIC_DisableIRQ(USB_IRQn);
|
NVIC_DisableIRQ(USB_IRQn);
|
||||||
|
#elif CFG_TUSB_MCU == OPT_MCU_STM32L1
|
||||||
|
NVIC_DisableIRQ(USB_LP_IRQn);
|
||||||
#elif CFG_TUSB_MCU == OPT_MCU_STM32F3
|
#elif CFG_TUSB_MCU == OPT_MCU_STM32F3
|
||||||
// Some STM32F302/F303 devices allow to remap the USB interrupt vectors from
|
// Some STM32F302/F303 devices allow to remap the USB interrupt vectors from
|
||||||
// shared USB/CAN IRQs to separate CAN and USB IRQs.
|
// shared USB/CAN IRQs to separate CAN and USB IRQs.
|
||||||
|
@ -83,6 +83,10 @@
|
|||||||
#include "stm32l0xx.h"
|
#include "stm32l0xx.h"
|
||||||
#define PMA_LENGTH (1024u)
|
#define PMA_LENGTH (1024u)
|
||||||
|
|
||||||
|
#elif CFG_TUSB_MCU == OPT_MCU_STM32L1
|
||||||
|
#include "stm32l1xx.h"
|
||||||
|
#define PMA_LENGTH (512u)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
#error You are using an untested or unimplemented STM32 variant. Please update the driver.
|
#error You are using an untested or unimplemented STM32 variant. Please update the driver.
|
||||||
// This includes L1x0, L1x1, L1x2, L4x2 and L4x3, G1x1, G1x3, and G1x4
|
// This includes L1x0, L1x1, L1x2, L4x2 and L4x3, G1x1, G1x3, and G1x4
|
||||||
|
Loading…
x
Reference in New Issue
Block a user