Fixup for bugs from patch in bug 174294.

The previous patch from bug #174294 still contained some bugs in the linuxrc
and scripts, that caused a failure during boot. Clean them up with one more
patch from Nelson Batalha <nelson_batalha@hotmail.com>, again on bug #174294.


git-svn-id: svn+ssh://svn.gentoo.org/var/svnroot/genkernel/trunk@523 67a159dc-881f-0410-a524-ba9dfbe2cb84
cleanup-cruft
Robin H. Johnson 18 years ago
parent 94e9ac1630
commit 43b1f3aa7e

@ -2,6 +2,12 @@
# Copyright 2006-2007 Gentoo Foundation; Distributed under the GPL v2 # Copyright 2006-2007 Gentoo Foundation; Distributed under the GPL v2
# $Header: $ # $Header: $
26 Jul 2007; Robin H. Johnson <robbat2@gentoo.org> generic/initrd.scripts,
generic/linuxrc:
The previous patch from bug #174294 still contained some bugs in the linuxrc
and scripts, that caused a failure during boot. Clean them up with one more
patch from Nelson Batalha <nelson_batalha@hotmail.com>, again on bug #174294.
26 Jul 2007; Andrew Gaffney <agaffney@gentoo.org> netboot/linuxrc.x: 26 Jul 2007; Andrew Gaffney <agaffney@gentoo.org> netboot/linuxrc.x:
enhanced netboot linuxrc from gustavoz enhanced netboot linuxrc from gustavoz

@ -107,29 +107,36 @@ findkeymount() {
do do
# Check for a block device to mount # Check for a block device to mount
if [ -b "${x}" ] if [ -b "${x}" ]
then
if [ ${crypt_silent} = '' ]
then then
good_msg "Attempting to mount key media:- ${x}" good_msg "Attempting to mount key media:- ${x}"
mount -r -t auto ${x} ${NEW_ROOT}/mnt/key \
> /dev/null 2>&1
fi fi
mount -r -t auto ${x} ${NEW_ROOT}/mnt/keydev \
> /dev/null 2>&1
if [ "$?" = '0' ] if [ "$?" = '0' ]
then then
# Check for the key # Check for the key
if [ -e ${NEW_ROOT}/mnt/key/${SUBDIR}/${KEYNAME} ] if [ -e ${NEW_ROOT}/mnt/keydev/${LUKS_ROOT_KEY} ]
then then
KEY_ROOT="${x}" LUKS_ROOT_KEYDEV="${x}"
umount ${NEW_ROOT}/mnt/keydev
break break
else else
umount ${NEW_ROOT}/mnt/key umount ${NEW_ROOT}/mnt/keydev
fi fi
fi fi
fi fi
done done
if [ "${KEY_ROOT}" != '' ] if [ "${LUKS_ROOT_KEYDEV}" != '' ]
then
if [ ${crypt_silent} = '' ]
then then
good_msg "Key media found on ${x}" good_msg "Key media found on ${x}"
fi fi
fi fi
fi
} }

@ -72,16 +72,13 @@ do
CDROOT=1 CDROOT=1
CDROOT_DEV=`parse_opt "${x}"` CDROOT_DEV=`parse_opt "${x}"`
;; ;;
# Start livecd loop, looptype options and encryption # Start livecd loop, looptype options
loop\=*) loop\=*)
LOOP=`parse_opt "${x}"` LOOP=`parse_opt "${x}"`
;; ;;
looptype\=*) looptype\=*)
LOOPTYPE=`parse_opt "${x}"` LOOPTYPE=`parse_opt "${x}"`
;; ;;
loop_crypt\=*)
LOOP_CRYPT=`parse_opt "${x}"`
;;
# Start Device Manager options # Start Device Manager options
devfs) devfs)
USE_DEVFS_NORMAL=1 USE_DEVFS_NORMAL=1
@ -182,6 +179,9 @@ do
crypt_swap\=*) crypt_swap\=*)
LUKS_SWAP=`parse_opt "${x}"` LUKS_SWAP=`parse_opt "${x}"`
;; ;;
crypt_silent\=*)
LUKS_SILENT=`parse_opt "${x}"`
;;
real_rootflags\=*) real_rootflags\=*)
REAL_ROOTFLAGS=`parse_opt "${x}"` REAL_ROOTFLAGS=`parse_opt "${x}"`
;; ;;
@ -236,8 +236,11 @@ setup_md_device
# Scan volumes # Scan volumes
startVolumes startVolumes
# Initialize LUKS root device # Initialize LUKS root device except for livecd's
startLUKS if [ "${CDROOT}" -ne '1' ]
then
startLUKS
fi
# Set up unionfs # Set up unionfs
mkdir -p ${NEW_ROOT} mkdir -p ${NEW_ROOT}
@ -264,7 +267,7 @@ then
mount -t tmpfs tmpfs ${NEW_ROOT} mount -t tmpfs tmpfs ${NEW_ROOT}
fi fi
for i in dev mnt mnt/cdrom mnt/livecd mnt/key tmp tmp/.initrd mnt/gentoo sys for i in dev mnt mnt/cdrom mnt/livecd mnt/keydev tmp tmp/.initrd mnt/gentoo sys
do do
mkdir -p ${NEW_ROOT}/$i mkdir -p ${NEW_ROOT}/$i
chmod 755 ${NEW_ROOT}/$i chmod 755 ${NEW_ROOT}/$i
@ -496,37 +499,41 @@ then
# If encrypted, find key and mount, otherwise mount as usual # If encrypted, find key and mount, otherwise mount as usual
if [ "${LOOP_CRYPT}" != '' ] if [ "${LUKS_ROOT}" != '' ]
then then
good_msg 'You booted an encrypted livecd' if [ "${LUKS_SILENT}" = '' ]
KEYNAME=$(head -n 1 ${NEW_ROOT}/mnt/cdrom/livecd)
if [ "${KEYNAME}" = '' ]
then then
good_msg 'It's not locked with a gpg key, attempting to decrypt manually' good_msg 'You booted an encrypted livecd'
losetup -e ${LOOP_CRYPT} /dev/loop1 ${NEW_ROOT}/mnt/cdrom/${LOOPEXT}${LOOP} fi
LUKS_ROOT_KEY=$(head -n 1 ${NEW_ROOT}/mnt/cdrom/livecd)
else if [ "${LUKS_ROOT_KEY}" ]
good_msg 'Livecd locked with gpg key' then
bootstrapKey bootstrapKey
good_msg 'Attempting to decrypt with key'
losetup -K ${NEW_ROOT}/mnt/key/${SUBDIR}/${KEYNAME} -e ${LOOP_CRYPT} /dev/loop1 \
${NEW_ROOT}/mnt/cdrom/${LOOPEXT}${LOOP}
fi fi
test_success 'Unencrypting loop' losetup /dev/loop0 ${NEW_ROOT}/mnt/cdrom/${LOOPEXT}${LOOP}
test_success 'Preparing loop filesystem'
LUKS_ROOT='/dev/loop0'
startLUKS
case ${LOOPTYPE} in case ${LOOPTYPE} in
squashfs)
MOUNTTYPE="squashfs"
normal) normal)
MOUNTTYPE="ext2" MOUNTTYPE="ext2"
;;
*)
MOUNTTYPE="${LOOPTYPE}"
;;
esac esac
mount -t ${MOUNTTYPE} -o ro /dev/loop1 ${NEW_ROOT}/mnt/livecd
test_success 'Mount filesystem, checking key' mount -t ${MOUNTTYPE} -o ro /dev/mapper/root ${NEW_ROOT}/mnt/livecd
test_success 'Mount filesystem'
FS_LOCATION='mnt/livecd' FS_LOCATION='mnt/livecd'
@ -590,7 +597,7 @@ then
test_success 'mount /dev/loop0 /' test_success 'mount /dev/loop0 /'
FS_LOCATION='mnt/livecd' FS_LOCATION='mnt/livecd'
fi fi
fi
# #
# End cdrom looptype determination and mounting if necessary # End cdrom looptype determination and mounting if necessary
# #

Loading…
Cancel
Save