娇小w搡bbbb搡bbb,《第一次の人妻》,中国成熟妇女毛茸茸,边啃奶头边躁狠狠躁视频免费观看

歷史上的今天

今天是:2024年12月17日(星期二)

正在發生

2018年12月17日 | STM32-讀保護功能和清除讀保護功能設置

發布者:春林初盛 來源: eefocus關鍵字:STM32  讀保護功能  清除讀保護功能 手機看文章 掃描二維碼
隨時隨地手機看文章

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)
{
FLASH_Unlock();
FLASH_ReadOutProtection(DISABLE); 

  while (1)
  {
  };
}

※對于在RAM中運行程序,說明如下:

(1)我使用IAR + J-Link,不用把Boot0和boot1腳設置成從RAM啟動也可在RAM中調試(我使用IAR沒有RAM中運行選項)。

(2)在IAR環境中設置Link文件為lnkarm_ram.xcl或者自己修改STM32F10x_FLASH.icf文件


//define symbol __ICFEDIT_region_ROM_start__ = 0x080000F0;  //修改為如下:
define symbol __ICFEDIT_region_ROM_start__ = 0x200000F0;

//define symbol __ICFEDIT_region_ROM_end__   = 0x0803FFFF;  //修改為如下
define symbol __ICFEDIT_region_ROM_end__   = 0x20001FFF;


//define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; //修改為如下
define symbol __ICFEDIT_region_RAM_start__ = 0x20002000;


(3)Debuger選項Download tab中勾全部去掉。

按上面設置完成后,按Debug按鈕,執行上面程序,讀保護可解除。


(4)點擊下載運行時。可能會提示錯誤(有時不提示)

當下載時,提示 CRC校驗失敗,選擇 NO(右邊)。

當下載時,提示無法擦除 sector 0,選擇NO(右邊)


(5)運行前使用J-Flash ARM"工具,Target->unsercure chip 解除了芯片的讀保護。不然會出現上述各種報錯。


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 后一定要上電復位,系統不復位是不行的。


關鍵字:STM32  讀保護功能  清除讀保護功能 引用地址:STM32-讀保護功能和清除讀保護功能設置

上一篇:使用IAR+Jlink開發STM32關于下載Flash的一點發現
下一篇:keil環境下stm32下載和擦除程序對Flash的影響

推薦閱讀

? ? ? ? 路透社披露了日本軟銀決定棄用華為4G設備的背后理由。  當地時間12月15日,報道援引消息人士稱,美國無線運營商巨頭T-Mobile和Sprint都認為,它們的外國母公司——德國電信和日本軟銀集團主動提出停止使用華為技術設備,將有助于美國清除兩家公司進行價值260億美元合并交易時面臨的障礙,“這突顯了華盛頓有多竭盡全力地想將這家中國公...
手套箱是將高純惰性氣體充入箱體內,并循環過濾掉其中的活性物質的實驗室設備。也稱真空手套箱、惰性氣體保護箱等。手套箱作為一個提供非常高純惰性氣體環境的通用工作平臺,這個工作平臺里的惰性氣體濃度能夠達到非常高級別,一些對水或氧非常敏感的材料研究、工藝或實驗能夠在手套箱中能夠得以實現。主要功能在于對O2,H2O,有機氣體的清除。因此被廣泛...
無懼酷暑、沒有假期,可以24小時全天候、全方位、多頻次檢查變電站、輸路、隧道,這就是當下最先進的智能巡檢機器人和5G巡檢無人機。 智能巡檢,應運而生 隨著電網行業智能化轉型的深入推進,電力系統的運行狀態監測、檢測體系正在逐步實現智能化。 輸電線路傳統的巡檢方式是運維人員到現場仔細地對每一基桿塔進行缺陷排查,及時發現運行隱患,這對運...
近日,國家統計局公布了11月份規模以上工業增加值數據。其中顯示,11月份,規模以上工業增加值同比實際增長3.8%,比2019年同期增長11.1%,兩年平均增長5.4%,增速延續回升態勢,分別環比增加0.3、0.2個百分點。從環比看,11月份,規模以上工業增加值比上月增長0.37%。1—11月份,規模以上工業增加值同比增長10.1%,兩年平均增長6.1%。其中高技術制造業增長...

史海拾趣

問答坊 | AI 解惑

DM642DK VER1.12 視頻開發板

DM642DK VER1.12 視頻開發板 這款開發平臺完全兼容TI原裝的EVM板,并且在硬件有所加強及擴充,軟件上TI原裝EVM板的所有例程都能在我們這個開發平臺上成功運行,沒有任何差異,而價格卻只有TI原裝板的13到14左右,極大的降低了人們進入DM642開發 ...…

查看全部問答∨

我們入職前必備書--video demystified 5th edition

我們的要求的通讀前7章。針對顯示器開發的必備基礎。…

查看全部問答∨

NEC單片機之——K0S如何寫匯編

本帖最后由 paulhyde 于 2014-9-15 08:58 編輯  …

查看全部問答∨

三極管的直流放大系數的困惑

1.網上經常看到有人說設三極管的直流放大系數為多少多少    怎么直流放大系數還能自己設置的?不是固定的嗎? 2.三極管數據手冊上的hfe怎么會有最大最小值?我要取值的話   該取多大的hfe? 望各位兄弟進來探討探討 &nb ...…

查看全部問答∨

CML、PECL及LVDS間的互相連接知識

CML、PECL及LVDS間的互相連接知識…

查看全部問答∨

Windows CE中實現藍牙串口驅動程序.pdf

Windows CE中實現藍牙串口驅動程序.pdf…

查看全部問答∨

有酬咨詢,急!!!!

在屏幕上隨機點任意多個點,怎么生成圓滑的曲線.好像是用二次樣條算法,我自己編了一個效果不好,希望懂的人能幫一下忙,可以付報酬(公司出錢)。最好有圖形算法這類經驗,可以外包一些程序。我EMAIL:jman009@tom.com  希望能盡快聯系!…

查看全部問答∨

如何制作一個圓角矩形按紐.

真誠的問各位高手大哥,如何在對話框上制作一個圓角矩形按紐,先在這里謝謝了.…

查看全部問答∨

針對Intel® Atom處理器N270的電源參考設計

此參考設計旨在給Intel® Atom N270處理器供電。…

查看全部問答∨
小廣播
設計資源 培訓 開發板 精華推薦

最新單片機文章
何立民專欄 單片機及嵌入式寶典

北京航空航天大學教授,20余年來致力于單片機與嵌入式系統推廣工作。

 
EEWorld訂閱號

 
EEWorld服務號

 
汽車開發圈

 
機器人開發圈

電子工程世界版權所有 京ICP證060456號 京ICP備10001474號-1 電信業務審批[2006]字第258號函 京公網安備 11010802033920號 Copyright ? 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
主站蜘蛛池模板: 卢湾区| 乐业县| 图们市| 盈江县| 沁源县| 合江县| 靖江市| 临颍县| 安岳县| 布拖县| 荆门市| 赤峰市| 三原县| 淮阳县| 铁岭市| 越西县| 招远市| 乌拉特中旗| 广州市| 章丘市| 和政县| 红原县| 凯里市| 普兰店市| 阿坝县| 中江县| 高雄县| 松原市| 长沙县| 疏附县| 巴东县| 太湖县| 揭西县| 彰化县| 兴和县| 华安县| 会同县| 洛隆县| 固安县| 新巴尔虎左旗| 琼中|