您现在的位置是:系统运维 >>正文
如何优雅的使用 MDK 解除芯片读保护?
系统运维47926人已围观
简介经历过产品量产的同学应该都知道,芯片一般会在出厂时开启读保护:要么在代码中加入,要么在烧录程序后人工通过软件开启该功能,比如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.noorid.com/html/943b499052.html
相关文章
《中国攻击面管理市场白皮书》:基于攻防视角构建网络安全的主动防御体系
系统运维在数字化转型过程中,数字技术对企业的业务模式、组织架构和企业文化产生了积极影响,但同时也给企业带来更多的安全威胁和风险:企业暴露在互联网上的攻击面数据呈指数级增长,攻击载体也随之大量增加。攻击面正在成 ...
【系统运维】
阅读更多重装系统教程(轻松学会使用电脑光盘启动来重装系统)
系统运维在电脑系统出现问题或需要升级时,重装系统是一个常见的解决方法。而使用电脑光盘启动则是重装系统的一种常用方式。本文将详细介绍如何使用电脑光盘来启动并重装系统,帮助读者轻松解决系统问题。1.准备工作在开始 ...
【系统运维】
阅读更多《高效使用产线打印机的教程》(快速上手,轻松提升生产力)
系统运维随着科技的发展和生产方式的改变,产线打印机已经成为现代工厂中不可或缺的设备。然而,许多人对于如何正确使用产线打印机仍然感到困惑。本文将为大家介绍如何高效使用产线打印机,让您轻松提升生产力。一、了解产线 ...
【系统运维】
阅读更多