0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

STM32F4的復(fù)位序列

電子設(shè)計(jì) ? 來源:電子設(shè)計(jì) ? 作者:電子設(shè)計(jì) ? 2022-02-21 10:02 ? 次閱讀

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

STM32F4的復(fù)位序列

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

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

pIYBAGAH2LCAYR5WAABpzKZc-Ho113.jpg

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

pIYBAGAH2PCABgecAABk3DwP3-E369.jpg

上電復(fù)位,先執(zhí)行IAP程序。此時(shí)用到的是位于0地址處的IAP程序的向量表(雖然圖中說此時(shí)VTOR的值等于0x08000000,實(shí)際上,因?yàn)镾T提供了存儲(chǔ)器地址重映射的功能,通過boot引腳的配置,已經(jīng)將0x08000000處的存儲(chǔ)空間重映射到了地址0處,所以0x08000000和地址0x00000000處開始的存儲(chǔ)空間是同一塊物理空間,其內(nèi)容當(dāng)然也是一樣的。所以不用修改VTOR的值,VTOR=0也是一樣的)。言歸正傳,上電后,先從IAP復(fù)位中斷程序開始執(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è)芯片廠商自己定義。

對于STM32F7來說,它是由BOOT_ADD0[15:0]和BOOT_ADD1[15:0]這兩個(gè)optionbytes決定的。

pIYBAGAH2TGAFEk4AACKN2KofZk918.png

Boot 腳= 0時(shí),由BOOT_ADD0 [15:0] 的值決定,ST默認(rèn)值為0x0020 0000。這是ITCM-FLASH的起始地址(通過ART加速器,訪問FLASH);

Boot 腳= 1時(shí),由BOOT_ADD1 [15:0] 的值決定,ST默認(rèn)值為0x0010 0000。這是system Bootloader的起始地址。

* 如果對BOOT_ADDx寫入的地址值超出了存儲(chǔ)器映射的范圍或者到了保留地址空間,系統(tǒng)將自動(dòng)轉(zhuǎn)為下面的值:

BOOT_ADD0 = 0x0020 0000;

BOOT_ADD1 = 0x0000 0000(和出廠時(shí)ST默認(rèn)的值0x0010 0000不一樣)

也就是說,只要你配置好了boot address, stm32F7芯片的硬件會(huì)自動(dòng)修改向量表的偏移地址寄存器VTOR,使之與boot address相匹配。不需要再通過軟件修改VTOR寄存器。

回到本文開始的那個(gè)問題。對于STM32F7來說,默認(rèn)狀態(tài)下,復(fù)位后它并不是從0地址開始執(zhí)行,而是從0x0020 0000 或者0x0010 0000開始執(zhí)行,所以與ITCM-RAM從0地址處開始并不沖突。如果你非要將向量表放在0地址開始的位置(修改VTOR寄存器),也不是不可以。只是這是,如果你還要在ITCM-RAM里面跑別的程序的話,就要注意向量表不要與其他程序的地址重疊了。

來源: STM32單片機(jī)
審核編輯:何安

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • STM32F4
    +關(guān)注

    關(guān)注

    3

    文章

    194

    瀏覽量

    28056
  • STM32F7
    +關(guān)注

    關(guān)注

    1

    文章

    48

    瀏覽量

    8967
收藏 人收藏

    評論

    相關(guān)推薦

    STM32項(xiàng)目實(shí)戰(zhàn):基于STM32F4的智能燈光控制系統(tǒng)(LVGL),附項(xiàng)目教程/源碼

    《智能燈光控制系統(tǒng)_STM32F4》項(xiàng)目完整文檔、項(xiàng)目源碼,私信小雯老師免費(fèi)領(lǐng)取。STM32項(xiàng)目實(shí)戰(zhàn)之“智能燈光控制系統(tǒng)”(基于STM32F4)今天小編來分享一個(gè)《智能燈光控制系統(tǒng)》的項(xiàng)目案例,硬件
    的頭像 發(fā)表于 10-17 16:16 ?796次閱讀
    <b class='flag-5'>STM32</b>項(xiàng)目實(shí)戰(zhàn):基于<b class='flag-5'>STM32F4</b>的智能燈光控制系統(tǒng)(LVGL),附項(xiàng)目教程/源碼

    STM32F40xxx、STM32F41xxx、STM32F42xxx、STM32F43xxx中文手冊

    STM32F4系列單片機(jī)中文手冊
    發(fā)表于 08-08 14:32 ?2次下載

    STM32F4系列有對PI/SI仿真要求的文件嗎?

    STM32F4系列有對PI/SI仿真要求的文件嗎?比如PDN Targets and Decoupling Example SI信號要求
    發(fā)表于 07-02 06:26

    請問STM32F4系列有對PI/SI仿真要求的文件嗎?

    STM32F4系列有對PI/SI仿真要求的文件嗎?
    發(fā)表于 06-03 06:25

    STM32f4采集的視頻怎么在電腦顯示?

    我用stm32f4采集到的視頻想通過網(wǎng)線傳輸?shù)诫娔X,在電腦上顯示采集到的視頻,有沒有大神做個(gè)過視頻傳輸啊,我該怎么弄啊???
    發(fā)表于 05-14 08:25

    stm32f4批量燒錄,用什么軟件?

    請問,stm32f4批量燒錄,用什么軟件
    發(fā)表于 05-09 06:02

    STM32F4驅(qū)動(dòng)MMC,返回的CID和CSD數(shù)據(jù)都為0是怎么回事?

    STM32F4驅(qū)動(dòng)MMC,返回的CID和CSD數(shù)據(jù)都為0
    發(fā)表于 04-19 08:07

    stm32f4 FLASH_ProgramDoubleWord函數(shù)數(shù)據(jù)不能寫入flash的原因?

    STM32F401芯片,調(diào)用flash寫函數(shù)時(shí),如果寫一個(gè)字,也就是調(diào)用stm32f4 FLASH_ProgramWord函數(shù),能正確寫入;如果換成stm32f4 FLASH_ProgramDoubleWord函數(shù),數(shù)據(jù)不能寫
    發(fā)表于 04-12 06:50

    STM32F4和一個(gè)煙霧傳感器(MQ-2)模塊相連,STM32F4板子的電壓不能超過3.3V如何解決?

    問題: 想用STM32F4和一個(gè)煙霧傳感器(MQ-2)模塊相連,但MQ-2模塊的輸出電壓范圍是0——5V,STM32F4板子的電壓不能超過3.3V,請問該如何解決?
    發(fā)表于 04-11 06:33

    STM32F4STM32F7的復(fù)位序列介紹

    內(nèi)核,而Cortex-M7和Cortex-M3/M4復(fù)位序列有些不一樣。本文中,將針對這個(gè)問題做詳細(xì)講解。 STM32F4復(fù)位
    發(fā)表于 04-08 07:05

    STM32F1改用STM32F2或STM32F4芯片后,發(fā)現(xiàn)芯片根本不能正常工作怎么解決?

    曾有工程師反映,之前用STM32F1系列芯片好好的,后來因?yàn)楫a(chǎn)品需要,改用STM32F2或STM32F4芯片后,發(fā)現(xiàn)芯片根本不能正常工作,即使最簡單的程序也跑不順暢。
    發(fā)表于 04-08 06:45

    stm32F4 64位變量操作異常怎么解決?

    stm32F4 64位變量使用報(bào)錯(cuò)解決
    發(fā)表于 04-02 07:16

    STM32F4內(nèi)部的DAC可以分時(shí)復(fù)用嗎?

    請問,STM32F4內(nèi)部的DAC可以分時(shí)復(fù)用嗎?
    發(fā)表于 03-28 08:38

    請問STM32F4的USB端口能讀寫512GB的UFS卡嗎?

    STM32F4的USB端口能讀寫512GB的UFS卡嗎?
    發(fā)表于 03-28 06:42

    請問引腳數(shù)相同的STM32F2的程序可以直接運(yùn)行在STM32F4的上嗎?

    引腳數(shù)相同的STM32F2的程序可以直接運(yùn)行在STM32F4的芯片上嗎?手冊上說F4全兼容F2的軟件
    發(fā)表于 03-27 07:43