3

如何优雅的使用 MDK 解除芯片读保护?

 2 years ago
source link: https://server.51cto.com/article/702709.html
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client
如何优雅的使用 MDK 解除芯片读保护?-51CTO.COM
如何优雅的使用 MDK 解除芯片读保护?
作者:鱼鹰Osprey 2022-02-28 09:19:12
今天鱼鹰介绍一种使用 MDK 解除读保护的方法,毕竟 MDK 软件绝大部分道友都会安装,所以使用它是最合适的。

经历过产品量产的同学应该都知道,芯片一般会在出厂时开启读保护:要么在代码中加入,要么在烧录程序后人工通过软件开启该功能,比如STM32 ST-LINK Utility:

f47583123cc12f9d00108414229041707564ee.png

当然也可以使用该工具关闭读保护功能。

为了保证程序不被读取,大多数产品应该会直接在量产代码中加入该功能,但这样会导致一个麻烦的问题:无法正常调试。

每次下载后,如果代码出现问题,都需要在线调试,而你的代码为了不忘记,默认就是开启读保护功能的,所以每次下载后,如果发现问题,你可能要找一个工具,如 J-Flash 或者上面的软件负责关闭读保护,让我们的开发效率降低不少。

是否有更好的方法解除读保护呢?

今天鱼鹰介绍一种使用 MDK 解除读保护的方法,毕竟 MDK 软件绝大部分道友都会安装,所以使用它是最合适的。

首先,说说它的读保护原理。

读保护功能是通过设置相应的 Option Bytes 来实现的,并且掉电不会消失,和 ROM 类似。

而解除是则是复位相应的 Option Bytes 来实现,掉电也不会消失,但是不同的是,设置完之后,芯片自动会擦除整颗芯片,这样你也就不能通过解除读保护进而读取整颗芯片代码了。

但是,你会发现一个现象,即使你无法读取FLASH 的代码,你仍然可以通过上述工具连接芯片,这样就给我们使用 MDK 解除读保护创造了条件。

在鱼鹰以前的笔记里面,有介绍如何使代码运行在 RAM 中,既然读保护保护的是 FLASH 区,RAM 并不受影响,那么我们就可以将我们解除的代码加载到 RAM 中运行,如此就可以通过 MDK 解除芯片的读保护了。

具体操作如下:

1、设置新的目标,比如:

9796a2b342b181498182779081ce383ebcf6ce.png

然后设置该目标的输出目录,这样只要编译一次,之后就可以直接切换目标后直接点击debug,不需要重复编译,相当方便(和正常输出目录不同)。

新建两个目录,并选择对应的目录即可

7329f99972fb355d4d31721f2fab0acd66b0d2.png

81fc1ab98baa758632f0116b2473171923ea28.png

c53bf1077e64bc50e314966af3fa6263ff8438.png

2、切换到新目标,然后在 C/C++ 选项卡中增加新宏 READ_PROTECT。

129a98e553a5d072361480f4b3799ee533f917.png

然后在代码中根据该宏加入解除读保护代码

98ca0a6260db764fb7c496bfe6bb72a811da8e.png

3、将代码地址重新定位到 RAM 中(0x20000000 为 RAM 首地址,假设 64 K 空间)

a133939173454875062175af4fd17cde18cc08.png

4、新建 run_ram文件,内容如下:

28084c114bde38d2762250203d5c7a5dd497bf.png

保存到工程目录下,然后将其正确添加:

d290035384f2746985b8325957b525c905cfbe.png

去掉勾选(这样就不会下载程序到 FLASH了):

f3be2802104197688ac241d830f0e053ca95ed.png

5、编译,然后点击Debug 即可,此时程序应该自动停止在断点处 __breakpoint(0),说明解除代码已经顺利运行完成。

b65bc3f628e17021ad9743e80f0e5ea8dce3cf.png

Enjoy it!!!

每次需要解除芯片读保护功能时,只要切换目标后即可成功解除(前提是已经编译过一次了),相当方便,当然你如果不想编译,也可以直接生成一个 axf 文件保存起来,只要每次加载这个文件即可成功解除。

一次设置,永不烦恼,相当的实用!


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK