diff options
50 files changed, 1435 insertions, 8 deletions
| diff --git a/demos/ARMCM4-STM32F303-DISCOVERY/mcuconf.h b/demos/ARMCM4-STM32F303-DISCOVERY/mcuconf.h index 2a721597c..6eb859b32 100644 --- a/demos/ARMCM4-STM32F303-DISCOVERY/mcuconf.h +++ b/demos/ARMCM4-STM32F303-DISCOVERY/mcuconf.h @@ -110,11 +110,15 @@  #define STM32_GPT_USE_TIM2                  FALSE
  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
  /*
 diff --git a/demos/ARMCM4-STM32F373-STM32373C_EVAL/mcuconf.h b/demos/ARMCM4-STM32F373-STM32373C_EVAL/mcuconf.h index 12fc6c5e6..f04aeaf7b 100644 --- a/demos/ARMCM4-STM32F373-STM32373C_EVAL/mcuconf.h +++ b/demos/ARMCM4-STM32F373-STM32373C_EVAL/mcuconf.h @@ -60,6 +60,25 @@  #define STM32_USBPRE                        STM32_USBPRE_DIV1P5
  /*
 + * ADC driver system settings.
 + */
 +#define STM32_ADC_USE_ADC1                  FALSE
 +#define STM32_ADC_USE_SDADC1                FALSE
 +#define STM32_ADC_USE_SDADC2                FALSE
 +#define STM32_ADC_USE_SDADC3                FALSE
 +#define STM32_ADC_ADC1_DMA_PRIORITY         2
 +#define STM32_ADC_SDADC1_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC2_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC3_DMA_PRIORITY       2
 +#define STM32_ADC_IRQ_PRIORITY              5
 +#define STM32_ADC_SDADC1_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC2_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC3_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC1_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC2_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC3_DMA_IRQ_PRIORITY   5
 +
 +/*
   * CAN driver system settings.
   */
  #define STM32_CAN_USE_CAN1                  TRUE
 @@ -90,10 +109,18 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * ICU driver system settings.
 diff --git a/demos/ARMCM4-STM32F407-DISCOVERY-G++/mcuconf.h b/demos/ARMCM4-STM32F407-DISCOVERY-G++/mcuconf.h index 2f832f6b5..62bf9e9b0 100644 --- a/demos/ARMCM4-STM32F407-DISCOVERY-G++/mcuconf.h +++ b/demos/ARMCM4-STM32F407-DISCOVERY-G++/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/demos/ARMCM4-STM32F407-DISCOVERY-MEMS/mcuconf.h b/demos/ARMCM4-STM32F407-DISCOVERY-MEMS/mcuconf.h index 9ee2ae59d..bdb446a18 100644 --- a/demos/ARMCM4-STM32F407-DISCOVERY-MEMS/mcuconf.h +++ b/demos/ARMCM4-STM32F407-DISCOVERY-MEMS/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/demos/ARMCM4-STM32F407-DISCOVERY/mcuconf.h b/demos/ARMCM4-STM32F407-DISCOVERY/mcuconf.h index d935ea995..ce20d98af 100644 --- a/demos/ARMCM4-STM32F407-DISCOVERY/mcuconf.h +++ b/demos/ARMCM4-STM32F407-DISCOVERY/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/demos/ARMCM4-STM32F407-LWIP-FATFS-USB/mcuconf.h b/demos/ARMCM4-STM32F407-LWIP-FATFS-USB/mcuconf.h index 09db70cae..3ac5df273 100644 --- a/demos/ARMCM4-STM32F407-LWIP-FATFS-USB/mcuconf.h +++ b/demos/ARMCM4-STM32F407-LWIP-FATFS-USB/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/demos/ARMCM4-STM32F407-LWIP/mcuconf.h b/demos/ARMCM4-STM32F407-LWIP/mcuconf.h index 22e7e4d1b..1fe3c18fa 100644 --- a/demos/ARMCM4-STM32F407-LWIP/mcuconf.h +++ b/demos/ARMCM4-STM32F407-LWIP/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/os/hal/platforms/STM32/gpt_lld.c b/os/hal/platforms/STM32/gpt_lld.c index 98aca51a5..35268fbe5 100644 --- a/os/hal/platforms/STM32/gpt_lld.c +++ b/os/hal/platforms/STM32/gpt_lld.c @@ -76,6 +76,22 @@ GPTDriver GPTD5;  #endif
  /**
 + * @brief   GPTD6 driver identifier.
 + * @note    The driver GPTD6 allocates the timer TIM6 when enabled.
 + */
 +#if STM32_GPT_USE_TIM6 || defined(__DOXYGEN__)
 +GPTDriver GPTD6;
 +#endif
 +
 +/**
 + * @brief   GPTD7 driver identifier.
 + * @note    The driver GPTD7 allocates the timer TIM7 when enabled.
 + */
 +#if STM32_GPT_USE_TIM7 || defined(__DOXYGEN__)
 +GPTDriver GPTD7;
 +#endif
 +
 +/**
   * @brief   GPTD8 driver identifier.
   * @note    The driver GPTD8 allocates the timer TIM8 when enabled.
   */
 @@ -83,6 +99,38 @@ GPTDriver GPTD5;  GPTDriver GPTD8;
  #endif
 +/**
 + * @brief   GPTD9 driver identifier.
 + * @note    The driver GPTD9 allocates the timer TIM9 when enabled.
 + */
 +#if STM32_GPT_USE_TIM9 || defined(__DOXYGEN__)
 +GPTDriver GPTD9;
 +#endif
 +
 +/**
 + * @brief   GPTD11 driver identifier.
 + * @note    The driver GPTD11 allocates the timer TIM11 when enabled.
 + */
 +#if STM32_GPT_USE_TIM11 || defined(__DOXYGEN__)
 +GPTDriver GPTD11;
 +#endif
 +
 +/**
 + * @brief   GPTD12 driver identifier.
 + * @note    The driver GPTD12 allocates the timer TIM12 when enabled.
 + */
 +#if STM32_GPT_USE_TIM12 || defined(__DOXYGEN__)
 +GPTDriver GPTD12;
 +#endif
 +
 +/**
 + * @brief   GPTD14 driver identifier.
 + * @note    The driver GPTD14 allocates the timer TIM14 when enabled.
 + */
 +#if STM32_GPT_USE_TIM14 || defined(__DOXYGEN__)
 +GPTDriver GPTD14;
 +#endif
 +
  /*===========================================================================*/
  /* Driver local variables and types.                                         */
  /*===========================================================================*/
 @@ -205,6 +253,44 @@ CH_IRQ_HANDLER(STM32_TIM5_HANDLER) {  }
  #endif /* STM32_GPT_USE_TIM5 */
 +#if STM32_GPT_USE_TIM6
 +#if !defined(STM32_TIM6_HANDLER)
 +#error "STM32_TIM6_HANDLER not defined"
 +#endif
 +/**
 + * @brief   TIM6 interrupt handler.
 + *
 + * @isr
 + */
 +CH_IRQ_HANDLER(STM32_TIM6_HANDLER) {
 +
 +  CH_IRQ_PROLOGUE();
 +
 +  gpt_lld_serve_interrupt(&GPTD6);
 +
 +  CH_IRQ_EPILOGUE();
 +}
 +#endif /* STM32_GPT_USE_TIM6 */
 +
 +#if STM32_GPT_USE_TIM7
 +#if !defined(STM32_TIM7_HANDLER)
 +#error "STM32_TIM7_HANDLER not defined"
 +#endif
 +/**
 + * @brief   TIM7 interrupt handler.
 + *
 + * @isr
 + */
 +CH_IRQ_HANDLER(STM32_TIM7_HANDLER) {
 +
 +  CH_IRQ_PROLOGUE();
 +
 +  gpt_lld_serve_interrupt(&GPTD7);
 +
 +  CH_IRQ_EPILOGUE();
 +}
 +#endif /* STM32_GPT_USE_TIM7 */
 +
  #if STM32_GPT_USE_TIM8
  #if !defined(STM32_TIM8_UP_HANDLER)
  #error "STM32_TIM8_UP_HANDLER not defined"
 @@ -224,6 +310,82 @@ CH_IRQ_HANDLER(STM32_TIM8_UP_HANDLER) {  }
  #endif /* STM32_GPT_USE_TIM8 */
 +#if STM32_GPT_USE_TIM9
 +#if !defined(STM32_TIM9_HANDLER)
 +#error "STM32_TIM9_HANDLER not defined"
 +#endif
 +/**
 + * @brief   TIM9 interrupt handler.
 + *
 + * @isr
 + */
 +CH_IRQ_HANDLER(STM32_TIM9_HANDLER) {
 +
 +  CH_IRQ_PROLOGUE();
 +
 +  gpt_lld_serve_interrupt(&GPTD9);
 +
 +  CH_IRQ_EPILOGUE();
 +}
 +#endif /* STM32_GPT_USE_TIM9 */
 +
 +#if STM32_GPT_USE_TIM11
 +#if !defined(STM32_TIM11_HANDLER)
 +#error "STM32_TIM11_HANDLER not defined"
 +#endif
 +/**
 + * @brief   TIM11 interrupt handler.
 + *
 + * @isr
 + */
 +CH_IRQ_HANDLER(STM32_TIM11_HANDLER) {
 +
 +  CH_IRQ_PROLOGUE();
 +
 +  gpt_lld_serve_interrupt(&GPTD11);
 +
 +  CH_IRQ_EPILOGUE();
 +}
 +#endif /* STM32_GPT_USE_TIM11 */
 +
 +#if STM32_GPT_USE_TIM12
 +#if !defined(STM32_TIM12_HANDLER)
 +#error "STM32_TIM12_HANDLER not defined"
 +#endif
 +/**
 + * @brief   TIM12 interrupt handler.
 + *
 + * @isr
 + */
 +CH_IRQ_HANDLER(STM32_TIM12_HANDLER) {
 +
 +  CH_IRQ_PROLOGUE();
 +
 +  gpt_lld_serve_interrupt(&GPTD12);
 +
 +  CH_IRQ_EPILOGUE();
 +}
 +#endif /* STM32_GPT_USE_TIM12 */
 +
 +#if STM32_GPT_USE_TIM14
 +#if !defined(STM32_TIM14_HANDLER)
 +#error "STM32_TIM14_HANDLER not defined"
 +#endif
 +/**
 + * @brief   TIM14 interrupt handler.
 + *
 + * @isr
 + */
 +CH_IRQ_HANDLER(STM32_TIM14_HANDLER) {
 +
 +  CH_IRQ_PROLOGUE();
 +
 +  gpt_lld_serve_interrupt(&GPTD14);
 +
 +  CH_IRQ_EPILOGUE();
 +}
 +#endif /* STM32_GPT_USE_TIM14 */
 +
  /*===========================================================================*/
  /* Driver exported functions.                                                */
  /*===========================================================================*/
 @@ -265,11 +427,47 @@ void gpt_lld_init(void) {    gptObjectInit(&GPTD5);
  #endif
 +#if STM32_GPT_USE_TIM6
 +  /* Driver initialization.*/
 +  GPTD6.tim = STM32_TIM6;
 +  gptObjectInit(&GPTD6);
 +#endif
 +
 +#if STM32_GPT_USE_TIM7
 +  /* Driver initialization.*/
 +  GPTD7.tim = STM32_TIM7;
 +  gptObjectInit(&GPTD7);
 +#endif
 +
  #if STM32_GPT_USE_TIM8
    /* Driver initialization.*/
    GPTD8.tim = STM32_TIM8;
    gptObjectInit(&GPTD8);
  #endif
 +
 +#if STM32_GPT_USE_TIM9
 +  /* Driver initialization.*/
 +  GPTD9.tim = STM32_TIM9;
 +  gptObjectInit(&GPTD9);
 +#endif
 +
 +#if STM32_GPT_USE_TIM11
 +  /* Driver initialization.*/
 +  GPTD11.tim = STM32_TIM11;
 +  gptObjectInit(&GPTD11);
 +#endif
 +
 +#if STM32_GPT_USE_TIM12
 +  /* Driver initialization.*/
 +  GPTD12.tim = STM32_TIM12;
 +  gptObjectInit(&GPTD12);
 +#endif
 +
 +#if STM32_GPT_USE_TIM14
 +  /* Driver initialization.*/
 +  GPTD14.tim = STM32_TIM14;
 +  gptObjectInit(&GPTD14);
 +#endif
  }
  /**
 @@ -331,6 +529,26 @@ void gpt_lld_start(GPTDriver *gptp) {      }
  #endif
 +#if STM32_GPT_USE_TIM6
 +    if (&GPTD6 == gptp) {
 +      rccEnableTIM6(FALSE);
 +      rccResetTIM6();
 +      nvicEnableVector(STM32_TIM6_NUMBER,
 +                       CORTEX_PRIORITY_MASK(STM32_GPT_TIM6_IRQ_PRIORITY));
 +      gptp->clock = STM32_TIMCLK1;
 +    }
 +#endif
 +
 +#if STM32_GPT_USE_TIM7
 +    if (&GPTD7 == gptp) {
 +      rccEnableTIM7(FALSE);
 +      rccResetTIM7();
 +      nvicEnableVector(STM32_TIM7_NUMBER,
 +                       CORTEX_PRIORITY_MASK(STM32_GPT_TIM7_IRQ_PRIORITY));
 +      gptp->clock = STM32_TIMCLK1;
 +    }
 +#endif
 +
  #if STM32_GPT_USE_TIM8
      if (&GPTD8 == gptp) {
        rccEnableTIM8(FALSE);
 @@ -340,6 +558,46 @@ void gpt_lld_start(GPTDriver *gptp) {        gptp->clock = STM32_TIMCLK2;
      }
  #endif
 +
 +#if STM32_GPT_USE_TIM9
 +    if (&GPTD9 == gptp) {
 +      rccEnableTIM9(FALSE);
 +      rccResetTIM9();
 +      nvicEnableVector(STM32_TIM9_NUMBER,
 +                       CORTEX_PRIORITY_MASK(STM32_GPT_TIM9_IRQ_PRIORITY));
 +      gptp->clock = STM32_TIMCLK2;
 +    }
 +#endif
 +
 +#if STM32_GPT_USE_TIM11
 +    if (&GPTD11 == gptp) {
 +      rccEnableTIM11(FALSE);
 +      rccResetTIM11();
 +      nvicEnableVector(STM32_TIM11_NUMBER,
 +                       CORTEX_PRIORITY_MASK(STM32_GPT_TIM11_IRQ_PRIORITY));
 +      gptp->clock = STM32_TIMCLK2;
 +    }
 +#endif
 +
 +#if STM32_GPT_USE_TIM12
 +    if (&GPTD12 == gptp) {
 +      rccEnableTIM12(FALSE);
 +      rccResetTIM12();
 +      nvicEnableVector(STM32_TIM12_NUMBER,
 +                       CORTEX_PRIORITY_MASK(STM32_GPT_TIM12_IRQ_PRIORITY));
 +      gptp->clock = STM32_TIMCLK1;
 +    }
 +#endif
 +
 +#if STM32_GPT_USE_TIM14
 +    if (&GPTD14 == gptp) {
 +      rccEnableTIM14(FALSE);
 +      rccResetTIM14();
 +      nvicEnableVector(STM32_TIM14_NUMBER,
 +                       CORTEX_PRIORITY_MASK(STM32_GPT_TIM14_IRQ_PRIORITY));
 +      gptp->clock = STM32_TIMCLK1;
 +    }
 +#endif
    }
    /* Prescaler value calculation.*/
 @@ -398,12 +656,48 @@ void gpt_lld_stop(GPTDriver *gptp) {        rccDisableTIM5(FALSE);
      }
  #endif
 +#if STM32_GPT_USE_TIM6
 +    if (&GPTD6 == gptp) {
 +      nvicDisableVector(STM32_TIM6_NUMBER);
 +      rccDisableTIM6(FALSE);
 +    }
 +#endif
 +#if STM32_GPT_USE_TIM7
 +    if (&GPTD7 == gptp) {
 +      nvicDisableVector(STM32_TIM7_NUMBER);
 +      rccDisableTIM7(FALSE);
 +    }
 +#endif
  #if STM32_GPT_USE_TIM8
      if (&GPTD8 == gptp) {
        nvicDisableVector(STM32_TIM8_UP_NUMBER);
        rccDisableTIM8(FALSE);
      }
  #endif
 +#if STM32_GPT_USE_TIM9
 +    if (&GPTD9 == gptp) {
 +      nvicDisableVector(STM32_TIM9_NUMBER);
 +      rccDisableTIM9(FALSE);
 +    }
 +#endif
 +#if STM32_GPT_USE_TIM11
 +    if (&GPTD11 == gptp) {
 +      nvicDisableVector(STM32_TIM11_NUMBER);
 +      rccDisableTIM11(FALSE);
 +    }
 +#endif
 +#if STM32_GPT_USE_TIM12
 +    if (&GPTD12 == gptp) {
 +      nvicDisableVector(STM32_TIM12_NUMBER);
 +      rccDisableTIM12(FALSE);
 +    }
 +#endif
 +#if STM32_GPT_USE_TIM14
 +    if (&GPTD14 == gptp) {
 +      nvicDisableVector(STM32_TIM14_NUMBER);
 +      rccDisableTIM14(FALSE);
 +    }
 +#endif
    }
  }
 diff --git a/os/hal/platforms/STM32/gpt_lld.h b/os/hal/platforms/STM32/gpt_lld.h index d547bb68b..ecb1dcb35 100644 --- a/os/hal/platforms/STM32/gpt_lld.h +++ b/os/hal/platforms/STM32/gpt_lld.h @@ -85,6 +85,24 @@  #endif
  /**
 + * @brief   GPTD6 driver enable switch.
 + * @details If set to @p TRUE the support for GPTD6 is included.
 + * @note    The default is @p TRUE.
 + */
 +#if !defined(STM32_GPT_USE_TIM6) || defined(__DOXYGEN__)
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#endif
 +
 +/**
 + * @brief   GPTD7 driver enable switch.
 + * @details If set to @p TRUE the support for GPTD7 is included.
 + * @note    The default is @p TRUE.
 + */
 +#if !defined(STM32_GPT_USE_TIM7) || defined(__DOXYGEN__)
 +#define STM32_GPT_USE_TIM7                  FALSE
 +#endif
 +
 +/**
   * @brief   GPTD8 driver enable switch.
   * @details If set to @p TRUE the support for GPTD8 is included.
   * @note    The default is @p TRUE.
 @@ -94,6 +112,42 @@  #endif
  /**
 + * @brief   GPTD9 driver enable switch.
 + * @details If set to @p TRUE the support for GPTD9 is included.
 + * @note    The default is @p TRUE.
 + */
 +#if !defined(STM32_GPT_USE_TIM9) || defined(__DOXYGEN__)
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#endif
 +
 +/**
 + * @brief   GPTD11 driver enable switch.
 + * @details If set to @p TRUE the support for GPTD11 is included.
 + * @note    The default is @p TRUE.
 + */
 +#if !defined(STM32_GPT_USE_TIM11) || defined(__DOXYGEN__)
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#endif
 +
 +/**
 + * @brief   GPTD12 driver enable switch.
 + * @details If set to @p TRUE the support for GPTD12 is included.
 + * @note    The default is @p TRUE.
 + */
 +#if !defined(STM32_GPT_USE_TIM12) || defined(__DOXYGEN__)
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#endif
 +
 +/**
 + * @brief   GPTD14 driver enable switch.
 + * @details If set to @p TRUE the support for GPTD14 is included.
 + * @note    The default is @p TRUE.
 + */
 +#if !defined(STM32_GPT_USE_TIM14) || defined(__DOXYGEN__)
 +#define STM32_GPT_USE_TIM14                 FALSE
 +#endif
 +
 +/**
   * @brief   GPTD1 interrupt priority level setting.
   */
  #if !defined(STM32_GPT_TIM1_IRQ_PRIORITY) || defined(__DOXYGEN__)
 @@ -129,11 +183,53 @@  #endif
  /**
 - * @brief   GPTD5 interrupt priority level setting.
 + * @brief   GPTD6 interrupt priority level setting.
 + */
 +#if !defined(STM32_GPT_TIM6_IRQ_PRIORITY) || defined(__DOXYGEN__)
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#endif
 +
 +/**
 + * @brief   GPTD7 interrupt priority level setting.
 + */
 +#if !defined(STM32_GPT_TIM7_IRQ_PRIORITY) || defined(__DOXYGEN__)
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
 +#endif
 +
 +/**
 + * @brief   GPTD8 interrupt priority level setting.
   */
  #if !defined(STM32_GPT_TIM8_IRQ_PRIORITY) || defined(__DOXYGEN__)
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
  #endif
 +
 +/**
 + * @brief   GPTD9 interrupt priority level setting.
 + */
 +#if !defined(STM32_GPT_TIM9_IRQ_PRIORITY) || defined(__DOXYGEN__)
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#endif
 +
 +/**
 + * @brief   GPTD11 interrupt priority level setting.
 + */
 +#if !defined(STM32_GPT_TIM11_IRQ_PRIORITY) || defined(__DOXYGEN__)
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#endif
 +
 +/**
 + * @brief   GPTD12 interrupt priority level setting.
 + */
 +#if !defined(STM32_GPT_TIM12_IRQ_PRIORITY) || defined(__DOXYGEN__)
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#endif
 +
 +/**
 + * @brief   GPTD14 interrupt priority level setting.
 + */
 +#if !defined(STM32_GPT_TIM14_IRQ_PRIORITY) || defined(__DOXYGEN__)
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
 +#endif
  /** @} */
  /*===========================================================================*/
 @@ -160,13 +256,40 @@  #error "TIM5 not present in the selected device"
  #endif
 +#if STM32_GPT_USE_TIM6 && !STM32_HAS_TIM6
 +#error "TIM6 not present in the selected device"
 +#endif
 +
 +#if STM32_GPT_USE_TIM7 && !STM32_HAS_TIM7
 +#error "TIM7 not present in the selected device"
 +#endif
 +
  #if STM32_GPT_USE_TIM8 && !STM32_HAS_TIM8
  #error "TIM8 not present in the selected device"
  #endif
 +#if STM32_GPT_USE_TIM9 && !STM32_HAS_TIM9
 +#error "TIM9 not present in the selected device"
 +#endif
 +
 +#if STM32_GPT_USE_TIM11 && !STM32_HAS_TIM11
 +#error "TIM11 not present in the selected device"
 +#endif
 +
 +#if STM32_GPT_USE_TIM12 && !STM32_HAS_TIM12
 +#error "TIM12 not present in the selected device"
 +#endif
 +
 +#if STM32_GPT_USE_TIM14 && !STM32_HAS_TIM14
 +#error "TIM14 not present in the selected device"
 +#endif
 +
  #if !STM32_GPT_USE_TIM1 && !STM32_GPT_USE_TIM2 &&                           \
 -    !STM32_GPT_USE_TIM3 && !STM32_GPT_USE_TIM4 &&                           \
 -    !STM32_GPT_USE_TIM5 && !STM32_GPT_USE_TIM8
 +    !STM32_GPT_USE_TIM3 && !STM32_GPT_USE_TIM4 &&  \
 +    !STM32_GPT_USE_TIM5 && !STM32_GPT_USE_TIM6 &&  \
 +    !STM32_GPT_USE_TIM7 && !STM32_GPT_USE_TIM8 &&  \
 +    !STM32_GPT_USE_TIM9 && !STM32_GPT_USE_TIM11 && \
 +    !STM32_GPT_USE_TIM12 && !STM32_GPT_USE_TIM14
  #error "GPT driver activated but no TIM peripheral assigned"
  #endif
 @@ -195,11 +318,41 @@  #error "Invalid IRQ priority assigned to TIM5"
  #endif
 +#if STM32_GPT_USE_TIM6 &&                                                   \
 +    !CORTEX_IS_VALID_KERNEL_PRIORITY(STM32_GPT_TIM6_IRQ_PRIORITY)
 +#error "Invalid IRQ priority assigned to TIM6"
 +#endif
 +
 +#if STM32_GPT_USE_TIM7 &&                                                   \
 +    !CORTEX_IS_VALID_KERNEL_PRIORITY(STM32_GPT_TIM7_IRQ_PRIORITY)
 +#error "Invalid IRQ priority assigned to TIM7"
 +#endif
 +
  #if STM32_GPT_USE_TIM8 &&                                                   \
      !CORTEX_IS_VALID_KERNEL_PRIORITY(STM32_GPT_TIM8_IRQ_PRIORITY)
  #error "Invalid IRQ priority assigned to TIM8"
  #endif
 +#if STM32_GPT_USE_TIM9 &&                                                   \
 +    !CORTEX_IS_VALID_KERNEL_PRIORITY(STM32_GPT_TIM9_IRQ_PRIORITY)
 +#error "Invalid IRQ priority assigned to TIM9"
 +#endif
 +
 +#if STM32_GPT_USE_TIM11 &&                                                   \
 +    !CORTEX_IS_VALID_KERNEL_PRIORITY(STM32_GPT_TIM11_IRQ_PRIORITY)
 +#error "Invalid IRQ priority assigned to TIM11"
 +#endif
 +
 +#if STM32_GPT_USE_TIM12 &&                                                   \
 +    !CORTEX_IS_VALID_KERNEL_PRIORITY(STM32_GPT_TIM12_IRQ_PRIORITY)
 +#error "Invalid IRQ priority assigned to TIM12"
 +#endif
 +
 +#if STM32_GPT_USE_TIM14 &&                                                   \
 +    !CORTEX_IS_VALID_KERNEL_PRIORITY(STM32_GPT_TIM14_IRQ_PRIORITY)
 +#error "Invalid IRQ priority assigned to TIM14"
 +#endif
 +
  /*===========================================================================*/
  /* Driver data structures and types.                                         */
  /*===========================================================================*/
 @@ -303,10 +456,34 @@ extern GPTDriver GPTD4;  extern GPTDriver GPTD5;
  #endif
 +#if STM32_GPT_USE_TIM6 && !defined(__DOXYGEN__)
 +extern GPTDriver GPTD6;
 +#endif
 +
 +#if STM32_GPT_USE_TIM7 && !defined(__DOXYGEN__)
 +extern GPTDriver GPTD7;
 +#endif
 +
  #if STM32_GPT_USE_TIM8 && !defined(__DOXYGEN__)
  extern GPTDriver GPTD8;
  #endif
 +#if STM32_GPT_USE_TIM9 && !defined(__DOXYGEN__)
 +extern GPTDriver GPTD9;
 +#endif
 +
 +#if STM32_GPT_USE_TIM11 && !defined(__DOXYGEN__)
 +extern GPTDriver GPTD11;
 +#endif
 +
 +#if STM32_GPT_USE_TIM12 && !defined(__DOXYGEN__)
 +extern GPTDriver GPTD12;
 +#endif
 +
 +#if STM32_GPT_USE_TIM14 && !defined(__DOXYGEN__)
 +extern GPTDriver GPTD14;
 +#endif
 +
  #ifdef __cplusplus
  extern "C" {
  #endif
 diff --git a/os/hal/platforms/STM32F30x/stm32_isr.h b/os/hal/platforms/STM32F30x/stm32_isr.h index f3ec2112a..94b04b63e 100644 --- a/os/hal/platforms/STM32F30x/stm32_isr.h +++ b/os/hal/platforms/STM32F30x/stm32_isr.h @@ -67,6 +67,8 @@  #define STM32_TIM2_HANDLER          VectorB0
  #define STM32_TIM3_HANDLER          VectorB4
  #define STM32_TIM4_HANDLER          VectorB8
 +#define STM32_TIM6_HANDLER          Vector118
 +#define STM32_TIM7_HANDLER          Vector11C
  #define STM32_TIM8_UP_HANDLER       VectorF0
  #define STM32_TIM8_CC_HANDLER       VectorF8
 @@ -75,6 +77,8 @@  #define STM32_TIM2_NUMBER           28
  #define STM32_TIM3_NUMBER           29
  #define STM32_TIM4_NUMBER           30
 +#define STM32_TIM6_NUMBER           54
 +#define STM32_TIM7_NUMBER           55
  #define STM32_TIM8_UP_NUMBER        44
  #define STM32_TIM8_CC_NUMBER        46
 diff --git a/os/hal/platforms/STM32F30x/stm32_rcc.h b/os/hal/platforms/STM32F30x/stm32_rcc.h index 13ea6bf99..9cc2edf52 100644 --- a/os/hal/platforms/STM32F30x/stm32_rcc.h +++ b/os/hal/platforms/STM32F30x/stm32_rcc.h @@ -578,6 +578,56 @@  #define rccResetTIM4() rccResetAPB1(RCC_APB1RSTR_TIM4RST)
  /**
 + * @brief   Enables the TIM6 peripheral clock.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM6(lp) rccEnableAPB1(RCC_APB1ENR_TIM6EN, lp)
 +
 +/**
 + * @brief   Disables the TIM6 peripheral clock.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM6(lp) rccDisableAPB1(RCC_APB1ENR_TIM6EN, lp)
 +
 +/**
 + * @brief   Resets the TIM6 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM6() rccResetAPB1(RCC_APB1RSTR_TIM6RST)
 +
 +/**
 + * @brief   Enables the TIM7 peripheral clock.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM7(lp) rccEnableAPB1(RCC_APB1ENR_TIM7EN, lp)
 +
 +/**
 + * @brief   Disables the TIM7 peripheral clock.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM7(lp) rccDisableAPB1(RCC_APB1ENR_TIM7EN, lp)
 +
 +/**
 + * @brief   Resets the TIM7 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM7() rccResetAPB1(RCC_APB1RSTR_TIM7RST)
 +
 +/**
   * @brief   Enables the TIM8 peripheral clock.
   * @note    The @p lp parameter is ignored in this family.
   *
 diff --git a/os/hal/platforms/STM32F37x/stm32_isr.h b/os/hal/platforms/STM32F37x/stm32_isr.h index 0ef2679bb..30d98163e 100644 --- a/os/hal/platforms/STM32F37x/stm32_isr.h +++ b/os/hal/platforms/STM32F37x/stm32_isr.h @@ -66,11 +66,19 @@  #define STM32_TIM3_HANDLER          VectorB4
  #define STM32_TIM4_HANDLER          VectorB8
  #define STM32_TIM5_HANDLER          Vector108
 +#define STM32_TIM6_HANDLER          Vector118
 +#define STM32_TIM7_HANDLER          Vector11C
 +#define STM32_TIM12_HANDLER         VectorEC
 +#define STM32_TIM14_HANDLER         VectorF4
  #define STM32_TIM2_NUMBER           28
  #define STM32_TIM3_NUMBER           29
  #define STM32_TIM4_NUMBER           30
  #define STM32_TIM5_NUMBER           50
 +#define STM32_TIM6_NUMBER           54
 +#define STM32_TIM7_NUMBER           55
 +#define STM32_TIM12_NUMBER          43
 +#define STM32_TIM14_NUMBER          45
  /*
   * USART units.
 diff --git a/os/hal/platforms/STM32F37x/stm32_rcc.h b/os/hal/platforms/STM32F37x/stm32_rcc.h index fa18f2740..607d9d7bc 100644 --- a/os/hal/platforms/STM32F37x/stm32_rcc.h +++ b/os/hal/platforms/STM32F37x/stm32_rcc.h @@ -629,6 +629,109 @@   * @api
   */
  #define rccResetTIM5() rccResetAPB1(RCC_APB1RSTR_TIM5RST)
 +
 +/**
 + * @brief   Enables the TIM6 peripheral clock.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM6(lp) rccEnableAPB1(RCC_APB1ENR_TIM6EN, lp)
 +
 +/**
 + * @brief   Disables the TIM6 peripheral clock.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM6(lp) rccDisableAPB1(RCC_APB1ENR_TIM6EN, lp)
 +
 +/**
 + * @brief   Resets the TIM6 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM6() rccResetAPB1(RCC_APB1RSTR_TIM6RST)
 +/** @} */
 +
 +/**
 + * @brief   Enables the TIM7 peripheral clock.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM7(lp) rccEnableAPB1(RCC_APB1ENR_TIM7EN, lp)
 +
 +/**
 + * @brief   Disables the TIM7 peripheral clock.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM7(lp) rccDisableAPB1(RCC_APB1ENR_TIM7EN, lp)
 +
 +/**
 + * @brief   Resets the TIM7 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM7() rccResetAPB1(RCC_APB1RSTR_TIM7RST)
 +/** @} */
 +
 +/**
 + * @brief   Enables the TIM12 peripheral clock.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM12(lp) rccEnableAPB1(RCC_APB1ENR_TIM12EN, lp)
 +
 +/**
 + * @brief   Disables the TIM12 peripheral clock.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM12(lp) rccDisableAPB1(RCC_APB1ENR_TIM12EN, lp)
 +
 +/**
 + * @brief   Resets the TIM12 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM12() rccResetAPB1(RCC_APB1RSTR_TIM12RST)
 +/** @} */
 +
 +/**
 + * @brief   Enables the TIM14 peripheral clock.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM14(lp) rccEnableAPB1(RCC_APB1ENR_TIM14EN, lp)
 +
 +/**
 + * @brief   Disables the TIM14 peripheral clock.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM14(lp) rccDisableAPB1(RCC_APB1ENR_TIM14EN, lp)
 +
 +/**
 + * @brief   Resets the TIM14 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM14() rccResetAPB1(RCC_APB1RSTR_TIM14RST)
  /** @} */
  /**
 diff --git a/os/hal/platforms/STM32F4xx/stm32_isr.h b/os/hal/platforms/STM32F4xx/stm32_isr.h index 2f3664f61..d501c7bcf 100644 --- a/os/hal/platforms/STM32F4xx/stm32_isr.h +++ b/os/hal/platforms/STM32F4xx/stm32_isr.h @@ -83,9 +83,14 @@  #define STM32_TIM3_HANDLER          TIM3_IRQHandler
  #define STM32_TIM4_HANDLER          TIM4_IRQHandler
  #define STM32_TIM5_HANDLER          TIM5_IRQHandler
 +#define STM32_TIM6_HANDLER          TIM6_IRQHandler
 +#define STM32_TIM7_HANDLER          TIM7_IRQHandler
  #define STM32_TIM8_UP_HANDLER       TIM8_UP_IRQHandler
  #define STM32_TIM8_CC_HANDLER       TIM8_CC_IRQHandler
 -#define STM32_TIM9_HANDLER          TIM9_IRQHandler
 +#define STM32_TIM9_HANDLER          TIM1_BRK_IRQHandler
 +#define STM32_TIM11_HANDLER         TIM1_TRG_COM_IRQHandler
 +#define STM32_TIM12_HANDLER         TIM8_BRK_IRQHandler
 +#define STM32_TIM14_HANDLER         TIM8_TRG_COM_IRQHandler
  #define STM32_TIM1_UP_NUMBER        TIM1_UP_TIM10_IRQn
  #define STM32_TIM1_CC_NUMBER        TIM1_CC_IRQn
 @@ -96,6 +101,9 @@  #define STM32_TIM8_UP_NUMBER        TIM8_UP_TIM13_IRQn
  #define STM32_TIM8_CC_NUMBER        TIM8_CC_IRQn
  #define STM32_TIM9_NUMBER           TIM1_BRK_TIM9_IRQn
 +#define STM32_TIM11_NUMBER          TIM1_TRG_COM_TIM11_IRQn
 +#define STM32_TIM12_NUMBER          TIM8_BRK_TIM12_IRQn
 +#define STM32_TIM14_NUMBER          TIM8_TRG_COM_TIM14_IRQn
  /*
   * USART units.
 diff --git a/os/hal/platforms/STM32F4xx/stm32_rcc.h b/os/hal/platforms/STM32F4xx/stm32_rcc.h index db3f594ee..7235f2caf 100644 --- a/os/hal/platforms/STM32F4xx/stm32_rcc.h +++ b/os/hal/platforms/STM32F4xx/stm32_rcc.h @@ -890,6 +890,60 @@  #define rccResetTIM5() rccResetAPB1(RCC_APB1RSTR_TIM5RST)
  /**
 + * @brief   Enables the TIM6 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM6(lp) rccEnableAPB1(RCC_APB1ENR_TIM6EN, lp)
 +
 +/**
 + * @brief   Disables the TIM6 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM6(lp) rccDisableAPB1(RCC_APB1ENR_TIM6EN, lp)
 +
 +/**
 + * @brief   Resets the TIM6 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM6() rccResetAPB1(RCC_APB1RSTR_TIM6RST)
 +
 +/**
 + * @brief   Enables the TIM7 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM7(lp) rccEnableAPB1(RCC_APB1ENR_TIM7EN, lp)
 +
 +/**
 + * @brief   Disables the TIM7 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM7(lp) rccDisableAPB1(RCC_APB1ENR_TIM7EN, lp)
 +
 +/**
 + * @brief   Resets the TIM7 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM7() rccResetAPB1(RCC_APB1RSTR_TIM7RST)
 +
 +/**
   * @brief   Enables the TIM8 peripheral clock.
   * @note    The @p lp parameter is ignored in this family.
   *
 @@ -942,9 +996,198 @@   * @api
   */
  #define rccEnableTIM9(lp) rccEnableAPB2(RCC_APB2ENR_TIM9EN, lp)
 +
 +/**
 + * @brief   Enables the TIM11 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM11(lp) rccEnableAPB2(RCC_APB2ENR_TIM11EN, lp)
 +
 +/**
 + * @brief   Disables the TIM11 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM11(lp) rccDisableAPB2(RCC_APB2ENR_TIM11EN, lp)
 +
 +/**
 + * @brief   Resets the TIM11 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM11() rccResetAPB2(RCC_APB2RSTR_TIM11RST)
 +
 +/**
 + * @brief   Enables the TIM12 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM12(lp) rccEnableAPB1(RCC_APB1ENR_TIM12EN, lp)
 +
 +/**
 + * @brief   Disables the TIM12 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM12(lp) rccDisableAPB1(RCC_APB1ENR_TIM12EN, lp)
 +
 +/**
 + * @brief   Resets the TIM12 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM12() rccResetAPB1(RCC_APB1RSTR_TIM12RST)
 +
 +/**
 + * @brief   Enables the TIM14 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM14(lp) rccEnableAPB1(RCC_APB1ENR_TIM14EN, lp)
 +
 +/**
 + * @brief   Disables the TIM14 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM14(lp) rccDisableAPB1(RCC_APB1ENR_TIM14EN, lp)
 +
 +/**
 + * @brief   Resets the TIM14 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM14() rccResetAPB1(RCC_APB1RSTR_TIM14RST)
  /** @} */
  /**
 + * @brief   Enables the TIM9 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM9(lp) rccEnableAPB2(RCC_APB2ENR_TIM9EN, lp)
 +
 +/**
 + * @brief   Disables the TIM9 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM9(lp) rccDisableAPB2(RCC_APB2ENR_TIM9EN, lp)
 +
 +/**
 + * @brief   Resets the TIM9 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM9() rccResetAPB2(RCC_APB2RSTR_TIM9RST)
 +
 +/**
 + * @brief   Enables the TIM11 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM11(lp) rccEnableAPB2(RCC_APB2ENR_TIM11EN, lp)
 +
 +/**
 + * @brief   Disables the TIM11 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM11(lp) rccDisableAPB2(RCC_APB2ENR_TIM11EN, lp)
 +
 +/**
 + * @brief   Resets the TIM11 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM11() rccResetAPB2(RCC_APB2RSTR_TIM11RST)
 +
 +/**
 + * @brief   Enables the TIM12 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM12(lp) rccEnableAPB1(RCC_APB1ENR_TIM12EN, lp)
 +
 +/**
 + * @brief   Disables the TIM12 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM12(lp) rccDisableAPB1(RCC_APB1ENR_TIM12EN, lp)
 +
 +/**
 + * @brief   Resets the TIM12 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM12() rccResetAPB1(RCC_APB1RSTR_TIM12RST)
 +
 +/**
 + * @brief   Enables the TIM14 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccEnableTIM14(lp) rccEnableAPB1(RCC_APB1ENR_TIM14EN, lp)
 +
 +/**
 + * @brief   Disables the TIM14 peripheral clock.
 + * @note    The @p lp parameter is ignored in this family.
 + *
 + * @param[in] lp        low power enable flag
 + *
 + * @api
 + */
 +#define rccDisableTIM14(lp) rccDisableAPB1(RCC_APB1ENR_TIM14EN, lp)
 +
 +/**
 + * @brief   Resets the TIM14 peripheral.
 + *
 + * @api
 + */
 +#define rccResetTIM14() rccResetAPB1(RCC_APB1RSTR_TIM14RST)
 +
 +/**
   * @name    USART/UART peripherals specific RCC operations
   * @{
   */
 diff --git a/readme.txt b/readme.txt index ce6e24253..7941d860e 100644 --- a/readme.txt +++ b/readme.txt @@ -138,6 +138,7 @@    (backported to 2.4.3).
  - FIX: Fixed wrong SPI path in platform_f105_f107.mk (bug 3598151).
  - FIX: Fixed PHY powerdown issues not fixed (bug 3596911).
 +- NEW: Added support for timers 6, 7, 9, 11, 12, 14 to the STM32 GPT driver.
  - NEW: Added support for timer 9 to the STM32 PWM driver.
  - NEW: Relicensed parts of the distribution tree under the Apache 2.0
    license in order to make specific parts of the code more accessible
 diff --git a/testhal/STM32F30x/ADC/mcuconf.h b/testhal/STM32F30x/ADC/mcuconf.h index 70c22d169..bcec98614 100644 --- a/testhal/STM32F30x/ADC/mcuconf.h +++ b/testhal/STM32F30x/ADC/mcuconf.h @@ -110,11 +110,15 @@  #define STM32_GPT_USE_TIM2                  FALSE
  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
  /*
 diff --git a/testhal/STM32F30x/ADC_DUAL/mcuconf.h b/testhal/STM32F30x/ADC_DUAL/mcuconf.h index 08815492d..3f638f4ee 100644 --- a/testhal/STM32F30x/ADC_DUAL/mcuconf.h +++ b/testhal/STM32F30x/ADC_DUAL/mcuconf.h @@ -110,11 +110,15 @@  #define STM32_GPT_USE_TIM2                  FALSE
  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
  /*
 diff --git a/testhal/STM32F30x/CAN/mcuconf.h b/testhal/STM32F30x/CAN/mcuconf.h index 6ff18bbce..d91256c8b 100644 --- a/testhal/STM32F30x/CAN/mcuconf.h +++ b/testhal/STM32F30x/CAN/mcuconf.h @@ -110,11 +110,15 @@  #define STM32_GPT_USE_TIM2                  FALSE
  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
  /*
 diff --git a/testhal/STM32F30x/EXT/mcuconf.h b/testhal/STM32F30x/EXT/mcuconf.h index 6ff18bbce..d91256c8b 100644 --- a/testhal/STM32F30x/EXT/mcuconf.h +++ b/testhal/STM32F30x/EXT/mcuconf.h @@ -110,11 +110,15 @@  #define STM32_GPT_USE_TIM2                  FALSE
  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
  /*
 diff --git a/testhal/STM32F30x/IRQ_STORM/mcuconf.h b/testhal/STM32F30x/IRQ_STORM/mcuconf.h index 8cbcc9bed..f387ae2e8 100644 --- a/testhal/STM32F30x/IRQ_STORM/mcuconf.h +++ b/testhal/STM32F30x/IRQ_STORM/mcuconf.h @@ -111,10 +111,14 @@  #define STM32_GPT_USE_TIM3                  TRUE
  #define STM32_GPT_USE_TIM4                  TRUE
  #define STM32_GPT_USE_TIM8                  TRUE
 +#define STM32_GPT_USE_TIM7                  TRUE
 +#define STM32_GPT_USE_TIM8                  TRUE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         6
  #define STM32_GPT_TIM3_IRQ_PRIORITY         10
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
  /*
 diff --git a/testhal/STM32F30x/PWM-ICU/mcuconf.h b/testhal/STM32F30x/PWM-ICU/mcuconf.h index 282a13d5b..acf8a67c9 100644 --- a/testhal/STM32F30x/PWM-ICU/mcuconf.h +++ b/testhal/STM32F30x/PWM-ICU/mcuconf.h @@ -110,11 +110,15 @@  #define STM32_GPT_USE_TIM2                  FALSE
  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
  /*
 diff --git a/testhal/STM32F30x/SPI/mcuconf.h b/testhal/STM32F30x/SPI/mcuconf.h index c3ae50276..10f1bde6b 100644 --- a/testhal/STM32F30x/SPI/mcuconf.h +++ b/testhal/STM32F30x/SPI/mcuconf.h @@ -110,11 +110,15 @@  #define STM32_GPT_USE_TIM2                  FALSE
  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
  /*
 diff --git a/testhal/STM32F30x/UART/mcuconf.h b/testhal/STM32F30x/UART/mcuconf.h index d57f62b4a..55b3d6446 100644 --- a/testhal/STM32F30x/UART/mcuconf.h +++ b/testhal/STM32F30x/UART/mcuconf.h @@ -110,11 +110,15 @@  #define STM32_GPT_USE_TIM2                  FALSE
  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
  /*
 diff --git a/testhal/STM32F30x/USB_CDC/mcuconf.h b/testhal/STM32F30x/USB_CDC/mcuconf.h index 2e1f7a3a3..d75c295e6 100644 --- a/testhal/STM32F30x/USB_CDC/mcuconf.h +++ b/testhal/STM32F30x/USB_CDC/mcuconf.h @@ -110,11 +110,15 @@  #define STM32_GPT_USE_TIM2                  FALSE
  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
  /*
 diff --git a/testhal/STM32F37x/ADC/mcuconf.h b/testhal/STM32F37x/ADC/mcuconf.h index ec57bb135..b6433b900 100644 --- a/testhal/STM32F37x/ADC/mcuconf.h +++ b/testhal/STM32F37x/ADC/mcuconf.h @@ -110,10 +110,18 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * ICU driver system settings.
 diff --git a/testhal/STM32F37x/CAN/mcuconf.h b/testhal/STM32F37x/CAN/mcuconf.h index 12fc6c5e6..f04aeaf7b 100644 --- a/testhal/STM32F37x/CAN/mcuconf.h +++ b/testhal/STM32F37x/CAN/mcuconf.h @@ -60,6 +60,25 @@  #define STM32_USBPRE                        STM32_USBPRE_DIV1P5
  /*
 + * ADC driver system settings.
 + */
 +#define STM32_ADC_USE_ADC1                  FALSE
 +#define STM32_ADC_USE_SDADC1                FALSE
 +#define STM32_ADC_USE_SDADC2                FALSE
 +#define STM32_ADC_USE_SDADC3                FALSE
 +#define STM32_ADC_ADC1_DMA_PRIORITY         2
 +#define STM32_ADC_SDADC1_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC2_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC3_DMA_PRIORITY       2
 +#define STM32_ADC_IRQ_PRIORITY              5
 +#define STM32_ADC_SDADC1_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC2_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC3_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC1_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC2_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC3_DMA_IRQ_PRIORITY   5
 +
 +/*
   * CAN driver system settings.
   */
  #define STM32_CAN_USE_CAN1                  TRUE
 @@ -90,10 +109,18 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * ICU driver system settings.
 diff --git a/testhal/STM32F37x/EXT/mcuconf.h b/testhal/STM32F37x/EXT/mcuconf.h index 12fc6c5e6..f04aeaf7b 100644 --- a/testhal/STM32F37x/EXT/mcuconf.h +++ b/testhal/STM32F37x/EXT/mcuconf.h @@ -60,6 +60,25 @@  #define STM32_USBPRE                        STM32_USBPRE_DIV1P5
  /*
 + * ADC driver system settings.
 + */
 +#define STM32_ADC_USE_ADC1                  FALSE
 +#define STM32_ADC_USE_SDADC1                FALSE
 +#define STM32_ADC_USE_SDADC2                FALSE
 +#define STM32_ADC_USE_SDADC3                FALSE
 +#define STM32_ADC_ADC1_DMA_PRIORITY         2
 +#define STM32_ADC_SDADC1_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC2_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC3_DMA_PRIORITY       2
 +#define STM32_ADC_IRQ_PRIORITY              5
 +#define STM32_ADC_SDADC1_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC2_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC3_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC1_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC2_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC3_DMA_IRQ_PRIORITY   5
 +
 +/*
   * CAN driver system settings.
   */
  #define STM32_CAN_USE_CAN1                  TRUE
 @@ -90,10 +109,18 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * ICU driver system settings.
 diff --git a/testhal/STM32F37x/I2C/mcuconf.h b/testhal/STM32F37x/I2C/mcuconf.h index 78da5f77b..c18448c10 100644 --- a/testhal/STM32F37x/I2C/mcuconf.h +++ b/testhal/STM32F37x/I2C/mcuconf.h @@ -60,6 +60,25 @@  #define STM32_USBPRE                        STM32_USBPRE_DIV1P5
  /*
 + * ADC driver system settings.
 + */
 +#define STM32_ADC_USE_ADC1                  FALSE
 +#define STM32_ADC_USE_SDADC1                FALSE
 +#define STM32_ADC_USE_SDADC2                FALSE
 +#define STM32_ADC_USE_SDADC3                FALSE
 +#define STM32_ADC_ADC1_DMA_PRIORITY         2
 +#define STM32_ADC_SDADC1_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC2_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC3_DMA_PRIORITY       2
 +#define STM32_ADC_IRQ_PRIORITY              5
 +#define STM32_ADC_SDADC1_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC2_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC3_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC1_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC2_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC3_DMA_IRQ_PRIORITY   5
 +
 +/*
   * CAN driver system settings.
   */
  #define STM32_CAN_USE_CAN1                  FALSE
 @@ -90,10 +109,18 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F37x/IRQ_STORM/mcuconf.h b/testhal/STM32F37x/IRQ_STORM/mcuconf.h index 7cf50cb05..f04aeaf7b 100644 --- a/testhal/STM32F37x/IRQ_STORM/mcuconf.h +++ b/testhal/STM32F37x/IRQ_STORM/mcuconf.h @@ -60,6 +60,25 @@  #define STM32_USBPRE                        STM32_USBPRE_DIV1P5
  /*
 + * ADC driver system settings.
 + */
 +#define STM32_ADC_USE_ADC1                  FALSE
 +#define STM32_ADC_USE_SDADC1                FALSE
 +#define STM32_ADC_USE_SDADC2                FALSE
 +#define STM32_ADC_USE_SDADC3                FALSE
 +#define STM32_ADC_ADC1_DMA_PRIORITY         2
 +#define STM32_ADC_SDADC1_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC2_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC3_DMA_PRIORITY       2
 +#define STM32_ADC_IRQ_PRIORITY              5
 +#define STM32_ADC_SDADC1_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC2_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC3_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC1_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC2_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC3_DMA_IRQ_PRIORITY   5
 +
 +/*
   * CAN driver system settings.
   */
  #define STM32_CAN_USE_CAN1                  TRUE
 @@ -86,14 +105,22 @@  /*
   * GPT driver system settings.
   */
 -#define STM32_GPT_USE_TIM2                  TRUE
 -#define STM32_GPT_USE_TIM3                  TRUE
 +#define STM32_GPT_USE_TIM2                  FALSE
 +#define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 -#define STM32_GPT_TIM2_IRQ_PRIORITY         6
 -#define STM32_GPT_TIM3_IRQ_PRIORITY         10
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
 +#define STM32_GPT_TIM2_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * ICU driver system settings.
 diff --git a/testhal/STM32F37x/PWM-ICU/mcuconf.h b/testhal/STM32F37x/PWM-ICU/mcuconf.h index da06e52f6..69456270b 100644 --- a/testhal/STM32F37x/PWM-ICU/mcuconf.h +++ b/testhal/STM32F37x/PWM-ICU/mcuconf.h @@ -60,6 +60,25 @@  #define STM32_USBPRE                        STM32_USBPRE_DIV1P5
  /*
 + * ADC driver system settings.
 + */
 +#define STM32_ADC_USE_ADC1                  FALSE
 +#define STM32_ADC_USE_SDADC1                FALSE
 +#define STM32_ADC_USE_SDADC2                FALSE
 +#define STM32_ADC_USE_SDADC3                FALSE
 +#define STM32_ADC_ADC1_DMA_PRIORITY         2
 +#define STM32_ADC_SDADC1_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC2_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC3_DMA_PRIORITY       2
 +#define STM32_ADC_IRQ_PRIORITY              5
 +#define STM32_ADC_SDADC1_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC2_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC3_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC1_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC2_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC3_DMA_IRQ_PRIORITY   5
 +
 +/*
   * CAN driver system settings.
   */
  #define STM32_CAN_USE_CAN1                  TRUE
 @@ -90,10 +109,18 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * ICU driver system settings.
 diff --git a/testhal/STM32F37x/SDADC/mcuconf.h b/testhal/STM32F37x/SDADC/mcuconf.h index 1c31f3d02..1317c07a4 100644 --- a/testhal/STM32F37x/SDADC/mcuconf.h +++ b/testhal/STM32F37x/SDADC/mcuconf.h @@ -109,10 +109,18 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * ICU driver system settings.
 diff --git a/testhal/STM32F37x/SPI/mcuconf.h b/testhal/STM32F37x/SPI/mcuconf.h index 0b26d09b7..b1359805f 100644 --- a/testhal/STM32F37x/SPI/mcuconf.h +++ b/testhal/STM32F37x/SPI/mcuconf.h @@ -60,6 +60,25 @@  #define STM32_USBPRE                        STM32_USBPRE_DIV1P5
  /*
 + * ADC driver system settings.
 + */
 +#define STM32_ADC_USE_ADC1                  FALSE
 +#define STM32_ADC_USE_SDADC1                FALSE
 +#define STM32_ADC_USE_SDADC2                FALSE
 +#define STM32_ADC_USE_SDADC3                FALSE
 +#define STM32_ADC_ADC1_DMA_PRIORITY         2
 +#define STM32_ADC_SDADC1_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC2_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC3_DMA_PRIORITY       2
 +#define STM32_ADC_IRQ_PRIORITY              5
 +#define STM32_ADC_SDADC1_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC2_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC3_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC1_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC2_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC3_DMA_IRQ_PRIORITY   5
 +
 +/*
   * CAN driver system settings.
   */
  #define STM32_CAN_USE_CAN1                  FALSE
 @@ -90,10 +109,18 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * ICU driver system settings.
 diff --git a/testhal/STM32F37x/UART/mcuconf.h b/testhal/STM32F37x/UART/mcuconf.h index 9f3d334e2..f01882c25 100644 --- a/testhal/STM32F37x/UART/mcuconf.h +++ b/testhal/STM32F37x/UART/mcuconf.h @@ -60,6 +60,25 @@  #define STM32_USBPRE                        STM32_USBPRE_DIV1P5
  /*
 + * ADC driver system settings.
 + */
 +#define STM32_ADC_USE_ADC1                  FALSE
 +#define STM32_ADC_USE_SDADC1                FALSE
 +#define STM32_ADC_USE_SDADC2                FALSE
 +#define STM32_ADC_USE_SDADC3                FALSE
 +#define STM32_ADC_ADC1_DMA_PRIORITY         2
 +#define STM32_ADC_SDADC1_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC2_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC3_DMA_PRIORITY       2
 +#define STM32_ADC_IRQ_PRIORITY              5
 +#define STM32_ADC_SDADC1_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC2_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC3_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC1_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC2_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC3_DMA_IRQ_PRIORITY   5
 +
 +/*
   * CAN driver system settings.
   */
  #define STM32_CAN_USE_CAN1                  FALSE
 @@ -90,10 +109,18 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * ICU driver system settings.
 diff --git a/testhal/STM32F37x/USB_CDC/mcuconf.h b/testhal/STM32F37x/USB_CDC/mcuconf.h index 8c0ad2a03..e2d12a214 100644 --- a/testhal/STM32F37x/USB_CDC/mcuconf.h +++ b/testhal/STM32F37x/USB_CDC/mcuconf.h @@ -60,6 +60,25 @@  #define STM32_USBPRE                        STM32_USBPRE_DIV1P5
  /*
 + * ADC driver system settings.
 + */
 +#define STM32_ADC_USE_ADC1                  FALSE
 +#define STM32_ADC_USE_SDADC1                FALSE
 +#define STM32_ADC_USE_SDADC2                FALSE
 +#define STM32_ADC_USE_SDADC3                FALSE
 +#define STM32_ADC_ADC1_DMA_PRIORITY         2
 +#define STM32_ADC_SDADC1_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC2_DMA_PRIORITY       2
 +#define STM32_ADC_SDADC3_DMA_PRIORITY       2
 +#define STM32_ADC_IRQ_PRIORITY              5
 +#define STM32_ADC_SDADC1_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC2_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC3_IRQ_PRIORITY       5
 +#define STM32_ADC_SDADC1_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC2_DMA_IRQ_PRIORITY   5
 +#define STM32_ADC_SDADC3_DMA_IRQ_PRIORITY   5
 +
 +/*
   * CAN driver system settings.
   */
  #define STM32_CAN_USE_CAN1                  FALSE
 @@ -90,10 +109,18 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * ICU driver system settings.
 diff --git a/testhal/STM32F4xx/ADC/mcuconf.h b/testhal/STM32F4xx/ADC/mcuconf.h index e202f06b7..6c025b539 100644 --- a/testhal/STM32F4xx/ADC/mcuconf.h +++ b/testhal/STM32F4xx/ADC/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/CAN/mcuconf.h b/testhal/STM32F4xx/CAN/mcuconf.h index 617598e45..4e1f0e0be 100644 --- a/testhal/STM32F4xx/CAN/mcuconf.h +++ b/testhal/STM32F4xx/CAN/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/DMA_STORM/mcuconf.h b/testhal/STM32F4xx/DMA_STORM/mcuconf.h index 9c549aa5e..d0efa10c1 100644 --- a/testhal/STM32F4xx/DMA_STORM/mcuconf.h +++ b/testhal/STM32F4xx/DMA_STORM/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/EXT/mcuconf.h b/testhal/STM32F4xx/EXT/mcuconf.h index 40ca17264..42c633843 100644 --- a/testhal/STM32F4xx/EXT/mcuconf.h +++ b/testhal/STM32F4xx/EXT/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/GPT/mcuconf.h b/testhal/STM32F4xx/GPT/mcuconf.h index 99738dfd5..011b6b6ef 100644 --- a/testhal/STM32F4xx/GPT/mcuconf.h +++ b/testhal/STM32F4xx/GPT/mcuconf.h @@ -114,12 +114,24 @@  #define STM32_GPT_USE_TIM4                  TRUE
  #define STM32_GPT_USE_TIM5                  TRUE
  #define STM32_GPT_USE_TIM8                  TRUE
 +#define STM32_GPT_USE_TIM7                  TRUE
 +#define STM32_GPT_USE_TIM8                  TRUE
 +#define STM32_GPT_USE_TIM9                  TRUE
 +#define STM32_GPT_USE_TIM11                 TRUE
 +#define STM32_GPT_USE_TIM12                 TRUE
 +#define STM32_GPT_USE_TIM14                 TRUE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/I2C/mcuconf.h b/testhal/STM32F4xx/I2C/mcuconf.h index 679a13247..437b76788 100644 --- a/testhal/STM32F4xx/I2C/mcuconf.h +++ b/testhal/STM32F4xx/I2C/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/IRQ_STORM/mcuconf.h b/testhal/STM32F4xx/IRQ_STORM/mcuconf.h index c122bb591..4f697b91a 100644 --- a/testhal/STM32F4xx/IRQ_STORM/mcuconf.h +++ b/testhal/STM32F4xx/IRQ_STORM/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  TRUE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         6
  #define STM32_GPT_TIM3_IRQ_PRIORITY         10
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/IRQ_STORM_FPU/mcuconf.h b/testhal/STM32F4xx/IRQ_STORM_FPU/mcuconf.h index c122bb591..4f697b91a 100644 --- a/testhal/STM32F4xx/IRQ_STORM_FPU/mcuconf.h +++ b/testhal/STM32F4xx/IRQ_STORM_FPU/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  TRUE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         6
  #define STM32_GPT_TIM3_IRQ_PRIORITY         10
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/PWM-ICU/mcuconf.h b/testhal/STM32F4xx/PWM-ICU/mcuconf.h index ddb8b6f34..dd99ff421 100644 --- a/testhal/STM32F4xx/PWM-ICU/mcuconf.h +++ b/testhal/STM32F4xx/PWM-ICU/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/RTC/mcuconf.h b/testhal/STM32F4xx/RTC/mcuconf.h index 6d2f47d3e..9620ad5fc 100644 --- a/testhal/STM32F4xx/RTC/mcuconf.h +++ b/testhal/STM32F4xx/RTC/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/RTC_FATTIME/mcuconf.h b/testhal/STM32F4xx/RTC_FATTIME/mcuconf.h index 2f832f6b5..62bf9e9b0 100755 --- a/testhal/STM32F4xx/RTC_FATTIME/mcuconf.h +++ b/testhal/STM32F4xx/RTC_FATTIME/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/SDC/mcuconf.h b/testhal/STM32F4xx/SDC/mcuconf.h index 2f832f6b5..62bf9e9b0 100755 --- a/testhal/STM32F4xx/SDC/mcuconf.h +++ b/testhal/STM32F4xx/SDC/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/SPI/mcuconf.h b/testhal/STM32F4xx/SPI/mcuconf.h index 6b19825b8..2fdc2e7df 100644 --- a/testhal/STM32F4xx/SPI/mcuconf.h +++ b/testhal/STM32F4xx/SPI/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/UART/mcuconf.h b/testhal/STM32F4xx/UART/mcuconf.h index 900e6e78b..48b99cf3d 100644 --- a/testhal/STM32F4xx/UART/mcuconf.h +++ b/testhal/STM32F4xx/UART/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 diff --git a/testhal/STM32F4xx/USB_CDC/mcuconf.h b/testhal/STM32F4xx/USB_CDC/mcuconf.h index 341f8f3e7..43888b232 100644 --- a/testhal/STM32F4xx/USB_CDC/mcuconf.h +++ b/testhal/STM32F4xx/USB_CDC/mcuconf.h @@ -113,13 +113,25 @@  #define STM32_GPT_USE_TIM3                  FALSE
  #define STM32_GPT_USE_TIM4                  FALSE
  #define STM32_GPT_USE_TIM5                  FALSE
 +#define STM32_GPT_USE_TIM6                  FALSE
 +#define STM32_GPT_USE_TIM7                  FALSE
  #define STM32_GPT_USE_TIM8                  FALSE
 +#define STM32_GPT_USE_TIM9                  FALSE
 +#define STM32_GPT_USE_TIM11                 FALSE
 +#define STM32_GPT_USE_TIM12                 FALSE
 +#define STM32_GPT_USE_TIM14                 FALSE
  #define STM32_GPT_TIM1_IRQ_PRIORITY         7
  #define STM32_GPT_TIM2_IRQ_PRIORITY         7
  #define STM32_GPT_TIM3_IRQ_PRIORITY         7
  #define STM32_GPT_TIM4_IRQ_PRIORITY         7
  #define STM32_GPT_TIM5_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM6_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM7_IRQ_PRIORITY         7
  #define STM32_GPT_TIM8_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM9_IRQ_PRIORITY         7
 +#define STM32_GPT_TIM11_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM12_IRQ_PRIORITY        7
 +#define STM32_GPT_TIM14_IRQ_PRIORITY        7
  /*
   * I2C driver system settings.
 | 
