1、STM32對(duì)內(nèi)部Flash的保護(hù)措施所有STM32的芯片都提供對(duì)Flash的保護(hù),防止對(duì)Flash的非法訪問 - 寫保護(hù)和讀保護(hù)。
1)、讀保護(hù)即大家通常說的“加密”,是作用于整個(gè)Flash存儲(chǔ)區(qū)域。一旦設(shè)置了Flash的讀保護(hù),內(nèi)置的Flash存儲(chǔ)區(qū)只能通過程序的正常執(zhí)行才能讀出,而不能通過下述任何一種方式讀出:
通過調(diào)試器(JTAG或SWD);
從RAM中啟動(dòng)并執(zhí)行的程序;
2)、寫保護(hù)是以四頁(1KB/頁) Flash存儲(chǔ)區(qū)為單位提供寫保護(hù),對(duì)被保護(hù)的頁實(shí)施編程或擦除操作將不被執(zhí)行,同時(shí)產(chǎn)生操作錯(cuò)誤標(biāo)志。
讀與寫設(shè)置的效果見下表:
讀保護(hù)寫保護(hù)對(duì)Flash的操作功能
有效 有效 CPU只能讀,禁止調(diào)試和非法訪問。
有效 無效 CPU可以讀寫,禁止調(diào)試和非法訪問,頁0~3為寫保護(hù)。
無效 有效 CPU可讀,允許調(diào)試和非法訪問。
無效 無效 CPU可以讀寫,允許調(diào)試和非法訪問。
2、當(dāng)Flash讀保護(hù)生效時(shí),CPU執(zhí)行程序可以讀受保護(hù)的Flash區(qū),但存在兩個(gè)例外情況:
1)、調(diào)試執(zhí)行程序時(shí);
2)、從RAM啟動(dòng)并執(zhí)行程序時(shí)
STM32還提供了一個(gè)特別的保護(hù),即對(duì)Flash存儲(chǔ)區(qū)施加讀保護(hù)后,即使沒有啟用寫保護(hù),F(xiàn)lash的第 0 ~ 3 頁也將處于寫保護(hù)狀態(tài),這是為了防止修改復(fù)位或中斷向量而跳轉(zhuǎn)到RAM區(qū)執(zhí)行非法程序代碼。
3、Flash保護(hù)相關(guān)函數(shù)
FLASH_Unlock();//Flash解鎖
FLASH_ReadOutProtection(DISABLE);//Flash讀保護(hù)禁止
FLASH_ReadOutProtection(ENABLE);//Flash讀保護(hù)允許
本文引用地址:http://www.ex-cimer.com/article/201611/321886.htm4、stm32置讀保護(hù)跟清讀保護(hù)操作
功能:讀保護(hù)設(shè)置后將不能讀出flash的內(nèi)容;當(dāng)解除讀保護(hù)的時(shí)候stm32會(huì)自動(dòng)擦出整篇flash;
讀保護(hù)設(shè)置:在程序的開頭加入“讀保護(hù)”代碼,即實(shí)現(xiàn)了讀保護(hù)功能;(每次程序運(yùn)行先開保護(hù))
解除讀保護(hù):解除讀保護(hù)可以設(shè)置在按鍵里面,方便實(shí)現(xiàn)解鎖,也不可不設(shè)按鍵在RAM中執(zhí)行程序再清除讀保護(hù);
(1)設(shè)置讀保護(hù):
intmain(void)
{
....
if(FLASH_GetReadOutProtectionStatus()!=SET)
{
//FLASH_Unlock();不解鎖FALSH也可設(shè)置讀保護(hù)???
FLASH_ReadOutProtection(ENABLE);
}
......
while(1)
{
.....
}
}
這個(gè)寫到程序當(dāng)中并執(zhí)行過后,使用j-link就不能‘讀出’程序了,就是‘讀保護(hù)’了!沒有使用此程序可以讀出下載到芯片中的程序,但是如果使用了此程序就無法讀出程序了。但是也無法再次燒寫新的程序到芯片中了(要測(cè)試請(qǐng)慎重?。。。。。。?/p>
可以在主程序當(dāng)中設(shè)置一按鍵專門清除“讀保護(hù)”,一旦按下按鍵則清除“讀保護(hù)”時(shí)芯片可以重新被燒寫。
(2)解除讀保護(hù):在程序中的某個(gè)操作中(如按鍵等)加入如下代碼,執(zhí)行后
代碼自己殺死了自己!
if(FLASH_GetReadOutProtectionStatus()!=RESET)
{
FLASH_Unlock();
FLASH_ReadOutProtection(DISABLE);
}
這些函數(shù)在stm32f10x_flash里面,注意:調(diào)用上面這個(gè)庫的時(shí)候需在#include"stm32f10x_flash.h"前加#define_FLASH_PROG;否則報(bào)(沒有定義)錯(cuò)。
如果你沒有做按鍵清除讀保護(hù)這一步還有方法二補(bǔ)救:專門寫一個(gè)清除“讀保護(hù)”程序,使用RAM中運(yùn)行程序的方法,運(yùn)行此程序解鎖“讀保護(hù)”,執(zhí)行后,F(xiàn)LASH會(huì)自動(dòng)全部擦除。代碼如下:
intmain(void)
{
Chinp_Init();
FLASH_Unlock();
FLASH_ReadOutProtection(DISABLE);
}
※對(duì)于在RAM中運(yùn)行程序,說明如下:
(1)我使用IAR+J-Link,不用把Boot0和boot1腳設(shè)置成從RAM啟動(dòng)也可在RAM中調(diào)試(我是設(shè)置成從FLASH啟動(dòng))。
(2)在IAR環(huán)境中設(shè)置Link文件為lnkarm_ram.xcl
(3)Debuger選項(xiàng)Downloadtab中勾全部去掉。
按上面設(shè)置完成后,按Debug按鈕,執(zhí)行上面程序,讀保護(hù)可解除。
*************************華麗麗的分割線***********************************************
if(FLASH_GetReadOutProtectionStatus()==RESET)
{
FLASH_Unlock();
FLASH_ReadOutProtection(ENABLE);
}
*************************華麗麗的分割線***********************************************
if(FLASH_GetReadOutProtectionStatus()==SET)
{
FLASH_Unlock();
FLASH_ReadOutProtection(DISABLE);
}
CPUFlash讀保護(hù)使能后,仿真器調(diào)試會(huì)失敗。J-LINK有個(gè)解鎖菜單,需要解鎖才能正常再次燒寫程序。當(dāng)然解鎖會(huì)導(dǎo)致Flash內(nèi)容被全部擦出。
啟動(dòng)"J-FlashARM"工具,Target->unsercurechip就解除了芯片的讀保護(hù)。Target->unsercurechip后一定要上電復(fù)位,系統(tǒng)不復(fù)位是不行的。
評(píng)論