您现在的位置是:IT资讯 >>正文
如何优雅的使用 MDK 解除芯片读保护?
IT资讯1人已围观
简介经历过产品量产的同学应该都知道,芯片一般会在出厂时开启读保护:要么在代码中加入,要么在烧录程序后人工通过软件开启该功能,比如STM32 ST-LINK Utility:当然也可以 ...
经历过产品量产的何优同学应该都知道,芯片一般会在出厂时开启读保护 :要么在代码中加入,使用要么在烧录程序后人工通过软件开启该功能,除芯比如STM32 ST-LINK Utility:

当然也可以使用该工具关闭读保护功能 。片读
为了保证程序不被读取 ,保护大多数产品应该会直接在量产代码中加入该功能 ,何优但这样会导致一个麻烦的使用问题:无法正常调试。
每次下载后,除芯如果代码出现问题,片读都需要在线调试,保护而你的何优代码为了不忘记 ,默认就是使用开启读保护功能的,源码库所以每次下载后,除芯如果发现问题,片读你可能要找一个工具,保护如 J-Flash 或者上面的软件负责关闭读保护 ,让我们的开发效率降低不少。
是否有更好的方法解除读保护呢?
今天鱼鹰介绍一种使用 MDK 解除读保护的方法 ,毕竟 MDK 软件绝大部分道友都会安装,所以使用它是最合适的 。
首先,建站模板说说它的读保护原理。
读保护功能是通过设置相应的 Option Bytes 来实现的 ,并且掉电不会消失 ,和 ROM 类似 。
而解除是则是复位相应的 Option Bytes 来实现 ,掉电也不会消失 ,但是不同的是免费模板,设置完之后 ,芯片自动会擦除整颗芯片 ,这样你也就不能通过解除读保护进而读取整颗芯片代码了。
但是,你会发现一个现象 ,即使你无法读取FLASH 的代码 ,你仍然可以通过上述工具连接芯片,这样就给我们使用 MDK 解除读保护创造了条件 。
在鱼鹰以前的笔记里面,有介绍如何使代码运行在 RAM 中,既然读保护保护的是源码下载 FLASH 区 ,RAM 并不受影响 ,那么我们就可以将我们解除的代码加载到 RAM 中运行,如此就可以通过 MDK 解除芯片的读保护了 。
具体操作如下:
1 、设置新的目标,比如:
然后设置该目标的输出目录,这样只要编译一次 ,之后就可以直接切换目标后直接点击debug ,不需要重复编译 ,相当方便(和正常输出目录不同) 。
新建两个目录 ,服务器租用并选择对应的目录即可




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



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

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


Enjoy it!!!
每次需要解除芯片读保护功能时 ,只要切换目标后即可成功解除(前提是香港云服务器已经编译过一次了) ,相当方便,当然你如果不想编译 ,也可以直接生成一个 axf 文件保存起来,只要每次加载这个文件即可成功解除 。
一次设置,永不烦恼,相当的实用!
Tags:
转载:欢迎各位朋友分享到网络,但转载请说明文章出处“算法与编程”。http://www.bzli.cn/news/721b299276.html
相关文章
网络安全行业的11个市场机遇
IT资讯随着信息化时代的发展,网络安全问题愈发突出,各行各业对网络监管和防护提出了更高的要求。以下是网络安全领域的十一大市场机遇:1.党政机关网络安全 党政机关作为国家权力机关的核心组成部分,对 ...
【IT资讯】
阅读更多win10更新1903重启老死机教程
IT资讯win10更新1903重启老死机是一个当时的普遍性BUG,很多用户都是游戏适配性的问题,解决方法需要简单的设置就可以了,需要的也用户快点来看看教程吧。win10更新1903老死机原因:这个是游戏的通用 ...
【IT资讯】
阅读更多360极速浏览器设置默认使用极速模式打开指定
IT资讯用户在面对众多的浏览器软件时,会根据自己的使用习惯来选择,其中就有用户会选择使用360极速浏览器,这款浏览器软件可以为用户带来不错的上网浏览体验,因此收获了庞大的用户群体,当用户在360极速浏览器软件 ...
【IT资讯】
阅读更多