public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
* [gentoo-commits] proj/genkernel:master commit in: defaults/, doc/
@ 2017-01-04  0:11 Robin H. Johnson
  0 siblings, 0 replies; 11+ messages in thread
From: Robin H. Johnson @ 2017-01-04  0:11 UTC (permalink / raw
  To: gentoo-commits

commit:     6cdbff3a7571e3e814fded0774e9b48cdcbffe38
Author:     Robin H. Johnson <robbat2 <AT> gentoo <DOT> org>
AuthorDate: Tue Jan  3 05:36:08 2017 +0000
Commit:     Robin H. Johnson <robbat2 <AT> gentoo <DOT> org>
CommitDate: Tue Jan  3 05:36:08 2017 +0000
URL:        https://gitweb.gentoo.org/proj/genkernel.git/commit/?id=6cdbff3a

Add quiet_genkernel to make quieter boot.

The kernel boot option 'quiet' makes both the kernel & genkernel boot
quietly.

The new kernel boot option 'quiet_genkernel' just makes genkernel boot
quietly, while not affecting the kernel verbosity.

Fixes: https://bugs.gentoo.org/show_bug.cgi?id=474472
Signed-off-by: Robin H. Johnson <robbat2 <AT> gentoo.org>

 defaults/linuxrc    | 2 +-
 doc/genkernel.8.txt | 6 +++++-
 2 files changed, 6 insertions(+), 2 deletions(-)

diff --git a/defaults/linuxrc b/defaults/linuxrc
index 965d28f..d09b96f 100644
--- a/defaults/linuxrc
+++ b/defaults/linuxrc
@@ -119,7 +119,7 @@ do
 		dobtrfs*)
 			USE_BTRFS=1
 		;;
-		quiet)
+		quiet|quiet_genkernel)
 			QUIET=1
 		;;
 		# Debug Options

diff --git a/doc/genkernel.8.txt b/doc/genkernel.8.txt
index ca8eff0..dafa25b 100644
--- a/doc/genkernel.8.txt
+++ b/doc/genkernel.8.txt
@@ -551,10 +551,14 @@ recognized by the kernel itself.
     switch_root into "<CHROOT>/<SUBDIR>" instead of "<CHROOT>/".
     <CHROOT> is "/newroot" (or "/union") usually.
 
-*quiet*::
+*quiet_genkernel*::
     Do not print anything but error and warning messages during
     the execution of the initramfs init scripts.
 
+*quiet*::
+    Implies *quiet_genkernel*, but also recognized by the kernel to
+    suppress kernel messages.
+
 *debug*::
     Drop into a debug shell early in the process.
 


^ permalink raw reply related	[flat|nested] 11+ messages in thread

* [gentoo-commits] proj/genkernel:master commit in: defaults/, doc/
@ 2019-08-07 15:46 Thomas Deutschmann
  0 siblings, 0 replies; 11+ messages in thread
From: Thomas Deutschmann @ 2019-08-07 15:46 UTC (permalink / raw
  To: gentoo-commits

commit:     1d79338fa7391f8bc41bb74411c9a955e24d81cd
Author:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
AuthorDate: Tue Aug  6 18:04:20 2019 +0000
Commit:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
CommitDate: Wed Aug  7 15:03:44 2019 +0000
URL:        https://gitweb.gentoo.org/proj/genkernel.git/commit/?id=1d79338f

initrd.scripts: prompt_user(): Read answer from $GK_PROMPT_FILE on timeout

This commit will bring back read timeout which was removed in
Commit a280829. Read timeout is still disabled by default but
can now be controlled via gk.prompt.timeout kernel command-line
argument.

When gk.prompt.timeout is != 0, the current prompt will be written
to $GK_PROMPT_FILE. This will allow remote user to notice that
there's a prompt.

In addition, on timeout, $GK_PROMPT_FILE will be read allowing
remote user to answer prompt and hopefully to fix the problem
and resume booting.

To make this work, gk.prompt.timeout will be set to 30 seconds
by default when SSH usage is enabled.

Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org>

 defaults/initrd.defaults |  2 ++
 defaults/initrd.scripts  | 36 ++++++++++++++++++++++++++++++------
 defaults/linuxrc         | 10 ++++++++++
 doc/genkernel.8.txt      |  9 +++++++++
 4 files changed, 51 insertions(+), 6 deletions(-)

diff --git a/defaults/initrd.defaults b/defaults/initrd.defaults
index 553600d..06057d7 100644
--- a/defaults/initrd.defaults
+++ b/defaults/initrd.defaults
@@ -85,6 +85,8 @@ GK_NET_TIMEOUT_DAD=10
 GK_NET_TIMEOUT_DECONFIGURATION=10
 GK_NET_TIMEOUT_DHCP=10
 GK_NET_TIMEOUT_INTERFACE=10
+GK_PROMPT_FILE='/tmp/current_prompt'
+GK_PROMPT_TIMEOUT=0
 GK_SHELL_LOCKFILE='/tmp/rescueshell.lock'
 GK_SSHD_LOCKFILE='/tmp/remote-rescueshell.lock'
 GK_SSHD_PIDFILE='/var/run/dropbear.pid'

diff --git a/defaults/initrd.scripts b/defaults/initrd.scripts
index 68adfb9..88046b4 100644
--- a/defaults/initrd.scripts
+++ b/defaults/initrd.scripts
@@ -1108,12 +1108,30 @@ prompt_user() {
 	bad_msg '- type "shell" for a shell'
 	bad_msg '- type "q" to skip ...'
 	printf "%s" "${2}(${oldvalue}) :: "
-	read ${1}
-	#if [ $? -gt 0 ]
-	#then
-	#	# prompt timed out
-	#	printf "\n"
-	#fi
+
+	if [ "${GK_PROMPT_TIMEOUT}" = '0' ]
+	then
+		read ${1}
+	else
+		local read_timeout_timestamp
+		let read_timeout_timestamp=$(date +%s)+${GK_PROMPT_TIMEOUT}
+
+		echo "# Could not find the ${2} in ${oldvalue}${explnt}" > "${GK_PROMPT_FILE}"
+		echo "# Please specify another value (file will be processed at $(date -d @${read_timeout_timestamp}):" >> "${GK_PROMPT_FILE}"
+		echo "${1}=${oldvalue}" >> "${GK_PROMPT_FILE}"
+		read -t ${GK_PROMPT_TIMEOUT} ${1}
+		if [ $? -gt 0 ]
+		then
+			# prompt timed out
+			printf "\n"
+
+			if [ -f "${GK_PROMPT_FILE}" ]
+			then
+				warn_msg "Timeout! Trying to read answer from '${GK_PROMPT_FILE}' ..."
+				. "${GK_PROMPT_FILE}" && run rm "${GK_PROMPT_FILE}"
+			fi
+		fi
+	fi
 
 	case $(eval echo '$'${1}) in
 		'q')
@@ -2145,6 +2163,12 @@ start_sshd() {
 		return
 	fi
 
+	if [ "${GK_PROMPT_TIMEOUT}" = '0' ]
+	then
+		warn_msg "Changing gk.prompt.timeout=0 to 30 ..."
+		GK_PROMPT_TIMEOUT=30
+	fi
+
 	if [ ! -x "/usr/sbin/dropbear" ]
 	then
 		bad_msg "/usr/sbin/dropbear not found! Did you call genkernel with --ssh parameter?"

diff --git a/defaults/linuxrc b/defaults/linuxrc
index b2ac54e..a57de1c 100644
--- a/defaults/linuxrc
+++ b/defaults/linuxrc
@@ -336,6 +336,16 @@ do
 			fi
 			unset tmp_wait
 		;;
+		gk.prompt.timeout=*)
+			tmp_timeout=${x#*=}
+			if is_int "${tmp_timeout}"
+			then
+				GK_PROMPT_TIMEOUT=${tmp_timeout}
+			else
+				warn_msg "'${x}' does not look like a valid time (second) value -- ignored!"
+			fi
+			unset tmp_timeout
+		;;
 		real_rootflags=*)
 			REAL_ROOTFLAGS=${x#*=}
 		;;

diff --git a/doc/genkernel.8.txt b/doc/genkernel.8.txt
index 3ab28ce..3ebd320 100644
--- a/doc/genkernel.8.txt
+++ b/doc/genkernel.8.txt
@@ -687,6 +687,15 @@ recognized by the kernel itself.
 *gk.net.timeout.interface*=<...>::
     By default we will wait up to 10 seconds for interface to show up.
 
+*gk.prompt.timeout*=<...>::
+By default a prompt within genkernel initramfs like shown when set
+*root* could not be found will never timeout. Use this option to set
+a timeout.
+
+NOTE: When *dosshd* is used, *gk.prompt.timeout* will be set to 30 seconds
+when not set. This will allow remote user to provide answer through
+*GK_PROMPT_FILE* which is set to '/tmp/current_prompt' by default.
+
 *dosshd*::
     Will bring up an interface and start a SSH daemon within initramfs
     allowing to remotely unlock encrypted devices or just for debugging


^ permalink raw reply related	[flat|nested] 11+ messages in thread

* [gentoo-commits] proj/genkernel:master commit in: defaults/, doc/
@ 2019-08-07 15:46 Thomas Deutschmann
  0 siblings, 0 replies; 11+ messages in thread
From: Thomas Deutschmann @ 2019-08-07 15:46 UTC (permalink / raw
  To: gentoo-commits

commit:     e7735c6b2e2cbfb44ce550fa8e7f4359ab5f073c
Author:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
AuthorDate: Tue Aug  6 17:45:19 2019 +0000
Commit:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
CommitDate: Wed Aug  7 15:03:40 2019 +0000
URL:        https://gitweb.gentoo.org/proj/genkernel.git/commit/?id=e7735c6b

linuxrc: Log initramfs output/commands

By default, any {bad,good,warn}_msg output and external command calls
will now be logged to /tmp/init.log in initramfs. This can be turned
off via gk.log.disabled={1,yes} kernel command-line argument.

This is especially helpful when working with remote servers when you
can access initramfs system through SSH.

In addition, initramfs' log file can be preserved, i.e. copied to
real system just before switch_root call. This can be controlled
via gk.log.keep kernel command-line argument: When just enabled,
initramfs will copy log to $NEWROOT/genkernel-boot.log. Keep in my
that the file path must be accessible for initramfs and by default,
initramfs will only mount / as $NEWROOT and no additional mountpoints.

Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org>

 defaults/initrd.defaults |   4 +
 defaults/initrd.scripts  | 535 ++++++++++++++++++++++++++++++++---------------
 defaults/linuxrc         | 142 ++++++++-----
 defaults/login-remote.sh |  27 ++-
 defaults/unlock-luks.sh  |  18 +-
 doc/genkernel.8.txt      |  16 ++
 6 files changed, 522 insertions(+), 220 deletions(-)

diff --git a/defaults/initrd.defaults b/defaults/initrd.defaults
index fdf948e..553600d 100644
--- a/defaults/initrd.defaults
+++ b/defaults/initrd.defaults
@@ -71,6 +71,10 @@ VERIFY=0
 
 IP='dhcp'
 GK_DEBUGMODE_STATEFILE="/tmp/debug.enabled"
+GK_INIT_LOG='/tmp/init.log'
+GK_INIT_LOG_COPYTO=
+GK_INIT_LOG_DISABLED='/tmp/no-init.log'
+GK_INIT_LOG_PREFIX=
 GK_NET_DHCP_PIDFILE='/var/run/udhcpc.pid'
 GK_NET_DHCP_RETRIES=3
 GK_NET_GW=

diff --git a/defaults/initrd.scripts b/defaults/initrd.scripts
index 6f7530f..f95f434 100644
--- a/defaults/initrd.scripts
+++ b/defaults/initrd.scripts
@@ -34,6 +34,17 @@ modules_scan() {
 	[ -n "${MODS}" ] && [ -z "${QUIET}" ] && \
 		printf "%b" "${BOLD}   ::${NORMAL} Loading from ${1}: "
 
+	if [ -z "${MODULES_SCAN_WARNING_SHOWN}" ]
+	then
+		local note_msg="NOTE: Due to how genkernel auto-detects your"
+		note_msg="${note_msg} hardware you will now see a lot of failed modprobe" \
+		note_msg="${note_msg} attempts which you can ignore:"
+
+		log_msg "${note_msg}"
+
+		MODULES_SCAN_WARNING_SHOWN=yes
+	fi
+
 	for x in ${MODS}
 	do
 		MLOAD=$(echo ${MLIST} | sed -e "s/.*${x}.*/${x}/")
@@ -55,7 +66,7 @@ modules_scan() {
 				printf "%b" "Scanning for ${x} ..."
 			fi
 
-			modprobe ${x} >/dev/null 2>&1
+			run modprobe ${x} >/dev/null 2>&1
 			loaded=${?}
 
 			is_debug && [ "${loaded}" = "0" ] && \
@@ -79,7 +90,6 @@ uppercase() {
 	echo $1 | tr 'a-z' 'A-Z'
 }
 
-
 findmediamount() {
 	# $1 = mount dir name / media name
 	# $2 = recognition file
@@ -130,14 +140,14 @@ findmediamount() {
 				fi
 				good_msg "Attempting to mount media: ${x}" ${CRYPT_SILENT}
 
-				mount -t ${CDROOT_TYPE} ${x} ${mntcddir} >/dev/null 2>&1
+				run mount -t ${CDROOT_TYPE} ${x} ${mntcddir} >/dev/null 2>&1
 				if [ $? -eq 0 ]
 				then
 					if [ -n "${ISOBOOT}" ]
 					then
 						if [ -f "${mntcddir}/${ISOBOOT}" ]
 						then
-							mount -o loop "${mntcddir}/${ISOBOOT}" "${mntdir}"
+							run mount -o loop "${mntcddir}/${ISOBOOT}" "${mntdir}"
 							if [ $? -eq 0 ]
 							then
 								good_msg "iso mounted on ${mntdir}"
@@ -153,7 +163,7 @@ findmediamount() {
 						good_msg "Media found on ${x}" ${CRYPT_SILENT}
 						break
 					else
-						umount ${mntcddir}
+						run umount ${mntcddir}
 					fi
 				fi
 			fi
@@ -203,37 +213,37 @@ bootstrapFS() {
 			aufs_branch=${aufs_memory}/aufs-rw-branch/${aufs_dev_uid}
 		fi
 
-		mkdir -p ${aufs_memory} ${aufs_union} ${aufs_dev_mnt}
+		run mkdir -p ${aufs_memory} ${aufs_union} ${aufs_dev_mnt}
 	else
 		# Legacy SquashFS implementation
 		good_msg "Making tmpfs for ${NEW_ROOT}"
-		mount -n -t tmpfs tmpfs ${NEW_ROOT}
+		run mount -n -t tmpfs tmpfs ${NEW_ROOT}
 	fi
 
 	# Setup the filesystem nodes and directories
 	for i in ${CDROOT_PATH} /mnt/livecd /mnt/key /mnt/gentoo /tmp /tmp/.initrd /dev /proc /run /sys; do
-		mkdir -p "${NEW_ROOT}${i}"
-		chmod 755 "${NEW_ROOT}${i}"
+		run mkdir -p "${NEW_ROOT}${i}"
+		run chmod 755 "${NEW_ROOT}${i}"
 	done
 
-	[ ! -d "${CDROOT_PATH}" ] && mkdir -p "${CDROOT_PATH}"
-	[ ! -e "${NEW_ROOT}/dev/null" ] && mknod -m 666 "${NEW_ROOT}"/dev/null c 1 3
-	[ ! -e "${NEW_ROOT}/dev/zero" ] && mknod -m 666 "${NEW_ROOT}"/dev/zero c 1 5
-	[ ! -e "${NEW_ROOT}/dev/console" ] && mknod -m 600 "${NEW_ROOT}"/dev/console c 5 1
-	[ ! -e "${NEW_ROOT}/dev/ttyS0" ] && mknod -m 660 "${NEW_ROOT}"/dev/ttyS0 c 4 64
+	[ ! -d "${CDROOT_PATH}" ]          && run mkdir -p "${CDROOT_PATH}"
+	[ ! -e "${NEW_ROOT}/dev/null" ]    && run mknod -m 666 "${NEW_ROOT}"/dev/null c 1 3
+	[ ! -e "${NEW_ROOT}/dev/zero" ]    && run mknod -m 666 "${NEW_ROOT}"/dev/zero c 1 5
+	[ ! -e "${NEW_ROOT}/dev/console" ] && run mknod -m 600 "${NEW_ROOT}"/dev/console c 5 1
+	[ ! -e "${NEW_ROOT}/dev/ttyS0" ]   && run mknod -m 660 "${NEW_ROOT}"/dev/ttyS0 c 4 64
 
 	# For SGI LiveCDs
 	if [ "${LOOPTYPE}" = "sgimips" ]
 	then
-		[ ! -e "${NEW_ROOT}/dev/sr0" ] && mknod "${NEW_ROOT}/dev/sr0" b 11 0
-		[ ! -e "${NEW_ROOT}/dev/loop0" ] && mknod "${NEW_ROOT}/dev/loop0" b 7 0
+		[ ! -e "${NEW_ROOT}/dev/sr0" ]   && run mknod "${NEW_ROOT}/dev/sr0" b 11 0
+		[ ! -e "${NEW_ROOT}/dev/loop0" ] && run mknod "${NEW_ROOT}/dev/loop0" b 7 0
 	fi
 
 	# Required for splash to work. Not an issue with the initrd as this
 	# device isn't created there and is not needed.
 	for minor in 0 1
 	do
-		[ ! -e "${NEW_ROOT}/dev/${minor}" ] && mknod -m 600 "${NEW_ROOT}/dev/tty${minor}" c 4 ${minor}
+		[ ! -e "${NEW_ROOT}/dev/${minor}" ] && run mknod -m 600 "${NEW_ROOT}/dev/tty${minor}" c 4 ${minor}
 	done
 }
 
@@ -254,11 +264,11 @@ bootstrapCD() {
 		if [ -f isoroot_checksums ]
 		then
 			good_msg "Verifying checksums, this may take some time ..."
-			if ! busybox sha512sum -c isoroot_checksums
+			if ! run sha512sum -c isoroot_checksums
 			then
 				bad_msg "Some checksums failed, press any key to poweroff ..."
 				read -n1 -s
-				busybox poweroff -f
+				poweroff -f
 			else
 				good_msg "Checksums all valid, continuing boot ..."
 			fi
@@ -294,23 +304,25 @@ cache_cd_contents() {
 			# echo ${z}
 			good_msg "Copying loop file for caching ..."
 			# Verify that the needed directory exists
-			mkdir -p "$(dirname ${NEW_ROOT}/mnt/${LOOP})"
-			cp -a ${CDROOT_PATH}/${LOOP} ${NEW_ROOT}/mnt/${LOOP}
+			run mkdir -p "$(dirname ${NEW_ROOT}/mnt/${LOOP})"
+			run cp -a ${CDROOT_PATH}/${LOOP} ${NEW_ROOT}/mnt/${LOOP}
 			if [ $? -ne 0 ]
 			then
 				warn_msg "Failed to cache the loop file! Lack of RAM?"
-				rm -rf ${NEW_ROOT}/mnt/${LOOP} 2>/dev/null
-				rm -rf ${NEW_ROOT}/mnt/livecd.* 2>/dev/null
-				rm -rf ${NEW_ROOT}/mnt/image.* 2>/dev/null
-				rm -rf ${NEW_ROOT}/mnt/zisofs 2>/dev/null
+				run rm -rf ${NEW_ROOT}/mnt/${LOOP} 2>/dev/null
+				run rm -rf ${NEW_ROOT}/mnt/livecd.* 2>/dev/null
+				run rm -rf ${NEW_ROOT}/mnt/image.* 2>/dev/null
+				run rm -rf ${NEW_ROOT}/mnt/zisofs 2>/dev/null
 			fi
 		fi
 	fi
 }
 
 mount_sysfs() {
-	mount -t sysfs sysfs /sys -o noexec,nosuid,nodev >/dev/null 2>&1
-	[ $? -eq 0 ] || bad_msg "Failed to mount /sys!"
+	if ! run mount -t sysfs sysfs /sys -o noexec,nosuid,nodev >/dev/null 2>&1
+	then
+		bad_msg "Failed to mount /sys!"
+	fi
 }
 
 # Check support for both aufs and overlayfs
@@ -345,8 +357,8 @@ is_union_modules() {
 		else
 			warn_msg "Adding all modules in ${mod_dir}"
 
-			mkdir /mnt/modules
-			mount "${mod_dir}" /mnt/modules
+			run mkdir /mnt/modules
+			run mount "${mod_dir}" /mnt/modules
 			union_insert_modules /mnt/modules
 		fi
 	fi
@@ -361,7 +373,7 @@ is_union_modules() {
 #
 aufs_insert_dir() {
 	# Always mount it over the precedent (add:1:)
-	if mount -n -o "remount,add:1:$2=rr" aufs "$1"
+	if run mount -n -o "remount,add:1:$2=rr" aufs "$1"
 	then
 		good_msg "Addition of $2 to $1 successful"
 	fi
@@ -409,18 +421,18 @@ union_mod() {
 	then
 		if [ ! -d "${aufs_union}"/mnt/"${mod}" ]
 		then
-			mkdir -p "${aufs_union}"/mnt/modules/"${mod}" || return
+			run mkdir -p "${aufs_union}"/mnt/modules/"${mod}" || return
 		fi
 
-		mount -o loop,ro "$2" "${aufs_union}"/mnt/modules/"${mod}"
+		run mount -o loop,ro "$2" "${aufs_union}"/mnt/modules/"${mod}"
 		aufs_insert_dir "${aufs_union}" "${aufs_union}"/mnt/modules/"${mod}"
 	else
 		if [ ! -d "${mod_dir}/.${mod}" ]
 		then
-			mkdir -p "${mod_dir}/.${mod}" || return
+			run mkdir -p "${mod_dir}/.${mod}" || return
 		fi
 
-		mount -o loop,ro "$2" "${mod_dir}/.${mod}"
+		run mount -o loop,ro "$2" "${mod_dir}/.${mod}"
 	fi
 }
 
@@ -450,7 +462,7 @@ conf_rc_no_umounts() {
 
 		if [ -n "${cmd}" ]
 		then
-			sed -i "${cmd%;}" ${conf}
+			run sed -i "${cmd%;}" ${conf}
 			test_success "Unable to edit /etc/conf.d/localmount"
 		fi
 	fi
@@ -486,6 +498,39 @@ is_int() {
 	done
 }
 
+is_log_enabled() {
+	if [ -z "${GK_INIT_LOG}" ]
+	then
+		return 1
+	elif [ -f "${GK_INIT_LOG_DISABLED}" ]
+	then
+		return 1
+	fi
+
+	return 0
+}
+
+is_true() {
+	case "$1" in
+		[Tt][Rr][Uu][Ee])
+			return 0
+		;;
+		[Tt])
+			return 0
+		;;
+		[Yy][Ee][Ss])
+			return 0
+		;;
+		[Yy])
+			return 0
+		;;
+		1)
+			return 0
+		;;
+	esac
+	return 1
+}
+
 # Function to create an ext2 fs on $aufs_dev, $aufs_dev_mnt mountpoint
 create_changefs() {
 	local size
@@ -504,13 +549,13 @@ create_changefs() {
 		then
 			bad_msg "Please give a size of at least 16 Megabytes"
 		else
-			if dd if=/dev/zero "of=${aufs_dev_mnt}${aufs_union_file}" bs=1 seek="${size}"M count=0 >/dev/null 2>&1
+			if run dd if=/dev/zero "of=${aufs_dev_mnt}${aufs_union_file}" bs=1 seek="${size}"M count=0 >/dev/null 2>&1
 			then
 				good_msg "Creation of ${aufs_union_file}, ${size}MB on ${aufs_dev successful}, formatting it ext2"
-				mke2fs -F "${aufs_dev_mnt}${aufs_union_file}" >/dev/null 2>&1
+				run mke2fs -F "${aufs_dev_mnt}${aufs_union_file}" >/dev/null 2>&1
 				break
 			else
-				rm "${aufs_dev_mnt}${aufs_union_file}"
+				run rm "${aufs_dev_mnt}${aufs_union_file}"
 				bad_msg "Unable to create ${aufs_union_file#*/} on ${aufs_dev} of ${size}MB"
 				bad_msg "Ensure your disk is not full or read-only"
 
@@ -518,7 +563,7 @@ create_changefs() {
 				if [ "${doabort}" = 'a' ]
 				then
 					bad_msg "Aborting creation of ${aufs_union_file}!"
-					umount "${aufs_dev}" && rmdir "${aufs_dev_mnt}"
+					run umount "${aufs_dev}" && rmdir "${aufs_dev_mnt}"
 					return 1
 				fi
 			fi
@@ -562,7 +607,7 @@ setup_aufs() {
 		then
 			good_msg "Mounting ${aufs_dev} to ${aufs_memory} for aufs support"
 
-			if ! mount -t auto "${aufs_dev}" "${aufs_dev_mnt}" >/dev/null 2>&1
+			if ! run mount -t auto "${aufs_dev}" "${aufs_dev_mnt}" >/dev/null 2>&1
 			then
 				bad_msg "Mount of ${aufs_dev} failed, falling back to ramdisk based aufs"
 				unset aufs_dev
@@ -572,12 +617,12 @@ setup_aufs() {
 		# Check and attempt to create the AUFS union file
 		if [ ! -e ${aufs_dev_mnt}${aufs_union_file} ] && [ -n "${aufs_dev}" ]
 		then
-			create_changefs && mount -t auto "${aufs_dev_mnt}${aufs_union_file}" "${aufs_memory}"
+			create_changefs && run mount -t auto "${aufs_dev_mnt}${aufs_union_file}" "${aufs_memory}"
 		elif [ -n "${aufs_dev}" ]
 		then
 			while :;
 			do
-				if mount -t auto "${aufs_dev_mnt}${aufs_union_file}" "${aufs_memory}" >/dev/null 2>&1
+				if run mount -t auto "${aufs_dev_mnt}${aufs_union_file}" "${aufs_memory}" >/dev/null 2>&1
 				then
 					if [ "${aufs_union_file}" = "/casper-rw" ]
 					then
@@ -592,18 +637,18 @@ setup_aufs() {
 						bad_msg "/sbin/e2fsck not found! aborting filesystem check"
 						bad_msg "Moving ${aufs_union_file#*/} to ${aufs_union_file#*/}.bad"
 
-						mv "${aufs_dev_mnt}${aufs_union_file}" "${aufs_dev_mnt}${aufs_union_file}.bad"
+						run mv "${aufs_dev_mnt}${aufs_union_file}" "${aufs_dev_mnt}${aufs_union_file}.bad"
 						break
 					fi
 
-					if e2fsck "${aufs_dev_mnt}${aufs_union_file}" >/dev/null 2>&1
+					if run e2fsck "${aufs_dev_mnt}${aufs_union_file}" >/dev/null 2>&1
 					then
 						good_msg "e2fsck ran successfully. Please verify data after bootup"
 					else
 						bad_msg "Your ${aufs_union_file#*/} image might be corrupted"
 						bad_msg "moving ${aufs_union_file#*/} to ${aufs_union_file#*/}.bad"
 
-						mv "${aufs_dev_mnt}${aufs_union_file}" "${aufs_dev_mnt}${aufs_union_file}.bad"
+						run mv "${aufs_dev_mnt}${aufs_union_file}" "${aufs_dev_mnt}${aufs_union_file}.bad"
 						break
 					fi
 				fi
@@ -628,22 +673,22 @@ setup_aufs() {
 			bad_msg "Falling back to ramdisk based aufs"
 			good_msg "Mounting ramdisk to ${aufs_memory} for aufs support"
 
-			mount -t tmpfs tmpfs "${aufs_memory}"
+			run mount -t tmpfs tmpfs "${aufs_memory}"
 		else
 			aufs_xino=${aufs_memory}/xino
 
-			mkdir -p "${aufs_xino}"
-			mount -t tmpfs aufs-xino "${aufs_xino}"
+			run mkdir -p "${aufs_xino}"
+			run mount -t tmpfs aufs-xino "${aufs_xino}"
 		fi
 	else
 		aufs_xino=${aufs_memory}
 
 		good_msg "Mounting ramdisk to ${aufs_memory} for aufs support"
-		mount -t tmpfs tmpfs "${aufs_memory}"
+		run mount -t tmpfs tmpfs "${aufs_memory}"
 	fi
 
-	mkdir -p "${aufs_branch}"
-	if ! mount -t aufs -n -o "nowarn_perm,udba=none,xino=${aufs_xino}/.aufs.xino,br:${aufs_branch}=rw" aufs "${aufs_union}"
+	run mkdir -p "${aufs_branch}"
+	if ! run mount -t aufs -n -o "nowarn_perm,udba=none,xino=${aufs_xino}/.aufs.xino,br:${aufs_branch}=rw" aufs "${aufs_union}"
 	then
 		bad_msg "Can't setup union ${aufs_union} in directory!"
 		aufs=0
@@ -660,11 +705,11 @@ setup_overlayfs() {
 	rundebugshell overlayfs
 	for i in "${overlay}" "${static}"
 	do
-		[ ! -d "${i}" ] && mkdir -p "${i}"
+		[ ! -d "${i}" ] && run mkdir -p "${i}"
 	done
 
 	good_msg "Loading overlayfs"
-	modprobe overlay >/dev/null 2>&1
+	run modprobe overlay >/dev/null 2>&1
 	checkfs overlay
 
 	mount -t squashfs -o loop,ro "${CDROOT_PATH}/${LOOPEXT}${LOOP}" "${static}"
@@ -672,7 +717,7 @@ setup_overlayfs() {
 	mkdir "${upperdir}" "${workdir}"
 
 	is_union_modules overlayfs
-	mount -t overlay overlay -o lowerdir="${static}${mod_path}",upperdir="${upperdir}",workdir="${workdir}" "${NEW_ROOT}"
+	run mount -t overlay overlay -o lowerdir="${static}${mod_path}",upperdir="${upperdir}",workdir="${workdir}" "${NEW_ROOT}"
 
 	[ ! -d "${NEW_ROOT}${overlay}" ] && mkdir -p "${NEW_ROOT}${overlay}"
 	[ ! -d "${NEW_ROOT}${static}" ] && mkdir -p "${NEW_ROOT}${static}"
@@ -681,7 +726,7 @@ setup_overlayfs() {
 
 	for i in "${overlay}" "${static}"
 	do
-		mount --bind "${i}" "${NEW_ROOT}${i}"
+		run mount --bind "${i}" "${NEW_ROOT}${i}"
 	done
 
 	# Did we populate the overlayfs modules path locations variable?
@@ -689,7 +734,7 @@ setup_overlayfs() {
 	then
 		for i in ${mods}
 		do
-			mount --bind "${overlay}/.${i}" "${NEW_ROOT}/${overlay}/.${i}"
+			run mount --bind "${overlay}/.${i}" "${NEW_ROOT}/${overlay}/.${i}"
 		done
 	fi
 }
@@ -747,7 +792,7 @@ findnfsmount() {
 			if [ "${CDROOT}" != '0' ]
 			then
 				good_msg "Attempting to mount NFS CD image on ${NFSROOT} with options ${NFSOPTIONS}"
-				mount -t nfs -o ${NFSOPTIONS} ${NFSROOT} ${CDROOT_PATH}
+				run mount -t nfs -o ${NFSOPTIONS} ${NFSROOT} ${CDROOT_PATH}
 				if [ $? -eq 0 ]
 				then
 					REAL_ROOT="/dev/nfs"
@@ -757,7 +802,7 @@ findnfsmount() {
 				fi
 			else
 				good_msg "Attempting to mount NFS root on ${NFSROOT} with options ${NFSOPTIONS}"
-				mount -t nfs -o ${NFSOPTIONS} ${NFSROOT} ${NEW_ROOT}
+				run mount -t nfs -o ${NFSOPTIONS} ${NFSROOT} ${NEW_ROOT}
 				if [ $? -eq 0 ]
 				then
 					REAL_ROOT="/dev/nfs"
@@ -815,10 +860,24 @@ check_loop() {
 	fi
 }
 
+run() {
+	local retval
+
+	if "$@"; then
+		retval=$?
+		log_msg "Executed: '$*'"
+	else
+		retval=$?
+		log_msg "Failed (${retval}): '$*'"
+	fi
+
+	return ${retval}
+}
+
 run_shell() {
 	[ -x /bin/sh ] && SH=/bin/sh || SH=/bin/ash
 
-	touch "${GK_SHELL_LOCKFILE}"
+	run touch "${GK_SHELL_LOCKFILE}"
 
 	export PS1='rescueshell \w \# '
 
@@ -834,14 +893,18 @@ run_shell() {
 		&& [ "${CONSOLE}" != "/dev/tty0" ] \
 		&& [ -c "${CONSOLE}" ]
 	then
+		log_msg "Opening rescue shell on ${CONSOLE} ..."
 		setsid ${SH} -c "exec sh --login <${CONSOLE} >${CONSOLE} 2>&1"
 	elif command -v cttyhack 1>/dev/null 2>&1
 	then
+		log_msg "Opening rescue shell using cttyhack ..."
 		setsid cttyhack ${SH} --login
 	elif [ -c '/dev/tty1' ]
 	then
+		log_msg "Opening rescue shell on /dev/tty1 fallback ..."
 		setsid ${SH} -c 'exec sh --login </dev/tty1 >/dev/tty1 2>&1'
 	else
+		log_msg "Opening rescue shell (last resort) ..."
 		${SH} --login
 	fi
 
@@ -872,15 +935,15 @@ mount_devfs() {
 	# Options copied from /etc/init.d/udev-mount, should probably be kept in sync
 	if ! fs_type_in_use devtmpfs
 	then
-		mount -t ${devfs} -o "exec,nosuid,mode=0755,size=10M" udev /dev \
+		run mount -t ${devfs} -o "exec,nosuid,mode=0755,size=10M" udev /dev \
 			|| bad_msg "Failed to mount /dev as ${devfs}"
 	fi
 
 	# http://git.busybox.net/busybox/plain/docs/mdev.txt
 	if ! fs_type_in_use devpts
 	then
-		mkdir -m 0755 /dev/pts
-		mount -t devpts -o gid=5,mode=0620 devpts /dev/pts || bad_msg "Failed to mount /dev/pts"
+		run mkdir -m 0755 /dev/pts
+		run mount -t devpts -o gid=5,mode=0620 devpts /dev/pts || bad_msg "Failed to mount /dev/pts"
 	fi
 }
 
@@ -896,6 +959,28 @@ test_success() {
 	fi
 }
 
+log_msg() {
+	is_log_enabled || return
+
+	if [ ! -f "${GK_INIT_LOG}" ]
+	then
+		touch "${GK_INIT_LOG}"
+	fi
+
+	local log_prefix=
+	[ -n "${GK_INIT_LOG_PREFIX}" ] && log_prefix="${GK_INIT_LOG_PREFIX}: "
+
+	local msg=${1}
+
+	# Cannot use substitution because $msg could contain infinite color
+	# codes and substitution can't be greedy.
+	# Because Busybox's sed cannot deal with control characters, we
+	# have to get rid of all non-printable characters like "^[" first...
+	LANG=C echo "${log_prefix}${msg}" | sed \
+		-e "s,[^[:print:]],,g" \
+		-e 's,\(\\033\)\?\[[0-9;]\+m,,g' \
+		| ts '[%Y-%m-%d %H:%M:%S]' >> "${GK_INIT_LOG}"
+}
 
 # msg functions arguments
 # $1 string
@@ -904,22 +989,31 @@ test_success() {
 good_msg() {
 	[ -n "${QUIET}" ] && ! is_debug && return 0
 
-	msg_string=${1}
+	local msg_string=${1}
 	msg_string="${msg_string:-...}"
+
+	log_msg "[OK] ${msg_string}"
+
 	[ "$2" != '1' ] && printf "%b\n" "${GOOD}>>${NORMAL}${BOLD} ${msg_string} ${NORMAL}"
 }
 
 good_msg_n() {
 	[ -n "${QUIET}" ] && ! is_debug && return 0
 
-	msg_string=${1}
+	local msg_string=${1}
 	msg_string="${msg_string:-...}"
+
+	log_msg "[OK] ${msg_string}"
+
 	[ "$2" != '1' ] && printf "%b" "${GOOD}>>${NORMAL}${BOLD} ${msg_string}"
 }
 
 bad_msg() {
-	msg_string=${1}
+	local msg_string=${1}
 	msg_string="${msg_string:-...}"
+
+	log_msg "[!!] ${msg_string}"
+
 	if [ "$2" != '1' ]
 	then
 		splash 'verbose' >/dev/null &
@@ -928,18 +1022,21 @@ bad_msg() {
 }
 
 warn_msg() {
-	msg_string=${1}
+	local msg_string=${1}
 	msg_string="${msg_string:-...}"
+
+	log_msg "[**] ${msg_string}"
+
 	[ "$2" != '1' ] && printf "%b\n" "${WARN}**${NORMAL}${BOLD} ${msg_string} ${NORMAL}"
 }
 
 crypt_filter() {
 	if [ "${CRYPT_SILENT}" = '1' ]
 	then
-		eval $1 >/dev/null 2>&1
+		eval run ${1} >/dev/null 2>&1
 	else
 		splash 'verbose' >/dev/null &
-		eval $1
+		eval run ${1}
 		res=$?
 		if [ ${res} -eq 0 ]
 		then
@@ -949,6 +1046,46 @@ crypt_filter() {
 	fi
 }
 
+preserve_log() {
+	is_log_enabled || return
+	[ ! -s "${GK_INIT_LOG}" ] && return
+	[ -z "${GK_INIT_LOG_COPYTO}" ] && return
+
+	local have_errors=0
+	local logfile_target="${CHROOT}/${GK_INIT_LOG_COPYTO#/}"
+	local logfile_target_dir="$(dirname "${logfile_target}")"
+	local fail_msg="Failed to copy '${GK_INIT_LOG}' to '${logfile_target}'"
+
+	if run mount -o remount,rw ${CHROOT}
+	then
+		if [ -z "${logfile_target_dir}" ]
+		then
+			have_errors=1
+			bad_msg "${fail_msg}: Failed to determine dirname of '${logfile_target}'!"
+		elif [ ! -d "${logfile_target_dir}" ]
+		then
+			if ! run mkdir -p "${logfile_target_dir}" 2>/dev/null
+			then
+				have_errors=1
+				bad_msg "${fail_msg}: Failed to create '${logfile_target_dir}'!"
+			fi
+		fi
+
+		if [ ${have_errors} = 0 ]
+		then
+			good_msg "gk.log.keep set; Copying '${GK_INIT_LOG}' to '${logfile_target}' ..."
+			if ! cp "${GK_INIT_LOG}" "${logfile_target}" 2>/dev/null
+			then
+				bad_msg "${fail_msg}!"
+			fi
+		fi
+
+		mount -o remount,ro ${CHROOT}
+	else
+		bad_msg "${fail_msg}: 'mount -o remount,rw ${CHROOT}' failed!"
+	fi
+}
+
 prompt_user() {
 	# $1 = variable whose value is the path (examples: "REAL_ROOT",
 	#      "LUKS_KEYDEV")
@@ -1043,7 +1180,7 @@ load_modules() {
 	# kernel version
 	if [ -d "/lib/modules/${KV}" ]
 	then
-		good_msg 'Loading modules'
+		good_msg 'Loading modules ...'
 		# Load appropriate kernel modules
 		for modules in ${MY_HWOPTS}
 		do
@@ -1060,13 +1197,12 @@ setup_keymap() {
 		if [ ! -e /dev/vc/0 -a ! -e /dev/tty0 ]
 		then
 			DEVBIND=1
-			mount -o bind ${NEW_ROOT}/dev /dev
+			run mount -o bind ${NEW_ROOT}/dev /dev
 		fi
-		[ ! -e /dev/tty0 ] && ln -s /dev/tty1 /dev/tty0
 
 		[ -f /lib/keymaps/keymapList ] && chooseKeymap
 
-		[ "${DEVBIND}" = '1' ] && umount /dev
+		[ "${DEVBIND}" = '1' ] && run umount /dev
 	fi
 }
 
@@ -1082,7 +1218,7 @@ chooseKeymap() {
 	if [ -z "${keymap}" ]
 	then
 		splash 'verbose' >/dev/null &
-		cat /lib/keymaps/keymapList
+		run cat /lib/keymaps/keymapList
 		read -t 10 -p '<< Load keymap (Enter for default): ' keymap
 		case ${keymap} in
 			1|azerty) keymap=azerty ;;
@@ -1135,9 +1271,9 @@ chooseKeymap() {
 	if [ -e /lib/keymaps/${keymap}.map ]
 	then
 		good_msg "Loading the '${keymap}' keymap ..."
-		loadkmap < /lib/keymaps/${keymap}.map
+		run loadkmap < /lib/keymaps/${keymap}.map
 
-		mkdir -p /etc/sysconfig
+		run mkdir -p /etc/sysconfig
 		echo "XKEYBOARD=${keymap}" > /etc/sysconfig/keyboard
 		splash set_msg "Set keymap to '${keymap}'"
 	elif [ -z "${keymap}" ]
@@ -1158,8 +1294,8 @@ chooseKeymap() {
 copyKeymap() {
 	if [ -e /etc/sysconfig/keyboard -a ${CDROOT} -eq 1 ]
 	then
-		[ ! -d ${NEW_ROOT}/etc/sysconfig ] && mkdir -p ${NEW_ROOT}/etc/sysconfig
-		cp /etc/sysconfig/keyboard ${NEW_ROOT}/etc/sysconfig/keyboard
+		[ ! -d ${NEW_ROOT}/etc/sysconfig ] && run mkdir -p ${NEW_ROOT}/etc/sysconfig
+		run cp /etc/sysconfig/keyboard ${NEW_ROOT}/etc/sysconfig/keyboard
 	fi
 }
 
@@ -1183,18 +1319,23 @@ start_volumes() {
 	# a symlink, which should hopefully fix bug #142775 and bug #147015
 	if [ -e /dev/device-mapper ] && [ ! -e /dev/mapper/control ]
 	then
-		mkdir -p /dev/mapper
-		ln -sf /dev/device-mapper /dev/mapper/control
+		run mkdir -p /dev/mapper
+		run ln -sf /dev/device-mapper /dev/mapper/control
 	fi
 
 	if [ "${USE_MDADM}" = '1' ]
 	then
 		if [ -x '/sbin/mdadm' ]
 		then
-			/sbin/mdadm --assemble --scan
+			local mdadm_cmd="run /sbin/mdadm --assemble --scan 2>&1"
+			is_log_enabled && mdadm_cmd="${mdadm_cmd} | tee -a '${GK_INIT_LOG}'"
+			eval "${mdadm_cmd}"
+
 			#Intel Matrix RAID (and possibly others) have a container layer above the actual volumes,
 			#So we have to look for volumes that haven't been activated.
-			/sbin/mdadm -IRs
+			mdadm_cmd="run /sbin/mdadm -IRs 2>&1"
+			is_log_enabled && mdadm_cmd="${mdadm_cmd} | tee -a '${GK_INIT_LOG}'"
+			eval "${mdadm_cmd}"
 		else
 			bad_msg "domdadm invoked but /sbin/mdadm not found; Skipping mdadm raid assembly ..."
 		fi
@@ -1226,19 +1367,24 @@ start_volumes() {
 		then
 			good_msg "Scanning for multipath devices"
 			good_msg ":: Populating scsi_id info for libudev queries"
-			mkdir -p /run/udev/data
+			run mkdir -p /run/udev/data
 
 			local ech
 			for ech in /sys/block/*
 			do
 				local tgtfile=b$(cat ${ech}/dev)
-				/lib/udev/scsi_id -g -x /dev/${ech##*/} |sed -e 's/^/E:/' >/run/udev/data/${tgtfile}
+				run /lib/udev/scsi_id -g -x /dev/${ech##*/} | sed -e 's/^/E:/' >/run/udev/data/${tgtfile}
 			done
 
-			${multipath_path} -v 0
+			local multipath_cmd="run ${multipath_path} -v 0 2>&1"
+			is_log_enabled && multipath_cmd="${multipath_cmd} | tee -a '${GK_INIT_LOG}'"
+			eval "${multipath_cmd}"
 			sleep 2
-			good_msg "Activating multipath devices"
-			${dmsetup_path} ls --target multipath --exec "${kpartx_path} -a -v"
+
+			good_msg "Activating multipath devices ..."
+			multipath_cmd="run ${dmsetup_path} ls --target multipath --exec '${kpartx_path} -a -v' 2>&1"
+			is_log_enabled && multipath_cmd="${multipath_cmd} | tee -a '${GK_INIT_LOG}'"
+			eval "${multipath_cmd}"
 		fi
 	fi
 
@@ -1246,14 +1392,23 @@ start_volumes() {
 	then
 		if [ -x '/sbin/dmraid' ]
 		then
-			good_msg "Activating Device-Mapper RAID(s)"
+			good_msg "Activating Device-Mapper RAID(s) ..."
+			local dmraid_cmd="run /sbin/dmraid -ay"
 			if [ -z "${DMRAID_OPTS}" ]
 			then
-				/sbin/dmraid -ay
+				dmraid_cmd="${dmraid_cmd} 2>&1"
 			else
-				/sbin/dmraid -ay ${DMRAID_OPTS}
+				dmraid_cmd="${dmraid_cmd} ${DMRAID_OPTS} 2>&1"
+			fi
+			is_log_enabled && dmraid_cmd="${dmraid_cmd} | tee -a '${GK_INIT_LOG}'"
+			eval "${dmraid_cmd}"
+
+			if [ -x '/sbin/kpartx' ]
+			then
+				dmraid_cmd="run /sbin/dmsetup ls --exec '/sbin/kpartx -a -s' 2>&1"
+				is_log_enabled && dmraid_cmd="${dmraid_cmd} | tee -a '${GK_INIT_LOG}'"
+				eval "${dmraid_cmd}"
 			fi
-			[ -x '/sbin/kpartx' ] && /sbin/dmsetup ls --exec '/sbin/kpartx -a -s'
 		else
 			bad_msg "dodmraid invoked but /sbin/dmraid not found; Skipping dmraid activation ..."
 		fi
@@ -1275,23 +1430,30 @@ start_volumes() {
 				setup_md_device "${dev}"
 			done
 
-			# This is needed for LVM to accept the following logic
-			lvm_commands="#! ${lvm_path}"
+			local lvm_cmd
 
 			# If there is a cache, update it. Unbreak at least dmcrypt
-			[ -d /etc/lvm/cache ] && lvm_commands="${lvm_commands} \nvgscan"
+			if [ -d /etc/lvm/cache ]
+			then
+				good_msg "Scanning for volume groups ..."
+				lvm_cmd="run ${lvm_path} vgscan 2>&1"
+				is_log_enabled && lvm_cmd="${lvm_cmd} | tee -a '${GK_INIT_LOG}'"
+				eval "${lvm_cmd}"
+			fi
+
+			good_msg "Activating volume groups ..."
 
 			# To activate volumegroups on all devices in the cache
-			lvm_commands="${lvm_commands} \nvgchange -ay --sysinit"
+			local lvm_cmd="run ${lvm_path} vgchange -ay --sysinit 2>&1"
+			is_log_enabled && lvm_cmd="${lvm_cmd} | tee -a '${GK_INIT_LOG}'"
+			eval "${lvm_cmd}"
 
-			# To create symlinks so users can use real_root=/dev/vg/root
+			# To create symlinks so users can use root=/dev/vg/root
 			# This needs to run after vgchange, using vgchange --mknodes is too
 			# early.
-			lvm_commands="${lvm_commands} \nvgmknodes --ignorelockingfailure"
-
-			# And finally execute it all (/proc/... needed if lvm is compiled without readline)
-			good_msg "Scanning for and activating Volume Groups"
-			printf "%b\n" "${lvm_commands}" | ${lvm_path} /proc/self/fd/0
+			local lvm_cmd="run ${lvm_path} vgmknodes --ignorelockingfailure 2>&1"
+			is_log_enabled && lvm_cmd="${lvm_cmd} | tee -a '${GK_INIT_LOG}'"
+			eval "${lvm_cmd}"
 		fi
 	fi
 
@@ -1308,6 +1470,7 @@ start_volumes() {
 				then
 					# Push all the block devices to register_quiet
 					# If its bcache, it will bring it up, if not, it will simply ignore it.
+					log_msg "COMMAND: 'echo \"/dev/${i}\" >/sys/fs/bcache/register_quiet'"
 					echo "/dev/${i}" >/sys/fs/bcache/register_quiet 2>/dev/null
 				else
 					warn_msg "'/dev/${i}' should exist but is missing; Ignoring ..."
@@ -1320,7 +1483,10 @@ start_volumes() {
 	then
 		if [ -x '/sbin/btrfs' ]
 		then
-			/sbin/btrfs device scan
+			local btrfs_cmd="run /sbin/btrfs device scan 2>&1"
+			is_log_enabled && btrfs_cmd="${btrfs_cmd} | tee -a '${GK_INIT_LOG}'"
+
+			eval "${btrfs_cmd}"
 		else
 			bad_msg "dobtrfs invoked but /sbin/btrfs not found; Skipping btrfs device scanning ..."
 		fi
@@ -1334,14 +1500,16 @@ start_volumes() {
 			bad_msg "Cannot import ZFS pool because /dev/zfs is missing"
 		elif [ -z "${ZFS_POOL}" ]
 		then
-			good_msg "Importing ZFS pools"
+			good_msg "Importing ZFS pools ..."
 
-			/sbin/zpool import -N -a ${ZPOOL_CACHE} ${ZPOOL_FORCE}
+			local zfs_cmd="run /sbin/zpool import -N -a ${ZPOOL_CACHE} ${ZPOOL_FORCE} 2>&1"
+			is_log_enabled && zfs_cmd="${zfs_cmd} | tee -a '${GK_INIT_LOG}'"
+			eval "${zfs_cmd}"
 			if [ $? -eq 0 ]
 			then
-				good_msg "Importing ZFS pools succeeded"
+				good_msg "Importing ZFS pools succeeded!"
 			else
-				bad_msg "Imported ZFS pools failed"
+				bad_msg "Imported ZFS pools failed!"
 			fi
 		else
 
@@ -1351,19 +1519,27 @@ start_volumes() {
 
 				if [ -n "${CRYPT_ROOT}" -o -n "${CRYPT_SWAP}" ]
 				then
-					good_msg "LUKS detected. Reimporting ${ZFS_POOL}"
-					/sbin/zpool export -f "${ZFS_POOL}"
-					/sbin/zpool import -N ${ZPOOL_CACHE} ${ZPOOL_FORCE} "${ZFS_POOL}"
+					good_msg "LUKS detected. Reimporting ${ZFS_POOL} ..."
+
+					local zfs_cmd="run /sbin/zpool export -f '${ZFS_POOL}' 2>&1"
+					is_log_enabled && zfs_cmd="${zfs_cmd} | tee -a '${GK_INIT_LOG}'"
+					eval "${zfs_cmd}"
+
+					zfs_cmd="run /sbin/zpool import -N ${ZPOOL_CACHE} ${ZPOOL_FORCE} '${ZFS_POOL}' 2>&1"
+					is_log_enabled && zfs_cmd="${zfs_cmd} | tee -a '${GK_INIT_LOG}'"
+					eval "${zfs_cmd}"
 				fi
 			else
-				good_msg "Importing ZFS pool ${ZFS_POOL}"
+				good_msg "Importing ZFS pool ${ZFS_POOL} ..."
 
-				/sbin/zpool import -N ${ZPOOL_CACHE} ${ZPOOL_FORCE} "${ZFS_POOL}"
+				local zfs_cmd="run /sbin/zpool import -N ${ZPOOL_CACHE} ${ZPOOL_FORCE} '${ZFS_POOL}' 2>&1"
+				is_log_enabled && zfs_cmd="${zfs_cmd} | tee -a '${GK_INIT_LOG}'"
+				eval "${zfs_cmd}"
 				if [ $? -eq 0 ]
 				then
-					good_msg "Import of ${ZFS_POOL} succeeded"
+					good_msg "Import of ${ZFS_POOL} succeeded!"
 				else
-					bad_msg "Import of ${ZFS_POOL} failed"
+					bad_msg "Import of ${ZFS_POOL} failed!"
 				fi
 			fi
 		fi
@@ -1371,10 +1547,15 @@ start_volumes() {
 }
 
 start_iscsi() {
+	local iscsi_cmd
+
 	if [ ! -n "${ISCSI_NOIBFT}" ]
 	then
-		good_msg "Activating iSCSI via iBFT"
-		iscsistart -b
+		good_msg "Activating iSCSI via iBFT ..."
+
+		iscsi_cmd="run iscsistart -b 2>&1"
+		is_log_enabled && iscsi_cmd="${iscsi_cmd} | tee -a '${GK_INIT_LOG}'"
+		eval "${iscsi_cmd}"
 	fi
 
 	if [ -n "${ISCSI_INITIATORNAME}" ] && [ -n "${ISCSI_TARGET}" ] && [ -n "${ISCSI_ADDRESS}" ]
@@ -1418,7 +1599,9 @@ start_iscsi() {
 			ADDITIONAL="${ADDITIONAL} -d ${ISCSI_DEBUG}"
 		fi
 
-		iscsistart -i "${ISCSI_INITIATORNAME}" -t "${ISCSI_TARGET}" -a "${ISCSI_ADDRESS}" ${ADDITIONAL}
+		iscsi_cmd="run iscsistart -i '${ISCSI_INITIATORNAME}' -t '${ISCSI_TARGET}' -a '${ISCSI_ADDRESS}' ${ADDITIONAL} 2>&1"
+		is_log_enabled && iscsi_cmd="${iscsi_cmd} | tee -a '${GK_INIT_LOG}'"
+		eval "${iscsi_cmd}"
 	fi
 }
 
@@ -1481,8 +1664,7 @@ openLUKS() {
 			fi
 
 			setup_md_device ${LUKS_DEVICE}
-			cryptsetup isLuks ${LUKS_DEVICE}
-			if [ $? -ne 0 ]
+			if ! run cryptsetup isLuks ${LUKS_DEVICE}
 			then
 				bad_msg "The LUKS device ${LUKS_DEVICE} does not contain a LUKS header" ${CRYPT_SILENT}
 				DEV_ERROR=1
@@ -1538,8 +1720,7 @@ openLUKS() {
 						# At this point a device was recognized, now let's see if the key is there
 						[ ! -d "${mntkey}" ] && mkdir -p "${mntkey}" >/dev/null 2>&1
 
-						mount -n -o ro ${REAL_LUKS_KEYDEV} ${mntkey} >/dev/null 2>&1
-						if [ "$?" != '0' ]
+						if ! run mount -n -o ro ${REAL_LUKS_KEYDEV} ${mntkey} >/dev/null 2>&1
 						then
 							KEYDEV_ERROR=1
 							bad_msg "Mounting of device ${REAL_LUKS_KEYDEV} failed." ${CRYPT_SILENT}
@@ -1550,7 +1731,7 @@ openLUKS() {
 							# keyfile exists?
 							if [ ! -e "${mntkey}${LUKS_KEY}" ]
 							then
-								umount -n "${mntkey}" >/dev/null 2>&1
+								run umount -n "${mntkey}" >/dev/null 2>&1
 								KEY_ERROR=1
 								KEYDEV_ERROR=1
 								bad_msg "Key {LUKS_KEY} on device ${REAL_LUKS_KEYDEV} not found." ${CRYPT_SILENT}
@@ -1568,8 +1749,8 @@ openLUKS() {
 							bad_msg "GPG-encrypted key file provided but gpg program is missing. Was initramfs built without --gpg parameter?"
 							bad_msg "Falling back to passphrase usage!"
 						else
-							[ -e /dev/tty ] && mv /dev/tty /dev/tty.org
-							mknod /dev/tty c 5 1
+							[ -e /dev/tty ] && run mv /dev/tty /dev/tty.org
+							run mknod /dev/tty c 5 1
 							cryptsetup_options="${cryptsetup_options} -d -"
 							gpg_cmd="/sbin/gpg --logger-file /dev/null --quiet --decrypt ${mntkey}${LUKS_KEY} |"
 						fi
@@ -1582,12 +1763,12 @@ openLUKS() {
 				crypt_filter_ret=$?
 
 				[ -e /dev/tty.org ] \
-					&& rm -f /dev/tty \
-					&& mv /dev/tty.org /dev/tty
+					&& run rm -f /dev/tty \
+					&& run mv /dev/tty.org /dev/tty
 
 				if [ ${crypt_filter_ret} -eq 0 ]
 				then
-					touch "${OPENED_LOCKFILE}"
+					run touch "${OPENED_LOCKFILE}"
 					good_msg "LUKS device ${LUKS_DEVICE} opened" ${CRYPT_SILENT}
 					break
 				elif [ ! -e "${OPENED_LOCKFILE}" ]
@@ -1600,8 +1781,13 @@ openLUKS() {
 			fi
 		fi
 	done
-	umount "${mntkey}" >/dev/null 2>&1
-	rmdir -p "${mntkey}" >/dev/null 2>&1
+
+	if run mountpoint "${mntkey}" >/dev/null 2>&1
+	then
+		run umount "${mntkey}" >/dev/null 2>&1
+	fi
+
+	[ -d "${mntkey}" ] run rmdir -p "${mntkey}" >/dev/null 2>&1
 }
 
 iface_name() {
@@ -1771,12 +1957,15 @@ start_network() {
 			# network for us. Really no need re-run dhcp...
 			warn_msg "Interface ${GK_NET_IFACE} is already up."
 			warn_msg "Skipping network setup; Will use existing network configuration ..."
-			touch "${GK_NET_LOCKFILE}"
+			run touch "${GK_NET_LOCKFILE}"
 			return 0
 		fi
 
+		local udhcpc_cmd="run udhcpc -i '${GK_NET_IFACE}' -n -t ${GK_NET_DHCP_RETRIES} -T ${GK_NET_TIMEOUT_DHCP} -R -p '${GK_NET_DHCP_PIDFILE}' 2>&1"
+		is_log_enabled && udhcpc_cmd="${udhcpc_cmd} | tee -a '${GK_INIT_LOG}'"
+
 		good_msg "Bringing up interface ${GK_NET_IFACE} using dhcp ..." ${QUIET}
-		busybox udhcpc -i "${GK_NET_IFACE}" -n -t ${GK_NET_DHCP_RETRIES} -T ${GK_NET_TIMEOUT_DHCP} -R -p "${GK_NET_DHCP_PIDFILE}"
+		eval "${udhcpc_cmd}"
 		if [ $? -ne 0 ]
 		then
 			bad_msg "Failed to start udhcpc for interface ${GK_NET_IFACE}!"
@@ -1793,10 +1982,10 @@ start_network() {
 		fi
 
 		good_msg "Bringing up interface ${GK_NET_IFACE} ..." ${QUIET}
-		ip link set "${GK_NET_IFACE}" up
+		run ip link set "${GK_NET_IFACE}" up
 
 		good_msg "Setting address '${IP}' on ${GK_NET_IFACE} ..." ${QUIET}
-		ip addr add "${IP}" dev "${GK_NET_IFACE}"
+		run ip addr add "${IP}" dev "${GK_NET_IFACE}"
 
 		if [ -n "${GK_NET_ROUTES}" ]
 		then
@@ -1804,25 +1993,25 @@ start_network() {
 			for route in ${GK_NET_ROUTES}
 			do
 				good_msg "Adding additional route '${route}' on ${GK_NET_IFACE} ..." ${QUIET}
-				ip route add "${route}" dev "${GK_NET_IFACE}"
+				run ip route add "${route}" dev "${GK_NET_IFACE}"
 			done
 		fi
 
 		if [ -n "${GK_NET_GW}" ]
 		then
 			good_msg "Adding default route via '${GK_NET_GW}' on ${GK_NET_IFACE} ..." ${QUIET}
-			ip route add default via "${GK_NET_GW}" dev "${GK_NET_IFACE}"
+			run ip route add default via "${GK_NET_GW}" dev "${GK_NET_IFACE}"
 		fi
 	fi
 
-	touch "${GK_NET_LOCKFILE}"
+	run touch "${GK_NET_LOCKFILE}"
 }
 
 kill_network() {
 	if [ -s "${GK_NET_DHCP_PIDFILE}" ]
 	then
 		good_msg "Stopping udhcpc ..."
-		kill $(cat "${GK_NET_DHCP_PIDFILE}")
+		run kill $(cat "${GK_NET_DHCP_PIDFILE}")
 	fi
 
 	if [ ! -d "/sys/class/net/${GK_NET_IFACE}" ]
@@ -1867,9 +2056,9 @@ kill_network() {
 	local deconfiguration_timeout=${GK_NET_TIMEOUT_DECONFIGURATION}
 	while [ ${deconfiguration_timeout} -gt 0 ]
 	do
-		ip addr flush dev "${GK_NET_IFACE}"
-		ip route flush dev "${GK_NET_IFACE}"
-		ip link set "${GK_NET_IFACE}" down
+		run ip addr flush dev "${GK_NET_IFACE}"
+		run ip route flush dev "${GK_NET_IFACE}"
+		run ip link set "${GK_NET_IFACE}" down
 		if grep -q "down" "/sys/class/net/${GK_NET_IFACE}/operstate" 2>/dev/null
 		then
 			break
@@ -1888,7 +2077,7 @@ kill_network() {
 		return
 	fi
 
-	[ -f "${GK_NET_LOCKFILE}" ] && rm "${GK_NET_LOCKFILE}"
+	[ -f "${GK_NET_LOCKFILE}" ] && run rm "${GK_NET_LOCKFILE}"
 }
 
 is_interface_up() {
@@ -1964,17 +2153,17 @@ start_sshd() {
 
 	# setup environment variables for the ssh login shell
 	local varname= varvalue=
-	touch "${CRYPT_ENV_FILE}"
+	run touch "${CRYPT_ENV_FILE}"
 	for varname in CRYPT_ROOT CRYPT_ROOT_TRIM CRYPT_SILENT CRYPT_SWAP
 	do
 		eval varvalue=\$${varname}
 		echo "${varname}=${varvalue}" >> "${CRYPT_ENV_FILE}"
 	done
 
-	touch /var/log/lastlog
+	run touch /var/log/lastlog
 
 	good_msg "Starting dropbear sshd ..." ${QUIET}
-	/usr/sbin/dropbear -p ${GK_SSHD_PORT} -R -P "${GK_SSHD_PIDFILE}" 2>/var/log/dropbear.log
+	run /usr/sbin/dropbear -p ${GK_SSHD_PORT} -R -P "${GK_SSHD_PIDFILE}" 2>/var/log/dropbear.log
 	test_success "Failed to start dropbear"
 }
 
@@ -1991,13 +2180,16 @@ wait_sshd() {
 
 	printf "%b" "${GOOD}>>${NORMAL}${BOLD} gk.sshd.wait set; Waiting ${GK_SSHD_WAIT} seconds for SSH connection ${NORMAL}..."
 
+	local last_cmd="run last -W 2>/dev/null | head -n 3"
+	is_log_enabled && last_cmd="${last_cmd} | tee -a '${GK_INIT_LOG}'"
+
 	local ssh_timeout=${GK_SSHD_WAIT}
 	while [ ${ssh_timeout} -gt 0 ]
 	do
 		if [ -f "${GK_SSHD_LOCKFILE}" ]
 		then
 			echo ""
-			last -W | head -n 3 2>/dev/null
+			eval "${last_cmd}"
 			break
 		fi
 		sleep 1
@@ -2012,7 +2204,7 @@ kill_sshd() {
 	if [ -s "${GK_SSHD_PIDFILE}" ]
 	then
 		good_msg "Stopping dropbear sshd ..." ${QUIET}
-		kill $(cat "${GK_SSHD_PIDFILE}")
+		run kill $(cat "${GK_SSHD_PIDFILE}")
 	fi
 }
 
@@ -2038,7 +2230,10 @@ cleanup() {
 	kill_sshd
 
 	# Ensure that we terminated any existing connection
-	pkill -9 dropbear >/dev/null 2>&1
+	if pgrep dropbear >/dev/null 2>&1
+	then
+		run pkill -9 dropbear >/dev/null 2>&1
+	fi
 
 	if [ -f "${GK_NET_LOCKFILE}" ]
 	then
@@ -2055,7 +2250,7 @@ sdelay() {
 	# Sleep a specific number of seconds if SDELAY is set
 	if [ -n "${SDELAY}" ]
 	then
-		good_msg_n "Waiting ${SDELAY} seconds ..."
+		good_msg_n "scandelay set; Waiting ${SDELAY} seconds ..."
 		while [ ${SDELAY} -gt 0 ]
 		do
 			let SDELAY=${SDELAY}-1
@@ -2071,12 +2266,20 @@ sdelay() {
 
 quiet_kmsg() {
 	# if QUIET is set make the kernel less chatty
-	[ -n "${QUIET}" ] && echo '0' > /proc/sys/kernel/printk
+	if [ -n "${QUIET}" ]
+	then
+		echo '0' > /proc/sys/kernel/printk \
+			&& log_msg "COMMAND: 'echo \"0\" > /proc/sys/kernel/printk'"
+	fi
 }
 
 verbose_kmsg() {
 	# if QUIET is set make the kernel less chatty
-	[ -n "${QUIET}" ] && echo '6' > /proc/sys/kernel/printk
+	if [ -n "${QUIET}" ]
+	then
+		echo '6' > /proc/sys/kernel/printk \
+			&& log_msg "COMMAND: 'echo \"6\" > /proc/sys/kernel/printk'"
+	fi
 }
 
 cdupdate() {
@@ -2091,7 +2294,7 @@ cdupdate() {
 		if [ -n "${cdupdate_path}" ]
 		then
 			good_msg "Running cdupdate.sh (${cdupdate_path})"
-			${cdupdate_path}
+			run ${cdupdate_path}
 			if [ "$?" != '0' ]
 			then
 				bad_msg "Executing cdupdate.sh failed!"
@@ -2105,7 +2308,13 @@ cdupdate() {
 
 setup_btrfsctl() {
 	# start BTRFS volume detection, if available
-	[ -x /sbin/btrfsctl ] && /sbin/btrfsctl -a
+	if [ -x /sbin/btrfsctl ]
+	then
+		local btrfs_cmd="run /sbin/btrfsctl -a 2>&1"
+		is_log_enabled && btrfs_cmd="${btrfs_cmd} | tee -a '${GK_INIT_LOG}'"
+
+		eval "${btrfs_cmd}"
+	fi
 }
 
 setup_md_device() {
@@ -2120,10 +2329,10 @@ setup_md_device() {
 		MD_NUMBER=$(echo ${device}|sed -e 's#\(luks:\)\?/dev/md\([[:digit:]]\+\)#\2#')
 		if [ ! -e /dev/md${MD_NUMBER} ]
 		then
-			mknod /dev/md${MD_NUMBER} b 9 ${MD_NUMBER} >/dev/null 2>&1
+			run mknod /dev/md${MD_NUMBER} b 9 ${MD_NUMBER} >/dev/null 2>&1
 			[ $? -ne 0 ] && bad_msg "Creation of /dev/md${MD_NUMBER} failed ..."
 		fi
-		mdstart ${MDPART} /dev/md${MD_NUMBER}
+		run mdstart ${MDPART} /dev/md${MD_NUMBER}
 	fi
 }
 
@@ -2242,16 +2451,16 @@ setup_squashfs_aufs() {
 
 	for dir in ${aufs_rw_branch} ${aufs_ro_branch}
 	do
-		[ ! -d "${dir}" ] && mkdir -p "${dir}"
+		[ ! -d "${dir}" ] && run mkdir -p "${dir}"
 	done
 
 	good_msg "Loading aufs module ..."
-	modprobe aufs >/dev/null 2>&1
+	run modprobe aufs >/dev/null 2>&1
 	checkfs aufs
 
-	mount -t squashfs -o loop,ro "${CDROOT_PATH}/${LOOPEXT}${LOOP}" "${aufs_ro_branch}"
-	mount -t tmpfs none "${aufs_rw_branch}"
-	mount -t aufs -o "br:${aufs_rw_branch}:${aufs_ro_branch}" aufs "${NEW_ROOT}"
+	run mount -t squashfs -o loop,ro "${CDROOT_PATH}/${LOOPEXT}${LOOP}" "${aufs_ro_branch}"
+	run mount -t tmpfs none "${aufs_rw_branch}"
+	run mount -t aufs -o "br:${aufs_rw_branch}:${aufs_ro_branch}" aufs "${NEW_ROOT}"
 }
 
 setup_unionfs() {
@@ -2270,9 +2479,9 @@ setup_unionfs() {
 #		fi
 
 #		mkdir -p ${MEMORY}
-		mkdir -p ${UNION}
+		run mkdir -p ${UNION}
 		good_msg "Loading fuse module"
-		modprobe fuse >/dev/null 2>&1
+		run modprobe fuse >/dev/null 2>&1
 #		 if [ -n "${UNIONFS}" ]
 #		 then
 #			 CHANGESDEV=${UNIONFS}
@@ -2299,12 +2508,12 @@ setup_unionfs() {
 #			 mount -t tmpfs tmpfs ${MEMORY}
 #		 fi
 
-		mkdir /tmp
-		mkdir -p ${UNION}
+		run mkdir /tmp
+		run mkdir -p ${UNION}
 #		mkdir -p ${CHANGES}
 #		mount -t unionfs -o dirs=${CHANGES}=rw unionfs ${UNION}
 		good_msg "Creating union mount"
-		unionfs -o allow_other,cow,noinitgroups,suid,dev,default_permissions,use_ino ${rw_dir}=RW:${ro_dir}=RO ${UNION} 2>/dev/null
+		run unionfs -o allow_other,cow,noinitgroups,suid,dev,default_permissions,use_ino ${rw_dir}=RW:${ro_dir}=RO ${UNION} 2>/dev/null
 		ret=$?
 		if [ ${ret} -ne 0 ]
 		then
@@ -2312,7 +2521,7 @@ setup_unionfs() {
 			USE_UNIONFS_NORMAL=0
 		fi
 		[ ! -d "${NEW_ROOT}${CDROOT_PATH}" ] && mkdir -p "${NEW_ROOT}${CDROOT_PATH}"
-		mount --bind "${CDROOT_PATH}" "${NEW_ROOT}${CDROOT_PATH}"
+		run mount --bind "${CDROOT_PATH}" "${NEW_ROOT}${CDROOT_PATH}"
 	else
 		USE_UNIONFS_NORMAL=0
 	fi

diff --git a/defaults/linuxrc b/defaults/linuxrc
index e3d5a2b..6e01209 100644
--- a/defaults/linuxrc
+++ b/defaults/linuxrc
@@ -28,7 +28,7 @@ then
 	exit 1
 fi
 
-mount -t proc -o noexec,nosuid,nodev proc /proc >/dev/null 2>&1
+run mount -t proc -o noexec,nosuid,nodev proc /proc >/dev/null 2>&1
 mount -o remount,rw / >/dev/null 2>&1
 
 # Prevent superfluous printks from being printed to the console
@@ -37,11 +37,11 @@ echo 1 > /proc/sys/kernel/printk
 if [ ! -s /etc/ld.so.cache ]
 then
 	# Looks like we were unable to run ldconfig during initramfs generation
-	[ -x /sbin/ldconfig ] && /sbin/ldconfig
+	[ -x /sbin/ldconfig ] && run /sbin/ldconfig
 fi
 
 # Set up symlinks
-/bin/busybox --install -s
+run /bin/busybox --install -s
 
 gk_ver="$(cat /etc/build_id)"
 gk_build_date="$(cat /etc/build_date)"
@@ -51,7 +51,7 @@ good_msg "${gk_ver} (${gk_build_date}). Linux kernel ${kernel_ver}"
 
 if [ "$0" = '/init' ]
 then
-	[ -e /linuxrc ] && rm /linuxrc
+	[ -e /linuxrc ] && run rm /linuxrc
 fi
 
 CMDLINE=$(cat /proc/cmdline)
@@ -63,7 +63,7 @@ ROOTFSTYPE='auto'
 CRYPT_SILENT=0
 QUIET=''
 
-mkdir -p /etc/cmdline /etc/modprobe.d
+run mkdir -p /etc/cmdline /etc/modprobe.d
 for x in ${CMDLINE}
 do
 	case "${x}" in
@@ -155,7 +155,7 @@ do
 		;;
 		# Debug Options
 		debug)
-			touch "${GK_DEBUGMODE_STATEFILE}"
+			run touch "${GK_DEBUGMODE_STATEFILE}"
 		;;
 		# Scan delay options
 		scandelay=*)
@@ -275,6 +275,47 @@ do
 		dosshd)
 			USE_SSH=1
 		;;
+		gk.log.disabled=*)
+			tmp_disabled=${x#*=}
+			if is_true "${tmp_disabled}"
+			then
+				[ -f "${GK_INIT_LOG}" ] && rm "${GK_INIT_LOG}"
+				GK_INIT_LOG=
+				touch "${GK_INIT_LOG_DISABLED}"
+			fi
+			unset tmp_disabled
+		;;
+		gk.log.keep=*)
+			case "${x#*=}" in
+				[Tt][Rr][Uu][Ee])
+					GK_INIT_LOG_COPYTO=/genkernel-boot.log
+				;;
+				[Yy][Ee][Ss])
+					GK_INIT_LOG_COPYTO=/genkernel-boot.log
+				;;
+				[Yy])
+					GK_INIT_LOG_COPYTO=/genkernel-boot.log
+				;;
+				1)
+					GK_INIT_LOG_COPYTO=/genkernel-boot.log
+				;;
+				[Ff][Aa][Ll][Ss][Ee])
+					GK_INIT_LOG_COPYTO=
+				;;
+				[Nn][Oo])
+					GK_INIT_LOG_COPYTO=
+				;;
+				[Nn])
+					GK_INIT_LOG_COPYTO=
+				;;
+				0)
+					GK_INIT_LOG_COPYTO=
+				;;
+				*)
+					GK_INIT_LOG_COPYTO=${x#*=}
+				;;
+			esac
+		;;
 		gk.sshd.port=*)
 			tmp_port=${x#*=}
 			if is_int "${tmp_port}"
@@ -442,14 +483,15 @@ mount_devfs
 mount_sysfs
 
 # Initialize mdev
-good_msg 'Activating mdev'
+good_msg 'Activating mdev ...'
 
 # Serialize hotplug events
-touch /dev/mdev.seq
+run touch /dev/mdev.seq
 
 # Setup hotplugging for firmware loading
 if [ -f "/proc/sys/kernel/hotplug" ]
 then
+	log_msg "COMMAND: 'echo /sbin/mdev > /proc/sys/kernel/hotplug'"
 	echo /sbin/mdev > /proc/sys/kernel/hotplug
 fi
 
@@ -459,7 +501,7 @@ then
 	good_msg 'Skipping module load; disabled via commandline'
 elif [ -d "/lib/modules/${KV}" ]
 then
-	good_msg 'Loading modules'
+	good_msg 'Loading modules ...'
 	if [ -n "${FIRSTMODS}" ]
 	then
 		# try these modules first -- detected modules for root device:
@@ -481,7 +523,7 @@ else
 fi
 
 # Ensure that device nodes are properly configured
-mdev -s || bad_msg "mdev -s failed"
+run mdev -s || bad_msg "mdev -s failed"
 
 cd /
 
@@ -561,7 +603,7 @@ then
 	fi
 fi
 
-mkdir -p "${NEW_ROOT}"
+run mkdir -p "${NEW_ROOT}"
 CHROOT="${NEW_ROOT}"
 
 # Run debug shell if requested
@@ -603,12 +645,12 @@ then
 	if [ "${REAL_ROOT}" = '' ] && [ "${got_good_root}" != '1' ]
 	then
 		# Undo stuff
-		umount  "${NEW_ROOT}/dev" 2>/dev/null
-		umount  "${NEW_ROOT}/sys" 2>/dev/null
-		umount /sys 2>/dev/null
+		run umount  "${NEW_ROOT}/dev" 2>/dev/null
+		run umount  "${NEW_ROOT}/sys" 2>/dev/null
+		run umount /sys 2>/dev/null
 
-		umount  "${NEW_ROOT}"
-		rm -rf  "${NEW_ROOT}/*"
+		run umount  "${NEW_ROOT}"
+		run rm -rf  "${NEW_ROOT}/*"
 
 		bad_msg 'Could not find CD to boot, something else needed!'
 		CDROOT=0
@@ -621,7 +663,7 @@ ROOTDELAY_TIME_WAITED=0
 [ -n "${ROOTDELAY}" -a ${ROOTDELAY} -gt 0 ] && let ROOTDELAY_TIMEOUT=${ROOTDELAY_TIMEOUT}+${ROOTDELAY}-1
 while true
 do
-	good_msg_n 'Determining root device ...'
+	good_msg_n "Determining root device (trying ${REAL_ROOT}) ..."
 
 	while [ "${got_good_root}" != '1' ]
 	do
@@ -650,7 +692,7 @@ do
 						got_good_root=1
 						REAL_ROOT="${ROOT_DEV}"
 						echo
-						good_msg "Detected real_root=${ROOT_DEV}"
+						good_msg "Root device detected as ${REAL_ROOT}!"
 						break
 					fi
 				;;
@@ -664,20 +706,20 @@ do
 					ROOT_DEV="${REAL_ROOT#*=}"
 					if [ "${ROOT_DEV}" != 'ZFS' ]
 					then
-						if [ "$(zfs get type -o value -H ${ROOT_DEV})" = 'filesystem' ]
+						if [ "$(zfs get type -o value -H ${ROOT_DEV} 2>/dev/null)" = 'filesystem' ]
 						then
 							got_good_root=1
 							REAL_ROOT=${ROOT_DEV}
 							ROOTFSTYPE=zfs
 							echo
-							good_msg "Detected real_root=${ROOT_DEV}"
+							good_msg "Root device detected as ${REAL_ROOT}!"
 							break
 						else
 							bad_msg "${ROOT_DEV} is not a filesystem"
 							continue
 						fi
 					else
-						BOOTFS=$(/sbin/zpool list -H -o bootfs)
+						BOOTFS=$(/sbin/zpool list -H -o bootfs 2>/dev/null)
 						if [ "${BOOTFS}" != '-' ]
 						then
 							for i in ${BOOTFS}
@@ -689,7 +731,7 @@ do
 									REAL_ROOT=${i}
 									ROOTFSTYPE=zfs
 									echo
-									good_msg "Detected real_root=${ROOT_DEV}"
+									good_msg "Root device detected as ${REAL_ROOT}!"
 									break
 								fi
 							done
@@ -701,7 +743,7 @@ do
 					then
 						got_good_root=1
 						echo
-						good_msg "Detected real_root=${REAL_ROOT}"
+						good_msg "Root device detected as ${REAL_ROOT}!"
 						break
 					fi
 				;;
@@ -732,10 +774,10 @@ do
 			then
 				# at this point we determined dataset and are ready to mount
 				# let's check if this dataset is encrypted and ask for passphrase
-				if [ "$(zpool list -H -o feature@encryption "${REAL_ROOT%%/*}")" = 'active' ]
+				if [ "$(zpool list -H -o feature@encryption "${REAL_ROOT%%/*}" 2>/dev/null)" = 'active' ]
 				then
-					ZFS_KEYSTATUS="$(zfs get -H -o value keystatus "${REAL_ROOT}")"
-					ZFS_ENCRYPTIONROOT="$(zfs get -H -o value encryptionroot "${REAL_ROOT}")"
+					ZFS_KEYSTATUS="$(zfs get -H -o value keystatus "${REAL_ROOT}" 2>/dev/null)"
+					ZFS_ENCRYPTIONROOT="$(zfs get -H -o value encryptionroot "${REAL_ROOT}" 2>/dev/null)"
 					if ! [ "${ZFS_ENCRYPTIONROOT}" = '-' ] || [ "${ZFS_KEYSTATUS}" = 'available' ]
 					then
 						good_msg "Detected ZFS encryption, asking for key"
@@ -796,11 +838,11 @@ do
 			if [ "${REAL_ROOTFLAGS}" = '' ]
 			then
 				good_msg "Using mount -t ${ROOTFSTYPE} -o ${MOUNT_STATE} ${REAL_ROOT} ${NEW_ROOT}"
-				mount -t ${ROOTFSTYPE} -o ${MOUNT_STATE} ${REAL_ROOT} ${NEW_ROOT}
+				run mount -t ${ROOTFSTYPE} -o ${MOUNT_STATE} ${REAL_ROOT} ${NEW_ROOT}
 				mountret=$?
 			else
 				good_msg "Using mount -t ${ROOTFSTYPE} -o ${MOUNT_STATE},${REAL_ROOTFLAGS} ${REAL_ROOT} ${NEW_ROOT}"
-				mount -t ${ROOTFSTYPE} -o ${MOUNT_STATE},${REAL_ROOTFLAGS} ${REAL_ROOT} ${NEW_ROOT}
+				run mount -t ${ROOTFSTYPE} -o ${MOUNT_STATE},${REAL_ROOTFLAGS} ${REAL_ROOT} ${NEW_ROOT}
 				mountret=$?
 			fi
 		fi
@@ -852,7 +894,7 @@ do
 	then
 		if mountpoint "${NEW_ROOT}" 1>/dev/null 2>&1
 		then
-			umount "${NEW_ROOT}" 1>/dev/null 2>&1
+			run umount "${NEW_ROOT}" 1>/dev/null 2>&1
 			if [ $? -ne 0 ]
 			then
 				echo
@@ -904,7 +946,7 @@ then
 				MOUNTTYPE="${LOOPTYPE}"
 				;;
 		esac
-		mount -t "${MOUNTTYPE}" -o ro /dev/mapper/root "${NEW_ROOT}/mnt/livecd"
+		run mount -t "${MOUNTTYPE}" -o ro /dev/mapper/root "${NEW_ROOT}/mnt/livecd"
 		test_success 'Mount filesystem'
 		FS_LOCATION='mnt/livecd'
 	# Setup the loopback mounts, if unencrypted
@@ -912,7 +954,7 @@ then
 		if [ "${LOOPTYPE}" = 'normal' ]
 		then
 			good_msg 'Mounting loop filesystem'
-			mount -t ext2 -o loop,ro "${CDROOT_PATH}/${LOOPEXT}${LOOP}" "${NEW_ROOT}/mnt/livecd"
+			run mount -t ext2 -o loop,ro "${CDROOT_PATH}/${LOOPEXT}${LOOP}" "${NEW_ROOT}/mnt/livecd"
 			test_success 'Mount filesystem'
 			FS_LOCATION='mnt/livecd'
 		elif [ "${LOOPTYPE}" = 'squashfs' ]
@@ -951,7 +993,7 @@ then
 			echo ' ' | losetup -E 19 -e ucl-0 -p0 "${NEW_ROOT}/dev/loop0" "${CDROOT_PATH}/${LOOPEXT}${LOOP}"
 			test_success 'losetup the loop device'
 
-			mount -t ext2 -o ro "${NEW_ROOT}/dev/loop0" "${NEW_ROOT}/mnt/livecd"
+			run mount -t ext2 -o ro "${NEW_ROOT}/dev/loop0" "${NEW_ROOT}/mnt/livecd"
 			test_success 'Mount the losetup loop device'
 			FS_LOCATION='mnt/livecd'
 		elif [ "${LOOPTYPE}" = 'zisofs' ]
@@ -979,7 +1021,7 @@ then
 			test_success 'losetup /dev/sr0 /dev/loop0'
 
 			good_msg 'Mounting the Root Partition'
-			mount -t squashfs -o ro "${NEW_ROOT}${CDROOT_DEV}" "${NEW_ROOT}/mnt/livecd"
+			run mount -t squashfs -o ro "${NEW_ROOT}${CDROOT_DEV}" "${NEW_ROOT}/mnt/livecd"
 			test_success 'mount /dev/loop0 /'
 			FS_LOCATION='mnt/livecd'
 		fi
@@ -997,7 +1039,7 @@ then
 		then
 			for dir in /var/tmp /tmp
 			do
-				[ ! -d ${CHROOT}${dir} ] && mkdir -p "${CHROOT}${dir}"
+				[ ! -d ${CHROOT}${dir} ] && run mkdir -p "${CHROOT}${dir}"
 			done
 
 			cat > "${CHROOT}/etc/fstab" << FSTAB
@@ -1020,8 +1062,8 @@ FSTAB
 		# Check to see if we successfully mounted $aufs_dev
 		if [ -n "${aufs_dev}" ] && grep ${aufs_dev} /etc/mtab 1>/dev/null
 		then
-			[ ! -d ${CHROOT}${aufs_dev_mnt} ] && mkdir -p "${CHROOT}${aufs_dev_mnt}"
-			mount --move "${aufs_dev_mnt}" "${CHROOT}${aufs_dev_mnt}"
+			[ ! -d ${CHROOT}${aufs_dev_mnt} ] && run mkdir -p "${CHROOT}${aufs_dev_mnt}"
+			run mount --move "${aufs_dev_mnt}" "${CHROOT}${aufs_dev_mnt}"
 		fi
 	fi
 
@@ -1111,10 +1153,10 @@ FSTAB
 	if [ "${aufs}" = '1' ]
 	then
 		[ ! -d "${CHROOT}${CDROOT_PATH}" ] && mkdir "${CHROOT}${CDROOT_PATH}"
-		mount --move "${CDROOT_PATH}" "${CHROOT}${CDROOT_PATH}"
+		run mount --move "${CDROOT_PATH}" "${CHROOT}${CDROOT_PATH}"
 	else
 		[ ! -d "${NEW_ROOT}${CDROOT_PATH}" ] && mkdir -p "${NEW_ROOT}${CDROOT_PATH}"
-		mount --move "${CDROOT_PATH}" "${NEW_ROOT}${CDROOT_PATH}"
+		run mount --move "${CDROOT_PATH}" "${NEW_ROOT}${CDROOT_PATH}"
 	fi
 
 	# Let Init scripts know that we booted from CD
@@ -1123,14 +1165,14 @@ FSTAB
 else
 	if [ "${USE_UNIONFS_NORMAL}" = '1' ]
 	then
-		mkdir /union_changes
-		mount -t tmpfs tmpfs /union_changes
+		run mkdir /union_changes
+		run mount -t tmpfs tmpfs /union_changes
 		setup_unionfs /union_changes ${NEW_ROOT}
-		mkdir -p ${UNION}/tmp/.initrd
+		run mkdir -p ${UNION}/tmp/.initrd
 	elif [ "${aufs}" = '1' ]
 	then
 		aufs_insert_dir "${aufs_union}" "${NEW_ROOT}"
-		mkdir -p "${aufs_union}/tmp/.initrd"
+		run mkdir -p "${aufs_union}/tmp/.initrd"
 	fi
 fi # if [ "${CDROOT}" = '1' ]
 
@@ -1184,19 +1226,19 @@ if [ "${aufs}" = '1' ]
 then
 	aufs_union_memory=${CHROOT}/.unions/memory
 
-	mkdir -p "${aufs_union_memory}"
-	mount --move "${aufs_memory}" "${aufs_union_memory}"
+	run mkdir -p "${aufs_union_memory}"
+	run mount --move "${aufs_memory}" "${aufs_union_memory}"
 	test_success "Failed to move aufs ${aufs_memory} into the system root"
 
 	for dir in /mnt/gentoo ${aufs_rw_branch} ${aufs_ro_branch}
 	do
-		mkdir -p "${CHROOT}${dir}"
-		chmod 755 "${CHROOT}${dir}"
+		run mkdir -p "${CHROOT}${dir}"
+		run chmod 755 "${CHROOT}${dir}"
 	done
 
 	for mount in ${aufs_rw_branch} ${aufs_ro_branch}
 	do
-		mount --move "${mount}" "${CHROOT}${mount}"
+		run mount --move "${mount}" "${CHROOT}${mount}"
 	done
 fi
 
@@ -1225,9 +1267,9 @@ for fs in /dev /sys /proc
 do
 	if grep -qs "${fs}" /proc/mounts
 	then
-		if ! mount -o move ${fs} "${CHROOT}"${fs}
+		if ! run mount -o move ${fs} "${CHROOT}"${fs}
 		then
-			umount ${fs} || \
+			run umount ${fs} || \
 			bad_msg "Failed to move and unmount the ramdisk ${fs}!"
 		fi
 	fi
@@ -1244,6 +1286,8 @@ fi
 # Run debug shell if requested
 rundebugshell "before entering switch_root"
 
+preserve_log
+
 # init_opts is set in the environment by the kernel when it parses the command line
 init=${REAL_INIT:-/sbin/init}
 if ! mountpoint "${CHROOT}" 1>/dev/null 2>&1

diff --git a/defaults/login-remote.sh b/defaults/login-remote.sh
index 12596b9..588504f 100644
--- a/defaults/login-remote.sh
+++ b/defaults/login-remote.sh
@@ -7,6 +7,20 @@
 
 [ -e /etc/initrd.splash ] && . /etc/initrd.splash
 
+GK_INIT_LOG_PREFIX=${0}
+if [ -n "${SSH_CLIENT}" ]
+then
+	SSH_CLIENT_IP=$(echo "${SSH_CLIENT}" | awk '{ print $1 }')
+	SSH_CLIENT_PORT=$(echo "${SSH_CLIENT}" | awk '{ print $2 }')
+
+	if [ -n "${SSH_CLIENT_IP}" ] && [ -n "${SSH_CLIENT_PORT}" ]
+	then
+		GK_INIT_LOG_PREFIX="${0}[${SSH_CLIENT_IP}:${SSH_CLIENT_PORT}]"
+		export SSH_CLIENT_IP
+		export SSH_CLIENT_PORT
+	fi
+fi
+
 receivefile() {
 	case ${1} in
 		root)
@@ -62,12 +76,16 @@ then
 			exit 1
 	esac
 else
+	run touch "${GK_SSHD_LOCKFILE}"
+
+	# Don't log further remote shell output
+	GK_INIT_LOG=
+
 	gk_ver="$(cat /etc/build_id)"
 	gk_build_date="$(cat /etc/build_date)"
 	kernel_ver="$(uname -r)"
 
 	export PS1='remote rescueshell \w \# '
-	touch "${GK_SSHD_LOCKFILE}"
 
 	GOOD=${BLUE} good_msg "${NORMAL}Welcome to ${BOLD}${gk_ver}${NORMAL} (${gk_build_date}) ${BOLD}remote rescue shell${NORMAL}!"
 	GOOD=${BLUE} good_msg "${NORMAL}...running Linux kernel ${BOLD}${kernel_ver}${NORMAL}"
@@ -90,7 +108,12 @@ else
 	echo
 
 	[ -x /bin/sh ] && SH=/bin/sh || SH=/bin/ash
-	exec ${SH} --login
+
+	exec \
+		env \
+		SSH_CLIENT_IP="${SSH_CLIENT_IP}" \
+		SSH_CLIENT_PORT="${SSH_CLIENT_PORT}" \
+		${SH} --login
 fi
 
 exit 0

diff --git a/defaults/unlock-luks.sh b/defaults/unlock-luks.sh
index ebcd2ca..457aa54 100644
--- a/defaults/unlock-luks.sh
+++ b/defaults/unlock-luks.sh
@@ -30,6 +30,12 @@ esac
 . /etc/initrd.scripts
 . "${CRYPT_ENV_FILE}"
 
+GK_INIT_LOG_PREFIX=${0}
+if [ -n "${SSH_CLIENT_IP}" ] && [ -n "${SSH_CLIENT_PORT}" ]
+then
+	GK_INIT_LOG_PREFIX="${0}[${SSH_CLIENT_IP}:${SSH_CLIENT_PORT}]"
+fi
+
 main() {
 	if [ ! -x /sbin/cryptsetup ]
 	then
@@ -58,7 +64,7 @@ main() {
 			fi
 
 			setup_md_device "${LUKS_DEVICE}"
-			if ! cryptsetup isLuks "${LUKS_DEVICE}"
+			if ! run cryptsetup isLuks "${LUKS_DEVICE}"
 			then
 				bad_msg "The LUKS device ${LUKS_DEVICE} does not contain a LUKS header" "${CRYPT_SILENT}"
 
@@ -84,12 +90,12 @@ main() {
 				crypt_filter_ret=$?
 
 				[ -e /dev/tty.org ] \
-					&& rm -f /dev/tty \
-					&& mv /dev/tty.org /dev/tty
+					&& run rm -f /dev/tty \
+					&& run mv /dev/tty.org /dev/tty
 
 				if [ ${crypt_filter_ret} -eq 0 ]
 				then
-					touch "${OPENED_LOCKFILE}"
+					run touch "${OPENED_LOCKFILE}"
 					good_msg "LUKS device ${LUKS_DEVICE} opened" "${CRYPT_SILENT}"
 					break
 				else
@@ -107,7 +113,7 @@ main() {
 	then
 		if  ! is_debug
 		then
-			rm -f "${LUKS_KEY}"
+			run rm -f "${LUKS_KEY}"
 		else
 			warn_msg "LUKS key file '${LUKS_KEY}' not deleted because DEBUG mode is enabled!"
 		fi
@@ -117,7 +123,7 @@ main() {
 	then
 		# Kill any running cryptsetup prompt for this device.
 		# But SIGINT only to keep shell functional.
-		pkill -2 -f "luksOpen.*${LUKS_NAME}\$" >/dev/null 2>&1
+		run pkill -2 -f "luksOpen.*${LUKS_NAME}\$" >/dev/null 2>&1
 	fi
 }
 

diff --git a/doc/genkernel.8.txt b/doc/genkernel.8.txt
index f5f877d..3ab28ce 100644
--- a/doc/genkernel.8.txt
+++ b/doc/genkernel.8.txt
@@ -760,6 +760,22 @@ recognized by the kernel itself.
 *debug*::
     Drop into a debug shell early in the process.
 
+*gk.log.disabled*=<...>::
+    By default, any shown message and external command calls will be logged
+    to '/tmp/init.log' in initramfs. This boolean option allows you to
+    disable logging for some reason.
+
+*gk.log.keep*=<...>::
+When set to a boolean value, genkernel will preserve '/tmp/init.log',
+see above, and copy file to '/genkernel-boot.log' on *root* device.
+You can also set your own file like '/root/my-genkernel-boot.log' to
+copy log to a custom path.
+
+NOTE: The default file '/genkernel-boot.log' on *root* was chosen because
+genkernel's initramfs will only mount root filesystem by default. If you
+want to store the log file in '/var/log/genkernel-boot.log' for example
+make sure that this mountpoint is accessible, see *initramfs.mounts*.
+
 *noload*=<...>::
     List of modules to skip loading.
     Separate using commas or spaces.


^ permalink raw reply related	[flat|nested] 11+ messages in thread

* [gentoo-commits] proj/genkernel:master commit in: defaults/, doc/
@ 2019-11-24 20:00 Thomas Deutschmann
  0 siblings, 0 replies; 11+ messages in thread
From: Thomas Deutschmann @ 2019-11-24 20:00 UTC (permalink / raw
  To: gentoo-commits

commit:     eccc25ea093340a4e3ba662ed8d9e858800cd134
Author:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 20 00:23:45 2019 +0000
Commit:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
CommitDate: Sun Nov 24 19:59:15 2019 +0000
URL:        https://gitweb.gentoo.org/proj/genkernel.git/commit/?id=eccc25ea

initrd.scripts: modules_load() refactored

- Add support for LABEL/UUID in root kernel parameter

- When loading network, always load all network modules
  even when root block device is already available

- Always load crypto and USB module group when CRYPT_{ROOT,SWAP}
  is set.

- Always load fs module group.

- Add gk.hw.load-all kernel command-line argument to allow
  user to force loading of all module groups.

Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org>

 defaults/initrd.defaults |  1 +
 defaults/initrd.scripts  | 43 ++++++++++++++++++++++++++++++++++++++++---
 defaults/linuxrc         |  8 ++++++++
 doc/genkernel.8.txt      |  7 +++++++
 4 files changed, 56 insertions(+), 3 deletions(-)

diff --git a/defaults/initrd.defaults b/defaults/initrd.defaults
index 8937e65..32f99ec 100644
--- a/defaults/initrd.defaults
+++ b/defaults/initrd.defaults
@@ -72,6 +72,7 @@ VERIFY=0
 IP='dhcp'
 GK_BOOTFONT_DISABLED=0
 GK_DEBUGMODE_STATEFILE="/tmp/debug.enabled"
+GK_HW_LOAD_ALL_MODULES=0
 GK_INIT_LOG='/tmp/init.log'
 GK_INIT_LOG_COPYTO=
 GK_INIT_LOG_COPYTO_DEFAULT='/genkernel-boot.log'

diff --git a/defaults/initrd.scripts b/defaults/initrd.scripts
index 1004ff5..053ac68 100644
--- a/defaults/initrd.scripts
+++ b/defaults/initrd.scripts
@@ -29,6 +29,37 @@ modules_load() {
 modules_scan() {
 	local MODS
 	local loaded
+	local smart_loading=yes
+	local _root_dev
+	local root_dev_found="Root block device found, skipping loading of module group \"${1}\" ..."
+
+	if [ "${GK_HW_LOAD_ALL_MODULES}" = '1' ]
+	then
+		smart_loading=
+	elif [ "${1}" = "net" ]
+	then
+		# We already load network modules only when we need
+		# network so don't stop loading network modules when
+		# $REAL_ROOT is already present or we will probably
+		# end up without network we wanted ...
+		smart_loading=
+	elif [ "${1}" = "fs" ]
+	then
+		# We don't know if kernel supports root filesystem so
+		# better load all filesystems ...
+		smart_loading=
+	elif [ -n "${CRYPT_ROOT}" ] || [ -n "${CRYPT_SWAP}" ]
+	then
+		if [ "${1}" = "crypto" ]
+		then
+			smart_loading=
+		elif [ "${1}" = "usb" ]
+		then
+			# We don't know if user is using an USB keyboard to
+			# enter passphrase so better load USB ...
+			smart_loading=
+		fi
+	fi
 
 	MODS=$(cat /etc/modules/${1} 2>/dev/null)
 	[ -n "${MODS}" ] && [ -z "${QUIET}" ] && \
@@ -54,10 +85,16 @@ modules_scan() {
 				printf "%b\n" "${BOLD}   ::${NORMAL} Skipping ${x} ..."
 		elif [ "${MLOAD}" = "${MLIST}" ]
 		then
-			if [ "${ROOTFSTYPE}" != 'auto' ] && [ -b "${REAL_ROOT}" ]
+			if [ -n "${smart_loading}" ]
 			then
-				echo "Root block device found, continuing ..."
-				break
+				_root_dev=$(findfs "${REAL_ROOT}" 2>/dev/null)
+
+				if [ $? -eq 0 ] && [ -n "${_root_dev}" ] && [ -b "${_root_dev}" ]
+				then
+					log_msg "${root_dev_found}"
+					printf "%b" "${root_dev_found}"
+					break
+				fi
 			fi
 
 			if is_debug

diff --git a/defaults/linuxrc b/defaults/linuxrc
index ee46293..f01203b 100644
--- a/defaults/linuxrc
+++ b/defaults/linuxrc
@@ -283,6 +283,14 @@ do
 			fi
 			unset tmp_disabled
 		;;
+		gk.hw.load-all=*)
+			tmp_disabled=${x#*=}
+			if is_true "${tmp_disabled}"
+			then
+				GK_HW_LOAD_ALL_MODULES=1
+			fi
+			unset tmp_disabled
+		;;
 		gk.log.disabled=*)
 			tmp_disabled=${x#*=}
 			if is_true "${tmp_disabled}"

diff --git a/doc/genkernel.8.txt b/doc/genkernel.8.txt
index bee3017..cb2009f 100644
--- a/doc/genkernel.8.txt
+++ b/doc/genkernel.8.txt
@@ -787,6 +787,13 @@ when not set. This will allow remote user to provide answer through
     will load that font. This boolean option allows you to disable
     loading of the user embedded bootfont.
 
+*gk.hw.load-all*=<...>::
+    By default, genkernel loads various module groups (nvme, sata,
+    scsi, pata, usb...) until block device specified in *root* parameter
+    becomes available. This boolean option allows you to force
+    loading of all module groups regardless whether root device is
+    already available.
+
 *gk.log.disabled*=<...>::
     By default, any shown message and external command calls will be logged
     to '/tmp/init.log' in initramfs. This boolean option allows you to


^ permalink raw reply related	[flat|nested] 11+ messages in thread

* [gentoo-commits] proj/genkernel:master commit in: defaults/, doc/
@ 2020-07-16 18:36 Thomas Deutschmann
  0 siblings, 0 replies; 11+ messages in thread
From: Thomas Deutschmann @ 2020-07-16 18:36 UTC (permalink / raw
  To: gentoo-commits

commit:     1a68a5349bb423ddff5ec56ea733631621eba862
Author:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 16 18:22:57 2020 +0000
Commit:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
CommitDate: Thu Jul 16 18:34:28 2020 +0000
URL:        https://gitweb.gentoo.org/proj/genkernel.git/commit/?id=1a68a534

linuxrc: Add gk.userinteraction.disabled

When this option is set and enabled, genkernel initramfs will not prompt
on errors, i.e. this will disable any user interaction, e.g. for a kiosk system.

Bug: https://bugs.gentoo.org/730966
Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org>

 defaults/initrd.defaults |  1 +
 defaults/initrd.scripts  | 52 ++++++++++++++++++++++++++++++++++++++++++++++++
 defaults/linuxrc         |  8 ++++++++
 doc/genkernel.8.txt      |  8 ++++++++
 4 files changed, 69 insertions(+)

diff --git a/defaults/initrd.defaults b/defaults/initrd.defaults
index 15326dd..79d7322 100644
--- a/defaults/initrd.defaults
+++ b/defaults/initrd.defaults
@@ -96,6 +96,7 @@ GK_SSHD_LOCKFILE='/tmp/remote-rescueshell.lock'
 GK_SSHD_PIDFILE='/var/run/dropbear.pid'
 GK_SSHD_PORT=22
 GK_SSHD_WAIT=
+GK_USERINTERACTION_DISABLED_STATEFILE='/tmp/user-interaction.disabled'
 
 CRYPT_ENV_FILE='/etc/CRYPT_ENV.conf'
 CRYPT_KEYFILE_ROOT='/tmp/root.key'

diff --git a/defaults/initrd.scripts b/defaults/initrd.scripts
index d5378b7..6dc588f 100644
--- a/defaults/initrd.scripts
+++ b/defaults/initrd.scripts
@@ -959,6 +959,12 @@ run() {
 }
 
 run_shell() {
+	if [ -f "${GK_USERINTERACTION_DISABLED_STATEFILE}" ]
+	then
+		bad_msg "gk.userinteraction.disabled is set; Spawning a shell is disabled!"
+		return
+	fi
+
 	[ -x /bin/sh ] && SH=/bin/sh || SH=/bin/ash
 
 	run touch "${GK_SHELL_LOCKFILE}"
@@ -1114,6 +1120,15 @@ warn_msg() {
 	[ "$2" != '1' ] && printf "%b\n" "${WARN}**${NORMAL}${BOLD} ${msg_string} ${NORMAL}"
 }
 
+warn_msg_n() {
+	local msg_string=${1}
+	msg_string="${msg_string:-...}"
+
+	log_msg "[**] ${msg_string}"
+
+	[ "$2" != '1' ] && printf "%b" "${WARN}**${NORMAL}${BOLD} ${msg_string}"
+}
+
 write_env_file() {
 	local env_file=${1}
 	shift
@@ -1233,6 +1248,43 @@ prompt_user() {
 	[ -n "${3}" ] && local explnt=" or : ${3}" || local explnt="."
 
 	bad_msg "Could not find the ${2} in ${oldvalue}${explnt}"
+
+	if [ -f "${GK_USERINTERACTION_DISABLED_STATEFILE}" ]
+	then
+		bad_msg "gk.userinteraction.disabled is set; No user interaction allowed!"
+
+		wait_sshd
+
+		if [ -f "${GK_SSHD_LOCKFILE}" ]
+		then
+			warn_msg "The lockfile at '${GK_SSHD_LOCKFILE}' exists."
+			warn_msg "The boot process will be paused until the lock is removed."
+			while true
+			do
+				if [ -f "${GK_SSHD_LOCKFILE}" ]
+				then
+					sleep 1
+				else
+					break
+				fi
+			done
+		fi
+
+		local timeout=${GK_PROMPT_TIMEOUT}
+		[ ${timeout} -eq 0 ] && timeout=10
+
+		warn_msg_n "System will automatically reboot in ${timeout} seconds ..."
+		while [ ${timeout} -gt 0 ]
+		do
+			let timeout=${timeout}-1
+			sleep 1
+			printf "."
+		done
+		echo
+
+		reboot -f
+	fi
+
 	bad_msg "Please specify another value or:"
 	bad_msg "- press Enter for the same"
 	bad_msg '- type "shell" for a shell'

diff --git a/defaults/linuxrc b/defaults/linuxrc
index 682f647..5354d09 100644
--- a/defaults/linuxrc
+++ b/defaults/linuxrc
@@ -356,6 +356,14 @@ do
 			fi
 			unset tmp_wait
 		;;
+		gk.userinteraction.disabled=*)
+			tmp_disabled=${x#*=}
+			if is_true "${tmp_disabled}"
+			then
+				touch "${GK_USERINTERACTION_DISABLED_STATEFILE}"
+			fi
+			unset tmp_disabled
+		;;
 		gk.prompt.timeout=*)
 			tmp_timeout=${x#*=}
 			if is_int "${tmp_timeout}"

diff --git a/doc/genkernel.8.txt b/doc/genkernel.8.txt
index 5b15a02..f84892c 100644
--- a/doc/genkernel.8.txt
+++ b/doc/genkernel.8.txt
@@ -835,6 +835,14 @@ genkernel's initramfs will only mount root filesystem by default. If you
 want to store the log file in '/var/log/genkernel-boot.log' for example
 make sure that this mountpoint is accessible, see *initramfs.mounts*.
 
+*gk.userinteraction.disabled*=<...>::
+By default, genkernel will prompt on errors. In case this is not wanted
+or desired, e.g. for a kiosk system, this boolean option will disable
+any prompting, including the rescue shell.
+
+NOTE: Because no user interaction is possible when this option is set,
+system will automatically reboot on error after a timeout.
+
 *noload*=<...>::
     List of modules to skip loading.
     Separate using commas or spaces.


^ permalink raw reply related	[flat|nested] 11+ messages in thread

* [gentoo-commits] proj/genkernel:master commit in: defaults/, doc/
@ 2020-08-26 22:54 Thomas Deutschmann
  0 siblings, 0 replies; 11+ messages in thread
From: Thomas Deutschmann @ 2020-08-26 22:54 UTC (permalink / raw
  To: gentoo-commits

commit:     809f1f547f0ba8bfa38bbd0977ab2c57ec4c4581
Author:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 26 21:35:52 2020 +0000
Commit:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
CommitDate: Wed Aug 26 21:46:37 2020 +0000
URL:        https://gitweb.gentoo.org/proj/genkernel.git/commit/?id=809f1f54

defaults/linuxrc: Disable processing of modules_load file by default

Now that we are using (e)udev with kmod support, we can rely on UDEV to
load required kernel modules.

Old module loading based on modules_load file can still be enabled via
boolean "gk.hw.use-modules_load" kernel command-line option which is inverting
and replacing previous "nodetect" kernel command-line option.

Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org>

 defaults/initrd.defaults |  1 +
 defaults/initrd.scripts  | 11 +++++++----
 defaults/linuxrc         | 26 ++++++++++++++++++--------
 doc/genkernel.8.txt      | 17 +++++++++++------
 4 files changed, 37 insertions(+), 18 deletions(-)

diff --git a/defaults/initrd.defaults b/defaults/initrd.defaults
index 3ac5856..e4c861b 100644
--- a/defaults/initrd.defaults
+++ b/defaults/initrd.defaults
@@ -73,6 +73,7 @@ IP='dhcp'
 GK_BOOTFONT_DISABLED=0
 GK_DEBUGMODE_STATEFILE="/tmp/debug.enabled"
 GK_HW_LOAD_ALL_MODULES=0
+GK_HW_USE_MODULES_LOAD=0
 GK_INIT_LOG='/tmp/init.log'
 GK_INIT_LOG_COPYTO=
 GK_INIT_LOG_COPYTO_DEFAULT='/genkernel-boot.log'

diff --git a/defaults/initrd.scripts b/defaults/initrd.scripts
index fd87623..29ec123 100644
--- a/defaults/initrd.scripts
+++ b/defaults/initrd.scripts
@@ -2019,10 +2019,13 @@ iface_name() {
 start_network() {
 	good_msg "Starting network ..."
 
-	# Load network modules only when we need them to avoid possible
-	# firmware problems for people not using network that early
-	modules_scan net
-	udevsettle
+	if [ "${GK_HW_USE_MODULES_LOAD}" = '1' ]
+	then
+		# Load network modules only when we need them to avoid possible
+		# firmware problems for people not using network that early
+		modules_scan net
+		udevsettle
+	fi
 
 	# At least gk.net.iface can only be processed after sysfs was
 	# mounted.

diff --git a/defaults/linuxrc b/defaults/linuxrc
index 9793fde..263f738 100644
--- a/defaults/linuxrc
+++ b/defaults/linuxrc
@@ -175,9 +175,6 @@ do
 		doload=*)
 			MDOLIST=$(echo ${MDOLIST} ${x#*=} | sed -e 's/^\ *//;s/,/ /g')
 		;;
-		nodetect)
-			NODETECT=1
-		;;
 		noload=*)
 			MLIST=$(echo ${MLIST} ${x#*=} | sed -e 's/^\ *//;s/,/ /g')
 			export MLIST
@@ -291,6 +288,14 @@ do
 			fi
 			unset tmp_disabled
 		;;
+		gk.hw.use-modules_load=*)
+			tmp_disabled=${x#*=}
+			if is_true "${tmp_disabled}"
+			then
+				GK_HW_USE_MODULES_LOAD=1
+			fi
+			unset tmp_disabled
+		;;
 		gk.log.disabled=*)
 			tmp_disabled=${x#*=}
 			if is_true "${tmp_disabled}"
@@ -542,26 +547,31 @@ fi
 # Load modules listed in MY_HWOPTS if /lib/modules exists for the running kernel
 if [ -z "${DO_modules}" ]
 then
-	good_msg 'Skipping module load; disabled via commandline'
+	good_msg 'Skipping module load; disabled via command-line'
 elif [ -d "/lib/modules/${KV}" ]
 then
-	good_msg 'Loading modules ...'
 	if [ -n "${FIRSTMODS}" ]
 	then
+		good_msg 'Loading first modules ...'
 		# try these modules first -- detected modules for root device:
 		modules_load firstmods ${FIRSTMODS}
 	fi
 
 	# Load appropriate kernel modules
-	if [ "${NODETECT}" != '1' ]
+	if [ "${GK_HW_USE_MODULES_LOAD}" = '1' ]
 	then
+		good_msg 'Loading modules ...'
 		for modules in ${MY_HWOPTS}
 		do
 			modules_scan ${modules}
 		done
 	fi
-	# Always eval doload=...
-	modules_load extra_load ${MDOLIST}
+
+	if [ -n "${MDOLIST}" ]
+	then
+		good_msg 'Loading modules from command-line ...'
+		modules_load extra_load ${MDOLIST}
+	fi
 else
 	good_msg 'Skipping module load; no modules in the ramdisk!'
 fi

diff --git a/doc/genkernel.8.txt b/doc/genkernel.8.txt
index 8c527b0..f0e4414 100644
--- a/doc/genkernel.8.txt
+++ b/doc/genkernel.8.txt
@@ -823,6 +823,12 @@ when not set. This will allow remote user to provide answer through
     loading of all module groups regardless whether root device is
     already available.
 
+*gk.hw.use-modules_load*=<...>::
+    By default, genkernel relies on UDEV's capability to load required
+    kernel modules. This boolean option allows you to force old module
+    loading depending on modules_load file until *root* device becomes
+    available.
+
 *gk.log.disabled*=<...>::
     By default, any shown message and external command calls will be logged
     to '/tmp/init.log' in initramfs. This boolean option allows you to
@@ -848,15 +854,14 @@ NOTE: Because no user interaction is possible when this option is set,
 system will automatically reboot on error after a timeout.
 
 *noload*=<...>::
-    List of modules to skip loading.
-    Separate using commas or spaces.
+List of modules to skip loading.
+Separate using commas or spaces.
 
-*nodetect*::
-    Skipping scanning modules using "modprobe <MODULE> -n".
-    Use *doload=* for specifying a whitelist of exceptions.
+NOTE: This option has only an effect when *gk.hw.use-modules_load* is
+enabled.
 
 *doload*=<...>::
-    List of modules to load despite *nodetect*.
+    List of modules which should always be loaded.
 
 *domodules*::
 *nomodules*::


^ permalink raw reply related	[flat|nested] 11+ messages in thread

* [gentoo-commits] proj/genkernel:master commit in: defaults/, doc/
@ 2020-08-28 20:18 Thomas Deutschmann
  0 siblings, 0 replies; 11+ messages in thread
From: Thomas Deutschmann @ 2020-08-28 20:18 UTC (permalink / raw
  To: gentoo-commits

commit:     8cca1dada7be5625cbdbcf4e8ab14c51d131e099
Author:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 28 13:28:33 2020 +0000
Commit:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
CommitDate: Fri Aug 28 16:35:59 2020 +0000
URL:        https://gitweb.gentoo.org/proj/genkernel.git/commit/?id=8cca1dad

defaults/linuxrc: Add gk.udev.debug to run udevd in debug mode

When gk.udev.debug=yes is set (boolean option), udevd will run in
debug mode. Output will be written to /run/initramfs/udevd.log.

Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org>

 defaults/initrd.defaults |  1 +
 defaults/linuxrc         | 10 +++++++++-
 doc/genkernel.8.txt      |  4 ++++
 3 files changed, 14 insertions(+), 1 deletion(-)

diff --git a/defaults/initrd.defaults b/defaults/initrd.defaults
index fa71ecb..b665355 100644
--- a/defaults/initrd.defaults
+++ b/defaults/initrd.defaults
@@ -96,6 +96,7 @@ GK_SSHD_PIDFILE='/var/run/dropbear.pid'
 GK_SSHD_PORT=22
 GK_SSHD_WAIT=
 GK_UDEV_LOG='/run/initramfs/udevd.log'
+GK_UDEV_DEBUG=0
 GK_UDEV_TIMEOUT=120
 GK_USERINTERACTION_DISABLED_STATEFILE='/tmp/user-interaction.disabled'
 

diff --git a/defaults/linuxrc b/defaults/linuxrc
index 1a4ddac..b42366f 100644
--- a/defaults/linuxrc
+++ b/defaults/linuxrc
@@ -332,6 +332,14 @@ do
 			fi
 			unset tmp_wait
 		;;
+		gk.udev.debug=*)
+			tmp_enabled=${x#*=}
+			if is_true "${tmp_enabled}"
+			then
+				GK_UDEV_DEBUG=1
+			fi
+			unset tmp_enabled
+		;;
 		gk.udev.timeout=*)
 			tmp_timeout=${x#*=}
 			if is_int "${tmp_timeout}"
@@ -566,7 +574,7 @@ fi
 good_msg 'Activating udev ...'
 
 udevd_cmd="run udevd --resolve-names=never"
-if is_debug
+if [ "${GK_UDEV_DEBUG}" = '1' ]
 then
 	udevd_cmd="${udevd_cmd} --debug > ${GK_UDEV_LOG} 2>&1 &"
 else

diff --git a/doc/genkernel.8.txt b/doc/genkernel.8.txt
index d8b9e09..7b96879 100644
--- a/doc/genkernel.8.txt
+++ b/doc/genkernel.8.txt
@@ -721,6 +721,10 @@ recognized by the kernel itself.
 *gk.net.timeout.interface*=<...>::
     By default we will wait up to 10 seconds for interface to show up.
 
+*gk.udev.debug*=<...>::
+    This boolean option allows you to run udevd in debug mode. Output
+    will be logged to '/run/initramfs/udevd.log'.
+
 *gk.udev.timeout*=<...>::
     By default we will wait up to 120 seconds (UDEV default) for
     UDEV event queue to become empty.


^ permalink raw reply related	[flat|nested] 11+ messages in thread

* [gentoo-commits] proj/genkernel:master commit in: defaults/, doc/
@ 2020-09-02 13:52 Thomas Deutschmann
  0 siblings, 0 replies; 11+ messages in thread
From: Thomas Deutschmann @ 2020-09-02 13:52 UTC (permalink / raw
  To: gentoo-commits

commit:     97b3a9235fdba36bfc6197baf1f47fd472fb74b6
Author:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
AuthorDate: Wed Sep  2 13:13:40 2020 +0000
Commit:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
CommitDate: Wed Sep  2 13:13:40 2020 +0000
URL:        https://gitweb.gentoo.org/proj/genkernel.git/commit/?id=97b3a923

defaults/initrd.scripts: openLUKS(): Trigger module loading when mounting {root,swap}_keydev

We need to do the same we do for rootfs since commit 05f968fda2c6839744b36c442b3feaa6de974e63
also for {root,swap}_keydev.

Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org>

 defaults/initrd.defaults |  2 ++
 defaults/initrd.scripts  | 15 +++++++++++----
 defaults/linuxrc         |  6 ++++++
 doc/genkernel.8.txt      |  6 ++++++
 4 files changed, 25 insertions(+), 4 deletions(-)

diff --git a/defaults/initrd.defaults b/defaults/initrd.defaults
index cf7406d..cd485ca 100644
--- a/defaults/initrd.defaults
+++ b/defaults/initrd.defaults
@@ -101,8 +101,10 @@ GK_UDEV_TIMEOUT=120
 GK_USERINTERACTION_DISABLED_STATEFILE='/tmp/user-interaction.disabled'
 
 CRYPT_ENV_FILE='/etc/CRYPT_ENV.conf'
+CRYPT_ROOT_KEYDEV_FSTYPE='auto'
 CRYPT_ROOT_KEYFILE='/tmp/root.key'
 CRYPT_ROOT_OPENED_LOCKFILE='/tmp/ROOT.opened'
+CRYPT_SWAP_KEYDEV_FSTYPE='auto'
 CRYPT_SWAP_KEYFILE='/tmp/swap.key'
 CRYPT_SWAP_OPENED_LOCKFILE='/tmp/SWAP.opened'
 

diff --git a/defaults/initrd.scripts b/defaults/initrd.scripts
index 7a84755..5181d6c 100644
--- a/defaults/initrd.scripts
+++ b/defaults/initrd.scripts
@@ -1780,7 +1780,7 @@ openLUKS() {
 		exit 1
 	fi
 
-	case $1 in
+	case ${1} in
 		root)
 			local TYPE=ROOT
 			;;
@@ -1789,8 +1789,12 @@ openLUKS() {
 			;;
 	esac
 
-	eval local LUKS_DEVICE='"${CRYPT_'${TYPE}'}"' LUKS_NAME="$1" LUKS_KEY='"${CRYPT_'${TYPE}'_KEY}"'
-	eval local LUKS_KEYDEV='"${CRYPT_'${TYPE}'_KEYDEV}"' LUKS_TRIM='"${CRYPT_'${TYPE}'_TRIM}"'
+	local LUKS_NAME="${1}"
+	eval local LUKS_DEVICE='"${CRYPT_'${TYPE}'}"'
+	eval local LUKS_KEY='"${CRYPT_'${TYPE}'_KEY}"'
+	eval local LUKS_KEYDEV='"${CRYPT_'${TYPE}'_KEYDEV}"'
+	eval local LUKS_KEYDEV_FSTYPE='"${CRYPT_'${TYPE}'_KEYDEV_FSTYPE}"'
+	eval local LUKS_TRIM='"${CRYPT_'${TYPE}'_TRIM}"'
 	eval local OPENED_LOCKFILE='"${CRYPT_'${TYPE}'_OPENED_LOCKFILE}"'
 	local DEV_ERROR=0 KEY_ERROR=0 KEYDEV_ERROR=0
 	local mntkey="/mnt/key/" crypt_filter_ret=
@@ -1886,7 +1890,10 @@ openLUKS() {
 						# At this point a device was recognized, now let's see if the key is there
 						[ ! -d "${mntkey}" ] && mkdir -p "${mntkey}" >/dev/null 2>&1
 
-						if ! run mount -n -o ro ${REAL_LUKS_KEYDEV} ${mntkey} >/dev/null 2>&1
+						# determine fs -- 'auto' will not trigger module loading!
+						LUKS_KEYDEV_FSTYPE=$(determine_fs "${REAL_LUKS_KEYDEV}" "${LUKS_KEYDEV_FSTYPE}")
+
+						if ! run mount -n -t ${LUKS_KEYDEV_FSTYPE} -o ro ${REAL_LUKS_KEYDEV} ${mntkey} >/dev/null 2>&1
 						then
 							KEYDEV_ERROR=1
 							bad_msg "Mounting of device ${REAL_LUKS_KEYDEV} failed." ${CRYPT_SILENT}

diff --git a/defaults/linuxrc b/defaults/linuxrc
index bab54e1..6d07d9b 100644
--- a/defaults/linuxrc
+++ b/defaults/linuxrc
@@ -257,6 +257,9 @@ do
 		root_keydev=*)
 			CRYPT_ROOT_KEYDEV=${x#*=}
 		;;
+		root_keydev_fstype=*)
+			CRYPT_ROOT_KEYDEV_FSTYPE=${x#*=}
+		;;
 		root_trim=*)
 			CRYPT_ROOT_TRIM=${x#*=}
 		;;
@@ -266,6 +269,9 @@ do
 		swap_keydev=*)
 			CRYPT_SWAP_KEYDEV=${x#*=}
 		;;
+		swap_keydev_fstype=*)
+			CRYPT_SWAP_KEYDEV_FSTYPE=${x#*=}
+		;;
 		real_resume=*|resume=*)
 			REAL_RESUME=${x#*=}
 		;;

diff --git a/doc/genkernel.8.txt b/doc/genkernel.8.txt
index 7ce7391..5d7b74d 100644
--- a/doc/genkernel.8.txt
+++ b/doc/genkernel.8.txt
@@ -646,6 +646,9 @@ recognized by the kernel itself.
     root_key.   If unset while using root_key, it will automatically
     look for the device in every boot.
 
+*root_keydev_fstype*=<...>::
+    Used filesystem for *root_keydev*. See *rootfstype* for more details.
+
 *root_trim*=(yes|no)::
     Enables TRIM support for a LUKS-based root device.  Only useful
     with SSD setups.  Have a look at 'https://en.wikipedia.org/wiki/TRIM'
@@ -657,6 +660,9 @@ recognized by the kernel itself.
 *swap_keydev*=<...>::
     Same as root_keydev for swap.
 
+*swap_keydev_fstype*=<...>::
+    Used filesystem for *swap_keydev*. See *rootfstype* for more details.
+
 *crypt_silent*::
     Set this to silent all the output related to the cryptographic
     software,  and in case your encrypted device isn't open with the


^ permalink raw reply related	[flat|nested] 11+ messages in thread

* [gentoo-commits] proj/genkernel:master commit in: defaults/, doc/
@ 2021-02-07 18:23 Thomas Deutschmann
  0 siblings, 0 replies; 11+ messages in thread
From: Thomas Deutschmann @ 2021-02-07 18:23 UTC (permalink / raw
  To: gentoo-commits

commit:     a0a6d6313874a7567a26c405713aaf610695285d
Author:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
AuthorDate: Sun Feb  7 18:02:29 2021 +0000
Commit:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
CommitDate: Sun Feb  7 18:02:29 2021 +0000
URL:        https://gitweb.gentoo.org/proj/genkernel.git/commit/?id=a0a6d631

linuxrc: add kernel command-line argument to allow user to pass additional options to cryptsetup

Cryptsetup supports additional options like "--perf-no_read_workqueue" or
"--perf-no_write_workqueue". While it is recommended to use LUKS2 format
and make these activiation flags permanent, you can also make use of
the new kernel command-line arguments "crypt_root_options" for root device
or "crypt_swap_options" for swap device to pass additional options
to cryptsetup.

These arguments can be specified multiple times or separate multiple
options with a comma.

Bug: https://bugs.gentoo.org/755587
Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org>

 defaults/initrd.defaults |  2 ++
 defaults/initrd.scripts  | 16 +++++++---------
 defaults/linuxrc         | 13 ++++++++++++-
 defaults/unlock-luks.sh  |  8 +++-----
 doc/genkernel.8.txt      | 10 ++++++++++
 5 files changed, 34 insertions(+), 15 deletions(-)

diff --git a/defaults/initrd.defaults b/defaults/initrd.defaults
index cd485ca..ac3b072 100644
--- a/defaults/initrd.defaults
+++ b/defaults/initrd.defaults
@@ -104,9 +104,11 @@ CRYPT_ENV_FILE='/etc/CRYPT_ENV.conf'
 CRYPT_ROOT_KEYDEV_FSTYPE='auto'
 CRYPT_ROOT_KEYFILE='/tmp/root.key'
 CRYPT_ROOT_OPENED_LOCKFILE='/tmp/ROOT.opened'
+CRYPT_ROOT_OPTIONS=''
 CRYPT_SWAP_KEYDEV_FSTYPE='auto'
 CRYPT_SWAP_KEYFILE='/tmp/swap.key'
 CRYPT_SWAP_OPENED_LOCKFILE='/tmp/SWAP.opened'
+CRYPT_SWAP_OPTIONS=''
 
 ZFS_ENC_ENV_FILE='/etc/ZFS_ENC_ENV.conf'
 ZFS_ENC_OPENED_LOCKFILE='/tmp/ZFS.opened'

diff --git a/defaults/initrd.scripts b/defaults/initrd.scripts
index f6e84fc..5d744ee 100644
--- a/defaults/initrd.scripts
+++ b/defaults/initrd.scripts
@@ -1193,7 +1193,7 @@ write_env_file() {
 	for varname in $*
 	do
 		eval varvalue=\$${varname}
-		echo "${varname}=${varvalue}" >> "${env_file}"
+		echo "${varname}='${varvalue}'" >> "${env_file}"
 	done
 }
 
@@ -1774,15 +1774,13 @@ openLUKS() {
 	eval local LUKS_KEY='"${CRYPT_'${TYPE}'_KEY}"'
 	eval local LUKS_KEYDEV='"${CRYPT_'${TYPE}'_KEYDEV}"'
 	eval local LUKS_KEYDEV_FSTYPE='"${CRYPT_'${TYPE}'_KEYDEV_FSTYPE}"'
-	eval local LUKS_TRIM='"${CRYPT_'${TYPE}'_TRIM}"'
+	eval local cryptsetup_options='"${CRYPT_'${TYPE}'_OPTIONS}"'
 	eval local OPENED_LOCKFILE='"${CRYPT_'${TYPE}'_OPENED_LOCKFILE}"'
 	local DEV_ERROR=0 KEY_ERROR=0 KEYDEV_ERROR=0
 	local mntkey="/mnt/key/" crypt_filter_ret=
 
 	while true
 	do
-		local cryptsetup_options=''
-
 		local gpg_cmd=""
 		if [ -e "${OPENED_LOCKFILE}" ]
 		then
@@ -1819,10 +1817,9 @@ openLUKS() {
 				DEV_ERROR=1
 				continue
 			else
-				if [ "x${LUKS_TRIM}" = "xyes" ]
+				if [ -n "${cryptsetup_options}" ]
 				then
-					good_msg "Enabling TRIM support for ${LUKS_NAME} ..." ${CRYPT_SILENT}
-					cryptsetup_options="${cryptsetup_options} --allow-discards"
+					good_msg "Using the following cryptsetup options for ${LUKS_NAME}: ${cryptsetup_options}" ${CRYPT_SILENT}
 				fi
 
 				# Handle keys
@@ -2333,9 +2330,10 @@ start_sshd() {
 	write_env_file \
 		"${CRYPT_ENV_FILE}" \
 		CRYPT_ROOT \
-		CRYPT_ROOT_TRIM \
+		CRYPT_ROOT_OPTIONS \
 		CRYPT_SILENT \
-		CRYPT_SWAP
+		CRYPT_SWAP \
+		CRYPT_SWAP_OPTIONS
 
 	run touch /var/log/lastlog
 

diff --git a/defaults/linuxrc b/defaults/linuxrc
index df0f570..e33576d 100644
--- a/defaults/linuxrc
+++ b/defaults/linuxrc
@@ -244,10 +244,16 @@ do
 			CRYPT_ROOT=${x#*=}
 			USE_CRYPTSETUP=1
 		;;
+		crypt_root_options=*)
+			CRYPT_ROOT_OPTIONS=$(echo ${CRYPT_ROOT_OPTIONS} ${x#*=} | sed -e 's/,/ /g')
+		;;
 		crypt_swap=*)
 			CRYPT_SWAP=${x#*=}
 			USE_CRYPTSETUP=1
 		;;
+		crypt_swap_options=*)
+			CRYPT_SWAP_OPTIONS=$(echo ${CRYPT_SWAP_OPTIONS} ${x#*=} | sed -e 's/,/ /g')
+		;;
 		root_key=*)
 			CRYPT_ROOT_KEY=${x#*=}
 		;;
@@ -258,7 +264,12 @@ do
 			CRYPT_ROOT_KEYDEV_FSTYPE=${x#*=}
 		;;
 		root_trim=*)
-			CRYPT_ROOT_TRIM=${x#*=}
+			tmp_enabled=${x#*=}
+			if is_true "${tmp_enabled}"
+			then
+				CRYPT_ROOT_OPTIONS="${CRYPT_ROOT_OPTIONS} --allow-discards"
+			fi
+			unset tmp_enabled
 		;;
 		swap_key=*)
 			CRYPT_SWAP_KEY=${x#*=}

diff --git a/defaults/unlock-luks.sh b/defaults/unlock-luks.sh
index a8ae990..59e086a 100644
--- a/defaults/unlock-luks.sh
+++ b/defaults/unlock-luks.sh
@@ -46,12 +46,11 @@ main() {
 	local LUKS_NAME="${NAME}"
 	eval local LUKS_DEVICE='"${CRYPT_'${TYPE}'}"'
 	eval local LUKS_KEY='"${CRYPT_'${TYPE}'_KEYFILE}"'
-	eval local LUKS_TRIM='"${CRYPT_'${TYPE}'_TRIM}"'
+	eval local cryptsetup_options='"${CRYPT_'${TYPE}'_OPTIONS}"'
 	eval local OPENED_LOCKFILE='"${CRYPT_'${TYPE}'_OPENED_LOCKFILE}"'
 
 	while true
 	do
-		local cryptsetup_options=""
 		local gpg_cmd crypt_filter_ret
 
 		if [ -e "${OPENED_LOCKFILE}" ]
@@ -74,10 +73,9 @@ main() {
 				# able to investigate the problem on its own.
 				exit 1
 			else
-				if [ "x${LUKS_TRIM}" = "xyes" ]
+				if [ -n "${cryptsetup_options}" ]
 				then
-					good_msg "Enabling TRIM support for ${LUKS_NAME} ..." "${CRYPT_SILENT}"
-					cryptsetup_options="${cryptsetup_options} --allow-discards"
+					good_msg "Using the following cryptsetup options for ${LUKS_NAME}: ${cryptsetup_options}" ${CRYPT_SILENT}
 				fi
 
 				# Handle keys

diff --git a/doc/genkernel.8.txt b/doc/genkernel.8.txt
index 8909fc7..ddccd9f 100644
--- a/doc/genkernel.8.txt
+++ b/doc/genkernel.8.txt
@@ -633,9 +633,19 @@ recognized by the kernel itself.
     This specifies the device encrypted by LUKS, which contains the
     root filesystem to mount.
 
+*crypt_root_options*=<...>::
+    This specifies additional options, which should get passed to
+    cryptsetup when opening root volume. Can be specified multiple
+    times or separate multiple options with a comma.
+
 *crypt_swap*=<...>::
     This specifies the swap device encrypted by LUKS.
 
+*crypt_swap_options*=<...>::
+    This specifies additional options, which should get passed to
+    cryptsetup when opening swap volume. Can be specified multiple
+    times or separate multiple options with a comma.
+
 *root_key*=<...>::
     In case your root is encrypted with a key, you can use a device
     like a  usb pen to store the key.  This value should be the key


^ permalink raw reply related	[flat|nested] 11+ messages in thread

* [gentoo-commits] proj/genkernel:master commit in: defaults/, doc/
@ 2021-03-14 20:05 Thomas Deutschmann
  0 siblings, 0 replies; 11+ messages in thread
From: Thomas Deutschmann @ 2021-03-14 20:05 UTC (permalink / raw
  To: gentoo-commits

commit:     858e9bbef4421cd4a1f85a1b5eeb3ebd4f3dce8a
Author:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
AuthorDate: Sat Mar 13 18:40:10 2021 +0000
Commit:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
CommitDate: Sun Mar 14 19:33:54 2021 +0000
URL:        https://gitweb.gentoo.org/proj/genkernel.git/commit/?id=858e9bbe

linuxrc: Drop "console" kernel argument handling

It was never really used; Kernel's console handling
already did the work.

Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org>

 defaults/linuxrc    | 21 ---------------------
 doc/genkernel.8.txt |  4 ----
 2 files changed, 25 deletions(-)

diff --git a/defaults/linuxrc b/defaults/linuxrc
index 28a504b..acb246c 100644
--- a/defaults/linuxrc
+++ b/defaults/linuxrc
@@ -178,12 +178,6 @@ do
 			MLIST=$(echo ${MLIST} ${x#*=} | sed -e 's/^\ *//;s/,/ /g')
 			export MLIST
 		;;
-		# Redirect output to a specific tty
-		CONSOLE=*|console=*)
-			NEW_CONSOLE=${x#*=}
-			NEW_CONSOLE=$(basename ${NEW_CONSOLE})
-			NEW_CONSOLE=${NEW_CONSOLE%%,*}
-		;;
 		# /dev/md
 		lvmraid=*)
 			warn_msg "'${x}' kernel command-line argument is deprecated; Use 'dolvm' instead!"
@@ -455,21 +449,6 @@ do
 	esac
 done
 
-if [ -n "${NEW_CONSOLE}" ]
-then
-	# We cannot update console while processing CMDLINE because we
-	# are only interested in last console= value.
-	[ ! -c "${NEW_CONSOLE}" ] && NEW_CONSOLE="/dev/${NEW_CONSOLE}"
-	if [ -c "${NEW_CONSOLE}" ]
-	then
-		exec 0<>${NEW_CONSOLE} 1<>${NEW_CONSOLE} 2<>${NEW_CONSOLE}
-		good_msg "Console switched from '${CONSOLE}' to '${NEW_CONSOLE}'!"
-		CONSOLE="${NEW_CONSOLE}"
-	else
-		bad_msg "Unable to switch console: '${NEW_CONSOLE}' not found or not a character device!"
-	fi
-fi
-
 good_msg "${gk_ver} (${gk_build_date}). Linux kernel ${kernel_ver}"
 
 if [ "${GK_BOOTFONT_DISABLED}" = '0' -a -e /lib/console/font ]

diff --git a/doc/genkernel.8.txt b/doc/genkernel.8.txt
index d7afc07..b75f979 100644
--- a/doc/genkernel.8.txt
+++ b/doc/genkernel.8.txt
@@ -872,10 +872,6 @@ enabled.
 *nomodules*::
     Enables/disables loading of modules in general.
 
-*CONSOLE*=<...>::
-*console*=<...>::
-    Override location of console, default is "/dev/console".
-
 *part*[=<0,1>]::
 *partitionable*::
     Enable/Disable partitionable RAIDs (metadata 0.x) during auto-run.


^ permalink raw reply related	[flat|nested] 11+ messages in thread

* [gentoo-commits] proj/genkernel:master commit in: defaults/, doc/
@ 2022-05-16  5:34 Robin H. Johnson
  0 siblings, 0 replies; 11+ messages in thread
From: Robin H. Johnson @ 2022-05-16  5:34 UTC (permalink / raw
  To: gentoo-commits

commit:     73a05632d61171685ac4960c6b684cefa6d82afd
Author:     Dmitry Baranov <reagentoo <AT> gmail <DOT> com>
AuthorDate: Wed Oct 14 19:03:01 2020 +0000
Commit:     Robin H. Johnson <robbat2 <AT> gentoo <DOT> org>
CommitDate: Sat Aug  7 17:20:10 2021 +0000
URL:        https://gitweb.gentoo.org/proj/genkernel.git/commit/?id=73a05632

Add support for LUKS detached header

Signed-off-by: Dmitry Baranov <reagentoo <AT> gmail.com>

 defaults/initrd.scripts | 162 +++++++++++++++++++++++++++++++++++++++++++-----
 defaults/linuxrc        |  18 ++++++
 doc/genkernel.8.txt     |  22 +++++++
 3 files changed, 186 insertions(+), 16 deletions(-)

diff --git a/defaults/initrd.scripts b/defaults/initrd.scripts
index 33a48b3..5a83d93 100644
--- a/defaults/initrd.scripts
+++ b/defaults/initrd.scripts
@@ -306,7 +306,7 @@ bootstrapFS() {
 	fi
 
 	# Setup the filesystem nodes and directories
-	for i in ${CDROOT_PATH} /mnt/livecd /mnt/key /mnt/gentoo /tmp /tmp/.initrd /dev /proc /run /sys; do
+	for i in ${CDROOT_PATH} /mnt/header /mnt/livecd /mnt/key /mnt/gentoo /tmp /tmp/.initrd /dev /proc /run /sys; do
 		run mkdir -p "${NEW_ROOT}${i}"
 		run chmod 755 "${NEW_ROOT}${i}"
 	done
@@ -391,6 +391,14 @@ bootstrapCD() {
 	fi
 }
 
+bootstrapHeader() {
+	# $1 = ROOT/SWAP
+	local HEADERDEVS=$(devicelist)
+	eval local headerloc='"${CRYPT_'${1}'_HEADER}"'
+
+	findmediamount "header" "${headerloc}" "CRYPT_${1}_HEADERDEV" "/mnt/header" ${HEADERDEVS}
+}
+
 bootstrapKey() {
 	# $1 = ROOT/SWAP
 	local KEYDEVS=$(devicelist)
@@ -1828,12 +1836,17 @@ openLUKS() {
 
 	local LUKS_NAME="${1}"
 	eval local LUKS_DEVICE='"${CRYPT_'${TYPE}'}"'
+	eval local LUKS_HEADER='"${CRYPT_'${TYPE}'_HEADER}"'
+	eval local LUKS_HEADERDEV='"${CRYPT_'${TYPE}'_HEADERDEV}"'
+	eval local LUKS_HEADERDEV_FSTYPE='"${CRYPT_'${TYPE}'_HEADERDEV_FSTYPE}"'
 	eval local LUKS_KEY='"${CRYPT_'${TYPE}'_KEY}"'
 	eval local LUKS_KEYDEV='"${CRYPT_'${TYPE}'_KEYDEV}"'
 	eval local LUKS_KEYDEV_FSTYPE='"${CRYPT_'${TYPE}'_KEYDEV_FSTYPE}"'
 	eval local OPENED_LOCKFILE='"${CRYPT_'${TYPE}'_OPENED_LOCKFILE}"'
-	local DEV_ERROR=0 KEY_ERROR=0 KEYDEV_ERROR=0
-	local mntkey="/mnt/key/" crypt_filter_ret=
+	local DEV_ERROR=0
+	local HEADER_ERROR=0 HEADERDEV_ERROR=0
+	local KEY_ERROR=0 KEYDEV_ERROR=0
+	local mntheader="/mnt/header/" mntkey="/mnt/key/" crypt_filter_ret=
 
 	if [ -z "${LUKS_DEVICE}" ]
 	then
@@ -1853,13 +1866,27 @@ openLUKS() {
 			good_msg "The LUKS device ${LUKS_DEVICE} meanwhile was opened by someone else."
 			break
 		# if crypt_silent=1 and some error occurs, enter shell quietly
-		elif [ \( ${CRYPT_SILENT} -eq 1 \) -a \( \( \( ${DEV_ERROR} -eq 1 \) -o \( ${KEY_ERROR} -eq 1 \) \) -o \( ${KEYDEV_ERROR} -eq 1 \) \) ]
+		elif [ \( ${CRYPT_SILENT} -eq 1 \) -a \( \( \( ${DEV_ERROR} -eq 1 \) \) ]
+		then
+			run_emergency_shell
+		elif [ \( ${CRYPT_SILENT} -eq 1 \) -a \( \( \( ${HEADER_ERROR} -eq 1 \) \) -o \( ${HEADERDEV_ERROR} -eq 1 \) \) ]
+		then
+			run_emergency_shell
+		elif [ \( ${CRYPT_SILENT} -eq 1 \) -a \( \( \( ${KEY_ERROR} -eq 1 \) \) -o \( ${KEYDEV_ERROR} -eq 1 \) \) ]
 		then
 			run_emergency_shell
 		elif [ ${DEV_ERROR} -eq 1 ]
 		then
 			prompt_user "LUKS_DEVICE" "${LUKS_NAME}"
 			DEV_ERROR=0
+		elif [ ${HEADER_ERROR} -eq 1 ]
+		then
+			prompt_user "LUKS_HEADER" "${LUKS_NAME} header"
+			HEADER_ERROR=0
+		elif [ ${HEADERDEV_ERROR} -eq 1 ]
+		then
+			prompt_user "LUKS_HEADERDEV" "${LUKS_NAME} header device"
+			HEADERDEV_ERROR=0
 		elif [ ${KEY_ERROR} -eq 1 ]
 		then
 			prompt_user "LUKS_KEY" "${LUKS_NAME} key"
@@ -1877,18 +1904,93 @@ openLUKS() {
 				continue
 			fi
 
-			if ! run cryptsetup isLuks ${LUKS_DEVICE}
+			# Handle headers
+			if [ -n "${LUKS_HEADER}" ]
+			then
+				local REAL_LUKS_HEADERDEV="${LUKS_HEADERDEV}"
+				if [ ! -e "${mntheader}${LUKS_HEADER}" ]
+				then
+					REAL_LUKS_HEADERDEV=$(find_real_device "${LUKS_HEADERDEV}")
+					if [ -b "${REAL_LUKS_HEADERDEV}" ]
+					then
+						good_msg "Using header device ${REAL_LUKS_HEADERDEV}." ${CRYPT_SILENT}
+					else
+						good_msg "Please insert removable device ${LUKS_HEADERDEV} for ${LUKS_NAME}" ${CRYPT_SILENT}
+						# abort after 10 secs
+						local count=10
+						while [ ${count} -gt 0 ]
+						do
+							count=$((count-1))
+							sleep 1
+							REAL_LUKS_HEADERDEV=$(find_real_device "${LUKS_HEADERDEV}")
+							if [ -b "${REAL_LUKS_HEADERDEV}" ]
+							then
+								good_msg "Removable device ${REAL_LUKS_HEADERDEV} detected." ${CRYPT_SILENT}
+								break
+							fi
+						done
+						if [ ! -b "${REAL_LUKS_HEADERDEV}" ]
+						then
+							eval CRYPT_${TYPE}_HEADER=${LUKS_HEADER}
+							bootstrapHeader ${TYPE}
+							eval LUKS_HEADERDEV='"${CRYPT_'${TYPE}'_HEADERDEV}"'
+							REAL_LUKS_HEADERDEV=$(find_real_device "${LUKS_HEADERDEV}")
+							if [ ! -b "${REAL_LUKS_HEADERDEV}" ]
+							then
+								HEADERDEV_ERROR=1
+								bad_msg "Removable device ${LUKS_HEADERDEV} not found." ${CRYPT_SILENT}
+								continue
+							fi
+							# continue otherwise will mount headerdev which is mounted by bootstrap
+							continue
+						fi
+					fi
+
+					# At this point a device was recognized, now let's see if the header is there
+					[ ! -d "${mntheader}" ] && mkdir -p "${mntheader}" >/dev/null 2>&1
+
+					# determine fs -- 'auto' will not trigger module loading!
+					LUKS_HEADERDEV_FSTYPE=$(determine_fs "${REAL_LUKS_HEADERDEV}" "${LUKS_HEADERDEV_FSTYPE}")
+
+					if ! run mount -n -t ${LUKS_HEADERDEV_FSTYPE} -o ro ${REAL_LUKS_HEADERDEV} ${mntheader} >/dev/null 2>&1
+					then
+						HEADERDEV_ERROR=1
+						bad_msg "Mounting of device ${REAL_LUKS_HEADERDEV} failed." ${CRYPT_SILENT}
+						continue
+					fi
+
+					good_msg "Removable device ${REAL_LUKS_HEADERDEV} mounted." ${CRYPT_SILENT}
+					sleep 2
+
+					# headerfile exists?
+					if [ ! -e "${mntheader}${LUKS_HEADER}" ]
+					then
+						run umount -n "${mntheader}" >/dev/null 2>&1
+						HEADER_ERROR=1
+						HEADERDEV_ERROR=1
+						bad_msg "Header {LUKS_HEADER} on device ${REAL_LUKS_HEADERDEV} not found." ${CRYPT_SILENT}
+						continue
+					fi
+				fi
+
+				if ! run cryptsetup isLuks ${LUKS_DEVICE} --header ${mntheader}${LUKS_HEADER}
+				then
+					bad_msg "The LUKS device ${LUKS_DEVICE} does not contain a LUKS header" ${CRYPT_SILENT}
+					DEV_ERROR=1
+					continue
+				fi
+
+				# At this point a candidate header exists (either mounted before or not)
+				good_msg "${LUKS_HEADER} on device ${REAL_LUKS_HEADERDEV} found" ${CRYPT_SILENT}
+
+				cryptsetup_options="${cryptsetup_options} --header ${mntheader}${LUKS_HEADER}"
+			elif ! run cryptsetup isLuks ${LUKS_DEVICE}
 			then
 				bad_msg "The LUKS device ${LUKS_DEVICE} does not contain a LUKS header" ${CRYPT_SILENT}
 				DEV_ERROR=1
 				continue
 			fi
 
-			if [ -n "${cryptsetup_options}" ]
-			then
-				good_msg "Using the following cryptsetup options for ${LUKS_NAME}: ${cryptsetup_options}" ${CRYPT_SILENT}
-			fi
-
 			# Handle keys
 			if [ -n "${LUKS_KEY}" ]
 			then
@@ -1946,6 +2048,7 @@ openLUKS() {
 
 					good_msg "Removable device ${REAL_LUKS_KEYDEV} mounted." ${CRYPT_SILENT}
 					sleep 2
+
 					# keyfile exists?
 					if [ ! -e "${mntkey}${LUKS_KEY}" ]
 					then
@@ -1956,6 +2059,7 @@ openLUKS() {
 						continue
 					fi
 				fi
+
 				# At this point a candidate key exists (either mounted before or not)
 				good_msg "${LUKS_KEY} on device ${REAL_LUKS_KEYDEV} found" ${CRYPT_SILENT}
 
@@ -1975,7 +2079,13 @@ openLUKS() {
 					cryptsetup_options="${cryptsetup_options} -d ${mntkey}${LUKS_KEY}"
 				fi
 			fi
-			# At this point, keyfile or not, we're ready!
+
+			if [ -n "${cryptsetup_options}" ]
+			then
+				good_msg "Using the following cryptsetup options for ${LUKS_NAME}: ${cryptsetup_options}" ${CRYPT_SILENT}
+			fi
+
+			# At this point, {header,key}file or not, we're ready!
 			crypt_filter "${gpg_cmd}cryptsetup ${cryptsetup_options} luksOpen ${LUKS_DEVICE} ${LUKS_NAME}"
 			crypt_filter_ret=$?
 
@@ -1992,6 +2102,8 @@ openLUKS() {
 			then
 				bad_msg "Failed to open LUKS device ${LUKS_DEVICE}" ${CRYPT_SILENT}
 				DEV_ERROR=1
+				HEADER_ERROR=1
+				HEADERDEV_ERROR=1
 				KEY_ERROR=1
 				KEYDEV_ERROR=1
 			fi
@@ -2000,11 +2112,17 @@ openLUKS() {
 
 	udevsettle
 
+	if run mountpoint "${mntheader}" >/dev/null 2>&1
+	then
+		run umount "${mntheader}" >/dev/null 2>&1
+	fi
+
 	if run mountpoint "${mntkey}" >/dev/null 2>&1
 	then
 		run umount "${mntkey}" >/dev/null 2>&1
 	fi
 
+	[ -d "${mntheader}" ] && run rmdir -p "${mntheader}" >/dev/null 2>&1
 	[ -d "${mntkey}" ] && run rmdir -p "${mntkey}" >/dev/null 2>&1
 }
 
@@ -2341,8 +2459,14 @@ start_LUKS() {
 	# if key is set but neither ssh enabled or key device is given, find
 	# the key device
 
-	[ -n "${CRYPT_ROOT_KEY}" ] && [ -z "${CRYPT_ROOT_KEYDEV}" ] \
-		&& sleep 6 && bootstrapKey "ROOT"
+	if [ -n "${CRYPT_ROOT_KEY}" ]
+	then
+		( [ -z "${CRYPT_ROOT_KEYDEV}" ] || [ -z "${CRYPT_ROOT_HEADERDEV}" ] ) \
+			&& sleep 6
+
+		[ -z "${CRYPT_ROOT_KEYDEV}" ] && bootstrapKey "ROOT"
+		[ -z "${CRYPT_ROOT_HEADERDEV}" ] && bootstrapHeader "ROOT"
+	fi
 
 	if [ -n "${CRYPT_ROOT}" ]
 	then
@@ -2356,9 +2480,15 @@ start_LUKS() {
 		fi
 	fi
 
-	# same for swap, but no need to sleep if root was unencrypted
-	[ -n "${CRYPT_SWAP_KEY}" ] && [ -z "${CRYPT_SWAP_KEYDEV}" ] \
-		&& { [ -z "${CRYPT_ROOT}" ] && sleep 6; bootstrapKey "SWAP"; }
+	if [ -n "${CRYPT_SWAP_KEY}" ]
+	then
+		# same for swap, but no need to sleep if root was unencrypted
+		( [ -z "${CRYPT_ROOT_KEYDEV}" ] || [ -z "${CRYPT_ROOT_HEADERDEV}" ] ) \
+			&& [ -z "${CRYPT_ROOT}" ] && sleep 6
+
+		[ -z "${CRYPT_SWAP_KEYDEV}" ] && bootstrapKey "SWAP"
+		[ -z "${CRYPT_SWAP_HEADERDEV}" ] && bootstrapHeader "SWAP"
+	fi
 
 	if [ -n "${CRYPT_SWAP}" ]
 	then

diff --git a/defaults/linuxrc b/defaults/linuxrc
index 6ede740..ff08ba2 100644
--- a/defaults/linuxrc
+++ b/defaults/linuxrc
@@ -228,6 +228,15 @@ do
 		crypt_swap_options=*)
 			CRYPT_SWAP_OPTIONS=$(echo ${CRYPT_SWAP_OPTIONS} ${x#*=} | sed -e 's/,/ /g')
 		;;
+		root_header=*)
+			CRYPT_ROOT_HEADER=${x#*=}
+		;;
+		root_headerdev=*)
+			CRYPT_ROOT_HEADERDEV=${x#*=}
+		;;
+		root_headerdev_fstype=*)
+			CRYPT_ROOT_HEADERDEV_FSTYPE=${x#*=}
+		;;
 		root_key=*)
 			CRYPT_ROOT_KEY=${x#*=}
 		;;
@@ -245,6 +254,15 @@ do
 			fi
 			unset tmp_enabled
 		;;
+		swap_header=*)
+			CRYPT_SWAP_HEADER=${x#*=}
+		;;
+		swap_headerdev=*)
+			CRYPT_SWAP_HEADERDEV=${x#*=}
+		;;
+		swap_headerdev_fstype=*)
+			CRYPT_SWAP_HEADERDEV_FSTYPE=${x#*=}
+		;;
 		swap_key=*)
 			CRYPT_SWAP_KEY=${x#*=}
 		;;

diff --git a/doc/genkernel.8.txt b/doc/genkernel.8.txt
index 262027b..33f7733 100644
--- a/doc/genkernel.8.txt
+++ b/doc/genkernel.8.txt
@@ -688,6 +688,19 @@ recognized by the kernel itself.
     cryptsetup when opening swap volume. Can be specified multiple
     times or separate multiple options with a comma.
 
+*root_header*=<...>::
+    In case your encrypted root uses a LUKS detached header, you can
+    use a device like a usb pen to store the header file. This value
+    should be the key path relative to the mount point.
+
+*root_headerdev*=<...>::
+    If necessary provide the name of the device that carries the
+    root_header. If unset while using root_header, it will automatically
+    look for the device in every boot.
+
+*root_headerdev_fstype*=<...>::
+    Used filesystem for *root_headerdev*. See *rootfstype* for more details.
+
 *root_key*=<...>::
     In case your root is encrypted with a key, you can use a device
     like a  usb pen to store the key.  This value should be the key
@@ -706,6 +719,15 @@ recognized by the kernel itself.
     with SSD setups.  Have a look at 'https://en.wikipedia.org/wiki/TRIM'
     for more information.
 
+*swap_header*=<...>::
+    Same as root_header for swap.
+
+*swap_headerdev*=<...>::
+    Same as root_headerdev for swap.
+
+*swap_headerdev_fstype*=<...>::
+    Used filesystem for *swap_headerdev*. See *rootfstype* for more details.
+
 *swap_key*=<...>::
     Same as root_key for swap.
 


^ permalink raw reply related	[flat|nested] 11+ messages in thread

end of thread, other threads:[~2022-05-16  5:34 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2021-02-07 18:23 [gentoo-commits] proj/genkernel:master commit in: defaults/, doc/ Thomas Deutschmann
  -- strict thread matches above, loose matches on Subject: below --
2022-05-16  5:34 Robin H. Johnson
2021-03-14 20:05 Thomas Deutschmann
2020-09-02 13:52 Thomas Deutschmann
2020-08-28 20:18 Thomas Deutschmann
2020-08-26 22:54 Thomas Deutschmann
2020-07-16 18:36 Thomas Deutschmann
2019-11-24 20:00 Thomas Deutschmann
2019-08-07 15:46 Thomas Deutschmann
2019-08-07 15:46 Thomas Deutschmann
2017-01-04  0:11 Robin H. Johnson

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox