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

发布时间:2024-03-19  

经历过产品量产的同学应该都知道,芯片一般会在出厂时开启读保护:要么在代码中加入,要么在烧录程序后人工通过软件开启该功能,比如 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 文件保存起来,只要每次加载这个文件即可成功解除。


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

文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    STM32如何设置读保护和解除读保护;关于STM32对内部Flash的保护       为了防止对Flash的非法访问,所有STM32的芯片都提供对Flash的保护,具体分为写保护和读保护......
      FLASH_ReadOutProtection(DISABLE);  //Flash读保护禁止    FLASH_ReadOutProtection(ENABLE);   //Flash读保护允许 STM32如何设置读保护和解除读保护......
      FLASH_ReadOutProtection(DISABLE);  //Flash读保护禁止    FLASH_ReadOutProtection(ENABLE);   //Flash读保护允许 STM32如何设置读保护和解除读保护......
    的相关函数 2)STM32如何设置读保护? 我们只需要在程序开头加入“设置读保护”的代码就可以,这样就可以在每次运行代码的时候都检查一下,如果没有开的话就打开,如果开了就跳过。下面是读保护的代码: 当我......
    介绍一种使用MDK解除读保护的方法;经历过产品量产的同学应该都知道,芯片一般会在出厂时开启读保护:要么在代码中加入,要么在烧录程序后人工通过软件开启该功能,比如 STM32 ST-LINK......
    、flash保护的相关函数 2、STM32如何设置读保护? 我们只需要在程序开头加入“设置读保护”的代码就可以,这样就可以在每次运行代码的时候都检查一下,如果没有开的话就打开,如果开了就跳过。下面是读保护......
    STM32CUBEMX开发GD32F303读保护与写保护概述;概述 芯片读保护以后,flash将不可以从外部读取,这样可以防止别人读取或者盗取芯片代码,如果想再次烧录代码,需要解除保护,有时......
    STM32用串口下载后,不小心写保护和读保护了,如何解锁?;在STM32的开发过程中,有些时候可能会不小心开启了写保护和读保护,这将导致程序无法正常使用。此时,需要解锁芯片以便重新烧写程序。本文将介绍如何......
    如何使用代码清除STM32单片机上的PCROP;前言 STM32PCROP专有代码读出保护,将某个区域设置为仅允许执行,可防止代码被非法读出与修改。ST网站提供了免费的PCROP参考代码,但是......
    如何优雅地解决STM32的Flash写保护的问题;本文介绍了如何解STM32 芯片 Flash 写保护导致无法下载程序,无法在线调试的问题;如果您遇到相同的问题,希望本文可以带来一些帮助;1......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>