summaryrefslogtreecommitdiff
path: root/meta/recipes-core/initrdscripts/files
diff options
context:
space:
mode:
authorJérémy Rosen <jeremy.rosen@openwide.fr>2016-03-11 11:38:31 +0100
committerRichard Purdie <richard.purdie@linuxfoundation.org>2016-03-20 22:57:55 +0000
commit2c10ca0fe612818cb43931b969ad2af5502f1e84 (patch)
tree23561d1723ac04fbb6102af658d7279c26b49f67 /meta/recipes-core/initrdscripts/files
parent2ebf697b46c42cee8bfa6d2e6087397f8cce385c (diff)
downloadopenembedded-core-2c10ca0fe612818cb43931b969ad2af5502f1e84.tar.gz
openembedded-core-2c10ca0fe612818cb43931b969ad2af5502f1e84.tar.bz2
openembedded-core-2c10ca0fe612818cb43931b969ad2af5502f1e84.zip
init-live : make it easier to add custom boot targets
When booting from the live image, the label from the bootloader is passed to init.sh. init.sh uses the label to either boot a live image or call a script to take over and install the system. It is possible to add new labels to the bootloader via the LABELS family of variables, but the names in init.sh were hardcoded to install and install-efi this patch checks if a shell script with the same name as the label is available instead of using a hardcoded list. Any recipe can add such file and this provide a new boot target to the live image Signed-off-by: Jérémy Rosen <jeremy.rosen@openwide.fr> Signed-off-by: Ross Burton <ross.burton@intel.com>
Diffstat (limited to 'meta/recipes-core/initrdscripts/files')
-rw-r--r--meta/recipes-core/initrdscripts/files/init-live.sh18
1 files changed, 6 insertions, 12 deletions
diff --git a/meta/recipes-core/initrdscripts/files/init-live.sh b/meta/recipes-core/initrdscripts/files/init-live.sh
index d852c5737f..f698535980 100644
--- a/meta/recipes-core/initrdscripts/files/init-live.sh
+++ b/meta/recipes-core/initrdscripts/files/init-live.sh
@@ -214,11 +214,7 @@ mount_and_boot() {
boot_live_root
}
-case $label in
- boot)
- mount_and_boot
- ;;
- install|install-efi)
+if [ "$label" != "boot" -a -f $label.sh ] ; then
if [ -f /run/media/$i/$ISOLINUX/$ROOT_IMAGE ] ; then
./$label.sh $i/$ISOLINUX $ROOT_IMAGE $video_mode $vga_mode $console_params
else
@@ -226,10 +222,8 @@ case $label in
fi
# If we're getting here, we failed...
- fatal "Installation image failed"
- ;;
- *)
- # Not sure what boot label is provided. Try to boot to avoid locking up.
- mount_and_boot
- ;;
-esac
+ fatal "Target $label failed"
+fi
+
+mount_and_boot
+