STM32启动模式详解
一、三種boot啟動模式:
? ? ? ?一般來說就是指我們下好程序后,重啟芯片時,SYSCLK的第4個上升沿,BOOT引腳的值將被鎖存。用戶可以通過設(shè)置BOOT1和BOOT0引腳的狀態(tài),來選擇在復(fù)位后的啟動模式。
 
1、第一種方式(boot0 = 0):Flash memory啟動方式。啟動地址:0x08000000 (stm32F207系列)
? ??是STM32內(nèi)置的Flash,一般我們使用JTAG或者SWD模式下載程序時,就是下載到這個里面,重啟后也直接從這啟動程序。
? ? 基本上都是采用這種模式。
2、第二種方式(boot0 = 1;boot1 = 0:System memory啟動方式。啟動地址:0x1FFF0000 (stm32F207系列)
? ??從系統(tǒng)存儲器啟動,這種模式啟動的程序功能是由廠家設(shè)置的。一般來說,這種啟動方式用的比較少。系統(tǒng)存儲器是芯片內(nèi)部一塊特定的區(qū)域,STM32在出廠時,由ST在這個區(qū)域內(nèi)部預(yù)置了一段BootLoader, 也就是我們常說的ISP程序, 這是一塊ROM,出廠后無法修改。一般來說,我們選用這種啟動模式時,是為了從串口下載程序,因為在廠家提供的BootLoader 中,提供了串口下載程序的固件,可以通過這個BootLoader將程序下載到系統(tǒng)的Flash中。但是這個下載方式需要以下步驟:
 
Step1:將BOOT0設(shè)置為1,BOOT1設(shè)置為0,然后按下復(fù)位鍵,這樣才能從系統(tǒng)存儲器啟動BootLoader
 
Step2:最后在BootLoader的幫助下,通過串口下載程序到Flash中
 Step3:程序下載完成后,又有需要將BOOT0設(shè)置為GND,手動復(fù)位,這樣,STM32才可以從Flash中啟動可以看到, 利用串 口下載程序還是比較的麻煩,需要跳帽跳來跳去的,非常的不注重用戶體驗。
3、第三種方式(boot0 = 1;boot1 = 1):SRAM啟動方式。啟動地址:0x20000000(stm32F207系列)
? ??內(nèi)置SRAM,既然是SRAM,自然也就沒有程序存儲的能力了,這個模式一般用于程序調(diào)試。假如我只修改了代碼中一個小小的? ? ? 地方,然后就需要重新擦除整個Flash,比較的費時,可以考慮從這個模式啟動代碼(也就是STM32的內(nèi)存中),用于快速的程序調(diào)試,等程序調(diào)試完成后,在將程序下載到SRAM中。
 
二、關(guān)于啟動地址:
? ??理論上,CM3中規(guī)定上電后CPU是從0地址開始執(zhí)行,但是這里中斷向量表卻被燒寫在0x0800 0000地址里(Flash memory啟動方式),那啟動時不就找不到中斷向量表了?既然CM3定下的規(guī)矩是從0地址啟動,SMT32當(dāng)然不能破壞ARM定下的“規(guī)矩”,所以它做了一個啟動映射的過程,就是和芯片上總能見到的BOOT0和BOOT1有關(guān)了,當(dāng)選擇從主Flash啟動模式后,芯片一上電,Flash的0x0800 0000地址被映射到0地址處,不影響CM3內(nèi)核的讀取,所以這時的CM3既可以在0地址處訪問中斷向量表,也可以在0x0800 0000地址處訪問中斷向量表,而代碼還是在0x0800 0000地址處存儲的。
 
三、關(guān)于flash死鎖的解決辦法(Flash memory啟動方式):
? ? ?開發(fā)調(diào)試過程中,由于某種原因?qū)е聝?nèi)部Flash鎖死,無法連接SWD以及Jtag調(diào)試,無法讀到設(shè)備,可以通過修改BOOT模式重新刷寫代碼。
? ? ?修改為BOOT0=1,BOOT1=0即可從系統(tǒng)存儲器啟動,ST出廠時自帶Bootloader程序,SWD以及JTAG調(diào)試接口都是專用的。重 新燒寫程序后,可將BOOT模式重新更換到BOOT0=0,BOOT1=X即可正常使用。
 
 
? ?
 
? ??
總結(jié)
以上是生活随笔為你收集整理的STM32启动模式详解的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: 编译arm平台的ethtool
- 下一篇: SVN 常用操作命令 使用笔记
