STM32之串口重定向printf函数和scanf函数

在进行STM32开发时,需要将日志打印出来,直接使用C语言的库函数printf是不起作用的,此时就需要我们将串口重定向printf函数。首先我们需要在keil集成开发环境中勾选STM32官方的微库,如下图所示:
STM32之串口重定向printf函数和scanf函数_第1张图片

然后就是重写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;
}

当然你可以将打印Log日志的宏写得更好,这里只是简单的书写下,功能更强大的Log打印宏请参考我的另一篇博客:http://blog.csdn.net/Andy001847/article/details/53692760

你可能感兴趣的:(C语言,嵌入式,调试技巧)