在进行STM32开发时,需要将日志打印出来,直接使用C语言的库函数printf是不起作用的,此时就需要我们将串口重定向printf函数。首先我们需要在keil集成开发环境中勾选STM32官方的微库,如下图所示:
然后就是重写fputc函数,使之定向到指定的串口中去。
在进行STM32开发时,需要将日志打印出来,直接使用C语言的库函数printf是不起作用的,此时就需要我们将串口重定向printf函数。首先我们需要在keil集成开发环境中勾选STM32官方的微库,如下图所示:
然后就是重写fputc函数,使之定向到指定的串口中去。代码如下:
/*
** Rewrite fputc function and make printf function work
**/
int fputc(int ch, FILE* file)
{
USART1->TDR = ch & 0xFF;
while((USART1->ISR & UART_FLAG_TC) == RESET);
return ch;
}
在该例中使用的USART1,这个看自己的实际需要改动。
做完这些,就可以直接使用printf函数了,不过个人建议最好重写printf函数,我的重写如下:
#include
#include
/* Log enable/disable switch */
#define ENABLE_LOG 1
#if ENABLE_LOG
#define Log(format, ...) printf(format, ##__VA_ARGS__)
#else
#define Log(format, ...)
#endif
同理可以重写fgetc函数,使scanf函数起作用,代码如下:
/*
** Rewrite fgetc function and make scanf function work
**/
int fgetc(FILE* file)
{
while((USART1->ISR & UART_IT_RXNE) == RESET);
return USART1->RDR;
}
在进行STM32开发时,需要将日志打印出来,直接使用C语言的库函数printf是不起作用的,此时就需要我们将串口重定向printf函数。首先我们需要在keil集成开发环境中勾选STM32官方的微库,如下图所示:
然后就是重写fputc函数,使之定向到指定的串口中去。
在进行STM32开发时,需要将日志打印出来,直接使用C语言的库函数printf是不起作用的,此时就需要我们将串口重定向printf函数。首先我们需要在keil集成开发环境中勾选STM32官方的微库,如下图所示:
然后就是重写fputc函数,使之定向到指定的串口中去。代码如下:
/*
** Rewrite fputc function and make printf function work
**/
int fputc(int ch, FILE* file)
{
USART1->TDR = ch & 0xFF;
while((USART1->ISR & UART_FLAG_TC) == RESET);
return ch;
}
在该例中使用的USART1,这个看自己的实际需要改动。
做完这些,就可以直接使用printf函数了,不过个人建议最好重写printf函数,我的重写如下:
#include
#include
/* Log enable/disable switch */
#define ENABLE_LOG 1
#if ENABLE_LOG
#define Log(format, ...) printf(format, ##__VA_ARGS__)
#else
#define Log(format, ...)
#endif
同理可以重写fgetc函数,使scanf函数起作用,代码如下:
/*
** Rewrite fgetc function and make scanf function work
**/
int fgetc(FILE* file)
{
while((USART1->ISR & UART_IT_RXNE) == RESET);
return USART1->RDR;
}
举报