你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

【实战经验】在没有外置晶振时HSE_RDY异常置位

[复制链接]
zero99 发布时间:2017-6-27 16:29
无外部高速时钟时HSE_RDY 被意外置位

前言
问题由客户提出,用户发现在STM32F103 器件上。用户在产品中使能了IWDG,在使用过程中发现当MCU被复位后,有时程序跑不下去;跟踪代码发现程序死在轮询PLL_RDY 处。用户反馈说用的就是ST库中的范例代码,怀疑STM32F103 有设计问题

调研
排查硬件供电无问题,用示波器测量NRST 发现复位信号正常,用STM32CubeMX 生成最小系统代码(时钟配置+IWDG)反复验证,未发现此问题,开始怀疑用户代码。

客户声称开发是基于ST 提供的SPL 库中自带的demo,使用SPL 中的范例代码加上IWDG 复位,确实可以复现此问题:通过调试器跟踪代码发现问题发生时HSE_RDY 位被异常置位(用户平台无外挂高速时钟源)

通过分析代码,发现SPL 库在设置时钟时会直接使能HSE,在复位若干次后HSE_RDY 位会被置位,从而导致程序(HSEStatus)按照HSE 来进行接下来的时钟配置。而SPL 中的demo 是跑在STM32F1 评估板上,而评估板自带高速时钟源,故没有此问题。

无外部高速时钟时HSE_RDY 被意外置位

无外部高速时钟时HSE_RDY 被意外置位
[size=0.83em]
1.PNG (91.21 KB, 下载次数: 0)
下载附件  [url=]保存到相册[/url]
2017-6-23 10:37 上传





结论
在MCU 复位后HSE_ON 默认是无效,反复对其进行使能操作会导致MCU 内部的噪声积累,造成时钟检测电路误判,并由寄存器反映出来。
   - 对STM32F103 来说,一旦HSE_RDY 被置位,只要不断电,无论如何复位HSE_RDY 都不会
被清除(即使失能HSE_ON)
   - 对STM32F030单片机进行类似操作,也会发现同样问题,不同之处在于在HSE_RDY被置位后复位MCU,HSE_RDY位会被清除,但是一旦HSE_ON被置位,HSE_RDY同样会被置位

处理
由于用户并不需要对是否有外接高速晶振进行判断,修改用户代码不要使能HSE,反复测试后问题不复现

建议
1 要了解HSE_RDY位是用来检测是否有外部时钟存在的必要条件,而非充分条件
2在使用STM32时,一定要按照硬件设计对软件做出修改,切勿图省事而造成问题



文档下载

更多实战经验
收藏 评论2 发布时间:2017-6-27 16:29

举报

2个回答
ataudio 回答时间:2017-6-27 16:40:08
好资料也要抢沙发。
MrJiu 回答时间:2017-6-27 17:03:11
换句话说就是,资料看的不认真!!!

所属标签

STM32团队

意法半导体微控制器和微处理器拥有广泛的产品线,包含低成本的8位单片机和基于ARM® Cortex®-M0、M0+、M3、M4、M33、M7及A7内核并具备丰富外设选择的32位微控制器及微处理器


最新内容

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版