STM32单片机编程调试常见问题(二) Keil5软件调试中常见的配置问题
文章目录
- 一.概要
- 二.Keil5调试时无法打断点并且部分代码语句执行被优化
- 三.Keil5烧录STM32程序代码后无法自动复位
- 四.Keil5调试时Watch界面中的变量不会实时更新
- 五.Keil5编译后无法进行 go to跳转到变量或函数
- 六.Keil5编辑时注释输入中文显示乱码问号
- 七.Keil5退出调试时出现Encountered an improper argument
- 小结
一.概要
在STM32单片机使用Keil5进行下载调试时,除了ST-Link这些下载调试器跟STM32开发板连接或者驱动安装配置的问题,还会遇到Keil5的配置不满足要求而引起的问题,下面针对常见由于配置引起的问题进行分析与解决。
二.Keil5调试时无法打断点并且部分代码语句执行被优化
优化大家都知道,-O0,-O1,-O2,-O3,等级越高优化程度越高,代码的执行效率也就越高。
Level0(-O0)不优化。
Level1(-O1)提供有限的优化,去除无用的inline和无用的static函数、死代码消除等,适合调试阶段使用。
Level2(-O2)提供高度优化,调试信息不友好,可能会修改代码和函数调用执行流程,自动对函数进行内联等。
Level3(-O3)提供最大程度的优化,产生极少量的调试信息,进行更多代码优化,例如循环展开和更激进的函数内联。
现象
在调试过程中,如果优化等级开的高,会造成断点的设置和变量值的查看异常。
比如下段代码:
第一段圈出来代码:Address = FLASH_USER_START_ADDR;可以打断点。
第二段圈出来的代码: Address = FLASH_USER_START_ADDR;却不可以打断点。
调试的过程中也会发现变量没有及时更新,但会在后面调用的时候才会更新,说明这句赋值的代码被优化了。
解决方法
修改优化等级由原来的Level3改为Level0。
清除目标生成代码,再重新编译
修改后的调试效果
主要代码:
int main(void)
{
/* USER CODE BEGIN 1 */
/* USER CODE END 1 */
/* MCU Configuration--------------------------------------------------------*/
/* Reset of all peripherals, Initializes the Flash interface and the Systick. */
HAL_Init();//初始化1毫秒 Tick
/* USER CODE BEGIN Init */
/* USER CODE END Init */
/* Configure the system clock */
SystemClock_Config();//外部8M晶振,系统72M主频
/* USER CODE BEGIN SysInit */
/* USER CODE END SysInit */
/* Initialize all configured peripherals */
MX_GPIO_Init();
/* USER CODE BEGIN 2 */
HAL_FLASH_Unlock();//FLASH解锁
/* Erase the user Flash area
(area defined by FLASH_USER_START_ADDR and FLASH_USER_END_ADDR) ***********/
/* Fill EraseInit structure*/
EraseInitStruct.TypeErase = FLASH_TYPEERASE_PAGES;
EraseInitStruct.PageAddress = FLASH_USER_START_ADDR;
EraseInitStruct.NbPages = (FLASH_USER_END_ADDR - FLASH_USER_START_ADDR) / FLASH_PAGE_SIZE;
if (HAL_FLASHEx_Erase(&EraseInitStruct, &PAGEError) != HAL_OK)//擦除FLASH
{
}
/* Program the user Flash area word by word
(area defined by FLASH_USER_START_ADDR and FLASH_USER_END_ADDR) ***********/
Address = FLASH_USER_START_ADDR;
while (Address < FLASH_USER_END_ADDR)
{
if (HAL_FLASH_Program(FLASH_TYPEPROGRAM_WORD, Address, DATA_32) == HAL_OK)//把0x12345678写入0x08008000开始的地址
{
Address = Address + 4;
}
else
{
}
}
HAL_FLASH_Lock();//FLASH锁
Address = FLASH_USER_START_ADDR;
MemoryProgramStatus = 0x0;
while (Address < FLASH_USER_END_ADDR)//取出来比对
{
data32 = *(__IO uint32_t *)Address;
if (data32 != DATA_32)
{
MemoryProgramStatus++;
}
Address = Address + 4;
}
while (1)
{
}
}
目前STM32cubeMX生成的Keil5工程代码的优化等级默认都是Level3,所以为了更好调试效果,可以把优化等级设置为Level0。
三.Keil5烧录STM32程序代码后无法自动复位
现象
STM32F103单片机每次烧写程序后都要按复位按键或重新上电程序才能运行,但有时候感觉又不需要按复位就能运行,一头雾水的感觉,其实主要是配置选项没有打开。
解决方法
遇到这种问题,一般需要如下图打开配置就可以
配置好后,下载完程序,单片机就能自动复位跑了,STM32cubeMX生成的Keil5工程代码默认是不打开的。
四.Keil5调试时Watch界面中的变量不会实时更新
现象
STM32F103单片机调试时,发现全局变量不会实时更新,只有停下来的时候变量的值才会更新。
解决方法
选择view菜单下的 Periodic window update就可以了
五.Keil5编译后无法进行 go to跳转到变量或函数
现象
鼠标右键无法Go To到变量或函数的定义处
解决方法
魔术棒下选择output选项卡 -> 勾选Browse information 选项 -> 重新编译工程
六.Keil5编辑时注释输入中文显示乱码问号
现象
有时会遇到中文注释无法正常显示的问题,出现的可能是方框或乱码
解决方法
选择界面Editor—>Configuration—>Encoding—> Chinese GB2312(Simplified)
七.Keil5退出调试时出现Encountered an improper argument
现象
Keil5调试完毕后要退出Debug模式,但是突然卡住了,还报错Error: Encountered an improper argument,只能通过任务管理器将它关闭。
解决方法
程序保存路径不要有中文字符、空格等,并且退出Debug模式时消除所设的断点,
修改程序路径这样就解决问题了。
小结
Keil5调试软件通过以上方法和技巧,可以有效解决Keil5调试中常见的问题,提高调试效率和准确性。