STM32對(duì)內(nèi)部Flash的保護(hù)措施
通過調(diào)試器(JTAG或SWD);
從RAM中啟動(dòng)并執(zhí)行的程序;
2、當(dāng)Flash讀保護(hù)生效時(shí),CPU執(zhí)行程序可以讀受保護(hù)的Flash區(qū),但存在兩個(gè)例外情況:
3、Flash保護(hù)相關(guān)函數(shù)
以下摘自論壇:
http://www.openedv.com/posts/list/9353.htm
(1)設(shè)置讀保護(hù)
int
{
....
if(FLASH_GetReadOutProtectionStat
{
//FLASH_Unlock();
FLASH_ReadOutProtection(ENABLE);
}
......
while(1)
{
.....
}
}
讀保護(hù)后無法使用j-link將程序讀出,當(dāng)然也無法在線仿真了
這個(gè)寫到程序當(dāng)中并執(zhí)行過后,使用j-link就不能‘讀出’程序了,就是‘讀保護(hù)’了!我已經(jīng)試過了,沒有使用此程序可以讀出下載到芯片中的程序,但是如果使用了此程序就無法讀出程序了。
但是也無法再次燒寫新的程序到芯片中了(要測試請(qǐng)慎重?。。。。。。?br />可以再主程序當(dāng)中設(shè)置一按鍵專門清除“讀保護(hù)”,一旦按下按鍵則清除“讀保護(hù)”時(shí)芯片可以重新被燒寫。(我沒有怎么做現(xiàn)在后悔死了!)
方法二:補(bǔ)救的方法,專門寫一個(gè)清除“讀保護(hù)”程序,使用RAM中運(yùn)行程序的方法,運(yùn)行此程序解鎖“讀保護(hù)”。明天再去測試下,此方法。
在主程序中,通過一個(gè)按鍵,寫入取消“讀保護(hù)”
if(FLASH_GetReadOutProtectionStat
{
FLASH_Unlock();
FLASH_ReadOutProtection(DISABLE);
}
使用j-link,可以正常讀寫程序和在線調(diào)試。
如果沒有在主程序中有寫這條指令,此芯片就無法再次燒寫程序(可以擦出但是擦出后還是無法燒寫程序)。
只有通過將此取消“讀保護(hù)”程序,燒寫到RAM中運(yùn)行后,才能取消“讀保護(hù)”(要嘗試的請(qǐng)慎重?。?!別救不會(huì)來就糟糕了)
評(píng)論