完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
如题,在fault report 里显示是usage fault->unaligned,通过异常时刻的上下文,定位到xPortPendSVHandler函数,在执行 /* Pop the core registers. */
ldmia r0!, {r4-r11, r14} /* Is the task using the FPU context? If so, pop the high vfp registers too. */ tst r14, #0x10 时出错。 之前我在回调函数_cbStatus中创建一个定时器,定时发送消息WM_NotifyParent(hIcon,WM_NOTIFICATION_RELEASED); 目的是切换界面,运行正常; 后来我把WM_NotifyParent(hIcon,WM_NOTIFICATION_RELEASED);放到按键任务里执行,就发生了上面的错误,请大神们帮忙分析一下是什么原因,谢谢!! |
|
相关推荐
1个回答
|
|
在STM32F429 + STM32CubeMX + CMSIS-OS环境中,出现HardFault异常的原因可能是Usage Fault -> Unaligned。根据您提供的信息,异常发生在xPortPendSVHandler函数中,特别是在执行以下代码时:
``` /* Pop the core registers. */ ldmia r0!, {r4-r11, r14} /* Is the task using the FPU context? If so, pop the high vfp registers too. */ ``` 这里的问题是,当尝试从R0寄存器地址加载一组寄存器时,地址可能没有正确对齐。在ARM架构中,加载和存储指令通常要求地址对齐。对于32位寄存器,地址应该是4的倍数。 要解决这个问题,您可以尝试以下方法: 1. 确保R0寄存器的值是4字节对齐的。您可以通过在R0的值上添加3并取反(即R0 = R0 + 3 ^ 3)来实现这一点。 2. 在xPortPendSVHandler函数中,使用单独的LDMIA指令来加载寄存器,而不是一次性加载所有寄存器。这样可以确保每个寄存器的地址都是对齐的。 3. 检查您的任务切换逻辑,确保在切换任务时,寄存器的值被正确地保存和恢复。 4. 如果您正在使用FPU,确保在加载和存储浮点寄存器时,地址也是对齐的。 5. 检查您的编译器设置,确保没有启用可能导致未对齐访问的优化选项。 6. 如果问题仍然存在,请尝试更新您的STM32CubeMX和CMSIS-OS库到最新版本,以确保您使用的是最新的修复和优化。 通过采取这些步骤,您应该能够解决Unaligned Usage Fault异常,并确保您的系统稳定运行。 |
|
|
|
只有小组成员才能发言,加入小组>>
调试STM32H750的FMC总线读写PSRAM遇到的问题求解?
1649 浏览 1 评论
X-NUCLEO-IHM08M1板文档中输出电流为15Arms,15Arms是怎么得出来的呢?
1566 浏览 1 评论
994 浏览 2 评论
STM32F030F4 HSI时钟温度测试过不去是怎么回事?
694 浏览 2 评论
ST25R3916能否对ISO15693的标签芯片进行分区域写密码?
1613 浏览 2 评论
1872浏览 9评论
STM32仿真器是选择ST-LINK还是选择J-LINK?各有什么优势啊?
657浏览 4评论
STM32F0_TIM2输出pwm2后OLED变暗或者系统重启是怎么回事?
527浏览 3评论
544浏览 3评论
stm32cubemx生成mdk-arm v4项目文件无法打开是什么原因导致的?
516浏览 3评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-28 02:59 , Processed in 0.852770 second(s), Total 80, Slave 63 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号