資料介紹
初次接觸到STM32F7,可能會有個疑惑,為什么0地址變成了ITCM RAM的起始地址。系統復位還是從地址0處開始執行嗎?如果是,那這似乎看起來是沖突的。實際上,STM32F7是基于Cortex-M7內核,而Cortex-M7和Cortex-M3/M4的復位序列有些不一樣。本文中,將針對這個問題做詳細講解。
STM32F4的復位序列
STM32F4基于Cortex-M4。對于基于Cortex-M3/M4的芯片,復位后總是從0x00000000地址處,取主堆棧指針(MSP)的值,從0x00000004處,取出PC的初始值(這個值是復位向量),然后從這個值對應的地址處取指。
這兩個值,就是中斷向量表里的第一個和第二個表項的值。
在Cortex-M3/M4里,復位后默認中斷向量表在0地址開始的位置。之后,可以通過修改VTOR寄存器的值,重定位中斷向量表。在IAP的應用中,我們會遇到這種情況,如下圖:
上電復位,先執行IAP程序。此時用到的是位于0地址處的IAP程序的向量表(雖然圖中說此時VTOR的值等于0x08000000,實際上,因為ST提供了存儲器地址重映射的功能,通過boot引腳的配置,已經將0x08000000處的存儲空間重映射到了地址0處,所以0x08000000和地址0x00000000處開始的存儲空間是同一塊物理空間,其內容當然也是一樣的。所以不用修改VTOR的值,VTOR=0也是一樣的)。言歸正傳,上電后,先從IAP復位中斷程序開始執行IAP程序,執行完IAP程序后,需要跳轉到用戶程序,這時就需要將向量表重定位到用戶程序的向量表位置(修改VTOR寄存器的值到用戶向量表的起始地址)。
這是M3/M4的情況,STM32F7之前的所有芯片都是一樣的。
STM32F7的復位序列
前面講的那些情況,在STM32F7中就有些不一樣了。在ARM Cortex-M7的Generic User Guide中,有一段如下描述:“On system reset, thevector table is at the address configured at implementation, typically0x00000000. ”從這段話,我們可以看出,在M7中,復位后向量表的位置不是固定在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寫入的地址值超出了存儲器映射的范圍或者到了保留地址空間,系統將自動轉為下面的值:
BOOT_ADD0 = 0x0020 0000;
BOOT_ADD1 = 0x0000 0000(和出廠時ST默認的值0x0010 0000不一樣)
也就是說,只要你配置好了boot address, stm32F7芯片的硬件會自動修改向量表的偏移地址寄存器VTOR,使之與boot address相匹配。不需要再通過軟件修改VTOR寄存器。
回到本文開始的那個問題。對于STM32F7來說,默認狀態下,復位后它并不是從0地址開始執行,而是從0x0020 0000 或者0x0010 0000開始執行,所以與ITCM-RAM從0地址處開始并不沖突。如果你非要將向量表放在0地址開始的位置(修改VTOR寄存器),也不是不可以。只是這是,如果你還要在ITCM-RAM里面跑別的程序的話,就要注意向量表不要與其他程序的地址重疊了。
來源: STM32單片機
- UM1907_基于STM32F746NG的STM32F7系列探索套件
- AN4031_STM32F2、STM32F4和STM32F7系列的DMA控制器的應用
- AN4860_STM32F4系列與STM32F7系列和STM32L4plus系列微控制器DSI主機
- STM32F7與STM32F4復位序列比較 0次下載
- 【STM32】STM32F4時鐘系統
- STM32F4 DAC數模轉換實驗例程
- STM32F4 PWM-DAC實驗例程
- STM32F4 SPI-FLASH實驗例程
- STM32F4內部Flash實驗例程
- stm32f4舵機控制代碼 68次下載
- STM32F4 簡介 23次下載
- STM32F4 31次下載
- STM32F7與STM32F4的復位序列比較 0次下載
- STM32F4 LWIP開發手冊 67次下載
- STM32F7介紹 0次下載
- 使用STM32F4芯片驗證SPI功能的問題分析 1558次閱讀
- 因STM32移植而引發的兩個小疑問 835次閱讀
- RT-thread源碼移植到STM32F10x和STM32F4xx 2020次閱讀
- stm32中復位電路如何設計 2173次閱讀
- FatFS文件系統在STM32F4上的移植和應用 2245次閱讀
- stm32f030和stm32f103功能差異 2.1w次閱讀
- 微雪電子32F746GDISCOVERY STM32F7開發板簡介 4040次閱讀
- 你知道STM32F4中的CCM內存該如何使用? 3695次閱讀
- 基于STM32介紹DMA的雙緩沖模式 2.3w次閱讀
- 基于STM32F4系列MCU新建立用庫工程的步驟及方法 3332次閱讀
- STM32F4時鐘系統原理圖解析 1.7w次閱讀
- 基于STM32F4/F7的圖形應用演示方案 4537次閱讀
- 以STM32F4為控制核心的四軸航拍飛行器的設計與實現 8601次閱讀
- 基于ARM?Cortex?-M7內核的高性能微控制器STM32F7系列特色分析 4315次閱讀
- stm32系列MCU芯片選型表 4.7w次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開關電源基礎知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統的設計與實現
- 0.61 MB | 2次下載 | 免費
- 6基于FPGA的C8051F單片機開發板設計
- 0.70 MB | 2次下載 | 免費
- 751單片機窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 8基于51單片機的RGB調色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關電源設計實例指南
- 未知 | 21548次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數字電路基礎pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅動電路設計》 溫德爾著
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537796次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191185次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183278次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論
查看更多