1、引言
STM32N6 是 ST 第一款带 NPU 的基于 Cortex-M55 内核的 MCU,在 STM32N6 开发过程中,有客户遇到 MCO2 无输出问题,他们使用 24MHz 外部晶振,使用 RCC HAL APIHAL_RCC_MCOConfig 设置 MCO2 输出,参数选择 RCC_MCO2,RCC_MCO2SOURCE_HSE, RCC_MCODIV_1,期待获得 24MHz 输出波形,但 MCO2 管脚一直没有输出。本文将介绍具体原因及解决办法。
2、MCO2 输出设置
首先需要确定 MCO2 是使用哪个管脚输出的。我们使用 STM32N6-DK 板,其芯片型号为 STM32N657X0H3 (VFBGA264), 我们查询 STM32N6 数据手册 DB4396,GPIO PC9AF0 功能为 MCO2。客户使用的是正确的管脚 PC9。
第二步检查客户代码如下,HAL_RCC_MCOConfig(RCC_MCO2, RCC_MCO2SOURCE_HSE, RCC_MCODIV_1);这里并没有异常,我们交叉验证了 MCO1,使用HAL_RCC_MCOConfig(RCC_MCO1, RCC_MCO1SOURCE_HSE, RCC_MCODIV_1);MCO1(PA8) 管脚是有正常波形输出的。
这里,我们发现 MCO2 (PC9) 管脚是由 VDDIO4 独立供电的。默认情况下 VDDIO4 并不存在,需要通过 OTP 设置生效。在 STM32N6 中 OTP 设置可以对系统及外设进行一定程度的配置。
另外,还需要注意寄存器 VDDIO4SV@PWR_SVMCR1, 使用 PC[1]、PC[12:6]和PH[9:2]I/O 时,必须设置此位。
3、小结
本文简介了 STM32N6 MCO2 无波形输出问题的根源与解决办法,供有需要的客户参考。
649