https://blog.csdn.net/gujintong1110/article/details/48683501
除了puts putc printf 也可以往串口打印信息。
puts 跟printf 的差别:
在串口初始化完成后,才能使用printf,否则在之前应该使用puts,理由如下。printf 是c的库函数,c运行环境准备好后,就可以运行。
如果串口已经使能,则又要判断gd->flags & GD_FLG_DEVINIT看标准输入输出设备(stdio)是否初始化,如果stdio初始化成功则会置GD_FLG_DEVINIT标志位,这时候就调用fputc(stdout, c);送给stdio处理,否则,直接调用串口底层API函数serial_putc(c)输出。
在console_init_r 函数
/* set default handlers at first */
gd->jt->getc = serial_getc;
gd->jt->tstc = serial_tstc;
gd->jt->putc = serial_putc;
gd->jt->puts = serial_puts;
gd->jt->printf = serial_printf;
可以看到从这个函数执行之后,就可以支持printf的信息输出。
换句话说在串口没初始化之前也能调用putc,puts函数。只是要等到串口初始化成功之后才会有打印输出。
测试了board_init_f 函数没有任何信息出书有点奇怪