minor impovements

This commit is contained in:
illiliti 2020-02-18 10:53:03 +03:00
parent 74fc37658e
commit 98888ecd1e
2 changed files with 23 additions and 55 deletions

View File

@ -20,7 +20,6 @@ msg() {
esac esac
} }
# create wrkdir
create_wrkdir() { create_wrkdir() {
msg info "creating working directory" msg info "creating working directory"
if [ -n "$XDG_CACHE_HOME" ]; then if [ -n "$XDG_CACHE_HOME" ]; then
@ -34,7 +33,6 @@ create_wrkdir() {
mkdir "$wrkdir" || msg panic "failed to create working directory" mkdir "$wrkdir" || msg panic "failed to create working directory"
} }
# remove wrkdir
remove_wrkdir() { remove_wrkdir() {
msg info "removing working directory" msg info "removing working directory"
rm -rf "$wrkdir" rm -rf "$wrkdir"
@ -49,11 +47,11 @@ check_currentdir() {
} }
} }
# install requirements
install_requirements() { install_requirements() {
msg info "installing requirements" msg info "installing requirements"
# install user specified binaries # install user specified binaries
[ -n "$binaries" ] && install_binary $binaries [ -n "$binaries" ] && install_binary "$binaries"
# install util-linux binaries # install util-linux binaries
[ "$util_linux" = 1 ] && install_binary mount blkid [ "$util_linux" = 1 ] && install_binary mount blkid
@ -62,7 +60,6 @@ install_requirements() {
install_binary busybox modprobe install_binary busybox modprobe
} }
# create FHS directory structure
create_structure() { create_structure() {
msg info "creating directory structure" msg info "creating directory structure"
for dir in dev tmp var run etc usr/lib usr/bin mnt/root proc root sys; do for dir in dev tmp var run etc usr/lib usr/bin mnt/root proc root sys; do
@ -97,14 +94,12 @@ create_symlinks() {
# TODO parse crypttab # TODO parse crypttab
#} #}
# install mdev
install_mdev() { install_mdev() {
msg info "installing mdev" msg info "installing mdev"
install -m644 mdev.conf -t "${wrkdir}/etc" install -m644 mdev.conf -t "${wrkdir}/etc"
install -Dm755 storage-device -t "${wrkdir}/lib/mdev" install -Dm755 storage-device -t "${wrkdir}/lib/mdev"
} }
# install mdevd
install_mdevd() { install_mdevd() {
msg info "installing mdevd" msg info "installing mdevd"
install_binary mdevd mdevd-coldplug install_binary mdevd mdevd-coldplug
@ -112,7 +107,6 @@ install_mdevd() {
install -Dm755 storage-device -t "${wrkdir}/lib/mdev" install -Dm755 storage-device -t "${wrkdir}/lib/mdev"
} }
# install udev
install_udev() { install_udev() {
msg info "installing udev" msg info "installing udev"
install_binary udevd udevadm dmsetup install_binary udevd udevadm dmsetup
@ -120,39 +114,40 @@ install_udev() {
find /usr/lib/udev -type f | grep -v "rc_keymaps\|hwdb.d" | cpio -pd "$wrkdir" > /dev/null 2>&1 find /usr/lib/udev -type f | grep -v "rc_keymaps\|hwdb.d" | cpio -pd "$wrkdir" > /dev/null 2>&1
} }
# handle lvm
install_lvm() { install_lvm() {
msg info "installing LVM" msg info "installing LVM"
install_binary lvm install_binary lvm
# if hostonly mode enabled install only needed drivers lvm_drivers="dm-thin-pool dm-multipath dm-snapshot dm-cache dm-log dm-mirror"
[ "$hostonly" = 1 ] && install_driver dm-thin-pool dm-multipath dm-snapshot dm-cache dm-log dm-mirror [ "$hostonly" = 1 ] && install_driver "$lvm_drivers"
# install lvm config
if [ "$lvm_conf" = 1 ]; then if [ "$lvm_conf" = 1 ]; then
install -Dm644 /etc/lvm/*.conf -t "${wrkdir}/etc/lvm" || msg panic "failed to install LVM config" install -Dm644 /etc/lvm/*.conf -t "${wrkdir}/etc/lvm" || msg panic "failed to install LVM config"
else else
mkdir "${wrkdir}/etc/lvm" mkdir "${wrkdir}/etc/lvm"
cat << EOF > "${wrkdir}/etc/lvm/lvm.conf" cat << EOF > "${wrkdir}/etc/lvm/lvm.conf"
devices { devices {
# block discard support
issue_discards = ${lvm_discard:-0} issue_discards = ${lvm_discard:-0}
} }
global { global {
# disable lvmetad
use_lvmetad = 0 use_lvmetad = 0
} }
EOF EOF
fi fi
} }
# handle luks
install_luks() { install_luks() {
msg info "installing LUKS" msg info "installing LUKS"
install_binary cryptsetup install_binary cryptsetup
# if hostonly mode enabled install only needed drivers luks_drivers="aes dm-crypt sha256 sha512 wp512 ecb lrw xts twofish serpent"
[ "$hostonly" = 1 ] && install_driver aes dm-crypt sha256 sha512 wp512 ecb lrw xts twofish serpent [ "$hostonly" = 1 ] && install_driver "$luks_drivers"
# avoid locking directory missing warning message # avoid "locking directory missing" warning message
mkdir "${wrkdir}/run/cryptsetup" mkdir "${wrkdir}/run/cryptsetup"
# TODO get rid of this workaround # TODO get rid of this workaround
@ -175,7 +170,6 @@ install_luks() {
} }
} }
# install drivers and deps
install_driver() { install_driver() {
# check monolithic kernel(builtin drivers) # check monolithic kernel(builtin drivers)
[ -d "${moddir}/${kernel}" ] || return 0 [ -d "${moddir}/${kernel}" ] || return 0
@ -184,20 +178,20 @@ install_driver() {
# strip path and extension # strip path and extension
driver="${driver##*/}" driver="${driver##*/}"
driver="${driver%%.*}" driver="${driver%%.*}"
# TODO busybox modprobe doesn't support -S option # TODO busybox modprobe doesn't support -S option
for driver_dep in $(modprobe -S "$kernel" -D "$driver" 2> /dev/null | grep -v builtin | cut -d " " -f 2); do modprobe -S "$kernel" -D "$driver" 2> /dev/null | grep -v builtin | cut -d " " -f 2 | while read -r driver_dep; do
install -Dm644 "$driver_dep" "${wrkdir}${driver_dep}" install -Dm644 "$driver_dep" "${wrkdir}${driver_dep}"
done done
done done
} }
# install hostonly drivers
install_hostonly_drivers() { install_hostonly_drivers() {
msg info "installing hostonly drivers" msg info "installing hostonly drivers"
[ -n "$root_type" ] || msg panic "hostonly mode required root_type option to be configured" [ -n "$root_type" ] || msg panic "hostonly mode required root_type option to be configured"
# perform autodetection of drivers via /sys # perform autodetection of drivers via /sys
install_driver $(find /sys -name modalias -exec sort -u "{}" "+") install_driver "$(find /sys -name modalias -exec sort -u "{}" "+")"
# TODO autodetect root fs driver # TODO autodetect root fs driver
# TODO separate root type option # TODO separate root type option
@ -208,13 +202,12 @@ install_hostonly_drivers() {
[ -n "$drivers" ] && install_driver "$drivers" [ -n "$drivers" ] && install_driver "$drivers"
} }
# find and install all drivers
install_all_drivers() { install_all_drivers() {
msg info "installing all drivers" msg info "installing all drivers"
modker="${moddir}/${kernel}/kernel" modker="${moddir}/${kernel}/kernel"
install_driver \ install_driver \
$(find \ "$(find \
"${modker}/arch" \ "${modker}/arch" \
"${modker}/crypto" \ "${modker}/crypto" \
"${modker}/fs" \ "${modker}/fs" \
@ -226,23 +219,18 @@ install_all_drivers() {
"${modker}/drivers/usb/storage" \ "${modker}/drivers/usb/storage" \
"${modker}/drivers/usb/host" \ "${modker}/drivers/usb/host" \
"${modker}/drivers/virtio" \ "${modker}/drivers/virtio" \
-type f 2> /dev/null) -type f 2> /dev/null)"
} }
# generate "modules" files
generate_depmod() { generate_depmod() {
msg info "running depmod" msg info "running depmod"
modker="${moddir}/${kernel}" modker="${moddir}/${kernel}"
# install list of drivers
cp "${modker}/modules.builtin" "${modker}/modules.order" "${wrkdir}/${modker}" cp "${modker}/modules.builtin" "${modker}/modules.order" "${wrkdir}/${modker}"
# generate dependencies list of drivers
depmod -b "$wrkdir" "$kernel" depmod -b "$wrkdir" "$kernel"
} }
# TODO make strip optional # TODO make strip optional
# handle binaries
install_binary() { install_binary() {
printf "%s\n" "$@" | while read -r binary; do printf "%s\n" "$@" | while read -r binary; do
msg info "installing binary $binary" msg info "installing binary $binary"
@ -256,14 +244,13 @@ install_binary() {
ldd "$(command -v $binary)" > /dev/null 2>&1 || continue ldd "$(command -v $binary)" > /dev/null 2>&1 || continue
# install libraries # install libraries
install_library $binary install_library "$binary"
done done
} }
# TODO make strip optional # TODO make strip optional
# handle libraries
install_library() { install_library() {
for library in $(ldd "$(command -v $1)" | sed -nre 's,.* (/.*lib.*/.*.so.*) .*,\1,p' -e 's,.*(/lib.*/ld.*.so.*) .*,\1,p'); do ldd "$(command -v $1)" | sed -nre 's,.* (/.*lib.*/.*.so.*) .*,\1,p' -e 's,.*(/lib.*/ld.*.so.*) .*,\1,p' | while read -r library; do
# check symlink # check symlink
if [ -h "$library" ]; then if [ -h "$library" ]; then
# check lib already existence # check lib already existence
@ -286,7 +273,6 @@ install_library() {
done done
} }
# install important files used by init
install_files() { install_files() {
msg info "installing files" msg info "installing files"
# FIXME eof broken # FIXME eof broken
@ -332,18 +318,16 @@ EOF
install -m755 ./init -t "$wrkdir" install -m755 ./init -t "$wrkdir"
} }
# TODO add more compession tools
# create and compress cpio archive # create and compress cpio archive
create_initramfs() { create_initramfs() {
msg info "creating initramfs image" msg info "creating initramfs image"
{ {
( (
cd "$wrkdir" cd "$wrkdir"
find . \ find . | cpio -oH newc | ${compress:-gzip -9}
| cpio -oH newc \
| ${compress:-gzip -9} ) | tee "${scriptdir}/${initramfs:=initramfs-${kernel}}"
) \
| tee "${scriptdir}/${initramfs:-initramfs-${kernel}}"
} > /dev/null 2>&1 || msg panic "failed to generate initramfs image" } > /dev/null 2>&1 || msg panic "failed to generate initramfs image"
} }
@ -357,10 +341,8 @@ trap remove_wrkdir EXIT INT
check_currentdir check_currentdir
# source config
. ./config || msg panic "failed to source config" . ./config || msg panic "failed to source config"
# handle debug mode
[ "$debug" = 1 ] && { [ "$debug" = 1 ] && {
# debug shell commands # debug shell commands
set -x set -x
@ -368,7 +350,6 @@ check_currentdir
trap : EXIT INT trap : EXIT INT
} }
# variables
kernel="${kernel:-$(uname -r)}" kernel="${kernel:-$(uname -r)}"
moddir="/lib/modules" moddir="/lib/modules"
@ -386,7 +367,6 @@ fi
generate_depmod generate_depmod
# handle device manager
case "$devmgr" in case "$devmgr" in
mdev) install_mdev ;; mdev) install_mdev ;;
mdevd) install_mdevd ;; mdevd) install_mdevd ;;
@ -400,4 +380,4 @@ esac
install_files install_files
create_initramfs create_initramfs
msg info "done! check out ${initramfs:-initramfs-${kernel}}" msg info "done! check out $initramfs"

14
init
View File

@ -11,7 +11,6 @@ panic() {
# TODO parse /proc/cmdline # TODO parse /proc/cmdline
#} #}
# mount pseudofs's
mnt_pseudofs() { mnt_pseudofs() {
mount -t proc none /proc mount -t proc none /proc
mount -t sysfs none /sys mount -t sysfs none /sys
@ -19,7 +18,6 @@ mnt_pseudofs() {
mount -t tmpfs none /tmp mount -t tmpfs none /tmp
} }
# setup mdev
setup_mdev() { setup_mdev() {
# setup hotplugger # setup hotplugger
if [ -e /proc/sys/kernel/hotplug ]; then if [ -e /proc/sys/kernel/hotplug ]; then
@ -41,10 +39,9 @@ setup_mdev() {
done done
# load drivers # load drivers
find /sys -name "modalias" -type f -exec sort -u "{}" "+" | xargs modprobe -qba find /sys -name modalias -type f -exec sort -u "{}" "+" | xargs modprobe -qba
} }
# setup mdevd
setup_mdevd() { setup_mdevd() {
# setup daemon # setup daemon
mdevd & mdevd &
@ -52,7 +49,6 @@ setup_mdevd() {
mdevd-coldplug mdevd-coldplug
} }
# setup udev
setup_udev() { setup_udev() {
udevd --daemon udevd --daemon
udevadm trigger --action=add --type=subsystems udevadm trigger --action=add --type=subsystems
@ -60,7 +56,6 @@ setup_udev() {
udevadm settle udevadm settle
} }
# shell findfs
findfs_sh() { findfs_sh() {
case "${1%%=*}" in case "${1%%=*}" in
LABEL) LABEL)
@ -86,23 +81,19 @@ findfs_sh() {
printf "%s\n" "$device" printf "%s\n" "$device"
} }
# unlock LUKS container
unlock_luks() { unlock_luks() {
# TODO improve mapper name ( crypttab or config option ) # TODO improve mapper name ( crypttab or config option )
cryptsetup $luks_args luksOpen $(findfs_sh "$luks_root") luks_root || panic "failed to unlock luks container" cryptsetup $luks_args luksOpen $(findfs_sh "$luks_root") luks_root || panic "failed to unlock luks container"
} }
# trigger LVM
trigger_lvm() { trigger_lvm() {
lvm vgchange --quiet --sysinit -a y > /dev/null lvm vgchange --quiet --sysinit -a y > /dev/null
} }
# mount rootfs to /mnt/root
mnt_rootfs() { mnt_rootfs() {
mount ${root_type:+-t $root_type} $root_args $(findfs_sh "$root") /mnt/root || panic "failed to mount rootfs" mount ${root_type:+-t $root_type} $root_args $(findfs_sh "$root") /mnt/root || panic "failed to mount rootfs"
} }
# kill and unmount
cleanup() { cleanup() {
case "$devmgr" in case "$devmgr" in
mdev) { printf "" > /proc/sys/kernel/hotplug || killall uevent; } > /dev/null 2>&1 ;; mdev) { printf "" > /proc/sys/kernel/hotplug || killall uevent; } > /dev/null 2>&1 ;;
@ -118,15 +109,12 @@ cleanup() {
umount /dev /sys /proc /tmp umount /dev /sys /proc /tmp
} }
# exec /mnt/root/sbin/init
boot_system() { boot_system() {
exec switch_root /mnt/root /sbin/init || panic "failed to boot system" exec switch_root /mnt/root /sbin/init || panic "failed to boot system"
} }
# install busybox
/sbin/busybox --install -s /sbin/busybox --install -s
# source config
. /config || panic "failed to source config" . /config || panic "failed to source config"
# TODO re-do # TODO re-do