From: Hongxu Jia Date: Mon, 11 Nov 2013 11:56:54 +0000 (+0800) Subject: kernel-grub.bbclass: support /boot area within root partition X-Git-Tag: rev_ivi_2015_02_04~10339 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=6d43e285540c424474468e00dd0ae585294250b5;p=scm%2Fbb%2Ftizen-distro.git kernel-grub.bbclass: support /boot area within root partition Previously, it supported the situation that /boot area with separate boot partition: ... menuentry "Update bzImage-3.10.10-WR6.0.0.0_standard-3.10" { set root=(hd0,1) linux /bzImage-3.10.10-WR6.0.0.0_standard root=/dev/sdb1 rw ip=dhcp } ... But didn't consider the situation that /boot within root partition: ... menuentry "Update bzImage-3.10.10-WR6.0.0.0_standard-3.10" { set root=(hd0,1) linux /boot/bzImage-3.10.10-WR6.0.0.0_standard root=/dev/sdb1 rw ip=dhcp } ... This fix supported them both. [YOCTO #5514] (From OE-Core rev: 53d342db9f9995564573715f28c3e4c9c8c68bf9) Signed-off-by: Hongxu Jia Signed-off-by: Saul Wold Signed-off-by: Richard Purdie --- diff --git a/meta/classes/kernel-grub.bbclass b/meta/classes/kernel-grub.bbclass index 70564f0..85721ff 100644 --- a/meta/classes/kernel-grub.bbclass +++ b/meta/classes/kernel-grub.bbclass @@ -40,10 +40,11 @@ pkg_preinst_kernel-image_append () { pkg_postinst_kernel-image_prepend () { get_new_grub_cfg() { grubcfg="$1" + old_image="$2" title="Update ${KERNEL_IMAGETYPE}-${KERNEL_VERSION}-${PV}" if [ "${grubcfg##*/}" = "grub.cfg" ]; then rootfs=`grep " *linux \+[^ ]\+ \+root=" $grubcfg -m 1 | \ - sed "s# *linux \+[^ ]\+ \+root=# linux /${KERNEL_IMAGETYPE}-${KERNEL_VERSION} root=#"` + sed "s#${old_image}#${old_image%/*}/${KERNEL_IMAGETYPE}-${KERNEL_VERSION}#"` echo "menuentry \"$title\" {" echo " set root=(hd0,1)" @@ -51,7 +52,7 @@ pkg_postinst_kernel-image_prepend () { echo "}" elif [ "${grubcfg##*/}" = "menu.list" ]; then rootfs=`grep "kernel \+[^ ]\+ \+root=" $grubcfg -m 1 | \ - sed "s#kernel \+[^ ]\+ \+root=#kernel /${KERNEL_IMAGETYPE}-${KERNEL_VERSION} root=#"` + sed "s#${old_image}#${old_image%/*}/${KERNEL_IMAGETYPE}-${KERNEL_VERSION}#"` echo "default 0" echo "timeout 30" @@ -79,9 +80,9 @@ pkg_postinst_kernel-image_prepend () { fi # Don't update grubcfg at first install while old bzImage doesn't exist. - if [ -f "$D/boot/$old_image" ]; then + if [ -f "$D/boot/${old_image##*/}" ]; then grubcfgtmp="$grubcfg.tmp" - get_new_grub_cfg "$grubcfg" > $grubcfgtmp + get_new_grub_cfg "$grubcfg" "$old_image" > $grubcfgtmp get_old_grub_cfg "$grubcfg" >> $grubcfgtmp mv $grubcfgtmp $grubcfg echo "Caution! Update kernel may affect kernel-module!"