STM32F103C8T6 程序上电跑飞

前言
某客户反应说他们做回来的板子测试发现程序上电就跑飞了,下载都正常。检查了一个礼拜都不知道哪里出了问题,感觉无从下手。

一 问题排查
1.1 检查电路板
排除虚焊漏焊现象,查看晶体起震波形正常,查看BOOT引脚配置正常。
1.2 检查软件代码
客户使用了老的标准库,反应说代码在别的板子上验证过,运行正常。
1.3 IDE检查
客户使用KEIL MDK V5.X版本,下载代码正常,连接ST-LINK/v2 仿真DEBUG, 程序跑飞。
停在了一段空白的地址空间中。

二 测试流程
2.1 编写测试代码
在老版本的标准库的基础上,做了一个LED闪烁的DEMO程序,方便直观的观察现象。
测试后,问题同样,代码跑飞。
2.2 重新梳理工程
在STM32Cube架构上重新新建工程,确认发现客户使用的晶体频率已经超过了16MHz的上限
马上更换一个合适的晶体后并修改时钟驱动代码后,程序运行正常。LED开始稳定闪烁。

三 小结
虽然很多工程师已经很熟悉老的标准库的使用,但还是应该推荐客户选择使用STM32Cube来进行开发,这样这个问题在一开始就会避免。

永不止步步 发表于02-20 09:49 浏览65535次
分享到:

已有0条评论

暂时还没有回复哟,快来抢沙发吧

添加一条新评论

只有登录用户才能评论,请先登录注册哦!

话题作者

永不止步步
金币:67417个|学分:363791个
立即注册
畅学电子网,带你进入电子开发学习世界
专业电子工程技术学习交流社区,加入畅学一起充电加油吧!

x

畅学电子网订阅号