0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

探究STM32H7芯片IAP跳转失败案例

茶话MCU 来源:cc 2019-02-26 15:32 次阅读

STM32用户反馈,他在使用STM32H750VB编写用户引导程序【BOOT CODE】和应用程序【APP CODE】。根据数据手册描述,STM32H750有128K Bytes的片内flash,地址是从0x0800 0000~~0x0801 FFFF。他将用户bootloader放在0x0800 0000~0x0800 2FFF,应用程序放在0x08003000~0x0801 FFFF。但当他按照这样的存储分配设计时,发现总是没法实现从BOOT区到APP区的跳转。

基于该用户的反馈信息,给他做了些提醒,比如中断矢量表定位问题,客户都说已经注意到了,代码应该没有问题。我这边就客户反馈的问题找了块STM32H743的板做了验证测试。发现从BOOT区到APP区的跳转并没有异常,那么客户怎么又有问题呢?

再次查看了客户邮件的反馈信息。他用的默认内部SRAM区为AXI SRAM,地址区间在0x24000000 --0x2407FFFF,即下面表格中的A区,而我使用的默认内部SRAM区是DTCM SRAM,地址区间在0x20000000 -0x2001FFFF,即下面表格中的B区。

难道是这个差别导致跳转的不同结果?当然,这两个SRAM区在使用上还是有差异的。

我尝试着将测试工程的默认SRAM区从TCM RAM也改成AXI SRAM进行测试。果真没法实现从BOOT区到APP区的跳转!看来跳转失败跟选择这个默认SRAM区有关系。也就是说当我默认使用DTCM RAM时跳转正常,如果默认使用AXI SRAM时会跳转失败。

我们知道,STM32H7系列芯片支持D-CACHE/I-CACHE。具体到这里,如果使用AXI SRAM往往会用到D-CACHE。我们的工程代码里也的确开启了D-CACHE,如果是因为这个原因,如果在做跳转操作之前关闭D-CACHE应该就能实现正常跳转。 于是对代码稍加调整,实际上也就是加了句关闭D-CACHE的代码。【红色方框处】

再次进行测试,此时即使使用AXI RAM做为默认内存空间,从用户BOOT区也能可靠跳转到APP区,完美实现。

这里涉及到STM32H7系列芯片内部不同存储区的访问特性和D-Cache相关知识,细节还是挺多的。有兴趣的话,可以自行查看相关技术手册做进一步的了解和探究。有时间,后续将在这里做进一步交流。此时分享该应用案例,一做应用提醒,二做抛砖引玉。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 芯片
    +关注

    关注

    455

    文章

    50812

    浏览量

    423533
  • STM32
    +关注

    关注

    2270

    文章

    10900

    浏览量

    355957

原文标题:一个STM32H7芯片IAP跳转失败的案例

文章出处:【微信号:stmcu832,微信公众号:茶话MCU】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    stm32H7 HAL库中存在的bug

    stm32H7 hal 库里面的以太网代码,坑了鱼鹰很多次(不知道最新版是否已经修复了这些bug),这里分享一篇网上的文章,因为鱼鹰也遇到过,靠它解决了其中一个编译优化问题,在此感谢作者。不过hal
    的头像 发表于 08-12 17:37 1171次阅读

    请问stm32h7系列怎么跑linux呢?

    stm32h7系列怎么跑linux?
    发表于 07-03 08:04

    STM32H7系列芯片发不出去的hello问题

    有人使用STM32H7系列芯片,用到UART做字符串输出时遇到点小问题。这里一起聊聊该问题,并分析问题原因。
    的头像 发表于 07-01 09:56 1452次阅读
    <b class='flag-5'>STM32H7</b>系列<b class='flag-5'>芯片</b>发不出去的hello问题

    如何用STM32H7 SPI驱动DAC芯片(非板上内置DAC)生成正弦波?

    我想用STM32H7用SPI 驱动DAC 芯片(非板上内置DAC)生成正弦波,有合适的例程或者思路给我借鉴吗
    发表于 05-31 06:35

    STM32H7的HRTIM可以生成12路的PWM吗?

    STM32H7的HRTIM可以生成12路的PWM吗,想做数字电源,控制三相NPC逆变器
    发表于 05-23 07:19

    STM32F1 IAP操作读保护选项字节设置,APP使用系统复位跳转后无法运行IAP的原因?

    最近调试一个程序,是基于STM32F1做的IAP,升级前后需要修改选项字节,FLASH_EraseOptionBytes函数内OB->RDP=RDP_Key语句实现读保护的解除,如果我
    发表于 05-13 08:09

    请问STM32H7是否支持Trace功能?

    报 “Trace HW not present”这个错误。stm32H7的dataSheet是明确表示该内核是有Trace功能的,是不是哪里设置有问题?
    发表于 04-25 07:38

    IAP跳转APP开始可以,如果从APP跳回IAP后再跳到APP失败的原因?

    IAP 跳转APP 开始可以,但如果从APP跳回IAP后,再跳到APP失败。 我是按照 下面ST官方文档来的: AN4657 Application note
    发表于 04-23 07:24

    STM32H7系列目前有没有支持h264编解码?fps大概为多少?

    STM32H7系列目前有没有支持h264编解码,fps大概为多少?
    发表于 04-07 06:06

    使用LL库生成STM32H7代码时存在报错是什么原因导致的?

    使用LL库生成STM32H7代码时存在的BUG
    发表于 04-03 07:33

    STM32H7读外部SRAM首次成功,之后保持不变是为什么?

    STM32H743读外部SRAM 芯片,首次读成功后,无法再次读取新的数据,使用示波器对STM32H7引脚进行测量,发现无波形输出。调试过程中,在程序中打个断点,就每次可以正常读取。
    发表于 03-27 06:13

    Stm32H7 spi会带来更大的adc噪声,导致小信号异常值的原因?

    [Stm32H7]spi会带来更大的adc噪声,导致小信号异常值
    发表于 03-25 06:10

    如何用STM32H7的EXTI0同步触发SPI DMA双缓冲?

    请教:有没有朋友用STM32H7 的EXTI0同步触发SPI DMA双缓冲的,指教一下
    发表于 03-14 08:22

    STM32H7 MCO可以设置输出频率为4.096Mhz的时钟吗?

    想有STM32H7 MCO 可以设置输出频率为4.096Mhz给外部ADC提供时钟,请问下MCO 可以设置输出为4.096Mhz?如何配置?
    发表于 03-14 06:19

    STM32H7的工程出现找不到rtconfig.h的错误如何解决?

    旧工程是能正常编译和运行的。在拉取最新代码后,编译出错,提示有些宏定义缺失。进入menuconfig配置后,AT32的工程是能正常编译的,STM32H7的工程出现找不到rtconfig.h的错误
    发表于 03-05 07:12