在尝试为 Friendship mini210s ARM 单板计算机创建 Debian Wheezy 映像时,我遇到了这个问题。
我已经通过串口打开了一个终端sudo screen /dev/cu.usbserial 115200
,我当前的输出:
[ 3.398751] apple 0003:05AC:0220.0003: input: USB HID v1.11 Device [Apple, Inc Apple Keyboard] on usb-s5p-ehci-1.4.2/input1
INIT: version 2.88 booting
INIT: Entering runlevel: 2
INIT: Id "X1" respawning too fast: disabled for 5 minutes
Debian GNU/Linux 7 FriendlyARM ttySAC0
FriendlyARM login: root <======= entered root and hit return
Unable to determine your tty name. <===== THE ISSUE
Debian GNU/Linux 7 FriendlyARM ttySAC0
FriendlyARM login:
INIT: Id "6" respawning too fast: disabled for 5 minutes
INIT: Id "5" respawning too fast: disabled for 5 minutes
INIT: Id "4" respawning too fast: disabled for 5 minutes
INIT: Id "3" respawning too fast: disabled for 5 minutes
INIT: Id "2" respawning too fast: disabled for 5 minutes
INIT: Id "X1" respawning too fast: disabled for 5 minutes
INIT: Id "5" respawning too fast: disabled for 5 minutes
INIT: Id "2" respawning too fast: disabled for 5 minutes
INIT: Id "6" respawning too fast: disabled for 5 minutes
INIT: Id "4" respawning too fast: disabled for 5 minutes
INIT: Id "3" respawning too fast: disabled for 5 minutes
在触摸屏上,我有一条消息:
“登录:PAM 失败,正在中止:严重错误 - 立即中止”
有人可以帮我解密这是什么吗?
我是如何创建我的rootfs
sudo debootstrap --arch=armel --foreign wheezy rootfs/ http://ftp.us.debian.org/debian
echo "proc /proc proc none 0 0" >> rootfs/etc/fstab
echo "mini210s-anybots"
echo "mini210s-anybots" > rootfs/etc/hostname
mkdir -p rootfs/usr/share/man/man1/
mknod rootfs/dev/console c 5 1
mknod rootfs/dev/tty1 c 4 1
mknod dev/ttySAC0 c 204 64 <==== the serial port
然后我创建了一个镜像并yaffs2utils
在我的FriendlyARM上启动(我在这里描述了这个过程,它有点长)。
我inittab
从运行的 Debian Squeeze 映像中复制了以下内容,其中包含这些行
T1:2345:respawn:/sbin/getty 115200 ttySAC0 <=== terminal on serial port RS232
X1:2345:respawn:/bin/login -f root tty1 </dev/tty1 >/dev/tty1 2>&1
2:23:respawn:/sbin/getty 38400 tty2
3:23:respawn:/sbin/getty 38400 tty3
4:23:respawn:/sbin/getty 38400 tty4
5:23:respawn:/sbin/getty 38400 tty5
6:23:respawn:/sbin/getty 38400 tty6
我肯定错过了几个步骤。
更新添加了缺失的设备
显然我需要配置一些设备。我的灵感来自于这个帖子
mknod -m 0600 ./rootfs/dev/console c 5 1
mknod -m 0660 ./rootfs/dev/full c 1 7
mknod -m 0640 ./rootfs/dev/kmem c 1 2
mknod -m 0660 ./rootfs/dev/loop0 b 7 0
mknod -m 0640 ./rootfs/dev/mem c 1 1
mknod -m 0666 ./rootfs/dev/null c 1 3
mknod -m 0640 ./rootfs/dev/port c 1 4
mknod -m 0666 ./rootfs/dev/random c 1 8
mknod -m 0660 ./rootfs/dev/tty c 5 0
mknod -m 0666 ./rootfs/dev/urandom c 1 9
mknod -m 0666 ./rootfs/dev/zero c 1 5
mknod -m 0660 ./rootfs/dev/tty0 c 5 0
mknod -m 0660 ./rootfs/dev/tty1 c 5 1
mknod -m 0660 ./rootfs/dev/tty2 c 5 2
mknod -m 0660 ./rootfs/dev/tty3 c 5 3
mknod -m 0660 ./rootfs/dev/tty4 c 5 4
mknod -m 0660 ./rootfs/dev/tty5 c 5 5
...但仍然遇到这个问题。
现在添加这些
mknod -m 0660 ./rootfs/dev/ram0 b 1 0
mknod -m 0660 ./rootfs/dev/ram1 b 1 1
mknod -m 0660 ./rootfs/dev/ram2 b 1 2
mknod -m 0660 ./rootfs/dev/ram3 b 1 3
mknod -m 0660 ./rootfs/dev/ram4 b 1 4
mknod -m 0660 ./rootfs/dev/ram5 b 1 5
mknod -m 0660 ./rootfs/dev/ram6 b 1 6
mknod -m 0660 ./rootfs/dev/ram7 b 1 7
mknod -m 0660 ./rootfs/dev/ram8 b 1 8
mknod -m 0660 ./rootfs/dev/ram9 b 1 9
mknod -m 0660 ./rootfs/dev/ram10 b 1 10
mknod -m 0660 ./rootfs/dev/ram11 b 1 11
mknod -m 0660 ./rootfs/dev/ram12 b 1 12
mknod -m 0660 ./rootfs/dev/ram13 b 1 13
mknod -m 0660 ./rootfs/dev/ram14 b 1 14
mknod -m 0660 ./rootfs/dev/ram15 b 1 15
我的新rootfs/dev
root@ubuntu:/home/joel/debian-mini210s/rootfs/dev# ls -al
total 8
drwxr-xr-x 2 root root 4096 Jan 19 17:27 .
drwxr-xr-x 19 root root 4096 Jun 22 2012 ..
crw-r--r-- 1 root root 5, 1 Jan 19 14:07 console
crw-rw---- 1 root root 1, 7 Jan 19 17:05 full
crw-r----- 1 root root 1, 2 Jan 19 17:05 kmem
brw-rw---- 1 root root 7, 0 Jan 19 17:05 loop0
crw-r----- 1 root root 1, 1 Jan 19 17:05 mem
crw-rw-rw- 1 root root 1, 3 Jan 19 17:05 null
crw-r----- 1 root root 1, 4 Jan 19 17:05 port
brw-rw---- 1 root root 1, 0 Jan 19 17:27 ram0
brw-rw---- 1 root root 1, 1 Jan 19 17:27 ram1
brw-rw---- 1 root root 1, 10 Jan 19 17:27 ram10
brw-rw---- 1 root root 1, 11 Jan 19 17:27 ram11
brw-rw---- 1 root root 1, 12 Jan 19 17:27 ram12
brw-rw---- 1 root root 1, 13 Jan 19 17:27 ram13
brw-rw---- 1 root root 1, 14 Jan 19 17:27 ram14
brw-rw---- 1 root root 1, 15 Jan 19 17:27 ram15
brw-rw---- 1 root root 1, 2 Jan 19 17:27 ram2
brw-rw---- 1 root root 1, 3 Jan 19 17:27 ram3
brw-rw---- 1 root root 1, 4 Jan 19 17:27 ram4
brw-rw---- 1 root root 1, 5 Jan 19 17:27 ram5
brw-rw---- 1 root root 1, 6 Jan 19 17:27 ram6
brw-rw---- 1 root root 1, 7 Jan 19 17:27 ram7
brw-rw---- 1 root root 1, 8 Jan 19 17:27 ram8
brw-rw---- 1 root root 1, 9 Jan 19 17:27 ram9
crw-rw-rw- 1 root root 1, 8 Jan 19 17:05 random
crw-rw---- 1 root root 5, 0 Jan 19 17:05 tty
crw-rw---- 1 root root 5, 0 Jan 19 17:07 tty0
crw-r--r-- 1 root root 4, 1 Jan 19 14:47 tty1
crw-rw---- 1 root root 5, 2 Jan 19 17:07 tty2
crw-rw---- 1 root root 5, 3 Jan 19 17:07 tty3
crw-rw---- 1 root root 5, 4 Jan 19 17:07 tty4
crw-rw---- 1 root root 5, 5 Jan 19 17:07 tty5
crw-r--r-- 1 root root 204, 64 Jan 19 14:11 ttySAC0
crw-rw-rw- 1 root root 1, 9 Jan 19 17:05 urandom
crw-rw-rw- 1 root root 1, 5 Jan 19 17:05 zero
但仍然得到Unable to determine your tty name
更新 - 添加ttySAC0
到/etc/securetty
排队vim /etc/pam.d/login
:
auth [success=ok new_authtok_reqd=ok ignore=ignore user_unknown=bad default=die] pam_securetty.so
如果列出了设备,这应该允许无密码登录。 ……但这并没有达到我的预期。
网上查到这个问题
答案1
我怀疑根本问题与你的 tty 无关,而是下面更重要的错误消息的结果,PAM 失败,正在中止:严重错误 - 立即中止。
本文Debian 帮助站点可能会有所帮助。 (TL;DR?PAM 配置文件中行尾的 CR/LF 是不好的。)但是如果不知道您对 PAM 子系统做了什么,那么它只能是猜测。
答案2
你遗漏了一些东西/dev
。您最初缺少/dev/tty
,内核在内部将其重新路由到调用进程自己的终端。getty
和程序login
与特定终端(此处/dev/ttySAC0
)通信,但之后其他程序只想通过它们运行的任何终端进行通信,并用于/dev/tty
此目的。您已创建它,但权限错误:/dev/tty
需要可由所有进程访问。顺便/dev/full
说一句,尽管它很少使用,所以在实践中可能不会破坏任何东西。
chmod a+rw /dev/tty
(/dev/console
另一方面,正确地保留给 root。/dev/tty
指的是进程运行的终端,可以是软件终端,例如 xterm、sshd、screen 等/dev/console
,另一方面,指的是控制台,即物理终端;很少有程序需要与控制台交互。)
另外,为了使用screen等终端模拟器,需要创建/dev/ptmx
并安装/dev/pts
。
mknod -m 666 /dev/ptmx c 5 2
mkdir /dev/pts
并将以下行放入/etc/fstab
或在启动时运行等效mount
命令,其中 5 替换为组 ID tty
(检查 `/etc/group):
devpts /dev/pts devpts gid=5,mode=620 0 0
目前我所看到的就是这些。我没有测试过,可能还缺少其他东西。