您现在的位置是:亿华云 > 应用开发
如何优雅的使用 MDK 解除芯片读保护?
亿华云2025-10-08 21:13:15【应用开发】2人已围观
简介经历过产品量产的同学应该都知道,芯片一般会在出厂时开启读保护:要么在代码中加入,要么在烧录程序后人工通过软件开启该功能,比如STM32 ST-LINK Utility:当然也可以
经历过产品量产的何优同学应该都知道,芯片一般会在出厂时开启读保护:要么在代码中加入,使用要么在烧录程序后人工通过软件开启该功能,除芯比如STM32 ST-LINK Utility:
当然也可以使用该工具关闭读保护功能。片读
为了保证程序不被读取,保护大多数产品应该会直接在量产代码中加入该功能,何优但这样会导致一个麻烦的使用问题:无法正常调试。
每次下载后,除芯如果代码出现问题,片读都需要在线调试,保护而你的何优代码为了不忘记,默认就是使用开启读保护功能的,所以每次下载后,除芯如果发现问题,片读你可能要找一个工具,保护如 J-Flash 或者上面的软件负责关闭读保护,让我们的开发效率降低不少。
是否有更好的方法解除读保护呢?
今天鱼鹰介绍一种使用 MDK 解除读保护的方法,毕竟 MDK 软件绝大部分道友都会安装,所以使用它是最合适的。
首先,说说它的b2b供应网读保护原理。
读保护功能是通过设置相应的 Option Bytes 来实现的,并且掉电不会消失,和 ROM 类似。
而解除是则是复位相应的 Option Bytes 来实现,掉电也不会消失,但是不同的是,设置完之后,芯片自动会擦除整颗芯片,这样你也就不能通过解除读保护进而读取整颗芯片代码了。
但是,你会发现一个现象,即使你无法读取FLASH 的代码,你仍然可以通过上述工具连接芯片,这样就给我们使用 MDK 解除读保护创造了条件。
在鱼鹰以前的笔记里面,有介绍如何使代码运行在 RAM 中,既然读保护保护的是 FLASH 区,RAM 并不受影响,源码下载那么我们就可以将我们解除的代码加载到 RAM 中运行,如此就可以通过 MDK 解除芯片的读保护了。
具体操作如下:
1、设置新的目标,比如:然后设置该目标的输出目录,这样只要编译一次,之后就可以直接切换目标后直接点击debug,不需要重复编译,相当方便(和正常输出目录不同)。
新建两个目录,并选择对应的目录即可
然后在代码中根据该宏加入解除读保护代码
保存到工程目录下,然后将其正确添加:
去掉勾选(这样就不会下载程序到 FLASH了):
Enjoy it!!!
每次需要解除芯片读保护功能时,只要切换目标后即可成功解除(前提是已经编译过一次了),相当方便,当然你如果不想编译,b2b信息网也可以直接生成一个 axf 文件保存起来,只要每次加载这个文件即可成功解除。
一次设置,永不烦恼,相当的实用!
很赞哦!(1)
下一篇: 4、说起来容易
相关文章
- 只要我们做的是从目前的市场情况选择域名,从简单易记,从个性特征上,我们就可以找到一个好域名进行注册。域名注册进行域名记录和解析以及绑定网站后,客户可以通过URL登录您的网站。
- 如何基于Nginx搭建流媒体服务器
- 英特尔携手合作共话可持续发展,加速液冷技术在数据中心应用落地
- Arm招股书高度重视RISC-V竞争风险 谷歌三星高通等都已做两手准备
- 3、不明先知,根据相关征兆预测可能发生的事件,以便提前做好准备,赶紧注册相关域名。;不差钱域名;buchaqian抢先注册,就是这种敏感类型。预言是最敏感的状态。其次,你应该有眼力。所谓眼力,就是善于从社会上时不时出现的各种热点事件中获取与事件相关的域名资源。眼力的前提是对域名领域的熟悉和丰富的知识。
- 成功管理和保护数据的三种方法
- 为什么Telnet依旧很流行!
- 什么是边缘数据中心,为什么它们对 5G 至关重要?
- 为了避免将来给我们的个人站长带来的麻烦,在选择域名后缀时,我们的站长最好省略不稳定的后缀域名,比如n,因为我们不知道策略什么时候会改变,更不用说我们将来是否还能控制这个域名了。因此,如果站长不是企业,或者有选择的话,如果不能选择域名的cn类,最好不要选择它。
- 为什么数据中心是游戏的未来