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

今天改写正点原子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。

猜你喜欢

转载自blog.csdn.net/Chauncyxu/article/details/110406387