本文介紹了如何解決STM32芯片Flash寫保護導致無法下載程序,無法在線調試的問題;如果您遇到相同的問題,希望本文可以帶來一些幫助;
如果本文幫到了您,請幫忙點個贊 👍👍👍;
如果本文幫到了您,請幫忙點個贊 👍👍👍;
如果本文幫到了您,請幫忙點個贊 👍👍👍;
1 FLASH的寫保護
如果對Flash設置了寫保護,那就無法對Flash進行編程和擦除。在開發STM32的時候,如果出現這種情況,通常仿真器都支持對Flash進行解鎖,像jlink,stlink等仿真器都支持這個功能。
2 錯誤提示
在使用MDK進行調試的時候,出現報錯 Flash Timeout.Reset Target and try it again,具體如下圖所示;

折騰了一番之后,並沒有解決問題,因為使用的仿真器是stlink,因此下載了stlink utility嘗試解決問題;
3 stlink utility
3.1 基本功能
stlink utility是ST官方提供的免費軟件,支持STM32 ST-LINK的程序包括帶有命令行界面(CLI)的圖形用戶界面(GUI)。
該工具還提供了較多的其他功能,具體如下;
- 可以對STM32 內部存儲器 (Flash,RAM,OTP和其他存儲器),外部存儲器進行編程;
- 驗證程序內容(校驗和,在編程期間和之后進行校驗,與文件進行比較等)
- 還能實現 STM32編程自動化;
- 另外還提供其他的功能;
3.2 解鎖Flash
在stlink連接目標板的情況下,打開stlink utility,在菜單欄的Target下選擇connect,因為這時候Flash已經被鎖住了,所以同樣地也看到相應的錯誤提示 Can not read memory Disable Read Out Protection and retry,具體如下圖所示;

OK,下面只需要接觸寫保護就行了,所以在菜單欄target里打開Option Bytes…選項,或者直接通過快捷鍵ctrl+B打開,請確保當前已經正確連接了stlink和目標板,否則會出現報錯;
正確連接的情況下,打開Option Bytes…,發現在這里Read Out Protection選項是enable,這個表示無法通過swd讀取STM32內部Flash的程序。

關鍵點:
將Read Out Protection選項設置位disable,點擊Apply,這時候Flash已經成功解鎖了。但是同時發現,內部Flash已經被擦除了,,這可能STM32的保護機制有關,防止程序被拷機,然后進行反編譯破解,這樣也可以提高破解的門檻。具體顯示如下圖所示;

完成以上步驟之后,在菜單欄Target下選擇Disconnect,或者通過快捷鍵ctrl+D斷開和目標板的連接;重新進入MDK,就能正常對目標板進行調試,仿真,以及程序的燒寫。
3.3 寫保護
在菜單欄target里打開Option Bytes…選項,我們還看到下面有Flash sector protection選項;選擇Select all之后,發現所有Page都已經寫保護了,只要選擇apply選項就可以對Flash進行寫保護;具體如下所示;

4 總結
對於Flash寫保護的問題可以結合STM32參考手冊進行相應的學習,其內部Flash提供相應的保護機制,本文只是結合ST官方工具stlink utility解決一下常見的這個簡單的問題。
筆者能力和水平有限,文中難免有錯誤和紕漏之處,請大佬們不吝賜教;
創作不易,如果本文幫到了您;
如果本文幫到了您,請幫忙點個贊 👍👍👍;
如果本文幫到了您,請幫忙點個贊 👍👍👍;
如果本文幫到了您,請幫忙點個贊 👍👍👍;
