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() {
|
2020-01-30 18:28:03 +03:00
|
|
|
printf "panic >> %s\n" "$@" && 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
|
|
|
|
}
|
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-01-30 17:40:13 +03:00
|
|
|
printf /sbin/mdev >/proc/sys/kernel/hotplug
|
2020-01-28 18:13:42 +03:00
|
|
|
else
|
|
|
|
uevent mdev &
|
|
|
|
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
|
|
|
|
case ${u##*/} in
|
|
|
|
[0-9]*-[0-9]*)
|
2020-01-30 17:40:13 +03:00
|
|
|
printf add > "${u}/uevent"
|
2020-01-28 18:13:42 +03:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
# load drivers
|
2020-02-05 21:03:23 +03:00
|
|
|
find /sys -name "modalias" -type f -exec sort -u "{}" "+" | xargs modprobe -ba
|
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
|
|
|
|
2020-02-02 15:37:14 +03:00
|
|
|
# unlock LUKS container
|
2020-01-30 17:40:13 +03:00
|
|
|
unlock_luks() {
|
2020-02-02 15:37:14 +03:00
|
|
|
# TODO implement POSIX findfs
|
2020-01-30 17:40:13 +03:00
|
|
|
# find device of luks root
|
2020-01-25 14:27:02 +03:00
|
|
|
luks_root="$(findfs $luks_root)"
|
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-01-28 18:13:42 +03:00
|
|
|
lvm vgchange --sysinit -a y
|
|
|
|
}
|
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
|
|
|
|
2020-01-30 17:40:13 +03:00
|
|
|
# mount rootfs
|
|
|
|
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() {
|
2020-02-02 15:37:14 +03:00
|
|
|
# stop mdev
|
2020-01-30 18:28:03 +03:00
|
|
|
[ "$devmgr" = "mdev" ] && { printf "" >/proc/sys/kernel/hotplug || killall uevent; } >/dev/null 2>&1
|
2020-02-02 15:37:14 +03:00
|
|
|
# stop mdevd
|
2020-01-30 18:28:03 +03:00
|
|
|
[ "$devmgr" = "mdevd" ] && killall mdevd
|
2020-02-02 15:37:14 +03:00
|
|
|
# stop udev
|
2020-01-30 18:28:03 +03:00
|
|
|
[ "$devmgr" = "udev" ] && udevadm control --exit
|
2020-02-02 15:37:14 +03:00
|
|
|
# if debug mode off then restore kernel logging
|
|
|
|
[ "$debug" = 0 ] && printf 1 >/proc/sys/kernel/printk
|
2020-01-30 17:40:13 +03:00
|
|
|
umount /dev /sys /proc
|
|
|
|
}
|
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
|
|
|
|
2020-01-30 18:28:03 +03:00
|
|
|
if [ "$debug" = 1 ]; then
|
|
|
|
# debug shell commands
|
|
|
|
set -x
|
|
|
|
else
|
|
|
|
# silence is golden
|
|
|
|
printf 0 >/proc/sys/kernel/printk
|
|
|
|
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
|