一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

STM32F4的復(fù)位序列對比STM32F7的復(fù)位序列

MCU開發(fā)加油站 ? 來源:STM32單片機(jī) ? 作者:STM32單片機(jī) ? 2021-01-18 16:44 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前言

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

STM32F4的復(fù)位序列

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

63291ee8-445e-11eb-8b86-12bb97331649.png

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

6356b042-445e-11eb-8b86-12bb97331649.jpg

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

6397fe76-445e-11eb-8b86-12bb97331649.jpg

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

63c6e2d6-445e-11eb-8b86-12bb97331649.png

Boot 腳= 0時,由BOOT_ADD0 [15:0] 的值決定,ST默認(rèn)值為0x0020 0000。這是ITCM-FLASH的起始地址(通過ART加速器,訪問FLASH); Boot 腳= 1時,由BOOT_ADD1 [15:0] 的值決定,ST默認(rèn)值為0x0010 0000。這是system Bootloader的起始地址。 * 如果對BOOT_ADDx寫入的地址值超出了存儲器映射的范圍或者到了保留地址空間,系統(tǒng)將自動轉(zhuǎn)為下面的值: BOOT_ADD0 = 0x0020 0000; BOOT_ADD1 = 0x0000 0000(和出廠時ST默認(rèn)的值0x0010 0000不一樣) 也就是說,只要你配置好了boot address, stm32F7芯片的硬件會自動修改向量表的偏移地址寄存器VTOR,使之與boot address相匹配。不需要再通過軟件修改VTOR寄存器。

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

責(zé)任編輯:lq

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

    關(guān)注

    0

    文章

    179

    瀏覽量

    24673
  • STM32F4
    +關(guān)注

    關(guān)注

    3

    文章

    203

    瀏覽量

    29054
  • STM32F7
    +關(guān)注

    關(guān)注

    1

    文章

    48

    瀏覽量

    9504

原文標(biāo)題:STM32F7與STM32F4之復(fù)位序列比較

文章出處:【微信號:mcugeek,微信公眾號:MCU開發(fā)加油站】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    使用studio構(gòu)建STM32F4工程報錯的原因?

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

    STM32F4標(biāo)準(zhǔn)外設(shè)庫資料

    stm32f4xx.h,標(biāo)準(zhǔn)外設(shè)庫
    發(fā)表于 06-08 09:49 ?0次下載

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

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

    STM32F40xxx和STM32f41xx flash編程手冊

    PM0081_STM32F40xxx and STM32F41xxx單片機(jī)編程手冊
    發(fā)表于 06-06 17:02 ?3次下載

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

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

    STM32F103x8 STM32F103xB單片機(jī)數(shù)據(jù)手冊

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

    STM32F103×8/STM32F103×B MCU手冊

    本文提供了STM32F103x8和STM32F103xB中密度高性能系列微控制器的訂購信息和機(jī)械器件特性。有關(guān)整個STMicroelectronics STM32F103xx系列的更多信息,請
    發(fā)表于 03-18 16:37 ?0次下載

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

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

    STM32F7中FMC接多個通信外設(shè)是否可行?

    STM32F7中FMC接多個通信外設(shè)是否可行,需共用數(shù)據(jù)線,分時傳輸
    發(fā)表于 03-07 16:44

    stm32f4 sdio時鐘如何獲取通過什么函數(shù)?

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

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

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

    【GD32 MCU 移植教程】9、從 STM32F10x 系列移植到 GD32F30x 系列

    GD32F30x 系列 MCU 是基于 Arm? Cortex?-M4 處理器的 32 位通用微控制器,與 STM32F10x 系列 MCU 保持高度兼容。本文主要從以下三個方面進(jìn)行介紹:硬件資源
    的頭像 發(fā)表于 09-07 09:57 ?1976次閱讀
    【GD32 MCU 移植教程】9、從 <b class='flag-5'>STM32F</b>10x 系列移植到 GD32<b class='flag-5'>F</b>30x 系列

    【GD32 MCU 移植教程】8、從 STM32F4xx 系列移植到 GD32F4xx 系

    GD32F4xx 系列 MCU 是基于 Arm? Cortex?-M4 處理器的 32 位通用微控制器,與 STM32F4xx系列 MCU 保持高度兼容。本文主要從以下三個方面進(jìn)行介紹:硬件資源
    的頭像 發(fā)表于 09-06 09:40 ?2640次閱讀
    【GD32 MCU 移植教程】8、從 <b class='flag-5'>STM32F4</b>xx 系列移植到 GD32<b class='flag-5'>F4</b>xx 系

    STM32F40xxx、STM32F41xxx、STM32F42xxx、STM32F43xxx中文手冊

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

    STM32復(fù)位電路用復(fù)位芯片和阻容復(fù)位電路區(qū)別

    STM32是一款廣泛使用的微控制器,其復(fù)位電路設(shè)計對于系統(tǒng)的穩(wěn)定性和可靠性至關(guān)重要。本文將詳細(xì)介紹STM32復(fù)位電路中使用復(fù)位芯片和阻容
    的頭像 發(fā)表于 08-06 10:26 ?2949次閱讀