資料介紹
初次接觸到STM32F7,可能會(huì)有個(gè)疑惑,為什么0地址變成了ITCM RAM的起始地址。系統(tǒng)復(fù)位還是從地址0處開(kāi)始執(zhí)行嗎?如果是,那這似乎看起來(lái)是沖突的。實(shí)際上,STM32F7是基于Cortex-M7內(nèi)核,而Cortex-M7和Cortex-M3/M4的復(fù)位序列有些不一樣。本文中,將針對(duì)這個(gè)問(wèn)題做詳細(xì)講解。
STM32F4的復(fù)位序列
STM32F4基于Cortex-M4。對(duì)于基于Cortex-M3/M4的芯片,復(fù)位后總是從0x00000000地址處,取主堆棧指針(MSP)的值,從0x00000004處,取出PC的初始值(這個(gè)值是復(fù)位向量),然后從這個(gè)值對(duì)應(yīng)的地址處取指。

這兩個(gè)值,就是中斷向量表里的第一個(gè)和第二個(gè)表項(xiàng)的值。

在Cortex-M3/M4里,復(fù)位后默認(rèn)中斷向量表在0地址開(kāi)始的位置。之后,可以通過(guò)修改VTOR寄存器的值,重定位中斷向量表。在IAP的應(yīng)用中,我們會(huì)遇到這種情況,如下圖:

上電復(fù)位,先執(zhí)行IAP程序。此時(shí)用到的是位于0地址處的IAP程序的向量表(雖然圖中說(shuō)此時(shí)VTOR的值等于0x08000000,實(shí)際上,因?yàn)镾T提供了存儲(chǔ)器地址重映射的功能,通過(guò)boot引腳的配置,已經(jīng)將0x08000000處的存儲(chǔ)空間重映射到了地址0處,所以0x08000000和地址0x00000000處開(kāi)始的存儲(chǔ)空間是同一塊物理空間,其內(nèi)容當(dāng)然也是一樣的。所以不用修改VTOR的值,VTOR=0也是一樣的)。言歸正傳,上電后,先從IAP復(fù)位中斷程序開(kāi)始執(zhí)行IAP程序,執(zhí)行完IAP程序后,需要跳轉(zhuǎn)到用戶程序,這時(shí)就需要將向量表重定位到用戶程序的向量表位置(修改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地址處,而是可以由各個(gè)芯片廠商自己定義。
對(duì)于STM32F7來(lái)說(shuō),它是由BOOT_ADD0[15:0]和BOOT_ADD1[15:0]這兩個(gè)optionbytes決定的。

Boot 腳= 0時(shí),由BOOT_ADD0 [15:0] 的值決定,ST默認(rèn)值為0x0020 0000。這是ITCM-FLASH的起始地址(通過(guò)ART加速器,訪問(wèn)FLASH);
Boot 腳= 1時(shí),由BOOT_ADD1 [15:0] 的值決定,ST默認(rèn)值為0x0010 0000。這是system Bootloader的起始地址。
* 如果對(duì)BOOT_ADDx寫(xiě)入的地址值超出了存儲(chǔ)器映射的范圍或者到了保留地址空間,系統(tǒng)將自動(dòng)轉(zhuǎn)為下面的值:
BOOT_ADD0 = 0x0020 0000;
BOOT_ADD1 = 0x0000 0000(和出廠時(shí)ST默認(rèn)的值0x0010 0000不一樣)
也就是說(shuō),只要你配置好了boot address, stm32F7芯片的硬件會(huì)自動(dòng)修改向量表的偏移地址寄存器VTOR,使之與boot address相匹配。不需要再通過(guò)軟件修改VTOR寄存器。
回到本文開(kāi)始的那個(gè)問(wèn)題。對(duì)于STM32F7來(lái)說(shuō),默認(rèn)狀態(tài)下,復(fù)位后它并不是從0地址開(kāi)始執(zhí)行,而是從0x0020 0000 或者0x0010 0000開(kāi)始執(zhí)行,所以與ITCM-RAM從0地址處開(kāi)始并不沖突。如果你非要將向量表放在0地址開(kāi)始的位置(修改VTOR寄存器),也不是不可以。只是這是,如果你還要在ITCM-RAM里面跑別的程序的話,就要注意向量表不要與其他程序的地址重疊了。
來(lái)源: STM32單片機(jī)
- UM1907_基于STM32F746NG的STM32F7系列探索套件
- AN4031_STM32F2、STM32F4和STM32F7系列的DMA控制器的應(yīng)用
- AN4860_STM32F4系列與STM32F7系列和STM32L4plus系列微控制器DSI主機(jī)
- AN5293 STM32F7系列移植到STM32H7系列
- STM32F7與STM32F4復(fù)位序列比較 0次下載
- 【STM32】STM32F4時(shí)鐘系統(tǒng)
- STM32F4 DAC數(shù)模轉(zhuǎn)換實(shí)驗(yàn)例程
- STM32F4 PWM-DAC實(shí)驗(yàn)例程
- STM32F4內(nèi)部Flash實(shí)驗(yàn)例程
- stm32f4舵機(jī)控制代碼 69次下載
- STM32F4 簡(jiǎn)介 23次下載
- STM32F4 31次下載
- STM32F7與STM32F4的復(fù)位序列比較 0次下載
- STM32F4 LWIP開(kāi)發(fā)手冊(cè) 67次下載
- STM32F7介紹 0次下載
- 使用STM32F4芯片驗(yàn)證SPI功能的問(wèn)題分析 2580次閱讀
- RT-thread源碼移植到STM32F10x和STM32F4xx 2662次閱讀
- stm32中復(fù)位電路如何設(shè)計(jì) 2655次閱讀
- FatFS文件系統(tǒng)在STM32F4上的移植和應(yīng)用 2679次閱讀
- stm32f030和stm32f103功能差異 2.2w次閱讀
- 微雪電子32F746GDISCOVERY STM32F7開(kāi)發(fā)板簡(jiǎn)介 4372次閱讀
- 微雪電子STM32F4-Discovery 開(kāi)發(fā)板簡(jiǎn)介 4960次閱讀
- 你知道STM32F4中的CCM內(nèi)存該如何使用? 3961次閱讀
- 基于STM32介紹DMA的雙緩沖模式 2.4w次閱讀
- 基于STM32F4系列MCU新建立用庫(kù)工程的步驟及方法 3416次閱讀
- STM32F4時(shí)鐘系統(tǒng)原理圖解析 1.8w次閱讀
- 基于STM32F4/F7的圖形應(yīng)用演示方案 4630次閱讀
- 以STM32F4為控制核心的四軸航拍飛行器的設(shè)計(jì)與實(shí)現(xiàn) 8962次閱讀
- 基于ARM?Cortex?-M7內(nèi)核的高性能微控制器STM32F7系列特色分析 4540次閱讀
- stm32系列MCU芯片選型表 4.7w次閱讀
下載排行
本周
- 1EMC電路設(shè)計(jì)工程師必備的EMC基礎(chǔ)
- 0.42 MB | 4次下載 | 2 積分
- 2AU3116 2×60W模擬輸入雙通道Class-D 音頻功率放大器數(shù)據(jù)手冊(cè)
- 1.19 MB | 1次下載 | 免費(fèi)
- 3低壓降肖特基整流管SR340L數(shù)據(jù)手冊(cè)
- 0.78 MB | 1次下載 | 免費(fèi)
- 4ZX8002E 觸摸調(diào)光LED集成IC數(shù)據(jù)手冊(cè)
- 2.27 MB | 次下載 | 免費(fèi)
- 5SOD-323塑料封裝ESD保護(hù)二極管SD05T系列規(guī)格書(shū)
- 1.07 MB | 次下載 | 免費(fèi)
- 6SOT-23塑料封裝ESD保護(hù)二極管SMxx Series系列規(guī)格書(shū)
- 0.93 MB | 次下載 | 免費(fèi)
- 7高效率整流二極管HER151 THRU HER158數(shù)據(jù)手冊(cè)
- 0.54 MB | 次下載 | 免費(fèi)
- 8低壓降肖特基整流管SL22 THRU SL210數(shù)據(jù)手冊(cè)
- 1.03 MB | 次下載 | 免費(fèi)
本月
- 1三相逆變主電路的原理圖和PCB資料合集免費(fèi)下載
- 27.35 MB | 111次下載 | 1 積分
- 2運(yùn)算放大器基本電路中文資料
- 1.30 MB | 16次下載 | 免費(fèi)
- 3蘋(píng)果iphone 11電路原理圖
- 4.98 MB | 11次下載 | 5 積分
- 4TL494工業(yè)用開(kāi)關(guān)電源原理圖資料
- 0.22 MB | 10次下載 | 1 積分
- 5常用電子元器件介紹
- 3.21 MB | 8次下載 | 免費(fèi)
- 6QW2893應(yīng)急燈專用檢測(cè)芯片
- 590.40 KB | 4次下載 | 免費(fèi)
- 7相關(guān)協(xié)議信號(hào)總結(jié)
- 0.94 MB | 4次下載 | 免費(fèi)
- 8EMC電路設(shè)計(jì)工程師必備的EMC基礎(chǔ)
- 0.42 MB | 4次下載 | 2 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935130次下載 | 10 積分
- 2開(kāi)源硬件-PMP21529.1-4 開(kāi)關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191390次下載 | 10 積分
- 5十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183344次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81591次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73815次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65989次下載 | 10 積分
評(píng)論