lvluoo 发表于 2025-5-26 23:00

使用 printf会触发 HardFault 异常

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 有时候踩坑太多。
页: [1]
查看完整版本: 使用 printf会触发 HardFault 异常