打印
[开发工具]

STM32 使用st-link调试遇到写保护 Flash Timeout 问题

[复制链接]
420|5
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
51xlf|  楼主 | 2022-5-10 20:38 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
ST, TI
1 FLASH的写保护

如果对Flash设置了写保护,那就无法对Flash进行编程和擦除。在开发STM32的时候,如果出现这种情况,通常仿真器都支持对Flash进行解锁,像jlink,stlink等仿真器都支持这个功能。

2 错误提示

在使用MDK进行调试的时候,出现报错 Flash Timeout.Reset Target and try it again,具体如下图所示;


折腾了一番之后,并没有解决问题,因为使用的仿真器是stlink,因此下载了stlink utility尝试解决问题;

3 stlink utility3.1 基本功能

stlink utility是ST官方提供的免费软件,支持STM32 ST-LINK的程序包括带有命令行界面(CLI)的图形用户界面(GUI)。
该工具还提供了较多的其他功能,具体如下;

  • 可以对STM32 内部存储器 (Flash,RAM,OTP和其他存储器),外部存储器进行编程;
  • 验证程序内容(校验和,在编程期间和之后进行校验,与文件进行比较等)
  • 还能实现 STM32编程自动化;
  • 另外还提供其他的功能;
3.2 解锁Flash

在stlink连接目标板的情况下,打开stlink utility,在菜单栏的Target下选择connect,因为这时候Flash已经被锁住了,所以同样地也看到相应的错误提示 Can not read memory Disable Read Out Protection and retry,具体如下图所示;


OK,下面只需要接触写保护就行了,所以在菜单栏target里打开Option Bytes…选项,或者直接通过快捷键ctrl+B打开,请确保当前已经正确连接了stlink和目标板,否则会出现报错;

正确连接的情况下,打开Option Bytes…,发现在这里Read Out Protection选项是enable,这个表示无法通过swd读取STM32内部Flash的程序。

关键点:
将Read Out Protection选项设置位disable,点击Apply,这时候Flash已经成功解锁了。但是同时发现,内部Flash已经被擦除了,,这可能STM32的保护机制有关,防止程序被拷机,然后进行反编译**,这样也可以提高**的门槛。具体显示如下图所示;

完成以上步骤之后,在菜单栏Target下选择Disconnect,或者通过快捷键ctrl+D断开和目标板的连接;重新进入MDK,就能正常对目标板进行调试,仿真,以及程序的烧写。

3.3 写保护

在菜单栏target里打开Option Bytes…选项,我们还看到下面有Flash sector protection选项;选择Select all之后,发现所有Page都已经写保护了,只要选择apply选项就可以对Flash进行写保护;具体如下所示;


使用特权

评论回复
沙发
kiwis66| | 2022-5-10 21:09 | 只看该作者
之前遇到过,不确定是不是这个问题了

使用特权

评论回复
板凳
lihuami| | 2022-5-28 16:53 | 只看该作者
为什么会内存保护了?

使用特权

评论回复
地板
minzisc| | 2022-5-29 09:47 | 只看该作者
之前遇到过,解锁不了。  

使用特权

评论回复
5
olivem55arlowe| | 2022-5-29 13:07 | 只看该作者
遇到过好几次了,是硬件的问题吗?

使用特权

评论回复
6
pklong| | 2022-5-29 19:08 | 只看该作者
用jink才能解锁吗?

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

534

主题

9586

帖子

23

粉丝