stm32/powerctrl: Fix configuring APB1/APB2 frequency when AHB also set.
APB1/APB2 are derived from AHB, so if the user sets AHB!=SYSCLK then the APB1/APB2 dividers must be computed from the new AHB.
This commit is contained in:
parent
dff14c740b
commit
9e4812771b
|
@ -110,13 +110,16 @@ set_clk:
|
||||||
} else {
|
} else {
|
||||||
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
|
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
|
||||||
}
|
}
|
||||||
|
#if !defined(STM32H7)
|
||||||
|
ahb = sysclk >> AHBPrescTable[RCC_ClkInitStruct.AHBCLKDivider >> RCC_CFGR_HPRE_Pos];
|
||||||
|
#endif
|
||||||
if (apb1 != 0) {
|
if (apb1 != 0) {
|
||||||
RCC_ClkInitStruct.APB1CLKDivider = calc_apb_div(sysclk / apb1);
|
RCC_ClkInitStruct.APB1CLKDivider = calc_apb_div(ahb / apb1);
|
||||||
} else {
|
} else {
|
||||||
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV4;
|
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV4;
|
||||||
}
|
}
|
||||||
if (apb2 != 0) {
|
if (apb2 != 0) {
|
||||||
RCC_ClkInitStruct.APB2CLKDivider = calc_apb_div(sysclk / apb2);
|
RCC_ClkInitStruct.APB2CLKDivider = calc_apb_div(ahb / apb2);
|
||||||
} else {
|
} else {
|
||||||
RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2;
|
RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue