chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

3天內不再提示

STM32F4的復位序列

電子設計 ? 來源:電子設計 ? 作者:電子設計 ? 2022-02-21 10:02 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

STM32F4的復位序列

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

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

pIYBAGAH2LCAYR5WAABpzKZc-Ho113.jpg

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

pIYBAGAH2PCABgecAABk3DwP3-E369.jpg

上電復位,先執(zhí)行IAP程序。此時用到的是位于0地址處的IAP程序的向量表(雖然圖中說此時VTOR的值等于0x08000000,實際上,因為ST提供了存儲器地址重映射的功能,通過boot引腳的配置,已經將0x08000000處的存儲空間重映射到了地址0處,所以0x08000000和地址0x00000000處開始的存儲空間是同一塊物理空間,其內容當然也是一樣的。所以不用修改VTOR的值,VTOR=0也是一樣的)。言歸正傳,上電后,先從IAP復位中斷程序開始執(zhí)行IAP程序,執(zhí)行完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決定的。

pIYBAGAH2TGAFEk4AACKN2KofZk918.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寫入的地址值超出了存儲器映射的范圍或者到了保留地址空間,系統(tǒng)將自動轉為下面的值:

BOOT_ADD0 = 0x0020 0000;

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

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

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

來源: STM32單片機
審核編輯:何安

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

    關注

    3

    文章

    204

    瀏覽量

    29841
  • STM32F7
    +關注

    關注

    1

    文章

    48

    瀏覽量

    9886
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    【教程】使用STM32F4進行E22-400T22S編程通信教程

    通過本文帶大家零基礎使用STM32F407VET6單片機進行E22-400T22S模塊編程并進行簡單的通信,當然如果學會了,也可以舉一反三應用于E22、E220、E32所有模塊上。一、STM32環(huán)境
    的頭像 發(fā)表于 08-28 19:32 ?1549次閱讀
    【教程】使用<b class='flag-5'>STM32F4</b>進行E22-400T22S編程通信教程

    stm32f4新手求教

    芯片包stm32f4xx_DFP3.0.0只有1.98m大小,芯片包stm32f4xx_DFP2.16.0卻有152m大小,為何差距這么大,我該裝哪個芯片包?
    發(fā)表于 07-09 12:04

    【教程】零基礎!手把手教你使用STM32F4進行E22-400T22S編程通信

    通過本文帶大家零基礎使用STM32F407VET6單片機進行E22-400T22S模塊編程并進行簡單的通信,當然如果學會了,也可以舉一反三應用于E22、E220、E32所有模塊上。一STM32環(huán)境
    的頭像 發(fā)表于 07-03 19:32 ?1100次閱讀
    【教程】零基礎!手把手教你使用<b class='flag-5'>STM32F4</b>進行E22-400T22S編程通信

    使用studio構建STM32F4工程報錯的原因?

    使用studio 構建STM32F4 工程,什么都沒有動報了以上錯誤.這是為什么 ?
    發(fā)表于 06-26 07:26

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

    本教程詳細介紹了基于STM32F4和ILI9486觸摸屏的日歷應用開發(fā),涵蓋硬件連接、軟件實現(xiàn)與零知IDE配置。核心功能包括月份視圖展示、滑動切換和日期標記,通過LVGL庫實現(xiàn)UI組件及觸摸事件處理
    的頭像 發(fā)表于 06-25 17:34 ?590次閱讀
    零知開源——<b class='flag-5'>STM32F4</b>實現(xiàn)ILI9486顯示屏UI界面系列教程(二):日歷功能實現(xiàn)

    STM32F4標準外設庫資料

    stm32f4xx.h,標準外設庫
    發(fā)表于 06-08 09:49 ?5次下載

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

    電子發(fā)燒友網站提供《STM32F3系列、STM32F4系列、STM32L4系列和STM32L4+系列Cortex-M4編程手冊.pdf》資料
    發(fā)表于 06-06 17:06 ?9次下載

    零知開源——STM32F4驅動MAX31865實現(xiàn)PT100高精度測溫

    STM32F
    PCB56242069
    發(fā)布于 :2025年05月26日 18:25:17

    STM32F103x8 STM32F103xB單片機數據手冊

    STM32F103x8STM32F103xB單片機數據手冊
    發(fā)表于 04-14 14:55 ?6次下載

    使用SPI進行通信,STM32F4做從機,通信時數據異常怎么解決?

    使用SPI進行通信,STM32F4做從機,通信時數據異常,SPI2中SR寄存器會出現(xiàn)0xc0,0xc1,0x80的異常狀態(tài)值,大概就是BYS位,OVR位,RXEN位
    發(fā)表于 03-14 12:14

    Arduino中可以使用STM32F1或者STM32F4系列芯片的內置看門狗嗎?

    Arduino中可以使用STM32F1或者STM32F4系列芯片的內置看門狗嗎
    發(fā)表于 03-13 07:32

    使用STM32F4的ADC的時候,發(fā)現(xiàn)測量結果不準確,是什么原因導致的?

    請教各位大佬一個問題,我在使用STM32F4的ADC的時候,發(fā)現(xiàn)測量結果不準確。上網查看教程,發(fā)現(xiàn)F1系列有自動校準的函數,但是F4沒有校準相關的設置,想請教一下是F4的HAL庫把校準
    發(fā)表于 03-11 06:29

    stm32f4 sdio時鐘如何獲取通過什么函數?

    stm32f4系列sdio 時鐘如何獲取,stm32h7可以通過sdmmc_clk=HAL_RCCEx_GetPeriphCLKFreq(STM32_RCC_PERIPHCLK_SDMMC);這個函數獲取
    發(fā)表于 03-07 08:26

    STM32F4xx中文參考手冊--ST意法半導體

    STM32F4xx中文參考手冊--全中文主營ST意法芯片,需要可提供樣品測試,數據手冊,歡迎聯(lián)系.
    發(fā)表于 02-11 16:39 ?7次下載

    ADS1115和STM32F4通訊,輸出的數一直都是不變的,為什么?

    實際連接時,ALERT是懸空的,上拉電阻是10K,我用的是差分輸入,AIN0接地,AIN1接3.3v,AIN2和AIN3都是懸空的,VDD也是3.3V供電。SCL和SDA分別和STM32F4板子
    發(fā)表于 01-09 06:24