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

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

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

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

探究STM32H7芯片IAP跳轉(zhuǎn)失敗案例

茶話MCU ? 來源:cc ? 2019-02-26 15:32 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

STM32用戶反饋,他在使用STM32H750VB編寫用戶引導(dǎo)程序【BOOT CODE】和應(yīng)用程序【APP CODE】。根據(jù)數(shù)據(jù)手冊描述,STM32H750有128K Bytes的片內(nèi)flash,地址是從0x0800 0000~~0x0801 FFFF。他將用戶bootloader放在0x0800 0000~0x0800 2FFF,應(yīng)用程序放在0x08003000~0x0801 FFFF。但當(dāng)他按照這樣的存儲分配設(shè)計時,發(fā)現(xiàn)總是沒法實(shí)現(xiàn)從BOOT區(qū)到APP區(qū)的跳轉(zhuǎn)。

基于該用戶的反饋信息,給他做了些提醒,比如中斷矢量表定位問題,客戶都說已經(jīng)注意到了,代碼應(yīng)該沒有問題。我這邊就客戶反饋的問題找了塊STM32H743的板做了驗(yàn)證測試。發(fā)現(xiàn)從BOOT區(qū)到APP區(qū)的跳轉(zhuǎn)并沒有異常,那么客戶怎么又有問題呢?

再次查看了客戶郵件的反饋信息。他用的默認(rèn)內(nèi)部SRAM區(qū)為AXI SRAM,地址區(qū)間在0x24000000 --0x2407FFFF,即下面表格中的A區(qū),而我使用的默認(rèn)內(nèi)部SRAM區(qū)是DTCM SRAM,地址區(qū)間在0x20000000 -0x2001FFFF,即下面表格中的B區(qū)。

難道是這個差別導(dǎo)致跳轉(zhuǎn)的不同結(jié)果?當(dāng)然,這兩個SRAM區(qū)在使用上還是有差異的。

我嘗試著將測試工程的默認(rèn)SRAM區(qū)從TCM RAM也改成AXI SRAM進(jìn)行測試。果真沒法實(shí)現(xiàn)從BOOT區(qū)到APP區(qū)的跳轉(zhuǎn)!看來跳轉(zhuǎn)失敗跟選擇這個默認(rèn)SRAM區(qū)有關(guān)系。也就是說當(dāng)我默認(rèn)使用DTCM RAM時跳轉(zhuǎn)正常,如果默認(rèn)使用AXI SRAM時會跳轉(zhuǎn)失敗。

我們知道,STM32H7系列芯片支持D-CACHE/I-CACHE。具體到這里,如果使用AXI SRAM往往會用到D-CACHE。我們的工程代碼里也的確開啟了D-CACHE,如果是因?yàn)檫@個原因,如果在做跳轉(zhuǎn)操作之前關(guān)閉D-CACHE應(yīng)該就能實(shí)現(xiàn)正常跳轉(zhuǎn)。 于是對代碼稍加調(diào)整,實(shí)際上也就是加了句關(guān)閉D-CACHE的代碼?!炯t色方框處】

再次進(jìn)行測試,此時即使使用AXI RAM做為默認(rèn)內(nèi)存空間,從用戶BOOT區(qū)也能可靠跳轉(zhuǎn)到APP區(qū),完美實(shí)現(xiàn)。

這里涉及到STM32H7系列芯片內(nèi)部不同存儲區(qū)的訪問特性和D-Cache相關(guān)知識,細(xì)節(jié)還是挺多的。有興趣的話,可以自行查看相關(guān)技術(shù)手冊做進(jìn)一步的了解和探究。有時間,后續(xù)將在這里做進(jìn)一步交流。此時分享該應(yīng)用案例,一做應(yīng)用提醒,二做拋磚引玉。

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

    關(guān)注

    463

    文章

    54004

    瀏覽量

    465803
  • STM32
    +關(guān)注

    關(guān)注

    2309

    文章

    11161

    瀏覽量

    373373

原文標(biāo)題:一個STM32H7芯片IAP跳轉(zhuǎn)失敗的案例

文章出處:【微信號:stmcu832,微信公眾號:茶話MCU】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

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

    CW32L083 IAP跳轉(zhuǎn)后中斷無響應(yīng)是什么原因?

    最近做一個項(xiàng)目,需要IAP。按照官方的教程一切順利,軟件APP跳轉(zhuǎn)一切正常,但是跳轉(zhuǎn)后中斷沒有響應(yīng)。搜索了一堆資料,APP在mian中找開了中斷,在不同地方設(shè)置VROT,都沒能解決,查了數(shù)據(jù)手冊,也
    發(fā)表于 12-09 07:19

    RTthread 4.1 stm32h7系列不支持pwm要怎么處理?

    找問題找了很久,搜到了一個4.0.2版本pwm 沒有支持STM32H7系列的帖子 現(xiàn)在是4.1 還是沒有,求助大佬幫改個代碼 報錯信息 驅(qū)動程序里沒有STM32H7的 static
    發(fā)表于 09-10 07:34

    從 rtthread studio 上拉下來的 stm32h7 FDACN 驅(qū)動調(diào)不通是哪里的問題?

    請問我從 rtthread studio 上拉下來的 stm32h7 FDACN 驅(qū)動調(diào)不通,是這個驅(qū)動有問題嗎
    發(fā)表于 09-10 06:03

    rt thread studio編寫STM32H7不能使用V2版串口驅(qū)動是怎么回事?

    使用rt thread studio編寫STM32H7程序,使用rt thread settings可視化工具配置:使用UART設(shè)備驅(qū)動程序,配置為RT_USING_SERIAL_V2,但是使用的還是drv_usart.c,沒有drv_usart_v2.c。這是真么回事
    發(fā)表于 08-29 07:56

    STM32H7使用HAL庫如何控制外置USB HS PHY進(jìn)入低功耗?

    項(xiàng)目使用STM32H7的HAL庫控制外置USB HS PHY(如USB3300或CH132)的。不知如何讓MCU通過ULPI接口寫寄存器讓USB HS PHY進(jìn)入低功耗,且USB保持鏈接狀態(tài)讓PC可以重新喚醒。
    發(fā)表于 08-14 07:21

    求助,關(guān)于stm32H7多DMA數(shù)據(jù)流問題求解

    情況如下:stm32H7配置了一個adc進(jìn)行采樣,通過dma進(jìn)行數(shù)據(jù)傳輸,串口接收和發(fā)送命令,用兩個dma數(shù)據(jù)流通道,采用的空閑中斷。 問題:adc一直在中斷中,調(diào)試未進(jìn)入串口中斷,關(guān)閉adc后串口
    發(fā)表于 07-29 15:02

    IAP升級跳轉(zhuǎn)APP跳轉(zhuǎn)Boot失敗了怎么解決?

    使用的MCU是STM32U535RC ,V6 編譯器 跳轉(zhuǎn)實(shí)現(xiàn)的功能如下 /** *@brief直接跳轉(zhuǎn)到 Boot 程序 */ void LibJumpToBoot(UINT32
    發(fā)表于 07-21 06:15

    有沒有哪位大神提供一個STM32H523或者STM32H563的串口升級的IAP程序?

    有沒有哪位大神提供一個STM32H523或者STM32H563的串口升級的IAP程序
    發(fā)表于 06-12 06:56

    STM32H7CubeMX配置硬件I2C,讀寫失敗是什么問題呀?

    STM32H7CubeMX配置硬件I2C,讀寫失敗什么問題呀,同樣的操作F4和F1都能正常使用,應(yīng)該不存在i2c地址錯誤,操作都是一樣的,但H7就是用不了。I2C_WaitOnFlagUntilTimeout返回HAL_ERRO
    發(fā)表于 06-12 06:21

    使用STM32H7的FDCAN通訊,為什么CAN1會收到CAN2的幀ID,CAN2也會收到CAN1的?

    使用STM32H7的FDCAN通訊,請問為什么CAN1會收到CAN2的幀ID,CAN2也會收到CAN1的?
    發(fā)表于 03-14 10:33

    當(dāng)內(nèi)存不夠時,stm32h7 ITCM可以當(dāng)普通ram用嗎?

    當(dāng)內(nèi)存不夠時,stm32h7 ITCM可以當(dāng)普通ram用嗎
    發(fā)表于 03-14 06:13

    求助,關(guān)于STM32H7系列芯片下的ECC功能的疑問求解

    我這里采用的是STM32H755的芯片,參考了文檔
    發(fā)表于 03-11 07:43

    STM32H7 ADC_IRQHandler和ADC3_IRQHandler這兩個中斷入口函數(shù)在使用上有什么區(qū)別?

    STM32H7,ADC_IRQHandler和ADC3_IRQHandler這兩個中斷入口函數(shù)在使用上有何區(qū)別?
    發(fā)表于 03-11 07:28

    請問STM32H5遞增HDPL后如何跳轉(zhuǎn)下一級程序?

    STM32H5的HDP保護(hù),比如某一級ROT提升HDP等級并跳轉(zhuǎn)下一級代碼運(yùn)行。那設(shè)置HDP等級提升后,立刻生效嗎?如果生效,芯片不能再執(zhí)行當(dāng)前ROT中的程序,接下來怎么跳轉(zhuǎn)到下一級程
    發(fā)表于 03-11 06:00

    STM32H7 0x00000000地址的內(nèi)容引發(fā)hardfault怎么解決?

    STM32H7,串口初始化時執(zhí)行HAL_UART_MspDeInit函數(shù),調(diào)用HAL_NVIC_DisableIRQ(huart->hdmarx-&gt
    發(fā)表于 03-07 08:15