关于printf重定向到串口

时间:2025-04-11 15:25:17


int fputc(int ch, FILE *f)

{

  /* . write a character to the USART */

  USART_SendData(USART1, (uint8_t) ch);


  /* Loop until the end of transmission */

  while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET)

  {}


  return ch;

}


    入口参数有字符和字符要输出到的文件指针。根据搜索,printf函数输出到stdout,而fprintf可以指定字符到达的文件。可FILE结构体中,没有一个是与串口相关的。


typedef struct {

  char *fpos; /* Current position of file pointer (absolute address) */

  void *base; /* Pointer to the base of the file */

  unsigned short handle; /* File handle */

  short flags; /* Flags (see FileFlags) */

  short unget; /* 1-byte buffer for ungetc (b15=1 if non-empty) */

  unsigned long alloc; /* Number of currently allocated bytes for the file */

  unsigned short buffincrement; /* Number of bytes allocated at once */

} FILE;


    该如何重定向呢?不知道。但有一个弥补的方法。

    自己定义n个FILE*指针,并任意赋值。在fputc中利用if..else来做判断,代码如下:


FILE* FileUart1 = (FILE*)0x19;

FILE* FileUart2 = (FILE*)0x28;

int fputc(int ch, FILE *f) {

  if ( f == FileUart1 ) {

    USART_SendData(COM_USART[0], (uint8_t) ch);

    while (USART_GetFlagStatus(COM_USART[0], USART_FLAG_TC) == RESET){}

  }

  else if ( f == FileUart2 ) {

    USART_SendData(COM_USART[1], (uint8_t) ch);

    while (USART_GetFlagStatus(COM_USART[1], USART_FLAG_TC) == RESET){}

  }

}


    这样,fprintf(FileUart1,...)和fprintf(FileUart2,...)便能向不同的串口发送数据。哈哈,虽然没有真正做到重定向,只是用了个歪招,但最初的目的还是达到了。

    如果哪位牛人能告知如何真正重定向,感激感激~~~~


    还要请问,如何使用__DEBUG__宏定义才能使fprintf("val is %d", val)或fprintf("val1 is %d, val2 is %d", val1, val2)在程序中任意被编译上或编译掉。当然,不包括#ifdef..#endif方法。不这么做就是为了代码清晰一些,便于阅读。谢谢啊~~