新手上路
- 积分
- 23
- 金钱
- 23
- 注册时间
- 2020-7-16
- 在线时间
- 6 小时
|
本帖最后由 goodmor9 于 2020-7-18 07:44 编辑
按照《STM32F429 开发指南V1.1 – HAL 库版本》3.3.1 新建基于HAL库工程模板,第一个例子LED闪灯完美运行,第二个例子撞到墙了。串口通讯,只收到了t:0就停止了。
想了想,找出下载的程序源码,打开,运行,一切正常。这就很有趣了。
调试模式,发现自己的工程到了delay_us里的if(tnow!=told)一直无法进入,两个值一直是0,再查SysTick.LOAD也是0.
于是调试下载的源码,发现SysTick.LOAD有值,那么问题出在初始化。
于是从头开始单步跟踪下载的源码 main-> HAL_Init(stm32f4xx_hal.c)->HAL_InitTick(stm32f4xx_hal.c) 发现HAL_InitTick声明带_weak,想到会不会被覆盖了。
再调试自己的代码 main-> HAL_Init(stm32f4xx_hal.c)->HAL_InitTick,到这一步蹦出一个新文件,stm32f4xx_hal_timebase_tim_template.c里面有个HAL_InitTick函数
程序就是跑到这里了。导致了两个工程运行的结果不一致。
这个文件里的函数为什么不好用目前还看不明白,先搞明白这个文件哪里来的。
发现这个文件在HALLIB里面,是F4的固件包,可是这个包里的文件都是从下载的 STM32参考资料 里的 STM32CubeF4固件包 下的文件。难道跟下载源码里的不一样?
比对了一下发现真的不一样,下载源码里的HALLIB里没有stm32f4xx_hal_timebase_tim_template.c这个文件。而固件包里却有。
再看开发指南里提到要排除的文件也不包括这个。再次比对,发现问题所在。
文档中写的固件包是v1.10.0 而下载资料里的固件包是v1.11.0 新版本就多了这个文件,而网站上最新版是v1.25.0 导致不正常的文件更多了。
刷程序再试,输出不对,一步一步跟踪发现stm32f4xx_hal_conf.h里的HSE_Value还是8M,改成25M,终于OK了。
至此,暂时告一段落。对于新人来说,这个坑还挺有趣。
|
|