我想要完成什么

我想要完成什么

我想要完成什么

我想通过 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 适配器工作正常。服务器是一个英特尔 NUC 5CPYH配备 Braswell 芯片组并运行Linux 4.9.0-4-amd64Debian 内核。

我的问题

我必须采取哪些行动才能使其正常工作?

编辑 1

当提供console=tty0 console=ttyUSB0,9600n8启动参数时,机器启动得很好,但我仍然无法连接到串行端口。另外,说该服务是和。我本来希望它能够启动并运行。systemctl status [email protected]loadedinactive (dead)

编辑 2

我做了一些研究,发现我的 initramfs 缺少相关的内核模块。我设法通过提供内核参数进入 initramfs shell break=init,并看到没有/dev/ttyUSB0设备。

在重新创建 initramfs 后,我添加了cp210xpl2303和,发现initramfs shell 中现在有一个设备。ftdi_sio/etc/initramfs-tools/modules/dev/ttyUSB0

尽管如此,我仍无法从其他机器进行连接。所以我尝试在该设备上手动启动 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

这就是我现在的处境。

答案1

您的系统没有冻结。你刚刚导演了全部您的输出到串行控制台。

将控制台参数传递给内核,必须同时包含本地控制台和串行接口。

TLDP - 远程串行控制台 HOWTO - 第 5 章配置 Linux 内核

图 5-2。推荐的内核参数,带显卡的电脑

console=tty0 console=ttyS0,9600n8

内核消息将出现在第一个虚拟终端和串行端口上。来自 init 系统和系统记录器的消息将仅出现在第一个串行端口上。当查看连接的显示器时,这可能会有点令人困惑:机器似乎启动然后挂起。不要惊慌,初始化系统已经启动,但现在正在将消息打印到串行端口,但没有在屏幕上打印任何内容。如果已配置 getty,则登录:提示最终将出现在连接的显示器上。

对于没有显卡的 PC,此 HOWTO 建议内核参数:

图 5-3。推荐的内核参数,没有显卡的电脑

console=ttyS0,9600n8

这些参数由引导加载程序传递到引导内核。接下来,我们将配置 Linux 安装所使用的引导加载程序,以将控制台参数传递到内核。

答案2

Debian 目前不使用 来构建其 Linux 内核CONFIG_USB_SERIAL_CONSOLE=y,而这是此功能正常工作所必需的。

对应的bug报告是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),我还必须在 initrd 中包含适配器的 FTDI 串行驱动程序:

# echo ftdi_sio >> /etc/initramfs-tools/modules
# update-initramfs -u

最后,我调整/etc/default/grub阅读:

GRUB_CMDLINE_LINUX_DEFAULT="panic=10 panic_on_oops=1 console=tty0 console=ttyUSB0,115200"

……然后跑了update-grub

之后,我成功地看到了启动消息,并且可以通过自动启动的serial-getty@ttyUSB0服务登录。

相关内容