三種BOOT模式
所謂啟動,一般來說就是指我們下好程序后,重啟芯片時,SYSCLK的第4個上升沿,BOOT引腳的值將被鎖存。用戶可以通過設置BOOT1和BOOT0引腳的狀態(tài),來選擇在復位后的啟動模式,相關(guān)文章:詳解STM32啟動文件。
Main Flash memory
是STM32內(nèi)置的Flash,一般我們使用JTAG或者SWD模式下載程序時,就是下載到這個里面,重啟后也直接從這啟動程序。
System memory
從系統(tǒng)存儲器啟動,這種模式啟動的程序功能是由廠家設置的。一般來說,這種啟動方式用的比較少。系統(tǒng)存儲器是芯片內(nèi)部一塊特定的區(qū)域,STM32在出廠時,由ST在這個區(qū)域內(nèi)部預置了一段BootLoader, 也就是我們常說的ISP程序, 這是一塊ROM,
出廠后無法修改。一般來說,我們選用這種啟動模式時,是為了從串口下載程序,因為在廠家提供的BootLoader中,提供了串口下載程序的固件,可以通過這個BootLoader將程序下載到系統(tǒng)的Flash中。但是這個下載方式需要以下步驟:
Step1:將BOOT0設置為1,BOOT1設置為0,然后按下復位鍵,這樣才能從系統(tǒng)存儲器啟動BootLoader
Step2:最后在BootLoader的幫助下,通過串口下載程序到Flash中
Step3:程序下載完成后,又有需要將BOOT0設置為GND,手動復位,這樣,STM32才可以從Flash中啟動可以看到, 利用串口下載程序還是比較的麻煩, 需要跳帽跳來跳去的,非常的不注重用戶體驗。
Embedded Memory
內(nèi)置SRAM,既然是SRAM,自然也就沒有程序存儲的能力了,這個模式一般用于程序調(diào)試。假如我只修改了代碼中一個小小的地方,然后就需要重新擦除整個Flash,比較的費時,可以考慮從這個模式啟動代碼(也就是STM32的內(nèi)存中),用于快速的程序調(diào)試,等程序調(diào)試完成后,在將程序下載到SRAM中。
開發(fā)BOOT模式選擇
通常使用程序代碼存儲在主閃存存儲器,配置方式:BOOT0=0,BOOT1=X。
Flash鎖死解決辦法
開發(fā)調(diào)試過程中,由于某種原因?qū)е聝?nèi)部Flash鎖死,無法連接SWD以及Jtag調(diào)試,無法讀到設備,可以通過修改BOOT模式重新刷寫代碼。相關(guān)文章:STM32的Flash寫了保護怎么辦?
修改為BOOT0=1,BOOT1=0即可從系統(tǒng)存儲器啟動,ST出廠時自帶Bootloader程序,SWD以及JTAG調(diào)試接口都是專用的。重新燒寫程序后,可將BOOT模式重新更換到BOOT0=0,BOOT1=X即可正常使用。
原文標題:STM32的啟動模式配置與應用
文章出處:【微信公眾號:STM32嵌入式開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
-
存儲器
+關(guān)注
關(guān)注
38文章
7606瀏覽量
165853 -
STM32
+關(guān)注
關(guān)注
2282文章
10986瀏覽量
361106 -
程序
+關(guān)注
關(guān)注
117文章
3816瀏覽量
82121 -
Boot
+關(guān)注
關(guān)注
0文章
152瀏覽量
36431
原文標題:STM32的啟動模式配置與應用
文章出處:【微信號:c-stm32,微信公眾號:STM32嵌入式開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
為什么BOOT_CFG1_1和BOOT_CFG1_6為L時不能寫入?
從emmc boot-partition引導LS1043a遇到的疑問求解
STM32U535能用USART1進行串口燒錄嗎?
STM32G4 option配置和SWD配置導致無法連接STLINK怎么解決?
Boot0通過10k電阻接地,Boot1作為輸入使用被配置成外部中斷,為什么會導致單片機加密無法運行,且無法解密?
單片機boot0和boot1怎么設置
stm32讀取boot引腳狀態(tài)
STM32引腳中的BOOT1在哪里
stm32boot0和boot1對應哪個p引腳
【GD32 MCU 入門教程】二、GD32 MCU 燒錄說明(1)ISP 燒錄

具有公共并行1/0引腳的8輸入通用移位/存儲寄存器數(shù)據(jù)表

評論