ST意法半导体
直播中

蒋美燕

7年用户 898经验值
私信 关注
[问答]

为什么STM32H745芯片上的HSI RC频率会下降呢

根据 STM32H745xI/G 数据表,64MHz HSI 在室温下的精度为 +/- 0.3 MHz,即 +/- 0.5%。
在测试期间,我注意到大约 10-20% 的 UART 字符被丢弃。然后我查看示波器上的信号,发现频率已关闭。
将系统时钟重定向到 MCO2 (PC9) 并在示波器上测量后,我发现了问题:
STM32H745芯片上的HSI RC (64 MHz) off 4%!!“工厂校准”就这么多了。
我在这里错过了什么吗?
时钟初始化(480MHz):
  • /** Initializes the CPU, AHB and APB busses clocks
  •   */
  • RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
  • RCC_OscInitStruct.HSIState = RCC_HSI_DIV1;
  • RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
  • RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  • RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI;
  • RCC_OscInitStruct.PLL.PLLM = 32;
  • RCC_OscInitStruct.PLL.PLLN = 480;
  • RCC_OscInitStruct.PLL.PLLP = 2;
  • RCC_OscInitStruct.PLL.PLLQ = 2;
  • RCC_OscInitStruct.PLL.PLLR = 2;
  • RCC_OscInitStruct.PLL.PLLRGE = RCC_PLL1VCIRANGE_1;
  • RCC_OscInitStruct.PLL.PLLVCOSEL = RCC_PLL1VCOWIDE;
  • RCC_OscInitStruct.PLL.PLLFRACN = 0;
  • if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) {
  •   Error_Handler();
  • }
  • /** Initializes the CPU, AHB and APB busses clocks
  •   */
  • RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_SYSCLK
  •    | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2 | RCC_CLOCKTYPE_D3PCLK1
  •    | RCC_CLOCKTYPE_D1PCLK1;
  • RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  • RCC_ClkInitStruct.SYSCLKDivider = RCC_SYSCLK_DIV1;
  • RCC_ClkInitStruct.AHBCLKDivider = RCC_HCLK_DIV2;
  • RCC_ClkInitStruct.APB3CLKDivider = RCC_APB3_DIV2;
  • RCC_ClkInitStruct.APB1CLKDivider = RCC_APB1_DIV2;
  • RCC_ClkInitStruct.APB2CLKDivider = RCC_APB2_DIV2;
  • RCC_ClkInitStruct.APB4CLKDivider = RCC_APB4_DIV2;
  • if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_4) != HAL_OK) {
  •   Error_Handler();
  • }
MCO 初始化:
  • HAL_RCC_MCOConfig(RCC_MCO2, RCC_MCO2SOURCE_SYSCLK, RCC_MCODIV_10);
测得的频率为 45.99 MHz,与应有的 48 MHz 相差 -4.2%。

如果我改成 400MHz,结果是一样的。-4.2% 从它应该是什么。

回帖(1)

李微波

2022-12-22 11:45:22
这里存在一些误解/错误信息。硬编码的校准值不能被覆盖。__HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST 和类似的是调整 HSITRIM,间接调整 HSICAL。原始的 HSICAL 总是可以通过恢复 HSITRIM 的默认复位值来复位,不幸的是,该值因芯片版本而异。
ST目前的代码如下:


  • #if defined(RCC_HSICFGR_HSITRIM_6)
  • #define RCC_HSICALIBRATION_DEFAULT     (0x40U)         /* Default HSI calibration trimming value, for STM32H7 rev.V and above  */
  • #else
  • #define RCC_HSICALIBRATION_DEFAULT     (0x20U)         /* Default HSI calibration trimming value, for STM32H7 rev.Y */
  • #endif

但由于始终定义 RCC_HSICFGR_HSITRIM_6,因此它的计算结果始终为 0x40。它不像不同的芯片版本有不同的包含文件。
举报

更多回帖

发帖
×
20
完善资料,
赚取积分