summaryrefslogtreecommitdiffstats
path: root/modules.d/dnbd3-rootfs/module-setup.sh
diff options
context:
space:
mode:
Diffstat (limited to 'modules.d/dnbd3-rootfs/module-setup.sh')
-rwxr-xr-xmodules.d/dnbd3-rootfs/module-setup.sh231
1 files changed, 231 insertions, 0 deletions
diff --git a/modules.d/dnbd3-rootfs/module-setup.sh b/modules.d/dnbd3-rootfs/module-setup.sh
new file mode 100755
index 00000000..77543a54
--- /dev/null
+++ b/modules.d/dnbd3-rootfs/module-setup.sh
@@ -0,0 +1,231 @@
+#!/usr/bin/env bash
+# -*- coding: utf-8 -*-
+
+
+_parse_dracut_args() {
+ local __doc__='
+ Set log level via dracut logging options and returns current debug state.
+
+ >>> echo "$_debug"
+ 1
+ >>> _parse_dracut_args; echo $?
+ 1
+
+ >>> _parse_dracut_args --stdlog 3; echo $?
+
+ >>> _parse_dracut_args --stdlog 4; echo $?
+ >>> logging.get_commands_level
+ >>> logging.get_level
+ 0
+ debug
+ debug
+
+ >>> logging.get_level
+ critical
+ >>> _parse_dracut_args --stdlog 4 --verbose
+ >>> logging.get_level
+ debug
+
+ >>> _parse_dracut_args --stdlog 4 --unknown-dracut-option; echo $?
+ 0
+ '
+ local verbose=false
+ local debug=false
+ while true; do
+ case "$1" in
+ --stdlog)
+ shift
+ local level="$1"
+ shift
+ [[ "$level" -ge 4 ]] && debug=true
+ ;;
+ --verbose)
+ shift
+ verbose=true
+ ;;
+ '')
+ break
+ ;;
+ *)
+ shift
+ ;;
+ esac
+ local level
+ $verbose && level=info
+ $debug && level=debug
+ #logging.set_level "$level"
+ #logging.set_commands_level debug
+ done
+ $debug
+ return $?
+}
+# WTF does this actually do aside from taking space!
+_debug=0
+_parse_dracut_args ${dracut_args[*]} || _debug=$?
+# endregion
+
+clean() {
+# Sourcing some helper functions
+ . "$(dirname "${BASH_SOURCE[0]}")/helper/build.inc"
+ clean_components
+}
+# region dracut plugin api
+check() {
+# Sourcing some helper functions
+ . "$(dirname "${BASH_SOURCE[0]}")/helper/build.inc"
+ if ! build_initialize_components; then
+ echo "Failed to initialize components."
+ return 1
+ fi
+ # NOTE: xmount must be compiled before qemu_xmount
+ local xmount_is_built=true
+ if [[ ! -f "$moddir/binaries/xmount/trunk/build/src/xmount" ]] ||
+ [[ ! -f "$moddir/binaries/qemu-xmount/libxmount_input_qemu.so" ]]; then
+ xmount_is_built=false
+ fi
+ # non-critical if failed
+ $xmount_is_built || warn "Compiling 'xmount'/'libxmount_input_qemu' failed."
+
+ if [[ ! -f "$moddir/binaries/dnbd3/build/dnbd3.ko" ]] || \
+ [[ ! -f "$moddir/binaries/dnbd3/build/dnbd3-client" ]]; then
+ CMAKE_FLAGS="-DKERNEL_VERSION=${kernel}" \
+ build_compile_dnbd3 "$moddir/binaries/dnbd3/"
+ [[ $? != 0 ]] && return 1
+ fi
+ if [[ ! -f "$moddir/binaries/systemd-preserve-process-marker/systemd-preserve-process-marker" ]]; then
+ build_compile_systemd_preserve_process_marker \
+ "$moddir/binaries/systemd-preserve-process-marker/"
+ [[ $? != 0 ]] && return 1
+ fi
+ # TODO do we still need this ?
+ # NOTE: This are workarounds for:
+ # - distributions where "systemd-udevd" doesn't lives in "/usr/lib" but in
+ # "/lib".
+ local alternate_systemd_udevd_location='/lib/systemd/systemd-udevd'
+ if [[ ! -f "${systemdutildir}/systemd-udevd" ]] && \
+ [[ -f "$alternate_systemd_udevd_location" ]]; then
+ mkdir --parents "${initdir}${systemdutildir}"
+ ln --symbolic --force "$alternate_systemd_udevd_location" \
+ "${initdir}${systemdutildir}/systemd-udevd"
+ fi
+ # WTF?
+ # - "/usr/bin/sh" isn't available but "/bin/sh".
+ if [[ ! -f /usr/bin/sh ]] && [[ -f /bin/sh ]]; then
+ ln --symbolic --force /bin/sh /usr/bin/sh
+ fi
+ return 255
+}
+depends() {
+ echo base bash kernel-modules shutdown slx-dmsetup slx-network
+}
+installkernel() {
+ local block_kmod_dir="/lib/modules/${kernel}/kernel/drivers/block"
+
+ # dnbd3
+ mkdir -p "${initdir}/${block_kmod_dir}"
+ inst "${moddir}/binaries/dnbd3/build/dnbd3.ko" "${block_kmod_dir}/dnbd3.ko"
+
+ # kqcow2 kernel
+ local kqcow_loop_kmod_dir="${moddir}/binaries/kernel-qcow2-linux/drivers/block/loop"
+ if [ -e "${kqcow_loop_kmod_dir}/loop.ko" ] && \
+ [ -e "${kqcow_loop_kmod_dir}/loop_file_fmt_raw.ko" ] && \
+ [ -e "${kqcow_loop_kmod_dir}/loop_file_fmt_qcow.ko" ]; then
+ mkdir -p "${initdir}/${block_kmod_dir}/loop"
+ for kmod in "${kqcow_loop_kmod_dir}/"*.ko ; do
+ inst "$kmod" "${block_kmod_dir}/loop/$(basename $kmod)"
+ done
+ fi
+}
+install() {
+ # region binaries
+ inst "$moddir/binaries/dnbd3/build/dnbd3-client" /usr/local/bin/dnbd3-client
+ inst "$moddir/binaries/systemd-preserve-process-marker/systemd-preserve-process-marker" \
+ /usr/local/bin/systemd-preserve-process-marker
+ # xmount
+ local \
+ xmount_installation="$moddir/binaries/xmount/trunk/build/release_build"
+ if [[ -f "${xmount_installation}/usr/bin/xmount" ]]; then
+ inst "${xmount_installation}/usr/bin/xmount" /usr/bin/xmount
+ for file in ${xmount_installation}/usr/lib/xmount/*; do
+ inst "$file" /usr/lib/xmount/"$(basename "$file")"
+ done
+ inst "$moddir/binaries/qemu-xmount/libxmount_input_qemu.so" \
+ /usr/lib/xmount/libxmount_input_qemu.so
+ # HACK fix missing libraries for some xmount input libs
+ # TODO copy the dependencies using dracut functions...
+ inst_libdir_file 'libafflib.so*'
+ inst_libdir_file 'libewf.so*'
+ fi
+ # kqcow2 losetup
+ local losetup_qcow2_dir="$moddir/binaries/kernel-qcow2-util-linux"
+ if [[ -f "${losetup_qcow2_dir}/.libs/losetup" ]]; then
+ inst "${losetup_qcow2_dir}/.libs/losetup" /usr/local/bin/losetup
+ mkdir -p "${initdir}/usr/local/lib"
+ cp -a "${losetup_qcow2_dir}/.libs/"*.so* "${initdir}/usr/local/lib"
+ fi
+ # endregion
+ # region hooks
+ inst_hook cmdline 00 "$moddir/hooks/enable-sysrq.sh"
+ # NOTE: Can be used to support old style ip append syntax and have an
+ # exclusive interface name - required when using dracut's regular
+ # 'network' module
+ dracut_module_included "network" && inst_hook cmdline 10 \
+ "$moddir/hooks/prepare-kernel-command-line-parameter.sh"
+ inst_hook cmdline 90 "$moddir/hooks/set-dracut-environment-variables.sh"
+ inst_hook pre-udev 00 "$moddir/hooks/load-custom-kernel-modules.sh"
+ # Get the openslx config from the servers configured in the kernel command
+ # line (${SLX_SERVER}/${SLX_SERVER_BASE}/config).
+ inst_hook pre-mount 10 "$moddir/hooks/fetch-config.sh"
+ # make the final blockdevice for the root system (dnbd3 -> xmount ->
+ # device-mapper)
+ if dracut_module_included "systemd-initrd"; then
+ inst "$moddir/hooks/prepare-root-partition.sh" \
+ /usr/local/bin/dnbd3root
+ inst_simple "${moddir}/services/dnbd3root.service" \
+ "${systemdsystemunitdir}/dnbd3root.service"
+ mkdir --parents \
+ "${initdir}/${systemdsystemunitdir}/dracut-mount.service.requires"
+ ln_r "${systemdsystemunitdir}/dnbd3root.service" \
+ "${systemdsystemunitdir}/dracut-mount.service.requires/dnbd3root.service"
+ mkdir --parents \
+ "${initdir}/${systemdsystemunitdir}/initrd.target.requires"
+ ln_r "${systemdsystemunitdir}/dnbd3root.service" \
+ "${systemdsystemunitdir}/initrd.target.requires/dnbd3root.service"
+ # Copy systemd services to new root (so they don't get killed after
+ # switch_root)
+ inst_hook pre-pivot 00 \
+ "$moddir/hooks/copy-dnbd3-service-into-newroot.sh"
+ inst_hook pre-pivot 00 \
+ "$moddir/hooks/copy-dracut-systemd-files-into-newroot.sh"
+ inst_hook pre-shutdown 00 "$moddir/hooks/shutdown-umount.sh"
+ else
+ inst_hook pre-mount 10 "$moddir/hooks/prepare-root-partition.sh"
+ fi
+ inst_hook mount 10 "$moddir/hooks/mount-root-device.sh"
+ inst_hook pre-pivot 00 \
+ "$moddir/hooks/copy-openslx-configuration-into-newroot.sh"
+ # endregion
+ # region scripts
+ # endregion
+ # region configuration files
+ # Use terminal readline settings from the template system.
+ inst /etc/inputrc /etc/inputrc
+ # Set some aliases for the initramfs context.
+ if [[ "$_debug" == 0 ]]; then
+ inst "$moddir/configuration/bash" '/etc/bash.bashrc'
+ inst "$moddir/configuration/bash" '/etc/profile.d/aliases'
+ fi
+ # endregion
+ inst_multiple \
+ awk \
+ basename bash blockdev \
+ cat cut curl \
+ dd diff dirname dmsetup \
+ find \
+ grep \
+ insmod \
+ lsblk \
+ mkfifo mktemp mount mountpoint \
+ sed sleep sort \
+ tee touch tr
+}