STM32串口调试之printf和重写函数fputc

您所在的位置:网站首页 stm32报错 STM32串口调试之printf和重写函数fputc

STM32串口调试之printf和重写函数fputc

2023-08-12 22:51| 来源: 网络整理| 查看: 265

今天改写正点原子STM32F103ZET6的串口实验程序 源程序使用串口1进行实验,修改为使用串口3进行实验 因为粗心,导致了奇怪的错误,在朋友的帮助下花了一个小时,才搞明白发生错误的原因。 (其实,早就知道重定义函数 fputc 中 USART1 改为 USART3就可以解决问题,但是还是一步步通过在主函数中打断点,找到了错误的原因。掌握了程序调试的基本方法。在此,感谢朋友!)

过程:

(1)将main.c、usart.h和usart.c中“USART1”替换为“USART3”; (2)将usart.c中的串口3的GPIOB和USART3使能。

问题:

在usart.c中的重定义函数中,USART1没有改:

//重定义fputc函数 int fputc(int ch, FILE *f) { while((USART1->SR&0X40)==0) ;//循环发送,直到发送完毕 USART1->DR = (u8) ch; return ch; }

导致程序:

else { times++; if(times%5000==0) { printf("\r\n串口实验\r\n"); printf("正点原子\r\n\r\n"); } if(times%200==0) { printf("请输入数据,以回车键结束\n"); } if(times%2==0)LED0=!LED0;// delay_ms(100); }

当 times == 200 时,执行 printf 语句,进入重定义函数 fputc,导致程序进入死循环。

解决:

当然就是把重定义函数 fputc 中的 USART1 改为 USART3。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3