OpenEdv-开源电子网

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

printf输出不到串口调试助手

[复制链接]

48

主题

179

帖子

0

精华

初级会员

Rank: 2

积分
185
金钱
185
注册时间
2017-6-19
在线时间
90 小时
发表于 2020-8-20 16:06:36 | 显示全部楼层 |阅读模式
10金钱
如题,printf(……)和USART_SendData(……),可是我在实际操作过程中,发现printf在运行过一段时间之后,不能输出到串口调试助手上。USART_SendData(……)却可以,后来重新定义了fputc函数 ,问题解决了,原因不详,代码如下,求解~
  1. int main(void)
  2. {                       
  3.         delay_init();                     //延时函数初始化          
  4.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2); //设置NVIC中断分组2:2位抢占优先级,2位响应优先级
  5.         uart_init(115200);         //串口初始化为115200

  6.         while(1)
  7.         {
  8.                         printf("\r\n我是谁\r\n");  
  9.                         delay_ms(300);
  10.                                        
  11.                         USART_SendData(USART3, 0X12);
  12.                         while(USART_GetFlagStatus(USART3,USART_FLAG_TC)!=SET);
  13.                         delay_ms(3000);
  14.         }         
  15. }
复制代码
之前printf(……)运行一段时间,不能打印到串口调试助手的fputc函数
  1. //重定义fputc函数
  2. int fputc(int ch, FILE *f)
  3. {      
  4.         while((USART3->SR&0X40)==0)//循环发送,直到发送完毕   
  5.     USART3->DR = (u8) ch;      
  6.         return ch;
  7. }
复制代码
更改后的fputc函数
  1. int fputc(int ch, FILE *f)
  2. {      
  3.     while( !(USART3->SR & (1 << 7)) );
  4.     USART_SendData(USART3,(uint8_t)ch);
  5.     return ch;
  6. }
复制代码


PS:网上的其它重定义fputc函数 ,供自己学习(未验证)~
  1. //重映射fputc函数,此函数为多个输出函数的基础函数
  2. int fputc(int ch, FILE *f)
  3. {
  4.         while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  5.         USART_SendData(USART1, (uint8_t) ch);
  6.         return ch;
  7. }
复制代码
PPS:一般打印的话要注意Target->Code Generation,勾选Use MicroLIB

最佳答案

查看完整内容[请看2#楼]

这个是原子历程,应该不存在你说的没结合起来的情况,但在我实际应用的过程中发现,似乎不太稳定,原因还没找到
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

48

主题

179

帖子

0

精华

初级会员

Rank: 2

积分
185
金钱
185
注册时间
2017-6-19
在线时间
90 小时
 楼主| 发表于 2020-8-20 16:06:37 | 显示全部楼层
ownbest 发表于 2020-8-22 16:31
原fputc函数是没有和串口结合起来的,,通过重定义fputc函数,改变了printf的输出方式,因为printf函数内部 ...
  1. //重定义fputc函数
  2. int fputc(int ch, FILE *f)
  3. {      
  4.         while((USART3->SR&0X40)==0)//循环发送,直到发送完毕   
  5.     USART3->DR = (u8) ch;      
  6.         return ch;
  7. }
复制代码


这个是原子历程,应该不存在你说的没结合起来的情况,但在我实际应用的过程中发现,似乎不太稳定,原因还没找到
回复

使用道具 举报

48

主题

179

帖子

0

精华

初级会员

Rank: 2

积分
185
金钱
185
注册时间
2017-6-19
在线时间
90 小时
 楼主| 发表于 2020-8-21 09:01:17 | 显示全部楼层
自己帮顶~
回复

使用道具 举报

48

主题

179

帖子

0

精华

初级会员

Rank: 2

积分
185
金钱
185
注册时间
2017-6-19
在线时间
90 小时
 楼主| 发表于 2020-8-22 10:27:14 | 显示全部楼层
求解求解~
回复

使用道具 举报

7

主题

47

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1961
金钱
1961
注册时间
2013-3-27
在线时间
198 小时
发表于 2020-8-22 16:31:11 | 显示全部楼层
原fputc函数是没有和串口结合起来的,,通过重定义fputc函数,改变了printf的输出方式,因为printf函数内部调用fputc函数
回复

使用道具 举报

1

主题

7

帖子

0

精华

新手入门

积分
17
金钱
17
注册时间
2020-5-24
在线时间
3 小时
发表于 2020-8-22 17:16:52 | 显示全部楼层
优秀谢谢分享
回复

使用道具 举报

84

主题

766

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2775
金钱
2775
注册时间
2015-6-1
在线时间
394 小时
发表于 2020-8-26 10:15:25 | 显示全部楼层
你是说,它可以运行一断时间,然后才无法打印的?这样的话与这个函数无关吧。我觉得还是串口引脚定义、波特率定义这块的问题,你改改试试?
另外打印的时候如果不用printf,而是自己直接写一个函数去用,是什么效果的?下面这个是L4的板子,你如果按F1的改一下,看看是啥效果呗
void UARTx_Write(USART_TypeDef* UARTx,uint8 *send_buf,uint16 len)
{
        uint16 t;
        for(t=0;t<len;t++)     //循环发送直到发送完毕
        {               
                while((UARTx->ISR & 0X40) == 0);
                UARTx->TDR = (uint8) send_buf[t];
        }
        while((UARTx->ISR & 0X40) == 0);
}
自在随心
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-9 15:01

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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