没事多年前的一块STM32F103ZE的开发板找出来,也借以打发时光。
找了一个LCD图片显示的工程,用HAL的库重新改了一下,一下就碰到了好多问题。毕竟刚刚接触HAL库。不断的找错,经过一下午的折腾,终于可以显示了,虽然有些显示的不对。
一个明显的感觉就是好像运行速度变慢了好多。难道是定时器配置问题导致延时不对?反复看了也没感觉哪有问题。打开debug查看TIM寄存器的配置,除了计数慢没有问题,只能是时钟不对了。打开RCC寄存器,结果发现了一个奇怪的问题,CPU时钟使用的是8MHz的HSI内部时钟,没有配置到72MHz,难怪感到慢。
于是在main()的第一行加上了SystemInit(),速度立马快了起来。但感觉定时部分还是不对,想到定时分频是用SystemCoreClock通过RCC寄存器参数算来的,于是又加上了SystemCoreClockUpdate(),让SystemCoreClock和RCC对应起来,终于可以正常显示字符图片了。
可问题是SystemInit()在启动的时候就已经执行了啊,改HAL之前也不需要再次执行。问题总需要搞清楚才好。于是又开始debug,断点设置发现启动的时候确实进了SystemInit,应该是配置时钟失败了,继续查找发现是HSE_STARTUP_TIMEOUT设置太小造成的,它的宏定义在STM32F1xx_hal_conf.h文件中为100,将它改为200,终于正常了。