0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

介绍一种使用MDK解除读保护的方法

Dp1040 来源:鱼鹰谈单片机 2023-12-26 09:18 次阅读

经历过产品量产的同学应该都知道,芯片一般会在出厂时开启读保护:要么在代码中加入,要么在烧录程序后人工通过软件开启该功能,比如 STM32 ST-LINK Utility:

wKgZomWKKiyAftiqAAD44MI3oUo030.png

当然也可以使用该工具关闭读保护功能。

为了保证程序不被读取,大多数产品应该会直接在量产代码中加入该功能,但这样会导致一个麻烦的问题:无法正常调试

每次下载后,如果代码出现问题,都需要在线调试,而你的代码为了不忘记,默认就是开启读保护功能的,所以每次下载后,如果发现问题,你可能要找一个工具,如 J-Flash 或者上面的软件负责关闭读保护,让我们的开发效率降低不少。

是否有更好的方法解除读保护呢?

今天给大家介绍一种使用 MDK 解除读保护的方法,毕竟 MDK 软件绝大部分道友都会安装,所以使用它是最合适的。

首先,说说它的读保护原理。

读保护功能是通过设置相应的 Option Bytes 来实现的,并且掉电不会消失,和 ROM 类似。

而解除是则是复位相应的 Option Bytes 来实现,掉电也不会消失,但是不同的是,设置完之后,芯片自动会擦除整颗芯片,这样你也就不能通过解除读保护进而读取整颗芯片代码了。

但是,你会发现一个现象,即使你无法读取 FLASH 的代码,你仍然可以通过上述工具连接芯片,这样就给我们使用 MDK 解除读保护创造了条件。

在鱼鹰以前的笔记里面,有介绍如何使代码运行在 RAM 中,既然读保护保护的是 FLASH 区,RAM 并不受影响,那么我们就可以将我们解除的代码加载到 RAM 中运行,如此就可以通过 MDK 解除芯片的读保护了。

具体操作如下(若如下操作不懂,建议参考这篇笔记《STM32工程模板建立之 RAM 目标(五)》):

1、设置新的目标,比如:

wKgaomWKKiyASEiIAABrUB2R_DY117.png

然后设置该目标的输出目录,这样只要编译一次,之后就可以直接切换目标后直接点击 debug,不需要重复编译,相当方便(和正常输出目录不同)。

新建两个目录,并选择对应的目录即可:

wKgaomWKKi2ACeZdAABjOE32AFs953.png

wKgZomWKKi2ACwZzAACO0eeT41o549.png

wKgaomWKKi2AFJiiAACQpxRjmrs926.png

2、切换到新目标,然后在 C/C++ 选项卡中增加新宏 READ_PROTECT。

wKgaomWKKi2AUkKgAABpfn6P1OE018.png

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

wKgaomWKKi2AB_q_AAHmFrbOQqI654.png

3、将代码地址重新定位到 RAM 中(0x20000000 为 RAM 首地址,假设 64 K 空间)。

wKgZomWKKi2AAn-rAACDE9KtSQs577.png

4、新建 run_ram文件,内容如下:

wKgaomWKKi2ASd2aAADteqqAz-o978.png

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

wKgaomWKKiyAaowRAAEgZW014dE543.png

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

wKgZomWKKi2AYC3-AABnLogySlc251.png

5、编译,然后点击Debug 即可。

此时,程序应该自动停止在断点处 __breakpoint(0),说明解除代码已经顺利运行完成。

wKgZomWKKi2ASdHLAAEHVX01nqs421.png

Enjoy it!!!

每次需要解除芯片读保护功能时,只要切换目标后即可成功解除(前提是已经编译过一次了),相当方便,当然你如果不想编译,也可以直接生成一个 axf 文件保存起来,只要每次加载这个文件即可成功解除。

一次设置,永不烦恼,相当的实用!






审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • ROM
    ROM
    +关注

    关注

    4

    文章

    563

    浏览量

    85731
  • STM32
    +关注

    关注

    2270

    文章

    10895

    浏览量

    355729
  • st-link
    +关注

    关注

    1

    文章

    43

    浏览量

    9610

原文标题:如何优雅的使用MDK解除芯片读保护?

文章出处:【微信号:玩点嵌入式,微信公众号:玩点嵌入式】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    STM32如何设置保护解除保护

    STM32还提供了个特别的保护,即对Flash存储区施加保护后,即使没有启用写保护,Flash的第 0 ~ 3 页也将处于写
    发表于 01-04 09:28 1.3w次阅读

    STM32CUBEMX开发GD32F303保护与写保护概述

    芯片保护以后,flash将不可以从外部读取,这样可以防止别人读取或者盗取芯片代码,如果想再次烧录代码,需要解除保护,有时候在代码调试的过程中,也有可能会触发
    的头像 发表于 07-17 14:36 2337次阅读
    STM32CUBEMX开发GD32F303<b class='flag-5'>读</b><b class='flag-5'>保护</b>与写<b class='flag-5'>保护</b>概述

    如何使用OPT_FLM文件实现解除保护功能?

    MDK工程里debug选项选择烧录的FLM文件就可以下载调试代码,那OPT_FLM文件该怎么在工程里使用实现解除保护功能呢?直接在debug里选择是不行的,求指点
    发表于 03-28 07:11

    分享一种新的失效保护方法

    分享一种在车身控制模块(BCM)设计中新的失效保护方法
    发表于 05-14 06:15

    介绍一种基于分级的RFID隐私保护方法

    介绍一种基于分级的RFID隐私保护方法
    发表于 05-26 06:17

    JFlash解除GD32保护方法

    JFlash解除GD32保护如果用户添加了保护或者误操作等导致的下载不了,可以先进行解锁尝试,步骤如下:1、打开J-Flash V6.4
    发表于 11-04 09:10

    STM32CubeProgrammer解除保护方法简述

    STM32CubeProgrammer解除保护方法简述STM32CubeProgrammer(STM32CUBEPROG)为任意环境下的STM32微控制器编程提供了
    发表于 02-14 06:29

    如何使用STM32 ST-LINK Utility解除芯片的保护

    STM32的芯片被保护了,怎样也无法对芯片进行烧写程序。用STlink也无法对单片机开发板进行下载程序了,只需要用STM32 ST-LINK Utility这个工具来解除
    发表于 02-18 06:47

    请问CH32V307VCT6保护如何解除

    在烧录程序时出现“保护目前为开启”,导致无法烧录程序,在下载配置中解除保护时失败,在WCH下载工具中
    发表于 05-18 08:44

    一种AHB2AHB桥的设计与实现

    介绍一种跨时钟域的32位AHB总线桥的设计与实现。通过采用状态机设计以及使用预防死锁与解除死锁相结合的方法解决死锁,使得该桥支持读写burst、
    发表于 04-15 09:05 30次下载

    STM32小技巧(2) STM32CubeProgrammer解除保护方法

    STM32CubeProgrammer解除保护方法简述STM32CubeProgrammer(STM32CUBEPROG)为任意环境下的STM32微控制器编程提供了
    发表于 12-09 14:51 21次下载
    STM32小技巧(2) STM32CubeProgrammer<b class='flag-5'>解除</b><b class='flag-5'>读</b><b class='flag-5'>保护</b>的<b class='flag-5'>方法</b>

    使用 STM32 ST-LINK Utility解除芯片的保护

    STM32的芯片被保护了,怎样也无法对芯片进行烧写程序。用STlink也无法对单片机开发板进行下载程序了,只需要用STM32 ST-LINK Utility这个工具来解除
    发表于 12-23 19:05 22次下载
    使用 STM32 ST-LINK Utility<b class='flag-5'>解除</b>芯片的<b class='flag-5'>读</b><b class='flag-5'>保护</b>

    一种Keil MDK生成BIN文件的简易方法

    一种Keil MDK生成BIN文件的简易方法
    发表于 01-13 10:18 2次下载

    STM32CUBEMX开发GD32F303(2)----保护与写保护

    芯片保护以后,flash将不可以从外部读取,这样可以防止别人读取或者盗取芯片代码,如果想再次烧录代码,需要解除保护,有时候在代码调试的过程中,也有可能会触发
    的头像 发表于 11-23 11:22 2373次阅读
    STM32CUBEMX开发GD32F303(2)----<b class='flag-5'>读</b><b class='flag-5'>保护</b>与写<b class='flag-5'>保护</b>

    STM32的Flash写了保护怎么办?STM32如何设置保护解除保护

    保护机制,然后才能更好地解决这个问题。 STM32的Flash有两保护一种是写保护一种
    的头像 发表于 10-29 17:24 1.2w次阅读