新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > STM32讀保護功能和清除讀保護功能設置

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

        作者: 時間:2016-11-26 來源:網絡 收藏
        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讀保護允許

        本文引用地址:http://www.104case.com/article/201611/321886.htm

        4、stm32置讀保護跟清讀保護操作

        功能:讀保護設置后將不能讀出flash的內容;當解除讀保護的時候stm32會自動擦出整篇flash;
        讀保護設置:在程序的開頭加入“讀保護”代碼,即實現了讀保護功能;(每次程序運行先開保護)
        解除讀保護:解除讀保護可以設置在按鍵里面,方便實現解鎖,也不可不設按鍵在RAM中執行程序再清除讀保護
        (1)設置讀保護:

        intmain(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會自動全部擦除。代碼如下:
        intmain(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選項Downloadtab中勾全部去掉。
        按上面設置完成后,按Debug按鈕,執行上面程序,讀保護可解除。

        *************************華麗麗的分割線***********************************************


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

        if(FLASH_GetReadOutProtectionStatus()==SET)
        {

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

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



        評論


        技術專區

        關閉
        主站蜘蛛池模板: 修武县| 阳曲县| 社会| 和静县| 永川市| 察隅县| 临朐县| 铜川市| 成安县| 湖口县| 武陟县| 孟州市| 青铜峡市| 赞皇县| 左云县| 千阳县| 奇台县| 大渡口区| 浦城县| 姜堰市| 琼中| 银川市| 襄樊市| 新巴尔虎右旗| 宜黄县| 永寿县| 九江市| 惠水县| 满洲里市| 绥德县| 蛟河市| 临朐县| 秦安县| 巴林左旗| 普兰县| 阿合奇县| 荆州市| 萨嘎县| 特克斯县| 涿州市| 新竹县|