基于STM32G030F6部分芯片烧录程序后无法识别也不运行之救砖笔记
目录
- 问题背景
- 思路
- 总结
问题背景
使用STM32G030F6这颗ic作设计,程序中有设置L1级读保护。首次烧写全部显示成功,打算再次烧录时有极个别已经找不到芯片,其中不能再次烧入的板子程序功能都不正常。使用SWD的连接方式已经不能正常识别芯片了。其中设置L1级别的读保护代码片段如下:
void FlashProtectCheck(void)
{
FLASH_OBProgramInitTypeDef OBInit;
HAL_FLASH_Unlock();
HAL_FLASH_OB_Unlock();
HAL_FLASHEx_OBGetConfig(&OBInit);
if(OBInit.RDPLevel != OB_RDP_LEVEL_1)
{
OBInit.OptionType = OPTIONBYTE_RDP;
OBInit.RDPLevel = OB_RDP_LEVEL_1;
HAL_FLASHEx_OBProgram(&OBInit);
}
HAL_FLASH_OB_Lock();
HAL_FLASH_Lock();
}
思路
既然出现上述情况,芯片变砖了,自然而然就想救一下砖,也算是折腾的一次尝试,找到BOOT0脚,跟SWD下载是共用的引脚,如下:
看一下芯片手册的启动模式:
翻译:启动,引导引脚和引导选择器选项位用于选择三个引导选项之一:
从用户闪存引导
从系统内存引导
从嵌入式SRAM引导
boot引脚与标准GPIO共享,可以通过引导选择器选项位启用。引导加载程序位于系统内存中。它通过引脚PA9/PA10或PA2/PA3上的USART,或通过引脚PB6/PB7或PB10/PB11上的I2C总线来管理闪存重编程。
现在还需要另外一个资料,找到对应的参考资料:AN2606
找到描述的内容:
这里资料描述的是ic出厂时芯片厂会烧入一段程序,这段程序的作用就是引导作用。现在就是看一下上电进行哪些操作可以进入这段程序代码,找到进入方式:
因为我的芯片里面不是空的芯片,有烧入过程序,我尝试使用上图描述的方式进入引导程序。问题的关键是和芯片建立连接,关键的问题是识别不到芯片。
启动STM32CubeProgrammer 选择串口方式进行连接尝试
发现总是失败,拿一片好的板子进行展示一下:
去掉了那个nBOOT_SEL的选项,将PA14引脚接到高电平上,重新上电,使用串口的方式进行连接
可以看得连接成功,有对应成功的日志信息,建立连接之后可以进行程序烧入等操作。
总结
变砖拯救失败,又是飞一堆线,又是找串口模块接线啥的,折腾一段时间之后一直进入不了内置的bootloader程序,放弃了,成果就是输出了这篇文章,积累点经验,记录了自己尝试解决问题的发力点。
感谢阅读,本文完!!