入门嵌入式 Linux,从修改串口波特率开始

Posted Li-Yongjun

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了入门嵌入式 Linux,从修改串口波特率开始相关的知识,希望对你有一定的参考价值。

环境

硬件:bananapi m1
软件:buildroot(uboot-2018.07 + linux-4.18.12)

默认波特率

编译

$ make bananapi_m1_defconfig
$ make

编译好后,SD 卡烧录镜像 sdcard.img,插入 BPI 启动,默认情况下 uboot 和 kernel 的串口波特率为 115200。我们把串口工具调到 115200,8n1,就可以看到系统启动时的 log 了,包括 uboot 和 kernel 的 log 打印。

修改波特率

如何修改波特率呢?同样也是分为两块,uboot 和 kernel。
先看 uboot,使用 make uboot-menuconfig 命令

→ Device Drivers → Serial drivers 路径下,将 Default baudrate 改成 57600。然后重新编译 uboot。
其实就是修改 output/build/uboot-2018.07/.config 中的 CONFIG_BAUDRATE

#
# Serial drivers
#
CONFIG_BAUDRATE=57600                                                                                                      
CONFIG_REQUIRE_SERIAL_CONSOLE=y
CONFIG_SPECIFY_CONSOLE_INDEX=y
CONFIG_SERIAL_PRESENT=y
CONFIG_SPL_SERIAL_PRESENT=y
CONFIG_CONS_INDEX=1
CONFIG_DM_SERIAL=y

接着修改 kernel 的串口波特率。不同的板子,不同的镜像,修改的位置是不一样的,我知道的有两种

1. 修改 dts

这里我看到编译好的镜像使用的是 sun7i-a20-bananapi.dtb 这个文件,于是就去修改 output/build/linux-4.18.12/arch/arm/boot/dts/sun7i-a20-bananapi.dts

    chosen {
        // stdout-path = "serial0:115200n8";
        stdout-path = "serial0:57600n8";
    };

重新编译 kernel,再完整编译生成 sdcard.img,重新烧录,串口工具波特率改成 57600,启动

可以看到,uboot 阶段显示正常,到 kernel 阶段出现了乱码,显然 kernel 的串口波特率并没有修改成功,那问题出现在哪呢?

2. 修改 boot.scr

仔细看了 uboot 的启动 log,没看到加载 sun7i-a20-bananapi.dtb 的打印,却看到了这一句 Found U-Boot script /boot.scr 这句是干嘛的呢?查资料知道,boot.scr 是通过 boot.cmd 编译生成的。
boot.cmd

setenv bootargs console=ttyS0,115200 earlyprintk root=/dev/mmcblk0p2 rootwait                                               
  
mmc dev 0
fatload mmc 0 $kernel_addr_r zImage
fatload mmc 0 $fdt_addr_r sun7i-a20-bananapi.dtb

bootz $kernel_addr_r - $fdt_addr_r

看到 boot.cmd 的内容瞬间就找到了答案,波特率是在这里通过启动参数的形式由 uboot 传递给 kernel 的。系统启动后,执行命令 cat /proc/cmdline 也能证实这一点

Welcome to Bananapi M1
buildroot login: root
# cat /proc/cmdline
console=ttyS0,115200 earlyprintk root=/dev/mmcblk0p2 rootwait
#

console=ttyS0,115200 earlyprintk root=/dev/mmcblk0p2 rootwait 这句就是 boot.scr 里面的内容。
下面我们来修改一下
boot.cmd

setenv bootargs console=ttyS0,57600 earlyprintk root=/dev/mmcblk0p2 rootwait                                               
  
mmc dev 0
fatload mmc 0 $kernel_addr_r zImage
fatload mmc 0 $fdt_addr_r sun7i-a20-bananapi.dtb

bootz $kernel_addr_r - $fdt_addr_r

编译

$  mkimage -A arm -T script -O linux -d boot.cmd boot.scr

我们可以不用重新编译并烧录整个镜像,只要单独编译并替换 boot.scr 这个文件就行了。替换后启动

可以看到,uboot 和 kernel 都以 57600 的波特率正常打印 log 了,通过 cat /proc/cmdline 查看波特率也是 57600。

# cat /proc/cmdline
console=ttyS0,57600 earlyprintk root=/dev/mmcblk0p2 rootwait

以上是关于入门嵌入式 Linux,从修改串口波特率开始的主要内容,如果未能解决你的问题,请参考以下文章

BluetoothChat用于蓝牙串口通信的修改方法

linux 怎么查看串口波特率

Linux C 配置串口

10通信入门之串口发送

Linux嵌入式开发环境之串口配置

linux的串口编程。read()读不出回车键