经历过产品量产的何优同学应该都知道,芯片一般会在出厂时开启读保护 :要么在代码中加入,使用要么在烧录程序后人工通过软件开启该功能 ,除芯比如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 文件保存起来,只要每次加载这个文件即可成功解除。 一次设置,永不烦恼 ,相当的实用! |
Realtek 蓝牙安全连接配对漏洞可导致攻击者发起拒绝服务攻击戴尔PowerEdge以高性能计算 为奥运健儿保驾护航谷歌 Chrome 零日漏洞遭广泛利用,可执行任意代码解决WiFi已连接但无法上网的问题(探索WiFi连接问题背后的原因及有效解决方案)企业通过谈判策略降低赎金支付的实战经验备份系统也能成为“核心设施”?瑞数信息给出了一套“有韧性”解题思路!数据中心在冷却、成本和二氧化碳减排方面均未达到目标出柜率、上架率、负载率,数据中心运营的三个重要指标,你知道吗?戴尔科技PowerScale在IDC行业追踪报告中年年保持销量冠军身份安全成焦点:Palo Alto Networks拟以250亿美元收购CyberArk源码库云服务器亿华云网站建设香港物理机企业服务器b2b信息平台