180 lines
3.7 KiB
Plaintext
Raw Normal View History

2020-01-27 16:39:58 +03:00
#!/sbin/busybox sh
2020-01-30 17:40:13 +03:00
#
# tiny init script
2020-01-05 21:01:39 +03:00
2020-01-30 17:40:13 +03:00
panic() {
printf "panic >> %s\n" "$1" && sh
2020-01-30 17:40:13 +03:00
}
2020-01-28 18:13:42 +03:00
2020-01-30 17:40:13 +03:00
# parse_cmdline() {
2020-01-28 18:13:42 +03:00
# TODO parse /proc/cmdline
2020-01-30 17:40:13 +03:00
#}
2020-01-05 21:01:39 +03:00
2020-02-02 15:37:14 +03:00
# mount pseudofs's
2020-01-30 17:40:13 +03:00
mnt_pseudofs() {
mount -t proc none /proc
mount -t sysfs none /sys
mount -t devtmpfs none /dev
mount -t tmpfs none /tmp
2020-01-30 17:40:13 +03:00
}
2020-01-05 21:01:39 +03:00
2020-02-02 15:37:14 +03:00
# setup mdev
2020-01-30 17:40:13 +03:00
use_mdev() {
2020-02-02 15:37:14 +03:00
# setup hotplugger
2020-01-28 18:13:42 +03:00
if [ -e /proc/sys/kernel/hotplug ]; then
2020-02-11 21:02:23 +03:00
printf /sbin/mdev > /proc/sys/kernel/hotplug
2020-01-28 18:13:42 +03:00
else
2020-02-11 21:02:23 +03:00
uevent mdev &
2020-01-28 18:13:42 +03:00
fi
2020-01-19 00:01:21 +03:00
2020-01-28 18:13:42 +03:00
# trigger mdev
mdev -s
# trigger uevent for usb devices
for u in /sys/bus/usb/devices/*; do
2020-02-11 21:02:23 +03:00
case ${u##*/} in
[0-9]*-[0-9]*)
printf add > "${u}/uevent"
;;
2020-01-28 18:13:42 +03:00
esac
done
# load drivers
2020-02-09 16:24:54 +03:00
find /sys -name "modalias" -type f -exec sort -u "{}" "+" | xargs modprobe -qba
2020-01-30 17:40:13 +03:00
}
2020-02-02 15:37:14 +03:00
# setup mdevd
2020-01-30 17:40:13 +03:00
use_mdevd() {
2020-02-02 15:37:14 +03:00
# setup daemon
2020-01-30 17:40:13 +03:00
mdevd &
# trigger uevents
mdevd-coldplug
# TODO investigate this
# avoid race condition
sleep 1.5
}
2020-02-02 15:37:14 +03:00
# setup udev
2020-01-30 17:40:13 +03:00
use_udev() {
2020-01-28 18:13:42 +03:00
udevd --daemon
udevadm trigger --action=add --type=subsystems
udevadm trigger --action=add --type=devices
udevadm settle
2020-01-30 17:40:13 +03:00
}
2020-01-05 21:01:39 +03:00
# shell findfs
findfs_sh() {
case "${1%%=*}" in
2020-02-11 21:02:23 +03:00
LABEL)
printf "/dev/disk/by-label/%s\n" "${1##*=}"
;;
UUID)
printf "/dev/disk/by-uuid/%s\n" "${1##*=}"
;;
PARTUUID)
printf "/dev/disk/by-partuuid/%s\n" "${1##*=}"
;;
/dev/*)
printf "%s\n" "$1"
;;
*)
panic "findfs option broken"
;;
esac
}
2020-02-02 15:37:14 +03:00
# unlock LUKS container
2020-01-30 17:40:13 +03:00
unlock_luks() {
# find device of luks root
luks_root="$(findfs_sh $luks_root)"
# TODO investigate this
# avoid race condition
[ "$devmgr" != "udev" ] && sleep 1.5
2020-01-30 17:40:13 +03:00
2020-01-25 14:27:02 +03:00
# TODO improve mapper name ( crypttab or config option )
2020-01-30 17:40:13 +03:00
# unlock luks container
cryptsetup $luks_args luksOpen "$luks_root" luks_root || panic "failed to unlock luks container"
2020-01-25 14:27:02 +03:00
}
2020-02-02 15:37:14 +03:00
# manually trigger LVM if udev disabled
2020-01-30 17:40:13 +03:00
trigger_lvm() {
2020-02-11 21:02:23 +03:00
lvm vgchange --quiet --sysinit -a y > /dev/null
2020-01-28 18:13:42 +03:00
}
2020-01-05 21:01:39 +03:00
2020-02-02 15:37:14 +03:00
# mount rootfs to /mnt/root
2020-01-30 17:40:13 +03:00
mnt_rootfs() {
# merge mount flags
[ -n "$root_args" ] && mount_args="$root_args"
[ -n "$root_type" ] && mount_args="$mount_args -t $root_type"
2020-01-05 21:01:39 +03:00
# find root
root="$(findfs_sh $root)"
2020-02-11 21:02:23 +03:00
# mount rootfs
2020-01-30 17:40:13 +03:00
mount $mount_args "$root" /mnt/root || panic "failed to mount rootfs"
}
2020-01-05 21:01:39 +03:00
2020-02-02 15:37:14 +03:00
# kill and unmount
2020-01-30 17:40:13 +03:00
cleanup() {
case "$devmgr" in
2020-02-11 21:02:23 +03:00
mdev)
# stop mdev
{ printf "" > /proc/sys/kernel/hotplug || killall uevent; } > /dev/null 2>&1
;;
mdevd)
# stop mdevd
killall mdevd
;;
udev)
# stop udev
udevadm control --exit
;;
esac
# TODO re-do
2020-02-02 15:37:14 +03:00
# if debug mode off then restore kernel logging
2020-02-11 21:02:23 +03:00
[ "$debug" = 0 ] && printf 1 > /proc/sys/kernel/printk
# unmount pseudofs's
umount /dev /sys /proc /tmp
2020-01-30 17:40:13 +03:00
}
2020-01-05 21:01:39 +03:00
2020-02-02 15:37:14 +03:00
# exec /mnt/root/sbin/init
2020-01-30 17:40:13 +03:00
boot_system() {
exec switch_root /mnt/root /sbin/init || panic "failed to boot system"
}
# install busybox
/sbin/busybox --install -s
2020-02-02 15:37:14 +03:00
# source config
. /config || panic "config doesn't exists"
2020-01-30 17:40:13 +03:00
# TODO re-do
2020-01-30 18:28:03 +03:00
if [ "$debug" = 1 ]; then
2020-02-11 21:02:23 +03:00
# debug shell commands
2020-01-30 18:28:03 +03:00
set -x
else
# silence is golden
2020-02-11 21:02:23 +03:00
printf 0 > /proc/sys/kernel/printk
2020-01-30 18:28:03 +03:00
fi
2020-01-30 17:40:13 +03:00
#parse_cmdline
mnt_pseudofs
2020-01-30 18:28:03 +03:00
2020-01-30 17:40:13 +03:00
case "$devmgr" in
mdev) use_mdev ;;
mdevd) use_mdevd ;;
udev) use_udev ;;
2020-01-30 18:28:03 +03:00
*) panic "devmgr option broken" ;;
2020-01-30 17:40:13 +03:00
esac
2020-01-30 18:28:03 +03:00
2020-01-30 17:40:13 +03:00
# TODO handle situations when LUKS on LVM
[ "$use_luks" = 1 ] && unlock_luks
2020-01-30 18:28:03 +03:00
[ "$use_lvm" = 1 ] && [ "$devmgr" != "udev" ] && trigger_lvm
2020-01-30 17:40:13 +03:00
mnt_rootfs
cleanup
boot_system