tinyramfs/init

145 lines
2.9 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() {
2020-02-13 05:18:53 +03:00
printf "panic >> %s\n" "$1"
sh -l
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-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-14 20:12:45 +03:00
setup_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
2020-02-13 05:18:53 +03:00
for device in /sys/bus/usb/devices/*; do
case ${device##*/} in
2020-02-11 21:02:23 +03:00
[0-9]*-[0-9]*)
2020-02-13 05:18:53 +03:00
printf add > "${device}/uevent"
2020-02-11 21:02:23 +03:00
;;
2020-01-28 18:13:42 +03:00
esac
done
# load drivers
2020-02-18 10:53:03 +03:00
find /sys -name modalias -type f -exec sort -u "{}" "+" | xargs modprobe -qba
2020-01-30 17:40:13 +03:00
}
2020-02-14 20:12:45 +03:00
setup_mdevd() {
2020-02-02 15:37:14 +03:00
# setup daemon
2020-01-30 17:40:13 +03:00
mdevd &
# trigger uevents
mdevd-coldplug
}
2020-02-14 20:12:45 +03:00
setup_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
findfs_sh() {
case "${1%%=*}" in
2020-02-11 21:02:23 +03:00
LABEL)
2020-02-15 22:33:13 +03:00
device="/dev/disk/by-label/${1##*=}"
2020-02-11 21:02:23 +03:00
;;
UUID)
2020-02-15 22:33:13 +03:00
device="/dev/disk/by-uuid/${1##*=}"
2020-02-11 21:02:23 +03:00
;;
PARTUUID)
2020-02-15 22:33:13 +03:00
device="/dev/disk/by-partuuid/${1##*=}"
2020-02-11 21:02:23 +03:00
;;
/dev/*)
2020-02-15 22:33:13 +03:00
device="$1"
2020-02-11 21:02:23 +03:00
;;
*)
panic "findfs option broken"
;;
esac
2020-02-15 22:33:13 +03:00
# avoid race condition
until [ -e "$device" ]; do sleep 0.5; done
printf "%s\n" "$device"
}
2020-01-30 17:40:13 +03:00
unlock_luks() {
2020-01-25 14:27:02 +03:00
# TODO improve mapper name ( crypttab or config option )
2020-02-13 05:18:53 +03:00
cryptsetup $luks_args luksOpen $(findfs_sh "$luks_root") luks_root || panic "failed to unlock luks container"
2020-01-25 14:27:02 +03:00
}
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-01-30 17:40:13 +03:00
mnt_rootfs() {
2020-02-15 22:33:13 +03:00
mount ${root_type:+-t $root_type} $root_args $(findfs_sh "$root") /mnt/root || panic "failed to mount rootfs"
2020-01-30 17:40:13 +03:00
}
2020-01-05 21:01:39 +03:00
2020-01-30 17:40:13 +03:00
cleanup() {
case "$devmgr" in
2020-02-13 05:18:53 +03:00
mdev) { printf "" > /proc/sys/kernel/hotplug || killall uevent; } > /dev/null 2>&1 ;;
mdevd) killall mdevd ;;
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-01-30 17:40:13 +03:00
boot_system() {
exec switch_root /mnt/root /sbin/init || panic "failed to boot system"
}
/sbin/busybox --install -s
2020-02-13 05:18:53 +03:00
. /config || panic "failed to source config"
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
2020-02-14 20:12:45 +03:00
mdev) setup_mdev ;;
mdevd) setup_mdevd ;;
udev) setup_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
2020-02-14 20:12:45 +03:00
[ "$luks" = 1 ] && unlock_luks
[ "$lvm" = 1 ] && trigger_lvm
2020-01-30 17:40:13 +03:00
mnt_rootfs
cleanup
boot_system