吴忠躺衫网络科技有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

基于Cortex-M4的STM32F4的復位序列

電子設計 ? 來源:STM32單片機 ? 作者:STM32單片機 ? 2021-02-16 06:14 ? 次閱讀

初次接觸到STM32F7,可能會有個疑惑,為什么0地址變成了ITCM RAM的起始地址。系統復位還是從地址0處開始執行嗎?如果是,那這似乎看起來是沖突的。實際上,STM32F7是基于Cortex-M7內核,而Cortex-M7和Cortex-M3/M4的復位序列有些不一樣。本文中,將針對這個問題做詳細講解。

STM32F4的復位序列

STM32F4基于Cortex-M4。對于基于Cortex-M3/M4的芯片,復位后總是從0x00000000地址處,取主堆棧指針(MSP)的值,從0x00000004處,取出PC的初始值(這個值是復位向量),然后從這個值對應的地址處取指。

pIYBAF_8AyqAaKHGAABiMYVAmhE037.png

這兩個值,就是中斷向量表里的第一個和第二個表項的值。

pIYBAF_8AzWAZWlfAAIXOu8qOiE677.png

在Cortex-M3/M4里,復位后默認中斷向量表在0地址開始的位置。之后,可以通過修改VTOR寄存器的值,重定位中斷向量表。在IAP的應用中,我們會遇到這種情況,如下圖:

o4YBAF_8A0GALlzvAAG0K3iieqs796.png

上電復位,先執行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決定的。

o4YBAF_8A06AcrC5AAB7cVQRijQ739.png

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里面跑別的程序的話,就要注意向量表不要與其他程序的地址重疊了。
編輯:hfy

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • STM32F7
    +關注

    關注

    1

    文章

    48

    瀏覽量

    9027
收藏 人收藏

    評論

    相關推薦

    STM32F7與STM32F4復位序列之比較

    7是基于Cortex-M7內核,而Cortex-M7和Cortex-M3/M4復位序列有些不一
    發表于 05-31 14:17

    STM32F7與STM32F4復位序列有什么區別

    Cortex-M7和Cortex-M3/M4復位序列有些不一樣。那么STM32F7與
    發表于 03-05 07:06

    Cortex-M4內核與STM32的關系是什么

    Cortex-M4處理器的內部資源 STM32F4系列提供的CPU外部資源總線矩陣:總線矩陣是STM32單片機內最重要的硬件結構之一,通過總線矩陣靈活地將Cortex-M4處理器的內核
    發表于 07-01 06:18

    STM32F7與STM32F4復位序列比較

    STM32F7與STM32F4復位序列比較
    發表于 12-08 11:52 ?0次下載

    STM32F4xxx的CORTEX-M4內核編程手冊

    STM32F4xxx的CORTEX-M4內核編程手冊
    發表于 09-22 16:21 ?87次下載
    <b class='flag-5'>STM32F4</b>xxx的<b class='flag-5'>CORTEX-M4</b>內核編程手冊

    基于STM32F4系列搶占Cortex_M4內核先機

    基于STM32F4系列搶占Cortex_M4內核先機
    發表于 09-26 09:07 ?14次下載
    基于<b class='flag-5'>STM32F4</b>系列搶占<b class='flag-5'>Cortex_M4</b>內核先機

    STM32F4xx-Cortex_-M4內核參考手冊

    developers. It gives a full description of the STM32F3 and STM32F4 Series Cortex -M4 proces
    發表于 12-05 16:11 ?27次下載

    STM32F4 Cortex-M4 性能簡介

    STM32F4 Cortex-M4在音頻處理的優勢.
    的頭像 發表于 06-22 16:35 ?1.9w次閱讀

    介紹STM32F4Cortex-M4內核和Cortex-M3內核方面的優勢

    該視頻通過STM32F4 MCU展示了在音頻處理應用方面Cortex-M4內核和Cortex-M3內核的比較優勢
    的頭像 發表于 07-03 04:19 ?1.4w次閱讀

    STM32F4復位序列對比STM32F7的復位序列

    STM32F4基于Cortex-M4。對于基于Cortex-M3/M4的芯片,復位后總是從0x00000000地址處,取主堆棧指針(MSP)
    的頭像 發表于 01-18 16:44 ?3164次閱讀

    STM32F4復位序列

    STM32F7是基于Cortex-M7內核,而Cortex-M7和Cortex-M3/M4復位
    的頭像 發表于 02-21 10:02 ?2800次閱讀
    <b class='flag-5'>STM32F4</b>的<b class='flag-5'>復位</b><b class='flag-5'>序列</b>

    STM32F7與STM32F4復位序列比較

    STM32F7是基于Cortex-M7內核,而Cortex-M7和Cortex-M3/M4復位
    發表于 03-03 06:54 ?6次下載
    <b class='flag-5'>STM32F</b>7與<b class='flag-5'>STM32F4</b>之<b class='flag-5'>復位</b><b class='flag-5'>序列</b>比較

    Cortex-M4內核與STM32的關系:

    Cortex-M4處理器的內部資源 STM32F4系列提供的CPU外部資源 總線矩陣:總線矩陣是STM32單片機內最重要的硬件結構之一,通過總線矩陣靈活地將Cortex-M
    發表于 12-01 11:51 ?6次下載
    <b class='flag-5'>Cortex-M4</b>內核與<b class='flag-5'>STM32</b>的關系:

    STM32F4】三、NVIC中斷優先級管理

    :本博文只是對正點原子課程的又一次重復,總結正點的教程、寫一些自己的感悟,并非以原創之名做抄襲之事。一、STM32F4中斷的介紹1. STM32F4的中斷個數、類型STM32F4的內核是ARM家的
    發表于 12-04 14:51 ?0次下載
    【<b class='flag-5'>STM32F4</b>】三、NVIC中斷優先級管理

    STM32F7與STM32F4復位序列比較

    7 基于 Cortex-M7 內核,Cortex-M7 和 Cortex-M3/M4復位序列
    發表于 09-28 11:11 ?0次下載
    百家乐官网群shozo| 娱乐场百家乐大都| 金龍娱乐城| 百家乐赢退输进有哪些| 百家乐官网筹码方形| 大发888赌场娱乐网规则| 百家乐另类投注法| 百家乐官网桌| 和硕县| 大发888游戏代充值| 百家乐娱乐城主页| 澳门百家乐官网娱乐城信誉如何| 云鼎娱乐城信誉| 大发888网上赌场官网| 足球.百家乐投注网出租| 八卦罗盘24山图| 蓝盾百家乐官网具体玩法技巧 | 百家乐游乐园| 网上百家乐赌钱| 粤港澳百家乐官网娱乐网| 百家乐官网分析绿色版| 赌片百家乐官网的玩法技巧和规则 | 百家乐国际娱乐场| 百家乐最长的闲| 东莞百家乐官网的玩法技巧和规则| 12倍百家乐官网秘籍| 淮滨县| 海王星| bet365滚球| 新全讯网网址g2vvv| JJ百家乐的玩法技巧和规则| 乐天堂百家乐娱乐场| 澳门百家乐在线| 百家乐微笑玩法| 永利百家乐娱乐场| 百家乐大钱赢小钱| 澳门百家乐新濠天地| 百家乐一柱擎天| 金樽百家乐的玩法技巧和规则 | 太子百家乐官网娱乐城| 百家乐官网游戏筹码|