首先用 NUCLEO-F411RE 开发板建立一个工程。 需要注意 STM32F0 系列不支持SWO。
默认 SWO 功能没有打开,需要在 System Core > SYS > Debug 下,选择 Trace Asynchronous Sw,然后就可以直接生成工程了。
然后修改 main.c,在文件头包含 stdio.h,才能调用 printf
#include <stdio.h>
接下来添加函数
int __io_putchar(int ch) {
ITM_SendChar(ch);
return ch;
}
在 main() 中调用 printf,注意末尾需要 \n,具体原因请参考前一篇:STM32 Cube IDE 下实现串口 printf。
printf("abc\n");
最后还需要设置使能 SWO 输出。点击 调试,弹出的窗口中,需要点击 调试器 页,SWV 使能,下面的 STM32 运行的时钟频率根据实际情况填写。点击 OK,等待下载完成。
然后需要打开 SWO 输出窗口,并设置输出通道。点击 window > Show View > SWV > SWV ITM Data Console
在出现的 SWV ITM Data Console 窗口中,点击右下角的设置按钮,使能 port 0
最后点击红色的 Start Trace,点击 Resume (F8) 运行程序,LOG 就从刚才的 SWV ITM Data Console 窗口中打印出来了。
最后的效果如图,如果要打印浮点数,也请参考前一篇: STM32 Cube IDE 下实现串口 printf。