STM32使用printf函数给串口打印信息的执行步骤为:
1.重定向printf函数
//重定向c库函数printf到USART1
int fputc(int ch, FILE *f)
{
/* 发送一个字节数据到USART1 */
USART_SendData(USART1, (uint8_t) ch);
/* 等待发送完毕 */
while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
return (ch);
}
2.增加头文件stdio
#include
3.勾选Use MircoLIB
如果只做了前两步,而没有勾选Use MicorLIB,编译器虽然不会报错,但是串口不会输出数据。很多人做了重定向函数以后,输出一串字符的第一个字符会丢失,根本原因是因为SR寄存器中的TC标志默认是置1的。
解决办法:
方法一:既然TC位初始为1导致的问题,那么我们在使用printf函数前把TC置0也可以解决问题,
写多一句USART1->SR&=~(1<<6);
方法二:直接修改while的等待条件,while(USART_GetFlagStatus(USART1, USART_FLAG_TXE)==RESET);把TC改为TXE,因为TXE只能硬件清零,在数据写进DR时就置0,数据移出时置1,可以保证数据不会在DR被覆盖;
方法三:清除SR寄存器的TC标志也能解决问题。(推荐使用)
/* 清SR寄存器中的TC标志 */
USART_ClearFlag(USART1,USART_FLAG_TC);
【注】USART_IT 值的含义
USART_IT_TXE 发送中断
USART_IT_TC 传输完成中断
STM32使用printf函数给串口打印信息的执行步骤为:
1.重定向printf函数
//重定向c库函数printf到USART1
int fputc(int ch, FILE *f)
{
/* 发送一个字节数据到USART1 */
USART_SendData(USART1, (uint8_t) ch);
/* 等待发送完毕 */
while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
return (ch);
}
2.增加头文件stdio
#include
3.勾选Use MircoLIB
如果只做了前两步,而没有勾选Use MicorLIB,编译器虽然不会报错,但是串口不会输出数据。很多人做了重定向函数以后,输出一串字符的第一个字符会丢失,根本原因是因为SR寄存器中的TC标志默认是置1的。
解决办法:
方法一:既然TC位初始为1导致的问题,那么我们在使用printf函数前把TC置0也可以解决问题,
写多一句USART1->SR&=~(1<<6);
方法二:直接修改while的等待条件,while(USART_GetFlagStatus(USART1, USART_FLAG_TXE)==RESET);把TC改为TXE,因为TXE只能硬件清零,在数据写进DR时就置0,数据移出时置1,可以保证数据不会在DR被覆盖;
方法三:清除SR寄存器的TC标志也能解决问题。(推荐使用)
/* 清SR寄存器中的TC标志 */
USART_ClearFlag(USART1,USART_FLAG_TC);
【注】USART_IT 值的含义
USART_IT_TXE 发送中断
USART_IT_TC 传输完成中断
举报