diff options
Diffstat (limited to 'os/hal')
| -rw-r--r-- | os/hal/platforms/STM32/OTGv1/usb_lld.c | 9 | ||||
| -rw-r--r-- | os/hal/platforms/STM32/OTGv1/usb_lld.h | 5 | ||||
| -rw-r--r-- | os/hal/platforms/STM32F1xx/stm32_isr.h | 8 | ||||
| -rw-r--r-- | os/hal/platforms/STM32F2xx/stm32_isr.h | 10 | ||||
| -rw-r--r-- | os/hal/platforms/STM32F4xx/stm32_isr.h | 10 | 
5 files changed, 39 insertions, 3 deletions
| diff --git a/os/hal/platforms/STM32/OTGv1/usb_lld.c b/os/hal/platforms/STM32/OTGv1/usb_lld.c index 68f4714fb..b4238a8a0 100644 --- a/os/hal/platforms/STM32/OTGv1/usb_lld.c +++ b/os/hal/platforms/STM32/OTGv1/usb_lld.c @@ -532,12 +532,15 @@ static void otg_epout_handler(USBDriver *usbp, usbep_t ep) {  /*===========================================================================*/
  #if STM32_USB_USE_OTG1 || defined(__DOXYGEN__)
 +#if !defined(STM32_OTG1_HANDLER)
 +#error "STM32_OTG1_HANDLER not defined"
 +#endif
  /**
   * @brief   OTG1 interrupt handler.
   *
   * @isr
   */
 -CH_IRQ_HANDLER(OTG_FS_IRQHandler) {
 +CH_IRQ_HANDLER(STM32_OTG1_HANDLER) {
    USBDriver *usbp = &USBD1;
    uint32_t sts;
 @@ -631,7 +634,7 @@ void usb_lld_start(USBDriver *usbp) {        rccResetOTG_FS();
        /* Enables IRQ vector.*/
 -      nvicEnableVector(OTG_FS_IRQn,
 +      nvicEnableVector(STM32_OTG1_NUMBER,
                         CORTEX_PRIORITY_MASK(STM32_USB_OTG1_IRQ_PRIORITY));
      }
  #endif
 @@ -686,7 +689,7 @@ void usb_lld_stop(USBDriver *usbp) {    if (usbp->state == USB_STOP) {
  #if STM32_USB_USE_USB1
      if (&USBD1 == usbp) {
 -      nvicDisableVector(OTG_FS_IRQn);
 +      nvicDisableVector(STM32_OTG1_NUMBER);
        rccDisableOTG1(FALSE);
      }
  #endif
 diff --git a/os/hal/platforms/STM32/OTGv1/usb_lld.h b/os/hal/platforms/STM32/OTGv1/usb_lld.h index 23e41d6e8..f44f1591e 100644 --- a/os/hal/platforms/STM32/OTGv1/usb_lld.h +++ b/os/hal/platforms/STM32/OTGv1/usb_lld.h @@ -87,6 +87,11 @@  #error "USB driver activated but no USB peripheral assigned"
  #endif
 +#if STM32_USB_USE_OTG1 &&                                                \
 +    !CORTEX_IS_VALID_KERNEL_PRIORITY(STM32_USB_OTG1_IRQ_PRIORITY)
 +#error "Invalid IRQ priority assigned to OTG1"
 +#endif
 +
  #if (STM32_USB_OTG1_RX_FIFO_SIZE & 3) != 0
  #error "RX FIFO size must be a multiple of 4"
  #endif
 diff --git a/os/hal/platforms/STM32F1xx/stm32_isr.h b/os/hal/platforms/STM32F1xx/stm32_isr.h index e79efd155..c8c5d7fde 100644 --- a/os/hal/platforms/STM32F1xx/stm32_isr.h +++ b/os/hal/platforms/STM32F1xx/stm32_isr.h @@ -59,9 +59,17 @@  #define STM32_CAN2_SCE_NUMBER       CAN2_SCE_IRQn
  /*
 + * OTG units.
 + */
 +#define STM32_OTG1_HANDLER          OTG_FS_IRQHandler
 +
 +#define STM32_OTG1_NUMBER           OTG_FS_IRQn
 +
 +/*
   * SDIO unit.
   */
  #define STM32_SDIO_HANDLER          SDIO_IRQHandler
 +
  #define STM32_SDIO_NUMBER           SDIO_IRQn
  /*
 diff --git a/os/hal/platforms/STM32F2xx/stm32_isr.h b/os/hal/platforms/STM32F2xx/stm32_isr.h index 18ead99e1..dc862f4de 100644 --- a/os/hal/platforms/STM32F2xx/stm32_isr.h +++ b/os/hal/platforms/STM32F2xx/stm32_isr.h @@ -59,9 +59,19 @@  #define STM32_CAN2_SCE_NUMBER       CAN2_SCE_IRQn
  /*
 + * OTG units.
 + */
 +#define STM32_OTG1_HANDLER          OTG_FS_IRQHandler
 +#define STM32_OTG2_HANDLER          OTG_HS_IRQHandler
 +
 +#define STM32_OTG1_NUMBER           OTG_FS_IRQn
 +#define STM32_OTG2_NUMBER           OTG_HS_IRQn
 +
 +/*
   * SDIO unit.
   */
  #define STM32_SDIO_HANDLER          SDIO_IRQHandler
 +
  #define STM32_SDIO_NUMBER           SDIO_IRQn
  /*
 diff --git a/os/hal/platforms/STM32F4xx/stm32_isr.h b/os/hal/platforms/STM32F4xx/stm32_isr.h index 23f9fc19d..383660551 100644 --- a/os/hal/platforms/STM32F4xx/stm32_isr.h +++ b/os/hal/platforms/STM32F4xx/stm32_isr.h @@ -59,9 +59,19 @@  #define STM32_CAN2_SCE_NUMBER       CAN2_SCE_IRQn
  /*
 + * OTG units.
 + */
 +#define STM32_OTG1_HANDLER          OTG_FS_IRQHandler
 +#define STM32_OTG2_HANDLER          OTG_HS_IRQHandler
 +
 +#define STM32_OTG1_NUMBER           OTG_FS_IRQn
 +#define STM32_OTG2_NUMBER           OTG_HS_IRQn
 +
 +/*
   * SDIO unit.
   */
  #define STM32_SDIO_HANDLER          SDIO_IRQHandler
 +
  #define STM32_SDIO_NUMBER           SDIO_IRQn
  /*
 | 
