mirror of
https://github.com/hathach/tinyusb.git
synced 2025-02-21 03:40:52 +00:00
ST FSDEV: No need to always reset the interrupt priority, also add some synchronization primitives after disabling interrupts.
This commit is contained in:
parent
a33a854793
commit
89ffe78f84
@ -258,12 +258,8 @@ void dcd_int_enable (uint8_t rhport)
|
|||||||
{
|
{
|
||||||
(void)rhport;
|
(void)rhport;
|
||||||
#if defined(STM32F0)
|
#if defined(STM32F0)
|
||||||
NVIC_SetPriority(USB_IRQn, 0);
|
|
||||||
NVIC_EnableIRQ(USB_IRQn);
|
NVIC_EnableIRQ(USB_IRQn);
|
||||||
#elif defined(STM32F3)
|
#elif defined(STM32F3)
|
||||||
NVIC_SetPriority(USB_HP_CAN_TX_IRQn, 0);
|
|
||||||
NVIC_SetPriority(USB_LP_CAN_RX0_IRQn, 0);
|
|
||||||
NVIC_SetPriority(USBWakeUp_IRQn, 0);
|
|
||||||
NVIC_EnableIRQ(USB_HP_CAN_TX_IRQn);
|
NVIC_EnableIRQ(USB_HP_CAN_TX_IRQn);
|
||||||
NVIC_EnableIRQ(USB_LP_CAN_RX0_IRQn);
|
NVIC_EnableIRQ(USB_LP_CAN_RX0_IRQn);
|
||||||
NVIC_EnableIRQ(USBWakeUp_IRQn);
|
NVIC_EnableIRQ(USBWakeUp_IRQn);
|
||||||
@ -283,6 +279,10 @@ void dcd_int_disable(uint8_t rhport)
|
|||||||
#else
|
#else
|
||||||
#error Unknown arch in USB driver
|
#error Unknown arch in USB driver
|
||||||
#endif
|
#endif
|
||||||
|
// I'm not convinced that memory synchronization is completely necessary, but
|
||||||
|
// it isn't a bad idea.
|
||||||
|
__DSB();
|
||||||
|
__ISB();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Receive Set Address request, mcu port must also include status IN response
|
// Receive Set Address request, mcu port must also include status IN response
|
||||||
|
Loading…
x
Reference in New Issue
Block a user