久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4099|回復: 0
打印 上一主題 下一主題
收起左側

STM32讀保護功能和清除讀保護功能設置

[復制鏈接]
跳轉到指定樓層
樓主
ID:159552 發表于 2017-1-3 11:49 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
1、STM32對內部Flash的保護措施
   所有STM32的芯片都提供對Flash的保護,防止對Flash的非法訪問 - 寫保護和讀保護。
   1)、讀保護即大家通常說的“加密”,是作用于整個Flash存儲區域。一旦設置了Flash的讀保護,內置的Flash存儲區只能通過程序的正常執行才能讀出,而不能通過下述任何一種方式讀出:
通過調試器(JTAG或SWD);
從RAM中啟動并執行的程序;
   2)、寫保護是以四頁(1KB/頁) Flash存儲區為單位提供寫保護,對被保護的頁實施編程或擦除操作將不被執行,同時產生操作錯誤標志。  
   讀與寫設置的效果見下表:
   讀保護寫保護      對Flash的操作功能
    有效 有效 CPU只能讀,禁止調試和非法訪問。
    有效 無效 CPU可以讀寫,禁止調試和非法訪問,頁0~3為寫保護。
    無效 有效 CPU可讀,允許調試和非法訪問。
    無效 無效 CPU可以讀寫,允許調試和非法訪問。
2、當Flash讀保護生效時,CPU執行程序可以讀受保護的Flash區,但存在兩個例外情況:
   1)、調試執行程序時;
   2)、從RAM啟動并執行程序時
   STM32還提供了一個特別的保護,即對Flash存儲區施加讀保護后,即使沒有啟用寫保護,Flash的第 0 ~ 3 頁也將處于寫保護狀態,這是為了防止修改復位或中斷向量而跳轉到RAM區執行非法程序代碼。
3、Flash保護相關函數
   FLASH_Unlock();   //Flash解鎖
   FLASH_ReadOutProtection(DISABLE);  //Flash讀保護禁止  
   FLASH_ReadOutProtection(ENABLE);   //Flash讀保護允許
4、stm32置讀保護跟清讀保護操作
  功能:讀保護設置后將不能讀出flash 的內容;當解除讀保護的時候stm32 會自動擦出整篇flash;
  讀保護設置:在程序的開頭加入“讀保護”代碼,即實現了讀保護功能;(每次程序運行先開保護)
  解除讀保護:解除讀保護可以設置在按鍵里面,方便實現解鎖,也不可不設按鍵在RAM中執行程序再清除讀保護;
  (1)設置讀保護:
int main(void)
{
    ....
      
    if(FLASH_GetReadOutProtectionStatus() != SET)
    {
        //FLASH_Unlock();不解鎖FALSH也可設置讀保護???
        FLASH_ReadOutProtection(ENABLE);   
    }
    ......
    while(1)
    {
       .....
     }
}
    這個寫到程序當中并執行過后,使用j-link就不能‘讀出’程序了,就是‘讀保護’了!沒有使用此程序可以讀出下載到芯片中的程序,但是如果使用了此程序就無法讀出程序了。但是也無法再次燒寫新的程序到芯片中了(要測試請慎重!!!!!!)
  可以在主程序當中設置一按鍵專門清除“讀保護”,一旦按下按鍵則清除“讀保護”時芯片可以重新被燒寫。
  (2)解除讀保護:在程序中的某個操作中(如按鍵等)加入如下代碼,執行后
代碼自己殺死了自己!
if(FLASH_GetReadOutProtectionStatus() != RESET)
{
FLASH_Unlock();
FLASH_ReadOutProtection(DISABLE);
}
   這些函數在stm32f10x_flash 里面,注意:調用上面這個庫的時候需在#include "stm32f10x_flash.h"前加#define _FLASH_PROG;否則報(沒有定義)錯。
   如果你沒有做按鍵清除讀保護這一步還有方法二補救:專門寫一個清除“讀保護”程序,使用RAM中運行程序的方法,運行此程序解鎖“讀保護”,執行后,FLASH會自動全部擦除。代碼如下:
int main(void)
{
Chinp_Init();
FLASH_Unlock();
FLASH_ReadOutProtection(DISABLE);
}

※對于在RAM中運行程序,說明如下:
(1)我使用IAR + J-Link,不用把Boot0和boot1腳設置成從RAM啟動也可在RAM中調試(我是設置成從FLASH啟動)。
(2)在IAR環境中設置Link文件為lnkarm_ram.xcl
(3)Debuger選項Download tab中勾全部去掉。
按上面設置完成后,按Debug按鈕,執行上面程序,讀保護可解除。

*************************華麗麗的分割線***********************************************
  
if (FLASH_GetReadOutProtectionStatus() == RESET)
{
FLASH_Unlock();
FLASH_ReadOutProtection(ENABLE);
}
*************************華麗麗的分割線***********************************************

if (FLASH_GetReadOutProtectionStatus() == SET)
{

FLASH_Unlock();
FLASH_ReadOutProtection(DISABLE);
}
CPU Flash讀保護使能后,仿真器調試會失敗。J-LINK有個解鎖菜單,需要解鎖才能正常再次燒寫程序。當然解鎖會導致Flash內容被全部擦出。



啟動"J-Flash ARM"工具,Target->unsercure chip 就解除了芯片的讀保護。Target->unsercure chip 后一定要上電復位,系統不復位是不行的。

   
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 日韩中文字幕在线视频 | 欧美国产日韩一区二区三区 | 99视频免费在线观看 | av入口| 国产男女视频网站 | 亚洲一二三在线 | 久久国产精品视频 | 嫩草视频在线看 | 高清黄色毛片 | 精品一区二区三区入口 | 国产精品久久久乱弄 | 日韩中文字幕免费在线观看 | 精品视频一区二区三区 | 中文字幕国产精品视频 | 午夜欧美 | 麻豆视频在线免费看 | 久夜精品| 99pao成人国产永久免费视频 | 久久精品小视频 | 欧美黑人一级爽快片淫片高清 | 日韩一区不卡 | 中文字幕视频在线看 | 91传媒在线观看 | 久久综合久| 欧美精品一区二区三区蜜桃视频 | 久久成人国产 | 国产免费av在线 | 国产在线色 | 女同久久另类99精品国产 | 精品久久久久国产免费第一页 | 中文字幕在线免费观看 | 国产又色又爽又黄又免费 | 亚洲精品久久久一区二区三区 | 国产一区二区三区 | 一区二区日本 | 国产高清精品在线 | 亚洲网站在线播放 | 精品一二区 | 亚洲欧美视频 | 在线一区二区三区 | 日韩在线免费视频 |