core: 完善 tty

This commit is contained in:
bin456789 2023-09-03 19:35:01 +08:00
parent 15de1ac098
commit e2ca64a255
No known key found for this signature in database
GPG Key ID: EE301B386DE6C11B
4 changed files with 46 additions and 40 deletions

View File

@ -46,22 +46,8 @@ done
# 设置 tty # 设置 tty
include=/tmp/include-bootloader include=/tmp/include-bootloader
str= console_cmdline=$(wget $confhome/ttys.sh -O- | sh -s console=)
for tty in tty0 ttyS0 ttyAMA0; do echo "bootloader --append=\"$console_cmdline\"" >$include
dev_tty=/dev/$tty
if [ -e $dev_tty ] && echo >$dev_tty 2>/dev/null; then
if [ -z "$str" ]; then
str="console=$tty"
else
str="$str console=$tty"
fi
fi
done
if [ -n "$str" ]; then
echo "bootloader --append=\"$str\"" >$include
else
echo "bootloader" >$include
fi
# 有 installer 分区,表示用了两步安装 # 有 installer 分区,表示用了两步安装
include=/tmp/include-packages-for-resize include=/tmp/include-packages-for-resize

View File

@ -882,6 +882,16 @@ build_extra_cmdline() {
fi fi
} }
echo_tmp_ttys() {
# 由于 windows 下无法测试各tty是否有效
# 这里的 tty 只临时使用,非最终系统的 tty
if is_in_windows; then
echo "console=ttyS0,115200n8 console=tty0"
else
curl -L $confhome/ttys.sh | sh -s "console="
fi
}
# shellcheck disable=SC2154 # shellcheck disable=SC2154
build_cmdline() { build_cmdline() {
if [ -n "$finalos_cmdline" ]; then if [ -n "$finalos_cmdline" ]; then
@ -1064,7 +1074,7 @@ menuentry "reinstall" {
insmod lvm insmod lvm
insmod xfs insmod xfs
search --no-floppy --file --set=root /reinstall-vmlinuz search --no-floppy --file --set=root /reinstall-vmlinuz
linux$efi /reinstall-vmlinuz $cmdline linux$efi /reinstall-vmlinuz $(echo_tmp_ttys) $cmdline
initrd$efi /reinstall-initrd initrd$efi /reinstall-initrd
} }
EOF EOF

View File

@ -141,20 +141,12 @@ setup_lighttpd() {
rc-service lighttpd start rc-service lighttpd start
} }
# 最后一个 tty 是主tty显示的信息最多
# 有些平台例如 aws/gcp 只能截图,不能输入(没有鼠标)
# 所以如果有显示器且有鼠标tty0 放最后面,否则 tty0 放前面
get_ttys() { get_ttys() {
prefix=$1 prefix=$1
str= wget $confhome/ttys.sh -O- | sh -s $prefix
for tty in tty0 ttyS0 ttyAMA0; do
dev_tty=/dev/$tty
if [ -e $dev_tty ] && echo >$dev_tty 2>/dev/null; then
if [ -z "$str" ]; then
str="$prefix$tty"
else
str="$str $prefix$tty"
fi
fi
done
echo $str
} }
setup_tty_and_log() { setup_tty_and_log() {
@ -390,9 +382,9 @@ EOF
# 如果是 vm 就用 virt 内核 # 如果是 vm 就用 virt 内核
if is_virt; then if is_virt; then
kernel_opt="-k virt" kernel_flavor="virt"
else else
kernel_opt="-k lts" kernel_flavor="lts"
fi fi
# 重置为官方仓库配置 # 重置为官方仓库配置
@ -405,8 +397,10 @@ EOF
# 安装到硬盘 # 安装到硬盘
# alpine默认使用 syslinux (efi 环境除外),这里强制使用 grub方便用脚本再次重装 # alpine默认使用 syslinux (efi 环境除外),这里强制使用 grub方便用脚本再次重装
KERNELOPTS="$(get_ttys console=)"
export KERNELOPTS
export BOOTLOADER="grub" export BOOTLOADER="grub"
printf 'y' | setup-disk -m sys $kernel_opt -s 0 /dev/$xda printf 'y' | setup-disk -m sys -k $kernel_flavor -s 0 /dev/$xda
} }
# shellcheck disable=SC2154 # shellcheck disable=SC2154

32
ttys.sh
View File

@ -1,13 +1,29 @@
#!/bin/sh #!/bin/sh
prefix=$1 prefix=$1
for tty in tty0 ttyS0 ttyAMA0; do
dev_tty=/dev/$tty # 最后一个 tty 是主 tty显示的信息最全
if [ -e $dev_tty ] && echo >$dev_tty 2>/dev/null; then # 有些平台例如 aws/gcp 后台vnc只能截图不能输入用有没有鼠标判断
if [ -z "$str" ]; then # 因此如果有显示器且有鼠标tty0 放最后面,否则 tty0 放前面
str="$prefix$tty" ttys="ttyS0 ttyAMA0"
else if [ -e /dev/fb0 ] && [ -e /dev/input/mouse0 ]; then
str="$str $prefix$tty" ttys="$ttys tty0"
else
ttys="tty0 $ttys"
fi
is_first=true
for tty in $ttys; do
if [ -e /dev/$tty ] && echo >/dev/$tty 2>/dev/null; then
if ! $is_first; then
printf " "
fi
is_first=false
printf "%s" "$prefix$tty"
if [ "$prefix" = "console=" ] && [ "$tty" = ttyS0 ]; then
printf ",115200n8"
fi fi
fi fi
done done
echo $str