mirror of https://github.com/rusefi/openblt.git
Refs #1874. Documented/corrected timer APB bus selection for the STM32C0, STM32G0 and STM32G4 ports.
git-svn-id: https://svn.code.sf.net/p/openblt/code/trunk@1137 5dc33758-31d5-4daf-9ae8-b24bf3d40d73
This commit is contained in:
parent
b6765765ca
commit
9f68b1457c
|
@ -73,6 +73,10 @@ void TimerInit(void)
|
||||||
/* All STM32C0 derivatives support a TIM1 peripheral. Its free running counter will be
|
/* All STM32C0 derivatives support a TIM1 peripheral. Its free running counter will be
|
||||||
* used to realize the polling based millisecond time reference in this module.
|
* used to realize the polling based millisecond time reference in this module.
|
||||||
* Start by enabling the periperhal.
|
* Start by enabling the periperhal.
|
||||||
|
*
|
||||||
|
* Note that the STM32C0 features one PCLK clock that drives both APB1 and APB2 busses.
|
||||||
|
* The RCC LL drivers call PCLK PCLK1 and APB APB1. Therefore the following lines
|
||||||
|
* use the PCLK1/APB1 APIs, even though TIM1 is actually on ABP2.
|
||||||
*/
|
*/
|
||||||
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_TIM1);
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_TIM1);
|
||||||
/* The TIM1 peripheral clock is derived from PCLK. Obtain the PCLK frequency. */
|
/* The TIM1 peripheral clock is derived from PCLK. Obtain the PCLK frequency. */
|
||||||
|
|
|
@ -80,6 +80,10 @@ void TimerInit(void)
|
||||||
/* All STM32G0 derivatives support a TIM1 peripheral. Its free running counter will be
|
/* All STM32G0 derivatives support a TIM1 peripheral. Its free running counter will be
|
||||||
* used to realize the polling based millisecond time reference in this module.
|
* used to realize the polling based millisecond time reference in this module.
|
||||||
* Start by enabling the periperhal.
|
* Start by enabling the periperhal.
|
||||||
|
*
|
||||||
|
* Note that the STM32G0 features one PCLK clock that drives both APB1 and APB2 busses.
|
||||||
|
* The RCC LL drivers call PCLK PCLK1 and APB APB1. Therefore the following lines
|
||||||
|
* use the PCLK1/APB1 APIs, even though TIM1 is actually on ABP2.
|
||||||
*/
|
*/
|
||||||
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_TIM1);
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_TIM1);
|
||||||
/* The TIM1 peripheral clock is derived from PCLK. Obtain the PCLK frequency. */
|
/* The TIM1 peripheral clock is derived from PCLK. Obtain the PCLK frequency. */
|
||||||
|
|
|
@ -76,12 +76,12 @@ void TimerInit(void)
|
||||||
*/
|
*/
|
||||||
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_TIM1);
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_TIM1);
|
||||||
/* The TIM1 peripheral clock is derived from PCLK. Obtain the PCLK frequency. */
|
/* The TIM1 peripheral clock is derived from PCLK. Obtain the PCLK frequency. */
|
||||||
pclk_frequency = __LL_RCC_CALC_PCLK1_FREQ(SystemCoreClock, LL_RCC_GetAPB1Prescaler());
|
pclk_frequency = __LL_RCC_CALC_PCLK2_FREQ(SystemCoreClock, LL_RCC_GetAPB2Prescaler());
|
||||||
/* According to the clock tree diagram in the RCC chapter of the reference manual,
|
/* According to the clock tree diagram in the RCC chapter of the reference manual,
|
||||||
* the TPCLK frequency = PLCK * 1, when the APB1 prescaler is 1, otherwise it is
|
* the TPCLK frequency = PLCK * 1, when the APB1 prescaler is 1, otherwise it is
|
||||||
* PCLK * 2.
|
* PCLK * 2.
|
||||||
*/
|
*/
|
||||||
tim_multiplier = (LL_RCC_GetAPB1Prescaler() == LL_RCC_APB1_DIV_1) ? 1U : 2U;
|
tim_multiplier = (LL_RCC_GetAPB2Prescaler() == LL_RCC_APB2_DIV_1) ? 1U : 2U;
|
||||||
/* Obtain the TPCLK frequency. */
|
/* Obtain the TPCLK frequency. */
|
||||||
pclk_tim_frequency = pclk_frequency * tim_multiplier;
|
pclk_tim_frequency = pclk_frequency * tim_multiplier;
|
||||||
/* Configure the free running counter as a 16-bit upwards counter that runs at the
|
/* Configure the free running counter as a 16-bit upwards counter that runs at the
|
||||||
|
|
Loading…
Reference in New Issue