您现在的位置是:物联网 >>正文
如何优雅的使用 MDK 解除芯片读保护?
物联网56663人已围观
简介经历过产品量产的同学应该都知道,芯片一般会在出厂时开启读保护:要么在代码中加入,要么在烧录程序后人工通过软件开启该功能,比如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.bziz.cn/html/832d399164.html
相关文章
关键基础设施的物联网安全解决方案
物联网对于关键基础设施,安全是不可协商的。保护网络、系统和资产以实现不间断运营对于组织、城市和国家的安全至关重要。令人遗憾的是,网络犯罪分子可以渗透 93% 的公司网络 (betanews.com)。鉴于此 ...
【物联网】
阅读更多五个数据中心冷却应避免的错误
物联网冷却数据中心似乎很简单。只要安装了传统的暖通空调设备,把空气吹过数据中心,就可以了?不一定。数据中心冷却是一个复杂的话题,容易出错,从而降低冷却系统的效率和有效性。考虑到这一现实,下面我们来看看常见的 ...
【物联网】
阅读更多未来五年,20%的以太网数据中心交换机端口将连接到AI服务器
物联网据 DellOro Group 最近发布的一份报告,到 2027 年20 %的以太网数据中心交换机端口将连接到加速服务器,以支持人工智能 (AI) 工作负载。新的生成式 AI 应 ...
【物联网】
阅读更多