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

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

3天内不再提示

实战经验 | TrustZone 架构下 LPBAM 使用导致的 HardFault

STM32单片机 来源:未知 2023-10-20 15:05 次阅读
wKgaomUyJ8mAUJSZAAHUHXdxAL4994.gif

关键词:TrustZone,HardFault

目录预览

1、简介

2、问题分析

3、总结

01

简介


客户使用 STM32U5 进行开发,并使能了 TrustZone 架构,程序需要从 bootloader 跳转到app。在之前版本都是正常跳转的,某一天 IAR 从 9.20 升级到 9.30 后,程序跳转失败,并且会导致 hardfault,想知道为什么会失败。

wKgaomUyJ8qAXhuzAAWv_yD84y0479.png

图1.IAR9.20 和 IAR9.30 生成的汇编代码对比

02

问题分析


通过断点和单步调试,我们发现出现问题的指令如下所示:

wKgaomUyJ8qAQSBjAAVSMORkRzs862.png

图2.程序下一步将 Hardfault

而没有发生 hardfault 的版本汇编代码,如下图:

wKgaomUyJ8qAIr2yAAlBO4Ea5y0597.png

图3.程序不会发生 Hardfault

通过单步调试,我们知道了 VLSTM SP 这条指令导致了 hardfault。接着我们再确认下 SP 指针,错误版本的 SP 的内容为:0x300020b4,正确版本的 SP 内容为:0x30000258。首先,我们对比了生成的 map 文件中 stack 的地址信息,发现其中 Stack 的地址和这里 SP 指令是相符的。

然后继续查找了 VLSTM 这条指令相关的描述,关于 VLSTM 在 PM0264 中有以下描述:

wKgaomUyJ8qAJ8EWAAIos6_SmHs908.png

图4.关于 VLSTM 指令

从上图可以看到,VLSTM SP 这条指令会把安全的浮点运算寄存器的值保存到 SP 地址中,并清除安全浮点寄存器的内容,如果 CPU 的状态是非安全的,那么这条指令相当于空指令,也不会导致 hard fault,所有从这里也还是分析不出为什么会导致 hard fault。

重新回到这条指令,现在问题可能比较大的就是 SP 的地址了。有问题的版本的 SP 内容为:0x300020b4,会不会是对齐导致的呢?

基于这个猜测,我们直接在 IAR 界面强制修改了 SP 的地址为 0x300020b8,并继续单步执行,然后程序可以正常执行了。所以目前所知的结论就是 VLSTM SP 这条指令,要求 SP 必须 8 字节对齐,可能 IAR 在编译的时候并没有注意到这一点。

然后,把这些信息反馈到 IAR 以后,IAR 的工程师回复如下:

根据目前的信息,问题应该是在 VLSTM 要求 8 字节对齐上。在 9.30.1 中,由于 PUSH.W {R4, R5, R7-R11}指令执行后,相当于占用了 28 个字节的栈空间,导致了 SP 和 9.20.1 相比,不是 8 字节对齐。

03

总结

在调试 TrustZone 工程的时候,由于使用了新的架构及新的汇编指令,需要对这些指令有一定基本的了解。在调查问题的时候,可以进行单步调试来定位发生问题的指令,然后再继续深入了解下为什么会导致 hardfault。

wKgaomUyJ8qAFOqEAAHiBpzEGaQ933.png

完整内容请点击“阅读原文”下载原文档。


原文标题:实战经验 | TrustZone 架构下 LPBAM 使用导致的 HardFault

文章出处:【微信公众号:STM32单片机】欢迎添加关注!文章转载请注明出处。

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

    关注

    6035

    文章

    44554

    浏览量

    634697
  • STM32
    +关注

    关注

    2270

    文章

    10896

    浏览量

    355757

原文标题:实战经验 | TrustZone 架构下 LPBAM 使用导致的 HardFault

文章出处:【微信号:STM32_STM8_MCU,微信公众号:STM32单片机】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    珠海航展无人机搭载相机选择的深度解析

    轩展科技,作为无人机视频产品解决方案提供商,具有15年的一体化摄像机模组二次开发实战经验,能为无人机通过各种分辨率、不同输出接口及性能的一站式视频产品解决方案,满足各种应用场景的需求。
    的头像 发表于 11-16 10:26 232次阅读

    【全新课程资料】正点原子《基于GD32 ARM32单片机项目实战入门》培训课程资料上线!

    ,提高编程能力和实战经验 四、适合人群 (1)单片机编程初学者 (2)电子工程师 (3)对ARM32单片机有兴趣的技术爱好者 五、课程详细介绍 1、培训课程包含: (1)全套培训课程视频(已全部录制
    发表于 09-24 18:06

    遇见一个编译优化导致的bug

    最近在调试 can 通信,因为 c8t6 flash 很小,而鱼鹰培训工程完成的驱动越来越多,导致 flash 不足,因此把 bsp 的优化级别设置成 -O2,谁知道在串口输入数据时直接 hardfault 了。
    的头像 发表于 08-12 17:26 319次阅读
    遇见一个编译优化<b class='flag-5'>导致</b>的bug

    STM32H5和STM32U5在trustzone上有哪些不同?

    我要做空调的空中升级FOTA的方案,需要加密,对于trustzone功能,采用那款芯片比较合适?STM32H5和STM32U5在trustzone上有哪些不同?
    发表于 07-05 07:03

    请问STM32L5和STM32H5对trustzone有哪些不同?

    STM32L5和STM32H5对trustzone有哪些不同?
    发表于 07-04 08:08

    运行ble_hello_sensor时出现了HardFault_Handler,为什么?

    当我运行 ble_hello_sensor 时,出现了 HardFault_Handler。 我认为 cy_rtos_create_thread(cybt_platform_task.c) 用于
    发表于 05-21 07:35

    STM32H7在设置MPU时为什么会进入hardfault

    MPU配置截图 这样配置会进入hardfault,这么配置的原因是这段里某些地址我用做了ETH和LWIP的缓存 标识符啥的 不知道这么配置为什么就会进入Hardfault,但是如果我把MPU Cacheable Permission打开后,就是正常的 不知道各位大佬有没
    发表于 05-17 15:02

    STM32程序运行时会莫名的进入HardFault硬件中断中,为什么?

    中断,串口中断,在进入HardFault后这些中断还在正常运行,可以排除是这些中断导致进入HardFault; 一周尝试下来,确定的现象就是将代码改动一问题就会消失或者重新出现,但是
    发表于 04-10 06:29

    STM32H5 DA证书链实战经验

    之前我们已经讲过了如何通过 DA 认证来回退芯片产品状态,或者重新打开调试口,这样开发人员在芯片为 Closed 状态时仍可以调试芯片。
    的头像 发表于 03-12 14:08 1074次阅读
    STM32H5 DA证书链<b class='flag-5'>实战经验</b>

    STM32H5 DA 之初体验(带 TrustZone)

    电子发烧友网站提供《STM32H5 DA 之初体验(带 TrustZone).pdf》资料免费下载
    发表于 02-19 14:19 0次下载
    STM32H5 DA 之初体验(带 <b class='flag-5'>TrustZone</b>)

    网络攻防模拟与城市安全演练 | 数字孪生

    在数字化浪潮的推动,网络攻防模拟和城市安全演练成为维护社会稳定的不可或缺的环节。基于数字孪生技术我们能够在虚拟环境中进行高度真实的网络攻防模拟,为安全专业人员提供实战经验,从而提升应对网络威胁的能力。同时,在城市安全演练中通过精准模拟各类紧急情况,帮助城市管理者制定更有
    的头像 发表于 02-04 10:48 663次阅读
    网络攻防模拟与城市安全演练 | 数字孪生

    安路科技完成新一届董事会、监事会换届,文华武任总经理,陈利光担任监事

    据了解,文华武在安路科技核心部门已有十余年丰富履历,长时间致力于市场需求响应和产品研发推进,具备相当的项目经验和对FPGA行业深邃理解。在把此类具有丰富实战经验且实力不俗的人才纳入到上市企业管理系统后,有利于更高效地构建公司组织架构
    的头像 发表于 01-23 13:56 1179次阅读

    圣晖集成手单余额13.19亿,稳步攀升

    作为洁净室项目相关赛道的先驱,圣晖集成深入电子企业,熟知业界实用技艺如净化工程、气候调节、微振控制及环境破坏风险防范等,且经过实践验证积累了丰富的实战经验
    的头像 发表于 01-16 11:30 567次阅读

    BlueNRG系列协处理器实战经验简介

    BlueNRG 系列芯片从最早的一代 BlueNRG-MS 开始就支持协处理器模式。
    的头像 发表于 01-05 18:16 1857次阅读
    BlueNRG系列协处理器<b class='flag-5'>实战经验</b>简介

    实战经验 | 如何在用户应用中开启 LoRa CAD

    关键词:LoRa, CAD, Channel Activity Detection 目录预览 1、LoRa CAD 应用场景举例 2、STM32WL LoRa CAD 原理和驱动 3、如何在示例工程 SubGHz_Phy_Per 中开启 CAD 4、小结 01 LoRa CAD 应用场景举例 在 STM32WL LoRa 某些应用中,尤其是电池供电的设备上,需要按需发送数据,如下发指令,让 STM32WL LoRa 发送数据,或做相应的操作。为了降低功耗,STM32WL不能一直处于接收状态,这样功耗会很高。我们可以开启 LoRa CAD(信道活动检测)功能,STM32WL 通过开启 CAD 功能,检测前导码的前 1/
    的头像 发表于 12-26 17:45 1533次阅读
    <b class='flag-5'>实战经验</b> | 如何在用户应用中开启 LoRa CAD