[STM32F4] 使用 printf会触发 HardFault 异常

[复制链接]
543|10
 楼主| lvluoo 发表于 2025-5-26 23:00 | 显示全部楼层 |阅读模式
STM32F407VG,遇到了 STM32CubeMX IDE 的 ITMdataconsole 问题。如果我使用函数 printf,就会触发 HardFault 异常

HFSR 位也未设置为任何值
公羊子丹 发表于 2025-5-27 07:40 | 显示全部楼层
我之前遇到类似情况,最后发现是 _write() 没正确重定向,printf 默认找不到输出通道就挂了。
周半梅 发表于 2025-5-27 07:41 | 显示全部楼层
你有没有打开 ITM 和 SWO 输出?如果 printf 输出不到地方,很容易触发 HardFault。
帛灿灿 发表于 2025-5-27 07:42 | 显示全部楼层
建议先用 ITM_SendChar 单字节测试下,看 SWV Console 能不能正常显示。
童雨竹 发表于 2025-5-27 07:42 | 显示全部楼层
检查一下是否开启了 Trace 端口,有时候 ITM 通道没打开也会触发异常。
万图 发表于 2025-5-27 07:43 | 显示全部楼层
如果是 newlib-nano 的 libc,printf 会依赖 _write(),你实现这个函数了吗?
Wordsworth 发表于 2025-5-27 07:44 | 显示全部楼层
printf 里有 float 吗?float 支持没开也有可能导致 printf 崩溃。
Bblythe 发表于 2025-5-27 07:45 | 显示全部楼层
printf 的堆栈消耗比较大,尝试调大一下栈的大小看看问题是否改善。
Pulitzer 发表于 2025-5-27 07:45 | 显示全部楼层
试下用 sprintf 到缓存区,看看是不是 ITM 输出部分出的问题。
Uriah 发表于 2025-5-27 07:46 | 显示全部楼层
你的 IDE 配置里 Debug 模式下 SWO 设置对了吗?默认可能没启用 trace。
Clyde011 发表于 2025-5-27 07:47 | 显示全部楼层
实在不行就先用简单的 USART 打印调试,printf + ITM 有时候踩坑太多。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

60

主题

86

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部