在linux系统下,如果想把kernel的调试信息,grub的调试信息输出到串口控制台,以便于查看调试信息。则首先
必须创建一个串口控制台,在/etc/event.d/目录下创建ttyS0控制台文件。
首先查看串口信息:dmesg | grep tty
将得到类似以下的输出
serial8250: ttyS0 at I/O 0x3f8 (irq = 4) is a 16550A
00:0c: ttyS0 at I/O 0x3f8 (irq = 4) is a 16550A
然后进入 /etc/event.d/ 目录, 创建文件 /etc/event.d/ttyS0 , 并加入以下内容:
# ttyS0 - getty
则串口控制台创建成功。此时就可以设置grub、kernel等将调试信息输出到控制台中。
配置grub方法:
1、配置 grub ,让启动信息也输出到串口。如果启动信息不需要输出到串口,
则忽略这一步
打开 /boot/grub/grub.conf (也可能是其他路径) 找到以下面字符开始的一行
kernel /vmlinuz-*** ro root=LABEL=/
修改成以下形式
kernel /vmlinuz-*** ro root=LABEL=/ console=ttyS0,115200 console=tty0
即添加了相关参数
console=ttyS0,115200n8 console=tty0
ttyS0 是串口命名,115200 是波特率,无校验,数据位 8 ;同时指定启动信息也要
输出到第一个终端 tty0
2、配置 init, 让其初始化串口终端。这里分两种情况: 老版本的 init 和 upstart
老版本的 init (sysvinit)
打开 /etc/inittab , 如果出现以下内容,则可以确认是老版本的 init,否则
请看 4.2
1:2345:respawn:/sbin/mingetty tty1
2:2345:respawn:/sbin/mingetty tty2
3:2345:respawn:/sbin/mingetty tty3
4:2345:respawn:/sbin/mingetty tty4
5:2345:respawn:/sbin/mingetty tty5
6:2345:respawn:/sbin/mingetty tty6
添加一行初始化串口的内容即可,添加后如下:
1:2345:respawn:/sbin/mingetty tty1
2:2345:respawn:/sbin/mingetty tty2
3:2345:respawn:/sbin/mingetty tty3
4:2345:respawn:/sbin/mingetty tty4
5:2345:respawn:/sbin/mingetty tty5
6:2345:respawn:/sbin/mingetty tty6
co:2345:respawn:/sbin/agetty ttyS0 115200 vt102
注意如果系统没有 /sbin/agetty, 则要改成 /sbin/getty 或其它。vt102 是
常用的 Linux 虚拟终端
3、赋予串口终端 root 登录权限
在文件 /etc/securetty 末尾加入如下一行(注意行前面没有空格)
ttyS0
加入上面一行后, root 将可以直接通过串口终端登录系统,否则只有普通用户可以
通过串口终端登录系统
4、注意
串口命名(ttyS0 ttyS1 等)一定要和系统识别的一致,不能想当然乱编。
确认系统有 /sbin/agetty, /sbin/getty 或其他初始化终端的命令,有哪个就用哪个。
终端波特率设置都要一致,用 115200 则全部都要用 115200. 据我的经验,9600有一
次就是不行,原因未知。可用的波特率如下
300/600/1200/2400/4800/9600/19200/38400/57600/115200/230400 等等
如果确认配置没错, 但就是无法工作, 可以换不同的波特率尝试一下 :)
5、配置好后,重启系统,用其他 windows 机器的超级终端或者 linux 机器的 minicom 连接即可。
记得设置好波特率,无校验,数据位 8
连接时两端都用 RS232 线缆(console 线,购买交换机、路由器都会随机带的那种线缆)即可。
6、关于 grub
通过步骤 3 配置的 grub, 只能让部分启动信息输出到串口终端,包括 grub 菜单接口在
内的另外一部分信息都无法输出到串口终端。要让 grub 完整的支持串口终端,需要重新编译
grub