STM32N6 平台如何使用 MCO2 输出 Clock

1. 引言

STM32N6 是 ST 第一款带 NPU 的基于 Cortex-M55 内核的 MCU,在 STM32N6 开发过程中,有客户遇到 MCO2 无输出问题,他们使用 24MHz 外部晶振,使用 RCC HAL API HAL_RCC_MCOConfig 设置 MCO2 输出,

参数选择 RCC_MCO2, RCC_MCO2SOURCE_HSE, RCC_MCODIV_1,期待获得 24MHz 输出波形,但 MCO2 管脚一直没有输出。本文将介绍具体原因及解决办法。

2. MCO2 输出设置

首先需要确定 MCO2 是使用哪个管脚输出的。我们使用 STM32N6-DK 板,其芯片型号为 STM32N657X0H3 (VFBGA264),

我们查询 STM32N6 数据手册 DB4396,GPIO PC9 AF0 功能为 MCO2。客户使用的是正确的管脚 PC9。

第二步检查客户代码如下,

C 复制代码
HAL_RCC_MCOConfig(RCC_MCO2, RCC_MCO2SOURCE_HSE, RCC_MCODIV_1);

这里并没有异常,我们交叉验证了 MCO1,使用

C 复制代码
HAL_RCC_MCOConfig(RCC_MCO1, RCC_MCO1SOURCE_HSE, RCC_MCODIV_1);

MCO1(PA8) 管脚是有正常波形输出的。

然后,我们查看了 PWR 输入输出供电设置,如下表 Table 1 (摘自参考手册 RM0486)

Table 1. PWR input/output signals connected to package pins or balls

这里,我们发现 MCO2 (PC9) 管脚是由 VDDIO4 独立供电的。默认情况下 VDDIO4 并不存在,需要通过 OTP 设置生效。

在 STM32N6 中 OTP 设置可以对系统及外设进行一定程度的配置。

如下表 2. OTP mapping(摘自 RM0486)所示,VDDIO4 IO Segment 可以通过OTP124 HCONF1 bit14 打开。

Table 2. OTP mapping

另外,还需要注意寄存器 VDDIO4SV@PWR_SVMCR1, 使用 PC[1]、PC[12:6]和PH[9:2]I/O 时,必须设置此位。

最后,在 OTP124 HCONF1 打开 HSLV_VDDIO4 的情况下,代码添加使能 VDDIO4 后问题解决。代码如下:

C 复制代码
HAL_PWREx_EnableVddIO4();
HAL_RCC_MCOConfig(RCC_MCO2, RCC_MCO2SOURCE_LSI, RCC_MCODIV_1);

3. 小结

本文简介了 STM32N6 MCO2 无波形输出问题的根源与解决办法,供有需要的客户参考。


本文档参考ST官方的《STM32N6 平台如何使用 MCO2 输出 Clock》文档。

相关推荐
Wave8454 小时前
基于 STM32 + ESP8266 + W25Q64 的双核 OTA 底层架构总结
stm32·嵌入式硬件·架构
xiangw@GZ5 小时前
WiFi 全世代(WiFi1~WiFi7)技术规范与核心参数总结
嵌入式硬件
振南的单片机世界6 小时前
CPU时钟:频率越高跑越快,但物理极限在“拖后腿”
stm32·单片机·嵌入式硬件
普中科技7 小时前
【普中 51-Ai8051 开发攻略】-- 第 20 章 输入捕获实验
单片机·嵌入式硬件·输入捕获·pca·普中科技·ai8051u·aicube
d111111111d7 小时前
直流电机位置式 PID 控制 和 舵机的区别
笔记·stm32·单片机·嵌入式硬件·学习
d111111111d9 小时前
了解Modbus
网络·笔记·stm32·单片机·嵌入式硬件·学习
三佛科技-1341638421210 小时前
主控FT32F031便携式吸尘器方案,迷你手持吸尘器MCU控制方案开发
单片机·嵌入式硬件·物联网·智能家居·pcb工艺
一个平凡而乐于分享的小比特11 小时前
一文读懂MCU与FPGA:核心区别、协同之道与双修秘籍
单片机·fpga开发·职场发展·mcu开发
踏着七彩祥云的小丑11 小时前
嵌入式——认识电子元器件——微动开关系列
单片机·嵌入式硬件
调光IC-小雅12 小时前
解析FP62××系列限流保护机制:为何它是DC/DC芯片的安全底线
单片机·嵌入式硬件