STM32 quad encoder: Don't calculate the timer prescaler value at runtime; pre-calculate it at compiler time
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@4424 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
327f552444
commit
f67d1e4e35
@ -65,6 +65,33 @@
|
|||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
* Pre-processor Definitions
|
* Pre-processor Definitions
|
||||||
************************************************************************************/
|
************************************************************************************/
|
||||||
|
/* Clocking *************************************************************************/
|
||||||
|
/* The CLKOUT value should not exceed the CLKIN value */
|
||||||
|
|
||||||
|
#if defined(CONFIG_STM32_TIM1_QE) && CONFIG_STM32_TIM1_QECLKOUT > STM32_APB2_TIM1_CLKIN
|
||||||
|
# warning "CONFIG_STM32_TIM1_QECLKOUT exceeds STM32_APB2_TIM1_CLKIN"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_STM32_TIM2_QE) && CONFIG_STM32_TIM2_QECLKOUT > STM32_APB1_TIM2_CLKIN
|
||||||
|
# warning "CONFIG_STM32_TIM2_QECLKOUT exceeds STM32_APB2_TIM2_CLKIN"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_STM32_TIM3_QE) && CONFIG_STM32_TIM3_QECLKOUT > STM32_APB1_TIM3_CLKIN
|
||||||
|
# warning "CONFIG_STM32_TIM3_QECLKOUT exceeds STM32_APB2_TIM3_CLKIN"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_STM32_TIM4_QE) && CONFIG_STM32_TIM4_QECLKOUT > STM32_APB1_TIM4_CLKIN
|
||||||
|
# warning "CONFIG_STM32_TIM4_QECLKOUT exceeds STM32_APB2_TIM4_CLKIN"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_STM32_TIM5_QE) && CONFIG_STM32_TIM5_QECLKOUT > STM32_APB1_TIM5_CLKIN
|
||||||
|
# warning "CONFIG_STM32_TIM5_QECLKOUT exceeds STM32_APB2_TIM5_CLKIN"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_STM32_TIM8_QE) && CONFIG_STM32_TIM8_QECLKOUT > STM32_APB2_TIM8_CLKIN
|
||||||
|
# warning "CONFIG_STM32_TIM8_QECLKOUT exceeds STM32_APB2_TIM6_CLKIN"
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Debug ****************************************************************************/
|
/* Debug ****************************************************************************/
|
||||||
/* Non-standard debug that may be enabled just for testing the quadrature encoder */
|
/* Non-standard debug that may be enabled just for testing the quadrature encoder */
|
||||||
|
|
||||||
@ -110,7 +137,7 @@ struct stm32_qeconfig_s
|
|||||||
uint16_t ti2cfg; /* TI2 input pin configuration (16-bit encoding) */
|
uint16_t ti2cfg; /* TI2 input pin configuration (16-bit encoding) */
|
||||||
#endif
|
#endif
|
||||||
uint32_t base; /* Register base address */
|
uint32_t base; /* Register base address */
|
||||||
uint32_t clkin; /* Timer input clock frequency */
|
uint32_t psc; /* Timer input clock prescaler */
|
||||||
xcpt_t handler; /* Interrupt handler for this IRQ */
|
xcpt_t handler; /* Interrupt handler for this IRQ */
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -202,7 +229,7 @@ static const struct stm32_qeconfig_s g_tim1config =
|
|||||||
.timid = 1,
|
.timid = 1,
|
||||||
.irq = STM32_IRQ_TIM1UP,
|
.irq = STM32_IRQ_TIM1UP,
|
||||||
.base = STM32_TIM1_BASE,
|
.base = STM32_TIM1_BASE,
|
||||||
.clkin = STM32_APB2_TIM1_CLKIN,
|
.psc = (STM32_APB2_TIM1_CLKIN / CONFIG_STM32_TIM1_QECLKOUT) - 1,
|
||||||
.ti1cfg = GPIO_TIM1_CH1IN,
|
.ti1cfg = GPIO_TIM1_CH1IN,
|
||||||
.ti2cfg = GPIO_TIM1_CH2IN,
|
.ti2cfg = GPIO_TIM1_CH2IN,
|
||||||
.handler = stm32_tim1interrupt,
|
.handler = stm32_tim1interrupt,
|
||||||
@ -223,7 +250,7 @@ static const struct stm32_qeconfig_s g_tim2config =
|
|||||||
.timid = 2,
|
.timid = 2,
|
||||||
.irq = STM32_IRQ_TIM2,
|
.irq = STM32_IRQ_TIM2,
|
||||||
.base = STM32_TIM2_BASE,
|
.base = STM32_TIM2_BASE,
|
||||||
.clkin = STM32_APB1_TIM2_CLKIN,
|
.psc = (STM32_APB1_TIM2_CLKIN / CONFIG_STM32_TIM2_QECLKOUT) - 1,
|
||||||
.ti1cfg = GPIO_TIM2_CH1IN,
|
.ti1cfg = GPIO_TIM2_CH1IN,
|
||||||
.ti2cfg = GPIO_TIM2_CH2IN,
|
.ti2cfg = GPIO_TIM2_CH2IN,
|
||||||
.handler = stm32_tim2interrupt,
|
.handler = stm32_tim2interrupt,
|
||||||
@ -244,7 +271,7 @@ static const struct stm32_qeconfig_s g_tim3config =
|
|||||||
.timid = 3,
|
.timid = 3,
|
||||||
.irq = STM32_IRQ_TIM3,
|
.irq = STM32_IRQ_TIM3,
|
||||||
.base = STM32_TIM3_BASE,
|
.base = STM32_TIM3_BASE,
|
||||||
.clkin = STM32_APB1_TIM3_CLKIN,
|
.psc = (STM32_APB1_TIM3_CLKIN / CONFIG_STM32_TIM3_QECLKOUT) - 1,
|
||||||
.ti1cfg = GPIO_TIM3_CH1IN,
|
.ti1cfg = GPIO_TIM3_CH1IN,
|
||||||
.ti2cfg = GPIO_TIM3_CH2IN,
|
.ti2cfg = GPIO_TIM3_CH2IN,
|
||||||
.handler = stm32_tim3interrupt,
|
.handler = stm32_tim3interrupt,
|
||||||
@ -265,7 +292,7 @@ static const struct stm32_qeconfig_s g_tim4config =
|
|||||||
.timid = 4,
|
.timid = 4,
|
||||||
.irq = STM32_IRQ_TIM4,
|
.irq = STM32_IRQ_TIM4,
|
||||||
.base = STM32_TIM4_BASE,
|
.base = STM32_TIM4_BASE,
|
||||||
.clkin = STM32_APB1_TIM4_CLKIN,
|
.psc = (STM32_APB1_TIM4_CLKIN / CONFIG_STM32_TIM4_QECLKOUT) - 1,
|
||||||
.ti1cfg = GPIO_TIM4_CH1IN,
|
.ti1cfg = GPIO_TIM4_CH1IN,
|
||||||
.ti2cfg = GPIO_TIM4_CH2IN,
|
.ti2cfg = GPIO_TIM4_CH2IN,
|
||||||
.handler = stm32_tim4interrupt,
|
.handler = stm32_tim4interrupt,
|
||||||
@ -286,7 +313,7 @@ static const struct stm32_qeconfig_s g_tim5config =
|
|||||||
.timid = 5,
|
.timid = 5,
|
||||||
.irq = STM32_IRQ_TIM5,
|
.irq = STM32_IRQ_TIM5,
|
||||||
.base = STM32_TIM5_BASE,
|
.base = STM32_TIM5_BASE,
|
||||||
.clkin = STM32_APB1_TIM5_CLKIN,
|
.psc = (STM32_APB1_TIM5_CLKIN / CONFIG_STM32_TIM5_QECLKOUT) - 1,
|
||||||
.ti1cfg = GPIO_TIM5_CH1IN,
|
.ti1cfg = GPIO_TIM5_CH1IN,
|
||||||
.ti2cfg = GPIO_TIM5_CH2IN,
|
.ti2cfg = GPIO_TIM5_CH2IN,
|
||||||
.handler = stm32_tim5interrupt,
|
.handler = stm32_tim5interrupt,
|
||||||
@ -307,7 +334,7 @@ static const struct stm32_qeconfig_s g_tim8config =
|
|||||||
.timid = 8,
|
.timid = 8,
|
||||||
.irq = STM32_IRQ_TIM8UP,
|
.irq = STM32_IRQ_TIM8UP,
|
||||||
.base = STM32_TIM8_BASE,
|
.base = STM32_TIM8_BASE,
|
||||||
.clkin = STM32_APB2_TIM8_CLKIN,
|
.psc = (STM32_APB2_TIM8_CLKIN / CONFIG_STM32_TIM8_QECLKOUT) - 1,
|
||||||
.ti1cfg = GPIO_TIM8_CH1IN,
|
.ti1cfg = GPIO_TIM8_CH1IN,
|
||||||
.ti2cfg = GPIO_TIM8_CH2IN,
|
.ti2cfg = GPIO_TIM8_CH2IN,
|
||||||
.handler = stm32_tim8interrupt,
|
.handler = stm32_tim8interrupt,
|
||||||
@ -608,7 +635,6 @@ static int stm32_tim8interrupt(int irq, FAR void *context)
|
|||||||
static int stm32_setup(FAR struct qe_lowerhalf_s *lower)
|
static int stm32_setup(FAR struct qe_lowerhalf_s *lower)
|
||||||
{
|
{
|
||||||
FAR struct stm32_lowerhalf_s *priv = (FAR struct stm32_lowerhalf_s *)lower;
|
FAR struct stm32_lowerhalf_s *priv = (FAR struct stm32_lowerhalf_s *)lower;
|
||||||
uint32_t psc;
|
|
||||||
uint16_t dier;
|
uint16_t dier;
|
||||||
uint16_t smcr;
|
uint16_t smcr;
|
||||||
uint16_t ccmr1;
|
uint16_t ccmr1;
|
||||||
@ -634,23 +660,13 @@ static int stm32_setup(FAR struct qe_lowerhalf_s *lower)
|
|||||||
|
|
||||||
stm32_putreg32(priv, STM32_GTIM_ARR_OFFSET, 0xffff);
|
stm32_putreg32(priv, STM32_GTIM_ARR_OFFSET, 0xffff);
|
||||||
|
|
||||||
/* Calculate and set the timer rescaler value. The clock input value (CLKIN) is
|
/* Set the timerp rescaler value. The clock input value (CLKIN) is based on the
|
||||||
* based on the peripheral clock (PCLK) and a multiplier. These CLKIN values are
|
* peripheral clock (PCLK) and a multiplier. These CLKIN values are provided in
|
||||||
* provided in the board.h file. The prescaler value is then that CLKIN value
|
* the board.h file. The prescaler value is then that CLKIN value divided by the
|
||||||
* divided by the the configured CLKOUT value (minus one)
|
* configured CLKOUT value (minus one)
|
||||||
*
|
|
||||||
* For example:
|
|
||||||
* TIM8 is APB2. Suppose HCLK==SYSCLOCK, HCLK is 168MHz and PCLK2 is HCLK/2, then
|
|
||||||
* the TIM8 CLKIN value will be 2*HCLK or 168MHz.
|
|
||||||
*
|
|
||||||
* If the desired CLKOUT is 28MHz, then the prescaler would be 5. NOTE that this
|
|
||||||
* calculation would fail if the CLKIN value is less than the CLKOUT value.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
DEBUGASSERT(priv->clkin >= CONFIG_STM32_TIM_QECLKOUT);
|
stm32_putreg16(priv, STM32_GTIM_PSC_OFFSET, (uint16_t)priv->psc);
|
||||||
psc = (priv->clkin / CONFIG_STM32_TIM_QECLKOUT) - 1;
|
|
||||||
|
|
||||||
stm32_putreg16(priv, STM32_GTIM_PSC_OFFSET, (uint16_t)psc);
|
|
||||||
|
|
||||||
#if defined(CONFIG_STM32_TIM1_QE) || defined(CONFIG_STM32_TIM8_QE)
|
#if defined(CONFIG_STM32_TIM1_QE) || defined(CONFIG_STM32_TIM8_QE)
|
||||||
if (priv->config->timid == 1 || priv->config->timid == 8)
|
if (priv->config->timid == 1 || priv->config->timid == 8)
|
||||||
|
Loading…
Reference in New Issue
Block a user