OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4608|回复: 1

STM32CubeIDE printf重定向问题

[复制链接]

1

主题

1

帖子

0

精华

新手上路

积分
22
金钱
22
注册时间
2019-6-10
在线时间
6 小时
发表于 2022-8-30 10:40:19 | 显示全部楼层 |阅读模式
1金钱
用CubeMX生成串口代码,直接调用 HAL_UART_Transmit 函数都能正常输出。重定向 printf,在 MDK 编译 printf 能正常输出,但在 CubeIDE 编译 printf 不输出,代码如下:在 main.c 中添加以下代码段

  1. <div>/* USER CODE BEGIN 0 */</div><div>#include "stdio.h"</div><div>#ifdef __GNUC__</div><div>#define PUTCHAR_PROTOTYPE int __io_putchar(int ch)   //STM32CubeIDE</div><div>#else</div><div>#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)  //Keil</div><div>#endif</div><div>PUTCHAR_PROTOTYPE</div><div>{</div><div><span style="white-space:pre">        </span>HAL_UART_Transmit(&huart1, (uint8_t*)&ch, 1, HAL_MAX_DELAY);</div><div><span style="white-space:pre">        </span>return ch;</div><div>}</div><div>
  2. </div><div>#ifdef __GNUC__</div><div>int _write(int file, char *ptr, int len)</div><div>{</div><div><span style="white-space:pre">        </span>int DataIdx;</div><div>
  3. </div><div><span style="white-space:pre">        </span>for(DataIdx=0; DataIdx<len; DataIdx++)</div><div><span style="white-space:pre">        </span>{</div><div><span style="white-space:pre">                </span>__io_putchar(*ptr++);</div><div><span style="white-space:pre">        </span>}</div><div>
  4. </div><div><span style="white-space:pre">        </span>return len;</div><div>}</div><div>#endif</div><div>/* USER CODE END 0 */</div>
复制代码
在 main 函数中调用输出:

  1. <div>int main(void)</div><div>{</div><div>    ...</div><div>   /* USER CODE BEGIN WHILE */</div><div>  while (1)</div><div>  {</div><div><span style="white-space:pre">        </span>  HAL_UART_Transmit(&huart1, "printf\n", 7, 1000);</div><div><span style="white-space:pre">        </span>  printf("---");</div><div><span style="white-space:pre">        </span>  HAL_Delay(500);</div><div>    /* USER CODE END WHILE */</div><div>  }</div><div>}</div>
复制代码
能够看到输出了 “printf” 字符串,但 “---” 只有在 keil 编译的固件会输出, CubeIDE 编译不输出,请各位大佬帮忙看看是什么原因?

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

0

主题

2

帖子

0

精华

新手入门

积分
3
金钱
3
注册时间
2022-9-1
在线时间
0 小时
发表于 2022-9-1 17:10:09 | 显示全部楼层
你的输出函数每个里面都加\n就可以了 ,就像这样printf("---\n");
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-5-8 18:32

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表