我想要完成的
我想通过 USB-RS232 适配器远程终端访问我的 NAS(运行 Debian Stretch)。由于这台机器应该是无头的,所以我也想看看串口线的启动过程。
(不过,为了评估这个问题,目前 HDMI 端口上连接了一个屏幕。)
我采取的行动
我附加console=ttyUSB0
到内核参数列表中。启动时,这会导致我的系统冻结。
引导输出的最后几行是:(Bootloader 是 extlinux)
Loading /vmlinuz... ok
Loading /initrd.img...ok
Probing EDD (edd=off to disable)... ok
当不使用所述内核参数时,机器正在引导而没有问题。从那里开始,我可以通过运行轻松完成串行终端访问
systemctl enable [email protected]
systemctl start [email protected]
在远程服务器上,以及
screen -F /dev/ttyUSB0 9600
在我的本地机器上。因此,USB-RS232 适配器工作正常。该服务器是带有 Braswell 芯片组的Intel NUC 5CPYH,运行Linux 4.9.0-4-amd64
debian 内核。
我的问题
我必须采取哪些措施才能使其正常工作?
编辑№1
当提供console=tty0 console=ttyUSB0,9600n8
启动参数时,机器启动得很好,但我仍然无法连接到串行端口。另外,systemctl status [email protected]
说服务是loaded
and inactive (dead)
。我本来预计它会在那时启动并运行。
编辑№2
我做了一些研究,发现我的 initramfs 缺少相关的内核模块。我通过提供内核参数设法进入 initramfs shell,break=init
发现没有/dev/ttyUSB0
设备。
我在重新创建 initramfs 后添加了cp210x
,pl2303
和ftdi_sio
to /etc/initramfs-tools/modules
,看到现在/dev/ttyUSB0
initramfs shell 中有一个设备。
不过,我无法从我的另一台机器连接。所以我尝试在该设备上手动启动 getty:
# /sbin/getty -L 9600 /dev/ttyUSB0 vt100
getty: setsid: Operation not permitted
# su root -c "/sbin/getty -L 9600 /dev/ttyUSB0 vt100"
sh: su: not found
这就是我现在的位置。
您的系统没有冻结。您刚刚将所有输出定向到串行控制台。
将控制台参数传递给内核,您必须同时包含本地控制台和串行接口。
请参阅TLDP - 远程串行控制台 HOWTO - 第 5 章。配置 Linux 内核
Debian 目前不使用 构建它的 Linux 内核
CONFIG_USB_SERIAL_CONSOLE=y
,这是该功能工作所必需的。对应的错误报告是https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=868352
CONFIG_USB_SERIAL_CONSOLE=y
在使用(参见https://kernel-team.pages.debian.net/kernel-handbook/ch-common-tasks.html#s-common-official )构建我自己的内核之后,我还必须包含 FTDI 串行驱动程序对于我在 initrd 中的适配器:最后,我调整
/etc/default/grub
阅读:……然后跑了
update-grub
。之后,我成功看到了启动信息,并且可以通过自动启动的serial-getty@ttyUSB0 服务登录。