0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

介紹一種使用MDK解除讀保護(hù)的方法

Dp1040 ? 來源:魚鷹談單片機(jī) ? 2023-12-26 09:18 ? 次閱讀

經(jīng)歷過產(chǎn)品量產(chǎn)的同學(xué)應(yīng)該都知道,芯片一般會(huì)在出廠時(shí)開啟讀保護(hù):要么在代碼中加入,要么在燒錄程序后人工通過軟件開啟該功能,比如 STM32 ST-LINK Utility:

wKgZomWKKiyAftiqAAD44MI3oUo030.png

當(dāng)然也可以使用該工具關(guān)閉讀保護(hù)功能。

為了保證程序不被讀取,大多數(shù)產(chǎn)品應(yīng)該會(huì)直接在量產(chǎn)代碼中加入該功能,但這樣會(huì)導(dǎo)致一個(gè)麻煩的問題:無法正常調(diào)試

每次下載后,如果代碼出現(xiàn)問題,都需要在線調(diào)試,而你的代碼為了不忘記,默認(rèn)就是開啟讀保護(hù)功能的,所以每次下載后,如果發(fā)現(xiàn)問題,你可能要找一個(gè)工具,如 J-Flash 或者上面的軟件負(fù)責(zé)關(guān)閉讀保護(hù),讓我們的開發(fā)效率降低不少。

是否有更好的方法解除讀保護(hù)呢?

今天給大家介紹一種使用 MDK 解除讀保護(hù)的方法,畢竟 MDK 軟件絕大部分道友都會(huì)安裝,所以使用它是最合適的。

首先,說說它的讀保護(hù)原理。

讀保護(hù)功能是通過設(shè)置相應(yīng)的 Option Bytes 來實(shí)現(xiàn)的,并且掉電不會(huì)消失,和 ROM 類似。

而解除是則是復(fù)位相應(yīng)的 Option Bytes 來實(shí)現(xiàn),掉電也不會(huì)消失,但是不同的是,設(shè)置完之后,芯片自動(dòng)會(huì)擦除整顆芯片,這樣你也就不能通過解除讀保護(hù)進(jìn)而讀取整顆芯片代碼了。

但是,你會(huì)發(fā)現(xiàn)一個(gè)現(xiàn)象,即使你無法讀取 FLASH 的代碼,你仍然可以通過上述工具連接芯片,這樣就給我們使用 MDK 解除讀保護(hù)創(chuàng)造了條件。

在魚鷹以前的筆記里面,有介紹如何使代碼運(yùn)行在 RAM 中,既然讀保護(hù)保護(hù)的是 FLASH 區(qū),RAM 并不受影響,那么我們就可以將我們解除的代碼加載到 RAM 中運(yùn)行,如此就可以通過 MDK 解除芯片的讀保護(hù)了。

具體操作如下(若如下操作不懂,建議參考這篇筆記《STM32工程模板建立之 RAM 目標(biāo)(五)》):

1、設(shè)置新的目標(biāo),比如:

wKgaomWKKiyASEiIAABrUB2R_DY117.png

然后設(shè)置該目標(biāo)的輸出目錄,這樣只要編譯一次,之后就可以直接切換目標(biāo)后直接點(diǎn)擊 debug,不需要重復(fù)編譯,相當(dāng)方便(和正常輸出目錄不同)。

新建兩個(gè)目錄,并選擇對(duì)應(yīng)的目錄即可:

wKgaomWKKi2ACeZdAABjOE32AFs953.png

wKgZomWKKi2ACwZzAACO0eeT41o549.png

wKgaomWKKi2AFJiiAACQpxRjmrs926.png

2、切換到新目標(biāo),然后在 C/C++ 選項(xiàng)卡中增加新宏 READ_PROTECT。

wKgaomWKKi2AUkKgAABpfn6P1OE018.png

然后在代碼中,根據(jù)該宏加入解除讀保護(hù)代碼:

wKgaomWKKi2AB_q_AAHmFrbOQqI654.png

3、將代碼地址重新定位到 RAM 中(0x20000000 為 RAM 首地址,假設(shè) 64 K 空間)。

wKgZomWKKi2AAn-rAACDE9KtSQs577.png

4、新建 run_ram文件,內(nèi)容如下:

wKgaomWKKi2ASd2aAADteqqAz-o978.png

保存到工程目錄下,然后將其正確添加:

wKgaomWKKiyAaowRAAEgZW014dE543.png

去掉勾選(這樣就不會(huì)下載程序到 FLASH了):

wKgZomWKKi2AYC3-AABnLogySlc251.png

5、編譯,然后點(diǎn)擊Debug 即可。

此時(shí),程序應(yīng)該自動(dòng)停止在斷點(diǎn)處 __breakpoint(0),說明解除代碼已經(jīng)順利運(yùn)行完成。

wKgZomWKKi2ASdHLAAEHVX01nqs421.png

Enjoy it!!!

每次需要解除芯片讀保護(hù)功能時(shí),只要切換目標(biāo)后即可成功解除(前提是已經(jīng)編譯過一次了),相當(dāng)方便,當(dāng)然你如果不想編譯,也可以直接生成一個(gè) axf 文件保存起來,只要每次加載這個(gè)文件即可成功解除。

一次設(shè)置,永不煩惱,相當(dāng)?shù)膶?shí)用!






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • ROM
    ROM
    +關(guān)注

    關(guān)注

    4

    文章

    549

    瀏覽量

    85559
  • STM32
    +關(guān)注

    關(guān)注

    2262

    文章

    10846

    瀏覽量

    353650
  • st-link
    +關(guān)注

    關(guān)注

    1

    文章

    43

    瀏覽量

    9572

原文標(biāo)題:如何優(yōu)雅的使用MDK解除芯片讀保護(hù)?

文章出處:【微信號(hào):玩點(diǎn)嵌入式,微信公眾號(hào):玩點(diǎn)嵌入式】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    STM32如何設(shè)置保護(hù)解除保護(hù)?

    STM32還提供了個(gè)特別的保護(hù),即對(duì)Flash存儲(chǔ)區(qū)施加保護(hù)后,即使沒有啟用寫保護(hù),F(xiàn)lash的第 0 ~ 3 頁(yè)也將處于寫
    發(fā)表于 01-04 09:28 ?1.2w次閱讀

    STM32CUBEMX開發(fā)GD32F303保護(hù)與寫保護(hù)概述

    芯片保護(hù)以后,flash將不可以從外部讀取,這樣可以防止別人讀取或者盜取芯片代碼,如果想再次燒錄代碼,需要解除保護(hù),有時(shí)候在代碼調(diào)試的過程中,也有可能會(huì)觸發(fā)
    的頭像 發(fā)表于 07-17 14:36 ?2217次閱讀
    STM32CUBEMX開發(fā)GD32F303<b class='flag-5'>讀</b><b class='flag-5'>保護(hù)</b>與寫<b class='flag-5'>保護(hù)</b>概述

    如何使用OPT_FLM文件實(shí)現(xiàn)解除保護(hù)功能?

    MDK工程里debug選項(xiàng)選擇燒錄的FLM文件就可以下載調(diào)試代碼,那OPT_FLM文件該怎么在工程里使用實(shí)現(xiàn)解除保護(hù)功能呢?直接在debug里選擇是不行的,求指點(diǎn)
    發(fā)表于 03-28 07:11

    BLUENRG-LP開啟保護(hù)的問題求解

    ,但是旦勾選讀保護(hù)選項(xiàng),后果也完全樣。然后就和設(shè)備失去通訊了,連不上,也無法用 mass erase命令來解除
    發(fā)表于 05-29 06:20

    分享一種新的失效保護(hù)方法

    分享一種在車身控制模塊(BCM)設(shè)計(jì)中新的失效保護(hù)方法。
    發(fā)表于 05-14 06:15

    介紹一種基于分級(jí)的RFID隱私保護(hù)方法

    介紹一種基于分級(jí)的RFID隱私保護(hù)方法
    發(fā)表于 05-26 06:17

    JFlash解除GD32保護(hù)方法

    JFlash解除GD32保護(hù)如果用戶添加了保護(hù)或者誤操作等導(dǎo)致的下載不了,可以先進(jìn)行解鎖嘗試,步驟如下:1、打開J-Flash V6.4
    發(fā)表于 11-04 09:10

    STM32CubeProgrammer解除保護(hù)方法簡(jiǎn)述

    STM32CubeProgrammer解除保護(hù)方法簡(jiǎn)述STM32CubeProgrammer(STM32CUBEPROG)為任意環(huán)境下的STM32微控制器編程提供了
    發(fā)表于 02-14 06:29

    如何使用STM32 ST-LINK Utility解除芯片的保護(hù)

    STM32的芯片被保護(hù)了,怎樣也無法對(duì)芯片進(jìn)行燒寫程序。用STlink也無法對(duì)單片機(jī)開發(fā)板進(jìn)行下載程序了,只需要用STM32 ST-LINK Utility這個(gè)工具來解除
    發(fā)表于 02-18 06:47

    請(qǐng)問CH32V307VCT6保護(hù)如何解除?

    在燒錄程序時(shí)出現(xiàn)“保護(hù)目前為開啟”,導(dǎo)致無法燒錄程序,在下載配置中解除保護(hù)時(shí)失敗,在WCH下載工具中
    發(fā)表于 05-18 08:44

    一種AHB2AHB橋的設(shè)計(jì)與實(shí)現(xiàn)

    介紹一種跨時(shí)鐘域的32位AHB總線橋的設(shè)計(jì)與實(shí)現(xiàn)。通過采用狀態(tài)機(jī)設(shè)計(jì)以及使用預(yù)防死鎖與解除死鎖相結(jié)合的方法解決死鎖,使得該橋支持讀寫burst、
    發(fā)表于 04-15 09:05 ?30次下載

    STM32小技巧(2) STM32CubeProgrammer解除保護(hù)方法

    STM32CubeProgrammer解除保護(hù)方法簡(jiǎn)述STM32CubeProgrammer(STM32CUBEPROG)為任意環(huán)境下的STM32微控制器編程提供了
    發(fā)表于 12-09 14:51 ?21次下載
    STM32小技巧(2) STM32CubeProgrammer<b class='flag-5'>解除</b><b class='flag-5'>讀</b><b class='flag-5'>保護(hù)</b>的<b class='flag-5'>方法</b>

    使用 STM32 ST-LINK Utility解除芯片的保護(hù)

    STM32的芯片被保護(hù)了,怎樣也無法對(duì)芯片進(jìn)行燒寫程序。用STlink也無法對(duì)單片機(jī)開發(fā)板進(jìn)行下載程序了,只需要用STM32 ST-LINK Utility這個(gè)工具來解除
    發(fā)表于 12-23 19:05 ?22次下載
    使用 STM32 ST-LINK Utility<b class='flag-5'>解除</b>芯片的<b class='flag-5'>讀</b><b class='flag-5'>保護(hù)</b>

    一種Keil MDK生成BIN文件的簡(jiǎn)易方法

    一種Keil MDK生成BIN文件的簡(jiǎn)易方法。
    發(fā)表于 01-13 10:18 ?2次下載

    STM32的Flash寫了保護(hù)怎么辦?STM32如何設(shè)置保護(hù)解除保護(hù)?

    保護(hù)機(jī)制,然后才能更好地解決這個(gè)問題。 STM32的Flash有兩保護(hù),一種是寫保護(hù),一種
    的頭像 發(fā)表于 10-29 17:24 ?1.1w次閱讀