<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > STM32對內部Flash的保護措施

STM32對內部Flash的保護措施

作者: 時(shí)間:2016-11-26 來(lái)源:網(wǎng)絡(luò ) 收藏
1、STM32內部Flash保護措施

所有STM32的芯片都提供對Flash的保護,防止對Flash的非法訪(fǎng)問(wèn) - 寫(xiě)保護和讀保護。
1)、讀保護即大家通常說(shuō)的“加密”,是作用于整個(gè)Flash存儲區域。一旦設置了Flash的讀保護,內置的Flash存儲區只能通過(guò)程序的正常執行才能讀出,而不能通過(guò)下述任何一種方式讀出:
通過(guò)調試器(JTAG或SWD);
從RAM中啟動(dòng)并執行的程序;
2)、寫(xiě)保護是以四頁(yè)(1KB/頁(yè)) Flash存儲區為單位提供寫(xiě)保護,對被保護的頁(yè)實(shí)施編程或擦除操作將不被執行,同時(shí)產(chǎn)生操作錯誤標志。
讀與寫(xiě)設置的效果見(jiàn)下表:
讀保護 寫(xiě)保護對Flash的操作功能
有效 有效 CPU只能讀,禁止調試和非法訪(fǎng)問(wèn)。
有效 無(wú)效 CPU可以讀寫(xiě),禁止調試和非法訪(fǎng)問(wèn),頁(yè)0~3為寫(xiě)保護。
無(wú)效 有效 CPU可讀,允許調試和非法訪(fǎng)問(wèn)。
無(wú)效 無(wú)效 CPU可以讀寫(xiě),允許調試和非法訪(fǎng)問(wèn)。
2、當Flash讀保護生效時(shí),CPU執行程序可以讀受保護的Flash區,但存在兩個(gè)例外情況:
1)、調試執行程序時(shí);
2)、從RAM啟動(dòng)并執行程序時(shí)
STM32還提供了一個(gè)特別的保護,即對Flash存儲區施加讀保護后,即使沒(méi)有啟用寫(xiě)保護,Flash的第 0 ~ 3 頁(yè)也將處于寫(xiě)保護狀態(tài),這是為了防止修改復位或中斷向量而跳轉到RAM區執行非法程序代碼。
3、Flash保護相關(guān)函數
FLASH_Unlock();//Flash解鎖
FLASH_ReadOutProtection(DISABLE);//Flash讀保護禁止
FLASH_ReadOutProtection(ENABLE);//Flash讀保護允許

本文引用地址:http://dyxdggzs.com/article/201611/321884.htm

以下摘自論壇:

http://www.openedv.com/posts/list/9353.htm

(1)設置讀保護
intmain(void)
{
....
if(FLASH_GetReadOutProtectionStatus()!=SET)
{
//FLASH_Unlock();
FLASH_ReadOutProtection(ENABLE);
}
......
while(1)
{
.....
}
}
讀保護后無(wú)法使用j-link將程序讀出,當然也無(wú)法在線(xiàn)仿真了

這個(gè)寫(xiě)到程序當中并執行過(guò)后,使用j-link就不能‘讀出’程序了,就是‘讀保護’了!我已經(jīng)試過(guò)了,沒(méi)有使用此程序可以讀出下載到芯片中的程序,但是如果使用了此程序就無(wú)法讀出程序了。
但是也無(wú)法再次燒寫(xiě)新的程序到芯片中了(要測試請慎重?。。。。。。?br />可以再主程序當中設置一按鍵專(zhuān)門(mén)清除“讀保護”,一旦按下按鍵則清除“讀保護”時(shí)芯片可以重新被燒寫(xiě)。(我沒(méi)有怎么做現在后悔死了!)
方法二:補救的方法,專(zhuān)門(mén)寫(xiě)一個(gè)清除“讀保護”程序,使用RAM中運行程序的方法,運行此程序解鎖“讀保護”。明天再去測試下,此方法。


在主程序中,通過(guò)一個(gè)按鍵,寫(xiě)入取消“讀保護”
if(FLASH_GetReadOutProtectionStatus()!=RESET)
{
FLASH_Unlock();
FLASH_ReadOutProtection(DISABLE);
}
使用j-link,可以正常讀寫(xiě)程序和在線(xiàn)調試。
如果沒(méi)有在主程序中有寫(xiě)這條指令,此芯片就無(wú)法再次燒寫(xiě)程序(可以擦出但是擦出后還是無(wú)法燒寫(xiě)程序)。
只有通過(guò)將此取消“讀保護”程序,燒寫(xiě)到RAM中運行后,才能取消“讀保護”(要嘗試的請慎重?。?!別救不會(huì )來(lái)就糟糕了)



關(guān)鍵詞: STM32內部Flash保護措

評論


技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>