初次接觸到STM32F7,可能會有個疑惑,為什么0地址變成了ITCM RAM的起始地址。系統(tǒng)復(fù)位還是從地址0處開始執(zhí)行嗎?如果是,那這似乎看起來是沖突的。實際上,STM32F7是基于Cortex-M7內(nèi)核,而Cortex-M7和Cortex-M3/M4的復(fù)位序列有些不一樣。本文中,將針對這個問題做詳細講解。
STM32F4的復(fù)位序列
STM32F4基于Cortex-M4。對于基于Cortex-M3/M4的芯片,復(fù)位后總是從0x00000000地址處,取主堆棧指針(MSP)的值,從0x00000004處,取出PC的初始值(這個值是復(fù)位向量),然后從這個值對應(yīng)的地址處取指。
這兩個值,就是中斷向量表里的第一個和第二個表項的值。
在Cortex-M3/M4里,復(fù)位后默認中斷向量表在0地址開始的位置。之后,可以通過修改VTOR寄存器的值,重定位中斷向量表。在IAP的應(yīng)用中,我們會遇到這種情況,如下圖:
上電復(fù)位,先執(zhí)行IAP程序。此時用到的是位于0地址處的IAP程序的向量表(雖然圖中說此時VTOR的值等于0x08000000,實際上,因為ST提供了存儲器地址重映射的功能,通過boot引腳的配置,已經(jīng)將0x08000000處的存儲空間重映射到了地址0處,所以0x08000000和地址0x00000000處開始的存儲空間是同一塊物理空間,其內(nèi)容當(dāng)然也是一樣的。所以不用修改VTOR的值,VTOR=0也是一樣的)。言歸正傳,上電后,先從IAP復(fù)位中斷程序開始執(zhí)行IAP程序,執(zhí)行完IAP程序后,需要跳轉(zhuǎn)到用戶程序,這時就需要將向量表重定位到用戶程序的向量表位置(修改VTOR寄存器的值到用戶向量表的起始地址)。
這是M3/M4的情況,STM32F7之前的所有芯片都是一樣的。
STM32F7的復(fù)位序列
前面講的那些情況,在STM32F7中就有些不一樣了。在ARM Cortex-M7的Generic User Guide中,有一段如下描述:“On system reset, thevector table is at the address configured at implementation, typically0x00000000. ”從這段話,我們可以看出,在M7中,復(fù)位后向量表的位置不是固定在0地址處,而是可以由各個芯片廠商自己定義。
對于STM32F7來說,它是由BOOT_ADD0[15:0]和BOOT_ADD1[15:0]這兩個optionbytes決定的。
Boot 腳= 0時,由BOOT_ADD0 [15:0] 的值決定,ST默認值為0x0020 0000。這是ITCM-FLASH的起始地址(通過ART加速器,訪問FLASH);
Boot 腳= 1時,由BOOT_ADD1 [15:0] 的值決定,ST默認值為0x0010 0000。這是system Bootloader的起始地址。
* 如果對BOOT_ADDx寫入的地址值超出了存儲器映射的范圍或者到了保留地址空間,系統(tǒng)將自動轉(zhuǎn)為下面的值:
BOOT_ADD0 = 0x0020 0000;
BOOT_ADD1 = 0x0000 0000(和出廠時ST默認的值0x0010 0000不一樣)
也就是說,只要你配置好了boot address, stm32F7芯片的硬件會自動修改向量表的偏移地址寄存器VTOR,使之與boot address相匹配。不需要再通過軟件修改VTOR寄存器。
回到本文開始的那個問題。對于STM32F7來說,默認狀態(tài)下,復(fù)位后它并不是從0地址開始執(zhí)行,而是從0x0020 0000 或者0x0010 0000開始執(zhí)行,所以與ITCM-RAM從0地址處開始并不沖突。如果你非要將向量表放在0地址開始的位置(修改VTOR寄存器),也不是不可以。只是這是,如果你還要在ITCM-RAM里面跑別的程序的話,就要注意向量表不要與其他程序的地址重疊了。
來源: STM32單片機
審核編輯:何安
-
STM32F4
+關(guān)注
關(guān)注
3文章
204瀏覽量
29678 -
STM32F7
+關(guān)注
關(guān)注
1文章
48瀏覽量
9819
發(fā)布評論請先 登錄
【教程】使用STM32F4進行E22-400T22S編程通信教程

stm32f4新手求教
【教程】零基礎(chǔ)!手把手教你使用STM32F4進行E22-400T22S編程通信

零知開源——STM32F4實現(xiàn)ILI9486顯示屏UI界面系列教程(二):日歷功能實現(xiàn)

STM32F3系列、STM32F4系列、STM32L4系列和STM32L4+系列Cortex-M4編程手冊

使用SPI進行通信,STM32F4做從機,通信時數(shù)據(jù)異常怎么解決?
Arduino中可以使用STM32F1或者STM32F4系列芯片的內(nèi)置看門狗嗎?
使用STM32F4的ADC的時候,發(fā)現(xiàn)測量結(jié)果不準(zhǔn)確,是什么原因?qū)е碌模?/a>
stm32f4 sdio時鐘如何獲取通過什么函數(shù)?
ADS1115和STM32F4通訊,輸出的數(shù)一直都是不變的,為什么?
使用STM32F4系列的芯片驅(qū)動ADS1110做電壓采樣,配置寄存器設(shè)置為0x8C,讀出的寄存器值時0XFF,為什么?
STM32項目實戰(zhàn):基于STM32F4的智能大棚溫控系統(tǒng)(LVGL),附項目教程/源碼

評論