<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > STM32對(duì)內(nèi)部Flash的保護(hù)措施

          STM32對(duì)內(nèi)部Flash的保護(hù)措施

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

          所有STM32的芯片都提供對(duì)Flash的保護(hù),防止對(duì)Flash的非法訪問(wèn) - 寫(xiě)保護(hù)和讀保護(hù)。
          1)、讀保護(hù)即大家通常說(shuō)的“加密”,是作用于整個(gè)Flash存儲(chǔ)區(qū)域。一旦設(shè)置了Flash的讀保護(hù),內(nèi)置的Flash存儲(chǔ)區(qū)只能通過(guò)程序的正常執(zhí)行才能讀出,而不能通過(guò)下述任何一種方式讀出:
          通過(guò)調(diào)試器(JTAG或SWD);
          從RAM中啟動(dòng)并執(zhí)行的程序;
          2)、寫(xiě)保護(hù)是以四頁(yè)(1KB/頁(yè)) Flash存儲(chǔ)區(qū)為單位提供寫(xiě)保護(hù),對(duì)被保護(hù)的頁(yè)實(shí)施編程或擦除操作將不被執(zhí)行,同時(shí)產(chǎn)生操作錯(cuò)誤標(biāo)志。
          讀與寫(xiě)設(shè)置的效果見(jiàn)下表:
          讀保護(hù) 寫(xiě)保護(hù)對(duì)Flash的操作功能
          有效 有效 CPU只能讀,禁止調(diào)試和非法訪問(wèn)。
          有效 無(wú)效 CPU可以讀寫(xiě),禁止調(diào)試和非法訪問(wèn),頁(yè)0~3為寫(xiě)保護(hù)。
          無(wú)效 有效 CPU可讀,允許調(diào)試和非法訪問(wèn)。
          無(wú)效 無(wú)效 CPU可以讀寫(xiě),允許調(diào)試和非法訪問(wèn)。
          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ù)后,即使沒(méi)有啟用寫(xiě)保護(hù),F(xiàn)lash的第 0 ~ 3 頁(yè)也將處于寫(xiě)保護(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/321884.htm

          以下摘自論壇:

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

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

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


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



          評(píng)論


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

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();