summaryrefslogtreecommitdiffstats
path: root/client/engine/Boot.lib
diff options
context:
space:
mode:
Diffstat (limited to 'client/engine/Boot.lib')
-rwxr-xr-xclient/engine/Boot.lib907
1 files changed, 685 insertions, 222 deletions
diff --git a/client/engine/Boot.lib b/client/engine/Boot.lib
index e9ddf38e..6808f094 100755
--- a/client/engine/Boot.lib
+++ b/client/engine/Boot.lib
@@ -37,12 +37,15 @@
#@version 1.1.0 - Nuevo parámetro opcional con opciones de arranque del Kernel.
#@author Ramon Gomez, ETSII Universidad de Sevilla
#@date 2015-07-15
+#@version 1.1.1 - UEFI: Permite iniciar linux recien instalados (ticket #802 #890)
+#@author Irina Gomez, ETSII Universidad de Sevilla
+#@date 2019-03-13
#*/ ##
function ogBoot ()
{
# Variables locales.
local PART TYPE MNTDIR PARAMS KERNEL INITRD APPEND FILE LOADER f
-local EFIDISK EFIPART EFIDIR BOOTLABEL BOOTNO
+local EFIDISK EFIPART EFIDIR BOOTLABEL BOOTLOADER BOOTNO DIRGRUB b
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
@@ -63,6 +66,8 @@ case "$TYPE" in
Linux|Android)
# Si no se indican, obtiene los parámetros de arranque para Linux.
PARAMS="${3:-$(ogLinuxBootParameters $1 $2 2>/dev/null)}"
+ # Si no existe y el UEFI buscar en particion ESP
+ [ -z "$PARAMS" ] && ogIsEfiActive && PARAMS="$(ogLinuxBootParameters $(ogGetEsp))"
# Si no existe, buscar sistema de archivo /boot en /etc/fstab.
if [ -z "$PARAMS" -a -e $MNTDIR/etc/fstab ]; then
# Localizar S.F. /boot en /etc/fstab del S.F. actual.
@@ -79,28 +84,39 @@ case "$TYPE" in
[ -e "$MNTDIR/etc" ] && APPEND=$(echo $APPEND | awk -v P="$PART " '{sub (/root=[-+=_/a-zA-Z0-9]* /,"root="P);print}')
# Comprobar tipo de sistema.
if ogIsEfiActive; then
- # Obtener parcición EFI.
- read -e EFIDISK EFIPART <<<"$(ogGetEsp)"
- [ -n "$EFIPART" ] || ogRaiseError $OG_ERR_PARTITION "ESP" || return $?
# Comprobar si el Kernel está firmado.
if ! file -k "$MNTDIR/$KERNEL" | grep -q "EFI app"; then
ogRaiseError $OG_ERR_NOTOS "$1 $2 ($TYPE, EFI)"
return $?
fi
- # Crear directorio para el cargador y copiar los ficheros.
- EFIDIR=$(ogMount $EFIDISK $EFIPART) || exit $?
+
BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2)
- mkdir -p $EFIDIR/EFI/$BOOTLABEL
- cp $MNTDIR/$KERNEL $EFIDIR/EFI/$BOOTLABEL/vmlinuz.efi
- cp $MNTDIR/$INITRD $EFIDIR/EFI/$BOOTLABEL/initrd.img
- # Borrar cargador guardado con la misma etiqueta.
- BOOTNO=$(efibootmgr -v | awk -v L=$BOOTLABEL '{if ($2==L) print $1}')
- [ -n "$BOOTNO" ] && efibootmgr -B -b ${BOOTNO:4:4}
+ BOOTLOADER="shimx64.efi"
+ # Obtener parcición EFI.
+ read -e EFIDISK EFIPART <<<"$(ogGetEsp)"
+ # TODO: Comprobamos que existe la BOOTLABEL, si no buscamos por sistema operativo
+ if [ "$(ogGetPath $EFIDISK $EFIPART EFI/$BOOTLABEL)" == "" ]; then
+ OSVERSION="$(ogGetOsVersion $1 $2)"
+ case $OSVERSION in
+ *SUSE*)
+ BOOTLABEL="opensuse"
+ ;;
+ *Fedora*)
+ BOOTLABEL="fedora"
+ ;;
+ *Ubuntu*)
+ BOOTLABEL="ubuntu"
+ ;;
+ *)
+ ogRaiseError $OG_ERR_NOTFOUND "$EFIDISK $EFIPART Boot loader"; return $?
+ ;;
+ esac
+ fi
+
# Crear orden de arranque (con unos valores por defecto).
- efibootmgr -C -d $(ogDiskToDev $EFIDISK) -p $EFIPART -L "$BOOTLABEL" -l /EFI/$BOOTLABEL/vmlinuz.efi -u "initrd=/EFI/$BOOTLABEL/initrd.img $APPEND"
+ ogNvramAddEntry $BOOTLABEL "/EFI/$BOOTLABEL/Boot/$BOOTLOADER"
# Marcar próximo arranque y reiniciar.
- BOOTNO=$(efibootmgr -v | awk -v L="$BOOTLABEL" '{if ($2==L) print $1}')
- [ -n "$BOOTNO" ] && efibootmgr -n ${BOOTNO:4:4}
+ ogNvramSetNext "$BOOTLABEL"
reboot
else
# Arranque BIOS: configurar kernel Linux con los parámetros leídos de su GRUB.
@@ -111,29 +127,23 @@ case "$TYPE" in
Windows)
# Comprobar tipo de sistema.
if ogIsEfiActive; then
+ BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2)
# Obtener parcición EFI.
read -e EFIDISK EFIPART <<<"$(ogGetEsp)"
[ -n "$EFIPART" ] || ogRaiseError $OG_ERR_PARTITION "ESP" || return $?
EFIDIR=$(ogMount $EFIDISK $EFIPART) || exit $?
# Comprobar cargador (si no existe buscar por defecto en ESP).
- LOADER=$(ogGetPath $1 $2 /Boot/bootmgfw.efi)
- [ -z "$LOADER" ] && LOADER=$(ogGetPath $EFIDIR/EFI/Microsoft/Boot/bootmgfw.efi)
+ LOADER=$(ogGetPath $EFIDIR/EFI/$BOOTLABEL/Boot/bootmgfw.efi)
+ [ -z "$LOADER" ] && BOOTLABEL=Microsoft && LOADER=$(ogGetPath $EFIDIR/EFI/Microsoft/Boot/bootmgfw.efi)
[ -n "$LOADER" ] || ogRaiseError $OG_ERR_NOTOS "$1 $2 ($TYPE, EFI)" || return $?
- # Crear directorio para el cargador y copiar los ficheros.
- BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2)
- mkdir -p $EFIDIR/EFI/$BOOTLABEL
- cp -a $(dirname "$LOADER") $EFIDIR/EFI/$BOOTLABEL
- # Borrar cargador guardado con la misma etiqueta.
- BOOTNO=$(efibootmgr -v | awk -v L=$BOOTLABEL '{if ($2==L) print $1}')
- [ -n "$BOOTNO" ] && efibootmgr -B -b ${BOOTNO:4:4}
+
# Crear orden de arranque (con unos valores por defecto).
- efibootmgr -C -d $(ogDiskToDev $EFIDISK) -p $EFIPART -L "$BOOTLABEL" -l "/EFI/$BOOTLABEL/Boot/BOOTMGFW.EFI"
+ ogNvramAddEntry $BOOTLABEL "/EFI${LOADER#*EFI}"
# Marcar próximo arranque y reiniciar.
- BOOTNO=$(efibootmgr -v | awk -v L="$BOOTLABEL" '{if ($2==L) print $1}')
- [ -n "$BOOTNO" ] && efibootmgr -n ${BOOTNO:4:4}
+ ogNvramSetNext "$BOOTLABEL"
reboot
else
- # Arranque BIOS: compruebar si hay un cargador de Windows.
+ # Arranque BIOS: comprueba si hay un cargador de Windows.
for f in io.sys ntldr bootmgr; do
FILE="$(ogGetPath $1 $2 $f 2>/dev/null)"
[ -n "$FILE" ] && LOADER="$f"
@@ -167,7 +177,7 @@ case "$TYPE" in
;;
GrubLoader)
# Reiniciar.
- reboot
+ #reboot
;;
*) ogRaiseError $OG_ERR_NOTOS "$1 $2 ${TYPE:+($TYPE)}"
return $?
@@ -471,7 +481,7 @@ fi
#TODO, solo si es ntfs o fat
PARTYPE=$(ogGetPartitionId $1 $2)
case "$PARTYPE" in
- 1|4|6|7|b|c|e|f|17|700)
+ 1|4|6|7|b|c|e|f|17|700|EF00)
;;
*)
return $(ogRaiseError $OG_ERR_PARTITION; echo $?)
@@ -490,9 +500,7 @@ main_part=$PART
fix_first_sector=yes
EOF
-spartlnx.run -cui -nm -a -f $FILE &
-sleep 5
-ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null
+timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -a -f $FILE
rm -f $FILE
}
@@ -518,12 +526,15 @@ rm -f $FILE
#@version 1.1.0 - Soporte para Windows 10.
#@author Ramon Gomez, ETSII Universidad de Sevilla
#@date 2016-01-19
+#@version 1.1.1 - Compatibilidad con UEFI (ticket #802 #889)
+#@author Irina Gomez, ETSII Universidad de Sevilla
+#@date 2019-01-28
#*/ ##
function ogWindowsBootParameters ()
{
# Variables locales.
-local PART DISK FILE WINVER MOUNT
+local PART DISK BOOTLABEL BCDFILE BOOTDISK BOOTPART FILE WINVER MOUNT
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
@@ -541,6 +552,19 @@ ogDiskToDev $1 $2 || return $(ogRaiseError $OG_ERR_PARTITION; echo $?)
let DISK=$1-1
PART=$2
FILE=/tmp/temp$$
+if ogIsEfiActive; then
+ read BOOTDISK BOOTPART <<< $(ogGetEsp)
+ ogUnmount $BOOTDISK $BOOTPART || ogRaiseError $OG_ERR_PARTITION "ESP: $BOOTDISK $BOOTPART" || return $?
+
+ let BOOTDISK=$BOOTDISK-1
+ BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2)
+ BCDFILE="boot_BCD_file=/EFI/$BOOTLABEL/Boot/BCD"
+else
+ BOOTDISK=$DISK
+ BOOTPART=$PART
+ BCDFILE=""
+fi
+
# Obtener versión de Windows.
WINVER=$(ogGetOsVersion $1 $2 | awk -F"[: ]" '$1=="Windows" {if ($3=="Server") print $2,$3,$4; else print $2,$3;}')
@@ -559,69 +583,94 @@ ogUnmount $1 $2 || return $(ogRaiseError $OG_ERR_PARTITION; echo $?)
#Preparando instruccion Windows Resume Application
cat > $FILE <<EOF
-boot_disk=$DISK
-boot_main_part=$PART
+boot_disk=$BOOTDISK
+boot_main_part=$BOOTPART
+$BCDFILE
disk=$DISK
main_part=$PART
boot_entry=Windows Resume Application
EOF
-spartlnx.run -cui -nm -w -f $FILE &
-sleep 5
-ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null
+timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE
-
#Preparando instruccion tipo windows
cat > $FILE <<EOF
-boot_disk=$DISK
-boot_main_part=$PART
+boot_disk=$BOOTDISK
+boot_main_part=$BOOTPART
+$BCDFILE
disk=$DISK
main_part=$PART
boot_entry=$WINVER
EOF
-spartlnx.run -cui -nm -w -f $FILE &
-sleep 5
-ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null
-
+timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE
##Preparando instruccion Ramdisk Options
cat > $FILE <<EOF
-boot_disk=$DISK
-boot_main_part=$PART
+boot_disk=$BOOTDISK
+boot_main_part=$BOOTPART
+$BCDFILE
disk=$DISK
main_part=$PART
boot_entry=Ramdisk Options
EOF
-spartlnx.run -cui -nm -w -f $FILE &
-sleep 5
-ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null
+timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE
+##Preparando instruccion Recovery Environment
+cat > $FILE <<EOF
+boot_disk=$BOOTDISK
+boot_main_part=$BOOTPART
+$BCDFILE
+disk=$DISK
+main_part=$PART
+boot_entry=Windows Recovery Environment
+EOF
+timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE
-#Preparando instruccion Windows Boot Manager
+##Preparando instruccion Recovery
cat > $FILE <<EOF
-boot_disk=$DISK
-boot_main_part=$PART
+boot_disk=$BOOTDISK
+boot_main_part=$BOOTPART
+$BCDFILE
disk=$DISK
main_part=$PART
-boot_entry=Windows Boot Manager
+boot_entry=Windows Recovery
EOF
-spartlnx.run -cui -nm -w -f $FILE &
-sleep 5
-ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null
+timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE
+#Preparando instruccion Windows Boot Manager
+cat > $FILE <<EOF
+boot_disk=$BOOTDISK
+boot_main_part=$BOOTPART
+$BCDFILE
+disk=$BOOTDISK
+main_part=$BOOTPART
+boot_entry=Windows Boot Manager
+EOF
+timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE
#Preparando instruccion Herramienta de diagnóstico de memoria de Windows
cat > $FILE <<EOF
-boot_disk=$DISK
-boot_main_part=$PART
-disk=$DISK
-main_part=$PART
+boot_disk=$BOOTDISK
+boot_main_part=$BOOTPART
+$BCDFILE
+disk=$BOOTDISK
+main_part=$BOOTPART
boot_entry=Herramienta de diagnóstico de memoria de Windows
EOF
-spartlnx.run -cui -nm -w -f $FILE &
-sleep 5
-ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null
+timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE
+
+#Preparando instruccion Herramienta de diagnóstico de memoria de Windows
+cat > $FILE <<EOF
+boot_disk=$BOOTDISK
+boot_main_part=$BOOTPART
+$BCDFILE
+disk=$BOOTDISK
+main_part=$BOOTPART
+boot_entry=Herramienta de diagn<f3>stico de memoria de Windows
+EOF
+timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE
+rm -f $FILE
}
@@ -695,9 +744,7 @@ main_part=$REGISTREDPART
;ext_part
part_letter=$REGISTREDVOL
EOF
-spartlnx.run -cui -nm -u -f $FILE &
-sleep 5
-ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null
+timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -u -f $FILE
}
@@ -724,6 +771,12 @@ ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null
#@version 1.1.0 - #827 Entrada para el ogLive si el equipo tiene partición cache.
#@author Antonio J. Doblas Viso. Universidad de Malaga.
#@date 2018-01-21
+#@version 1.1.1 - #802 Equipos EFI: Se crea el grub.cfg de la partición EFI
+#@author Irina Gomez, ETSII Universidad de Sevilla
+#@date 2019-01-08
+#@version 1.1.1 - #890 UEFI: el grub.cfg original es necesario para obtener los datos del kernel efi: se mueve al final.
+#@author Irina Gomez, ETSII Universidad de Sevilla
+#@date 2019-03-05
#*/ ##
function ogGrubInstallMbr ()
@@ -731,6 +784,7 @@ function ogGrubInstallMbr ()
# Variables locales.
local PART DISK VERSION FIRSTAGE SECONSTAGE CHECKOS KERNELPARAM BACKUPNAME
+local EFIDISK EFIPART EFISECONDSTAGE EFISUBDIR EFIOPTGRUB
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
@@ -758,7 +812,7 @@ BACKUPNAME=".backup.og"
FIRSTSTAGE=$(ogDiskToDev 1)
#localizar disco segunda etapa del grub
-SECONDSTAGE=$(ogMount $DISK $PART)
+SECONDSTAGE=$(ogMount "$DISK" "$PART") || return $?
# prepara el directorio principal de la segunda etapa
[ -d ${SECONDSTAGE}/boot/grub/ ] || mkdir -p ${SECONDSTAGE}/boot/grub/
@@ -766,43 +820,82 @@ SECONDSTAGE=$(ogMount $DISK $PART)
#Localizar directorio segunda etapa del grub
PREFIXSECONDSTAGE="/boot/grubMBR"
+# Instalamos grub para EFI en ESP
+EFIOPTGRUB=""
+if ogIsEfiActive; then
+ read EFIDISK EFIPART <<< $(ogGetEsp)
+ # Comprobamos que exista ESP y el directorio para ubuntu
+ EFISECONDSTAGE=$(ogMount $EFIDISK $EFIPART)
+ if [ $? -ne 0 ]; then
+ ogFormat $EFIDISK $EFIPART FAT32
+ EFISECONDSTAGE=$(ogMount $EFIDISK $EFIPART) || ogRaiseError $OG_ERR_PARTITION "ESP" || return $?
+ fi
+ EFISUBDIR="grub"
+ # Borramos la configuración anterior
+ [ -d ${EFISECONDSTAGE}/EFI/$EFISUBDIR ] && rm -rf ${EFISECONDSTAGE}/EFI/$EFISUBDIR
+ mkdir -p ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot
+ EFIOPTGRUB=" --removable --no-nvram --uefi-secure-boot --target $(ogGetArch)-efi --efi-directory=${EFISECONDSTAGE}/EFI/$EFISUBDIR "
+fi
+
# Si Reconfigurar segunda etapa (grub.cfg) == FALSE
-if [ -f ${SECONDSTAGE}/boot/grub/grub.cfg -o -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ]
+if [ "${CHECKOS^^}" == "FALSE" ] && [ -f ${SECONDSTAGE}/boot/grub/grub.cfg -o -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ]
then
- if [ "$CHECKOS" == "false" -o "$CHECKOS" == "FALSE" ]
- then
# Si no se reconfigura se utiliza el grub.cfg orginal
[ -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ${SECONDSTAGE}/boot/grub/grub.cfg
- # Si no se reconfigure se borra los ficheros previos de configuración específicos de opengnsys.
+ # Si no se reconfigure se borra los ficheros previos de configuración específicos de opengnsys.
[ -d ${SECONDSTAGE}${PREFIXSECONDSTAGE} ] && rm -fr ${SECONDSTAGE}${PREFIXSECONDSTAGE}
- # Reactivamos el grub con el grub.cfg original.
- grub-install --force --root-directory=${SECONDSTAGE} $FIRSTSTAGE
- return $?
- fi
-fi
+ PREFIXSECONDSTAGE=""
+else
+ # SI Reconfigurar segunda etapa (grub.cfg) == TRUE
-# SI Reconfigurar segunda etapa (grub.cfg) == TRUE
+ #llamada a updateBootCache para que aloje la primera fase del ogLive
+ updateBootCache
-#llamada a updateBootCache para que aloje la primera fase del ogLive
-updateBootCache
+ if ogIsEfiActive; then
+ # UEFI: grubSintax necesita grub.cfg para detectar los kernels: si no existe recupero backup.
+ if ! [ -f ${SECONDSTAGE}/boot/grub/grub.cfg ]; then
+ [ -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ${SECONDSTAGE}/boot/grub/grub.cfg
+ fi
+ else
+ #Evitar detectar modo recovery - mover grub.cfg original a grub.cfg.backup
+ mv ${SECONDSTAGE}/boot/grub/grub.cfg ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME
+ fi
-#Configur la sintaxis grub para evitar menus de "recovery" en el OGLive
-echo "GRUB_DISABLE_RECOVERY=\"true\"" >> /etc/default/grub
-echo "GRUB_DISABLE_LINUX_UUID=\"true\"" >> /etc/default/grub
+ #Configur la sintaxis grub para evitar menus de "recovery" en el OGLive
+ echo "GRUB_DISABLE_RECOVERY=\"true\"" >> /etc/default/grub
+ echo "GRUB_DISABLE_LINUX_UUID=\"true\"" >> /etc/default/grub
-#Evitar detectar modo recovery - mover grub.cfg original a grub.cfg.backup
-[ -f ${SECONDSTAGE}/boot/grub/grub.cfg ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME
-#Preparar configuración segunda etapa: crear ubicacion
-mkdir -p ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/
-#Preparar configuración segunda etapa: crear cabecera del fichero (ignorar errores)
-sed -i 's/^set -e/#set -e/' /etc/grub.d/00_header
-/etc/grub.d/00_header > ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg 2>/dev/null
-#Preparar configuración segunda etapa: crear entrada del sistema operativo
-grubSyntax "$KERNELPARAM" >> ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg
+ #Preparar configuración segunda etapa: crear ubicacion
+ mkdir -p ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/
+ #Preparar configuración segunda etapa: crear cabecera del fichero (ignorar errores)
+ sed -i 's/^set -e/#set -e/' /etc/grub.d/00_header
+ # (ogLive 5.0) Si 'pkgdatadir' está vacía ponemos valor de otros ogLive
+ sed -i '/grub-mkconfig_lib/i\pkgdatadir=${pkgdatadir:-"${datarootdir}/grub"}' /etc/grub.d/00_header
+ /etc/grub.d/00_header > ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg 2>/dev/null
+
+ #Preparar configuración segunda etapa: crear entrada del sistema operativo
+ grubSyntax "$KERNELPARAM" >> ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg
+
+ # Renombramos la configuración de grub antigua
+ [ -f ${SECONDSTAGE}/boot/grub/grub.cfg ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME
+
+fi
+
+#Instalar el grub
+grub-install --force ${EFIOPTGRUB} --root-directory=${SECONDSTAGE}${PREFIXSECONDSTAGE} $FIRSTSTAGE
+EVAL=$?
+
+# Movemos el grubx64.efi
+if ogIsEfiActive; then
+ mv ${EFISECONDSTAGE}/EFI/$EFISUBDIR/EFI/BOOT/* ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot
+ rm -rf ${EFISECONDSTAGE}/EFI/$EFISUBDIR/EFI
+ cp /usr/lib/shim/shimx64.efi.signed ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot
+ # Nombre OpenGnsys para cargador
+ cp ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot/{shimx64.efi.signed,ogloader.efi}
+fi
+return $EVAL
-#Instalar el grub
-grub-install --force --root-directory=${SECONDSTAGE}${PREFIXSECONDSTAGE} $FIRSTSTAGE
}
@@ -824,6 +917,12 @@ grub-install --force --root-directory=${SECONDSTAGE}${PREFIXSECONDSTAGE} $FIRSTS
#@version 1.0.3 - Ficheros de configuracion independientes segun ubicación de la priemra etapa
#@author Antonio J. Doblas Viso. Universidad de Malaga.
#@date 2012-03-13
+#@version 1.1.1 - #802 Equipos EFI: Se crea el grub.cfg de la partición EFI
+#@author Irina Gomez, ETSII Universidad de Sevilla
+#@date 2019-01-08
+#@version 1.1.1 - #890 UEFI: el grub.cfg original es necesario para obtener los datos del kernel efi: se mueve al final.
+#@author Irina Gomez, ETSII Universidad de Sevilla
+#@date 2019-03-05
#*/ ##
function ogGrubInstallPartition ()
@@ -831,6 +930,7 @@ function ogGrubInstallPartition ()
# Variables locales.
local PART DISK VERSION FIRSTAGE SECONSTAGE CHECKOS KERNELPARAM BACKUPNAME
+local EFIDISK EFIPART EFISECONDSTAGE EFISUBDIR EFIOPTGRUB EFIBOOTDIR
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
@@ -861,39 +961,77 @@ SECONDSTAGE=$(ogMount $DISK $PART)
#Localizar directorio segunda etapa del grub
PREFIXSECONDSTAGE="/boot/grubPARTITION"
+# Si es EFI instalamos el grub en la ESP
+EFIOPTGRUB=""
+# Desde el bootdir uefi y bios buscan el grub.cfg en subdirectorios distintos.
+EFIBOOTDIR=""
+if ogIsEfiActive; then
+ read EFIDISK EFIPART <<< $(ogGetEsp)
+ # Comprobamos que exista ESP y el directorio para ubuntu
+ EFISECONDSTAGE=$(ogMount $EFIDISK $EFIPART)
+ if [ $? -ne 0 ]; then
+ ogFormat $EFIDISK $EFIPART FAT32
+ EFISECONDSTAGE=$(ogMount $EFIDISK $EFIPART) || ogRaiseError $OG_ERR_PARTITION "ESP" || return $?
+ fi
+ EFISUBDIR=$(printf "Part-%02d-%02d" $DISK $PART)
+ # Borramos la configuración anterior
+ [ -d ${EFISECONDSTAGE}/EFI/$EFISUBDIR ] && rm -rf ${EFISECONDSTAGE}/EFI/$EFISUBDIR
+ mkdir -p ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot
+ EFIOPTGRUB=" --removable --no-nvram --uefi-secure-boot --target $(ogGetArch)-efi --efi-directory=${EFISECONDSTAGE}/EFI/$EFISUBDIR "
+ EFIBOOTDIR="/boot"
+fi
+
# Si Reconfigurar segunda etapa (grub.cfg) == FALSE
-if [ -f ${SECONDSTAGE}/boot/grub/grub.cfg -o -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ]
+if [ "${CHECKOS^^}" == "FALSE" ] && [ -f ${SECONDSTAGE}/boot/grub/grub.cfg -o -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ]
then
- if [ "$CHECKOS" == "false" -o "$CHECKOS" == "FALSE" ]
- then
# Si no se reconfigura se utiliza el grub.cfg orginal
[ -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ${SECONDSTAGE}/boot/grub/grub.cfg
- # Si no se reconfigure se borra los ficheros previos de configuración específicos de opengnsys.
+ # Si no se reconfigure se borra los ficheros previos de configuración específicos de opengnsys.
[ -d ${SECONDSTAGE}${PREFIXSECONDSTAGE} ] && rm -fr ${SECONDSTAGE}${PREFIXSECONDSTAGE}
# Reactivamos el grub con el grub.cfg original.
- grub-install --force --root-directory=${SECONDSTAGE} $FIRSTSTAGE
- return $?
- fi
-fi
+ PREFIXSECONDSTAGE=""
+else
+ # SI Reconfigurar segunda etapa (grub.cfg) == TRUE
-# SI Reconfigurar segunda etapa (grub.cfg) == TRUE
-#Configur la sintaxis grub para evitar menus de "recovery" en el OGLive
-echo "GRUB_DISABLE_RECOVERY=\"true\"" >> /etc/default/grub
-echo "GRUB_DISABLE_LINUX_UUID=\"true\"" >> /etc/default/grub
+ if ogIsEfiActive; then
+ # UEFI: grubSintax necesita grub.cfg para detectar los kernels: si no existe recupero backup.
+ if ! [ -f ${SECONDSTAGE}/boot/grub/grub.cfg ]; then
+ [ -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ${SECONDSTAGE}/boot/grub/grub.cfg
+ fi
+ else
+ #Evitar detectar modo recovery - mover grub.cfg original a grub.cfg.backup
+ mv ${SECONDSTAGE}/boot/grub/grub.cfg ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME
+ fi
-#Evitar detectar modo recovery - mover grub.cfg original a grub.cfg.backup.og
-[ -f ${SECONDSTAGE}/boot/grub/grub.cfg ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME
+ #Configur la sintaxis grub para evitar menus de "recovery" en el OGLive
+ echo "GRUB_DISABLE_RECOVERY=\"true\"" >> /etc/default/grub
+ echo "GRUB_DISABLE_LINUX_UUID=\"true\"" >> /etc/default/grub
-#Preparar configuración segunda etapa: crear ubicacion
-mkdir -p ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/
-#Preparar configuración segunda etapa: crear cabecera del fichero (ingnorar errores)
-sed -i 's/^set -e/#set -e/' /etc/grub.d/00_header
-/etc/grub.d/00_header > ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg 2>/dev/null
-#Preparar configuración segunda etapa: crear entrada del sistema operativo
-grubSyntax $DISK $PART "$KERNELPARAM" >> ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg
+ #Preparar configuración segunda etapa: crear ubicacion
+ mkdir -p ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/
+ #Preparar configuración segunda etapa: crear cabecera del fichero (ingnorar errores)
+ sed -i 's/^set -e/#set -e/' /etc/grub.d/00_header
+ # (ogLive 5.0) Si 'pkgdatadir' está vacía ponemos valor de otros ogLive
+ sed -i '/grub-mkconfig_lib/i\pkgdatadir=${pkgdatadir:-"${datarootdir}/grub"}' /etc/grub.d/00_header
+ /etc/grub.d/00_header > ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg 2>/dev/null
+ #Preparar configuración segunda etapa: crear entrada del sistema operativo
+ grubSyntax $DISK $PART "$KERNELPARAM" >> ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg
+fi
#Instalar el grub
-grub-install --force --root-directory=${SECONDSTAGE}${PREFIXSECONDSTAGE} $FIRSTSTAGE
+grub-install --force ${EFIOPTGRUB} --root-directory=${SECONDSTAGE}${PREFIXSECONDSTAGE} $FIRSTSTAGE
+EVAL=$?
+
+# Movemos el grubx64.efi
+if ogIsEfiActive; then
+ mv ${EFISECONDSTAGE}/EFI/$EFISUBDIR/EFI/BOOT/* ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot
+ rm -rf ${EFISECONDSTAGE}/EFI/$EFISUBDIR/EFI
+ cp /usr/lib/shim/shimx64.efi.signed ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot/shimx64.efi
+ # Nombre OpenGnsys para cargador
+ cp ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot/{shimx64.efi,ogloader.efi}
+fi
+
+return $EVAL
}
@@ -912,11 +1050,15 @@ grub-install --force --root-directory=${SECONDSTAGE}${PREFIXSECONDSTAGE} $FIRSTS
#@version 1.0.6b - correccion. Si no hay partición fisica para la SWAP, eliminar entrada del fstab.
#@author Antonio J. Doblas Viso. Universidad de Malaga.
#@date 2016-11-03
+#@version 1.1.1 - Se configura la partición ESP (para sistemas EFI) (ticket #802)
+#@author Irina Gómez, ETSII Universidad de Sevilla
+#@date 2018-12-13
#*/ ##
function ogConfigureFstab ()
{
# Variables locales.
local FSTAB DEFROOT PARTROOT DEFSWAP PARTSWAP
+local EFIDISK EFIPART EFIDEV EFIOPT
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
@@ -954,9 +1096,19 @@ else
echo "No hay partición SWAP -> configuramos FSTAB" # Mensaje temporal.
sed "/swap/d" ${FSTAB}.backup > ${FSTAB}
fi
-}
+# Si es un sistema EFI incluimos partición ESP (Si existe la modificamos)
+if ogIsEfiActive; then
+ read EFIDISK EFIPART <<< $(ogGetEsp)
+ EFIDEV=$(ogDiskToDev $EFIDISK $EFIPART)
+ # Opciones de la partición ESP: si no existe ponemos un valor por defecto
+ EFIOPT=$(awk '$1!~/#/ && $2=="/boot/efi" {print $3"\t"$4"\t"$5"\t"$6 }' ${FSTAB})
+ [ "$EFIOPT" == "" ] && EFIOPT='vfat\tumask=0077\t0\t1'
+ sed -i /"boot\/efi"/d ${FSTAB}
+ echo -e "$EFIDEV\t/boot/efi\t$EFIOPT" >> ${FSTAB}
+fi
+}
#/**
# ogSetLinuxName int_ndisk int_nfilesys [str_name]
@@ -1188,6 +1340,8 @@ function ogBurgHidePartitions ()
#@brief Configura el grub/burg para que oculte las particiones de windows que no se esten iniciando.
#@param 1 Numero de disco
#@param 2 Numero de particion
+#@param 3 Numero de disco de la partición de datos (no ocultar)
+#@param 4 Numero de particion de datos (no ocultar)
#@return (nada)
#@exception OG_ERR_FORMAT Formato incorrecto.
#@exception No existe archivo de configuracion del grub/burg.
@@ -1200,11 +1354,14 @@ function ogBurgHidePartitions ()
#@version 1.1.1 Se incluye comentarios en codigo para autodocuemtnacion con Doxygen
#@author Antonio J. Doblas Viso, EVLT Univesidad de Malaga.
#@date 2018-07-05
+#@version Se permite una partición de datos que no se ocultará. Soporta más de un disco. Compatible con grub.cfg creado por ogLive 5.0
+#@author Irina Gomez, ETSII Universidad de Sevilla
+#@date 2019-08-26
#*/
function ogBootLoaderHidePartitions ()
{
- local FUNC DIRMOUNT GFCFILE PARTTABLETYPE WINENTRY ENTRY PART TEXT LINE2 PART2 HIDDEN
+ local FUNC DIRMOUNT GFCFILE PARTTABLETYPE WINENTRY WINPART ENTRY LINE PART PARTDATA TEXT PARTHIDDEN HIDDEN
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
@@ -1217,11 +1374,13 @@ function ogBootLoaderHidePartitions ()
FUNC="${FUNC%%\ *}"
# Error si no se reciben 2 parámetros.
- [ $# -lt 2 ] && return $(ogRaiseError session $OG_ERR_FORMAT "$MSG_FORMAT: $FUNCNAME num_disk num_part"; echo $?)
+ [ $# -lt 2 ] && return $(ogRaiseError session $OG_ERR_FORMAT "$MSG_FORMAT: $FUNCNAME num_disk num_part [ num_disk_partdata num_partdata ]"; echo $?)
+ # Si no existe $4 pongo un valor imposible para la partición de datos
+ [ $# -eq 4 ] && PARTDATA=$(ogDiskToDev $3 $4) || PARTDATA=0
# Archivo de configuracion del grub
DIRMOUNT=$(ogMount $1 $2)
- # La función debe ser llamanda desde ogGrubHidePartitions or ogBurgHidePartitions.
+ # La función debe ser llamanda desde ogGrubHidePartitionsCdc or ogBurgHidePartitionsCdc.
case "$FUNC" in
ogGrubHidePartitions)
CFGFILE="$DIRMOUNT/boot/grubMBR/boot/grub/grub.cfg"
@@ -1230,7 +1389,7 @@ function ogBootLoaderHidePartitions ()
CFGFILE="$DIRMOUNT/boot/burg/burg.cfg"
;;
*)
- ogRaiseError $OG_ERR_FORMAT "Use ogGrubHidePartitions or ogBurgHidePartitions."
+ ogRaiseError $OG_ERR_FORMAT "Use ogGrubHidePartitionsCdc or ogBurgHidePartitionsCdc."
return $?
;;
esac
@@ -1239,37 +1398,41 @@ function ogBootLoaderHidePartitions ()
[ -r $CFGFILE ] || return $(ogRaiseError log session $OG_ERR_NOTFOUND "$CFGFILE" 1>&2; echo $?)
# Si solo hay una particion de Windows me salgo
- [ $(fdisk -l $(ogDiskToDev $1) | grep 'NTFS' |wc -l) -eq 1 ] && return 0
+ [ $(fdisk -l $(ogDiskToDev) | grep 'NTFS' |wc -l) -eq 1 ] && return 0
# Elimino llamadas a parttool, se han incluido en otras ejecuciones de esta funcion.
sed -i '/parttool/d' $CFGFILE
PARTTABLETYPE=$(ogGetPartitionTableType $1 | tr [:upper:] [:lower:])
+
# /* (comentario de bloque para Doxygen)
# Entradas de Windows: numero de linea y particion. De mayor a menor.
- WINENTRY=$(awk '/menuentry.*Windows/ {gsub(/\)\"/, ""); print NR":"$6} ' $CFGFILE | sed -e '1!G;h;$!d' -e s/[a-z\/]//g)
+ WINENTRY=$(awk '/menuentry.*Windows/ {gsub(/\)\"/, ""); gsub(/^.*dev/,""); print NR":/dev"$1} ' $CFGFILE | sed -e '1!G;h;$!d')
#*/ (comentario para bloque Doxygen)
# Particiones de Windows, pueden no estar en el grub.
- WINPART=$(fdisk -l $(ogDiskToDev $1)|awk '/NTFS/ {print substr($1,9,1)}' |sed '1!G;h;$!d')
+ WINPART=$(fdisk -l $(ogDiskToDev)|awk '/NTFS/ {print $1}'|sed '1!G;h;$!d')
+
+
# Modifico todas las entradas de Windows.
for ENTRY in $WINENTRY; do
LINE=${ENTRY%:*}
- PART=${ENTRY#*:}
+ PART=${ENTRY#*:}
+
# En cada entrada, oculto o muestro cada particion.
TEXT=""
- for PART2 in $WINPART; do
- # Muestro solo la particion de la entrada actual.
- [ $PART2 -eq $PART ] && HIDDEN="-" || HIDDEN="+"
+ for PARTHIDDEN in $WINPART; do
+ # Muestro la particion de la entrada actual y la de datos.
+ [ "$PARTHIDDEN" == "$PART" -o "$PARTHIDDEN" == "$PARTDATA" ] && HIDDEN="-" || HIDDEN="+"
+ read NUMDISK NUMPART <<< $(ogDevToDisk $PARTHIDDEN)
- TEXT="\tparttool (hd0,$PARTTABLETYPE$PART2) hidden$HIDDEN \n$TEXT"
+ TEXT="\tparttool (hd$((NUMDISK-1)),$PARTTABLETYPE$NUMPART) hidden$HIDDEN \n$TEXT"
done
-
+
sed -i "${LINE}a\ $TEXT" $CFGFILE
done
# Activamos la particion que se inicia en todas las entradas de windows.
sed -i "/chainloader/i\\\tparttool \$\{root\} boot+" $CFGFILE
-
}
#/**
@@ -1307,13 +1470,32 @@ function ogBurgDeleteEntry ()
}
#/**
+# ogRefindDeleteEntry num_disk_delete num_part_delete
+#@brief ver ogBootLoaderDeleteEntry
+#@see ogBootLoaderDeleteEntry
+#*/
+function ogRefindDeleteEntry ()
+{
+ local EFIDISK EFIPART
+ # Si se solicita, mostrar ayuda.
+ if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME int_disk_delete int_npartition_delete" \
+ "$FUNCNAME 2 1"
+ return
+ fi
+ read EFIDISK EFIPART <<< $(ogGetEsp)
+ ogBootLoaderDeleteEntry $EFIDISK $EFIPART $@
+ return $?
+}
+
+#/**
# ogBootLoaderDeleteEntry num_disk num_part num_part_delete
#@brief Borra en el grub las entradas para el inicio en una particion.
#@param 1 Numero de disco donde esta el grub
#@param 2 Numero de particion donde esta el grub
#@param 3 Numero del disco del que borramos las entradas
#@param 4 Numero de la particion de la que borramos las entradas
-#@note Tiene que ser llamada desde ogGrubDeleteEntry o ogBurgDeleteEntry
+#@note Tiene que ser llamada desde ogGrubDeleteEntry, ogBurgDeleteEntry o ogRefindDeleteEntry
#@return (nada)
#@exception OG_ERR_FORMAT Use ogGrubDeleteEntry or ogBurgDeleteEntry.
#@exception OG_ERR_FORMAT Formato incorrecto.
@@ -1325,11 +1507,11 @@ function ogBurgDeleteEntry ()
function ogBootLoaderDeleteEntry ()
{
- local FUNC DIRMOUNT CFGFILE DEVICE MENUENTRY DELETEENTRY ENDENTRY ENTRY
+ local FUNC DIRMOUNT CFGFILE LABEL MENUENTRY DELETEENTRY ENDENTRY ENTRY
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
- ogHelp "$FUNCNAME" "$MSG_SEE ogBurgDeleteEntry ogGrubDeleteEntry"
+ ogHelp "$FUNCNAME" "$MSG_SEE ogBurgDeleteEntry, ogGrubDeleteEntry or ogRefindDeleteEntry"
return
fi
@@ -1343,7 +1525,7 @@ function ogBootLoaderDeleteEntry ()
# Archivo de configuracion del grub
DIRMOUNT=$(ogMount $1 $2)
- # La función debe ser llamanda desde ogGrubDeleteEntry or ogBurgDeleteEntry.
+ # La función debe ser llamanda desde ogGrubDeleteEntry, ogBurgDeleteEntry or ogRefindDeleteEntry.
case "$FUNC" in
ogGrubDeleteEntry)
CFGFILE="$DIRMOUNT/boot/grubMBR/boot/grub/grub.cfg"
@@ -1351,26 +1533,33 @@ function ogBootLoaderDeleteEntry ()
ogBurgDeleteEntry)
CFGFILE="$DIRMOUNT/boot/burg/burg.cfg"
;;
+ ogRefindDeleteEntry)
+ CFGFILE="$DIRMOUNT/EFI/refind/refind.conf"
+ ;;
*)
- ogRaiseError $OG_ERR_FORMAT "Use ogGrubDeleteEntry or ogBurgDeleteEntry."
+ ogRaiseError $OG_ERR_FORMAT "Use ogGrubDeleteEntry, ogBurgDeleteEntry or ogRefindDeleteEntry."
return $?
;;
esac
# Dispositivo
- DEVICE=$(ogDiskToDev $3 $4)
+ if [ "$(basename $CFGFILE)" == "refind.conf" ]; then
+ LABEL=$(printf "Part-%02d-%02d" $3 $4)
+ else
+ LABEL=$(ogDiskToDev $3 $4)
+ fi
- # Error si no existe archivo del grub)
+ # Error si no existe archivo de configuración
[ -r $CFGFILE ] || ogRaiseError log session $OG_ERR_NOTFOUND "$CFGFILE" || return $?
# Numero de linea de cada entrada.
MENUENTRY="$(grep -n -e menuentry $CFGFILE| cut -d: -f1 | sed '1!G;h;$!d' )"
# Entradas que hay que borrar.
- DELETEENTRY=$(grep -n menuentry.*$DEVICE $CFGFILE| cut -d: -f1)
+ DELETEENTRY=$(grep -n menuentry.*$LABEL $CFGFILE| cut -d: -f1)
# Si no hay entradas para borrar me salgo con aviso
- [ "$DELETEENTRY" != "" ] || ogRaiseError log session $OG_ERR_NOTFOUND "Menuentry $DEVICE" || return $?
+ [ "$DELETEENTRY" != "" ] || ogRaiseError log session $OG_ERR_NOTFOUND "Menuentry $LABEL" || return $?
# Recorremos el fichero del final hacia el principio.
ENDENTRY="$(wc -l $CFGFILE|cut -d" " -f1)"
@@ -1569,7 +1758,6 @@ EOF
#Preparar configuración segunda etapa: crear entrada del sistema operativo
grubSyntax "$KERNELPARAM" >> "$FILECFG"
-
#Instalar el burg
burg-install --force --root-directory=${SECONDSTAGE} $FIRSTSTAGE 2>&1>/dev/null
}
@@ -1608,6 +1796,27 @@ function ogBurgDefaultEntry ()
return $?
}
+
+#/**
+# ogRefindDefaultEntry int_disk_default_entry int_npartition_default_entry
+#@brief ver ogBootLoaderDefaultEntry
+#@see ogBootLoaderDefaultEntry
+#*/ ##
+function ogRefindDefaultEntry ()
+{
+ local EFIDISK EFIPART
+ # Si se solicita, mostrar ayuda.
+ if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME int_disk_default_entry int_npartition_default_entry" \
+ "$FUNCNAME 1 1"
+ return
+ fi
+
+ read EFIDISK EFIPART <<< $(ogGetEsp)
+ ogBootLoaderDefaultEntry $EFIDISK $EFIPART $@
+ return $?
+}
+
#/**
# ogBootLoaderDefaultEntry int_disk_CFG int_partition_CFG int_disk_default_entry int_npartition_default_entry
#@brief Configura la entrada por defecto de Burg
@@ -1631,11 +1840,11 @@ function ogBootLoaderDefaultEntry ()
{
# Variables locales.
-local PART CFGFILE DEFAULTENTRY MSG
+local PART FUNC DIRMOUNT LABEL CFGFILE DEFAULTENTRY MENUENTRY MSG
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
- ogHelp "$FUNCNAME" "$MSG_SEE ogGrubDefaultEntry ogBurgDefaultEntry"
+ ogHelp "$FUNCNAME" "$MSG_SEE ogGrubDefaultEntry, ogBurgDefaultEntry or ogRefindDefaultEntry."
return
fi
@@ -1650,7 +1859,7 @@ FUNC="${FUNC%%\ *}"
DIRMOUNT=$(ogMount $1 $2) || return $?
# Comprobamos que exista fichero de configuración
-# La función debe ser llamanda desde ogGrubDefaultEntry or ogBurgDefaultEntry.
+# La función debe ser llamanda desde ogGrubDefaultEntry, ogBurgDefaultEntry or ogRefindDefaultEntry.
case "$FUNC" in
ogGrubDefaultEntry)
CFGFILE="$DIRMOUNT/boot/grubMBR/boot/grub/grub.cfg"
@@ -1658,8 +1867,11 @@ case "$FUNC" in
ogBurgDefaultEntry)
CFGFILE="$DIRMOUNT/boot/burg/burg.cfg"
;;
+ ogRefindDefaultEntry)
+ CFGFILE="$DIRMOUNT/EFI/refind/refind.conf"
+ ;;
*)
- ogRaiseError $OG_ERR_FORMAT "Use ogGrubDefaultEntry or ogBurgDefaultEntry."
+ ogRaiseError $OG_ERR_FORMAT "Use ogGrubDefaultEntry, ogBurgDefaultEntry or ogRefindDefaultEntry."
return $?
;;
esac
@@ -1668,19 +1880,29 @@ esac
[ -r $CFGFILE ] || ogRaiseError $OG_ERR_NOTFOUND "$CFGFILE" || return $?
# Dispositivo
-DEVICE=$(ogDiskToDev $3 $4)
+if [ "$(basename $CFGFILE)" == "refind.conf" ]; then
+ LABEL=$(printf "Part-%02d-%02d" $3 $4)
+else
+ LABEL=$(ogDiskToDev $3 $4)
+fi
# Número de línea de la entrada por defecto en CFGFILE (primera de la partición).
-DEFAULTENTRY=$(grep -n -m 1 menuentry.*$DEVICE $CFGFILE| cut -d: -f1)
+DEFAULTENTRY=$(grep -n -m 1 menuentry.*$LABEL $CFGFILE| cut -d: -f1)
# Si no hay entradas para borrar me salgo con aviso
-[ "$DEFAULTENTRY" != "" ] || ogRaiseError session log $OG_ERR_NOTFOUND "No menuentry $DEVICE" || return $?
+[ "$DEFAULTENTRY" != "" ] || ogRaiseError session log $OG_ERR_NOTFOUND "No menuentry $LABEL" || return $?
# Número de la de linea por defecto en el menú de usuario
MENUENTRY="$(grep -n -e menuentry $CFGFILE| cut -d: -f1 | grep -n $DEFAULTENTRY |cut -d: -f1)"
-# Las líneas empiezan a contar desde cero
-let MENUENTRY=$MENUENTRY-1
-sed --regexp-extended -i s/"set default=\"?[0-9]*\"?"/"set default=\"$MENUENTRY\""/g $CFGFILE
+
+if [ "$(basename $CFGFILE)" == "refind.conf" ]; then
+ sed -i /default_selection.*$/d $CFGFILE
+ sed -i "1 i\default_selection $MENUENTRY" $CFGFILE
+else
+ # En grub y burg las líneas empiezan a contar desde cero
+ let MENUENTRY=$MENUENTRY-1
+ sed --regexp-extended -i s/"set default=\"?[0-9]*\"?"/"set default=\"$MENUENTRY\""/g $CFGFILE
+fi
MSG="MSG_HELP_$FUNC"
echo "${!MSG%%\.}: $@"
}
@@ -1719,6 +1941,28 @@ function ogBurgOgliveDefaultEntry ()
return $?
}
+
+#/**
+# ogRefindOgliveDefaultEntry
+#@brief ver ogBootLoaderOgliveDefaultEntry
+#@see ogBootLoaderOgliveDefaultEntry
+#*/ ##
+function ogRefindOgliveDefaultEntry ()
+{
+ local EFIDISK EFIPART
+ # Si se solicita, mostrar ayuda.
+ if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME" \
+ "$FUNCNAME"
+ return
+ fi
+
+ read EFIDISK EFIPART <<< $(ogGetEsp)
+ ogBootLoaderOgliveDefaultEntry $EFIDISK $EFIPART
+ return $?
+}
+
+
#/**
# ogBootLoaderOgliveDefaultEntry
#@brief Configura la entrada de ogLive como la entrada por defecto de Burg.
@@ -1744,7 +1988,7 @@ local FUNC PART CFGFILE NUMENTRY MSG
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
- ogHelp "$FUNCNAME" "$MSG_SEE ogGrubOgliveDefaultEntry ogBurgOgliveDefaultEntry" \
+ ogHelp "$FUNCNAME" "$MSG_SEE ogGrubOgliveDefaultEntry, ogBurgOgliveDefaultEntry or ogRefindOgliveDefaultEntry" \
return
fi
@@ -1757,7 +2001,7 @@ FUNC="${FUNC%%\ *}"
# Error si no puede montar sistema de archivos.
PART=$(ogMount $1 $2) || return $?
-# La función debe ser llamanda desde ogGrubOgliveDefaultEntry or ogBurgOgliveDefaultEntry.
+# La función debe ser llamanda desde ogGrubOgliveDefaultEntry, ogBurgOgliveDefaultEntry or ogRefindOgliveDefaultEntry.
case "$FUNC" in
ogGrubOgliveDefaultEntry)
CFGFILE="$PART/boot/grubMBR/boot/grub/grub.cfg"
@@ -1765,8 +2009,11 @@ case "$FUNC" in
ogBurgOgliveDefaultEntry)
CFGFILE="$PART/boot/burg/burg.cfg"
;;
+ ogRefindOgliveDefaultEntry)
+ CFGFILE="$PART/EFI/refind/refind.conf"
+ ;;
*)
- ogRaiseError $OG_ERR_FORMAT "Use ogGrubOgliveDefaultEntry or ogBurgOgliveDefaultEntry."
+ ogRaiseError $OG_ERR_FORMAT "Use ogGrubOgliveDefaultEntry, ogBurgOgliveDefaultEntry or ogRefindOgliveDefaultEntry."
return $?
;;
esac
@@ -1780,8 +2027,14 @@ NUMENTRY=$(grep ^menuentry $CFGFILE| grep -n "OpenGnsys Live"|cut -d: -f1)
# Si no existe entrada de ogLive nos salimos
[ -z "$NUMENTRY" ] && (ogRaiseError $OG_ERR_NOTFOUND "menuentry OpenGnsys Live in $CFGFILE" || return $?)
-let NUMENTRY=$NUMENTRY-1
-sed --regexp-extended -i s/"set default=\"?[0-9]+\"?"/"set default=\"$NUMENTRY\""/g $CFGFILE
+if [ "$(basename $CFGFILE)" == "refind.conf" ]; then
+ sed -i /default_selection.*$/d $CFGFILE
+
+ sed -i "1 i\default_selection $NUMENTRY" $CFGFILE
+else
+ let NUMENTRY=$NUMENTRY-1
+ sed --regexp-extended -i s/"set default=\"?[0-9]+\"?"/"set default=\"$NUMENTRY\""/g $CFGFILE
+fi
MSG="MSG_HELP_$FUNC"
echo "${!MSG%%\.}: $@"
@@ -1827,6 +2080,42 @@ function ogBurgSetTheme ()
}
+#/**
+# ogRefindSetTheme str_theme
+#@brief ver ogBootLoaderSetTheme
+#@see ogBootLoaderSetTheme
+#*/ ##
+function ogRefindSetTheme () {
+ local PART DIRTHEME CFGFILE
+ # Si se solicita, mostrar ayuda.
+ if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME str_themeName" \
+ "$FUNCNAME ThemeBasic"
+ echo -e "\nThemes in $OGLIB/refind:\n$(ls $OGLIB/refind/themes/ 2>/dev/null)"
+
+ return
+ fi
+
+ # Detectamos partición ESP
+ read EFIDISK EFIPART <<< $(ogGetEsp)
+
+ PART=$(ogMount $EFIDISK $EFIPART) || return $?
+ DIRTHEME="$PART/EFI/refind/themes"
+ CFGFILE="$PART/EFI/refind/refind.conf"
+
+ # Para utilizar ogBootLoaderSetTheme es necesario la entrada set theme_name
+ if [ -f $CFGFILE ]; then
+ sed -i '1 i\set theme_name=none' $CFGFILE
+ else
+ ogRaiseError $OG_ERR_NOTFOUND "$CFGFILE" || return $?
+ fi
+ # Creamos el directorio para los temas
+ [ -d $DIRTHEME ] || mkdir $DIRTHEME
+
+ ogBootLoaderSetTheme $EFIDISK $EFIPART $@
+ return $?
+}
+
#/**
# ogBootLoaderSetTheme
@@ -1837,21 +2126,26 @@ function ogBurgSetTheme ()
#@return
#@exception OG_ERR_FORMAT Formato incorrecto.
#@exception OG_ERR_PARTITION Partición errónea o desconocida (ogMount).
-#@exception OG_ERR_NOTFOUND Fichero de configuración no encontrado: grub.cfg burg.cfg.
+#@exception OG_ERR_NOTFOUND Fichero de configuración no encontrado: grub.cfg burg.cfg refind.conf.
#@exception OG_ERR_NOTFOUND Entrada deltema no encontrada en burg.cfg.
+#@exception OG_ERR_NOTFOUND Fichero de configuración del tema no encontrado: theme.conf (sólo refind).
+#@note El tema debe situarse en OGLIB/BOOTLOADER/themes
#@version 1.1.0 - Primeras pruebas con Burg. grub no soportado.
#@author Antonio J. Doblas Viso. Universidad de Malaga
#@date 2018-01-24
+#@version 1.1.1 - Soporta rEFInd (ticket #802 #888).
+#@author Irina Gomez. Universidad de Sevilla
+#@date 2019-03-22
#*/ ##
function ogBootLoaderSetTheme ()
{
# Variables locales.
-local FUNC PART CFGFILE THEME NEWTHEME BOOTLOADER MSG
+local FUNC PART CFGFILE THEME NEWTHEME BOOTLOADER MSG NEWTHEMECFG
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
- ogHelp "$FUNCNAME" "$MSG_SEE ogGrubSetTheme ogBurgSetTheme"
+ ogHelp "$FUNCNAME" "$MSG_SEE ogGrubSetTheme, ogBurgSetTheme or ogRefindSetTheme."
return
fi
@@ -1864,27 +2158,32 @@ FUNC="${FUNC%%\ *}"
-# Error si no se reciben 2 parametros.
+# Error si no se reciben 3 parametros.
[ $# -eq 3 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_ndiskSecondStage int_partitionSecondStage str_themeName" || return $?
# Error si no puede montar sistema de archivos.
PART=$(ogMount $1 $2) || return $?
-# La función debe ser llamanda desde ogGrubSetTheme or ogBurgSetTheme.
+# La función debe ser llamanda desde ogGrubSetTheme, ogBurgSetTheme or ogRefindSetTheme.
case "$FUNC" in
ogGrubSetTheme)
- BOOTLOADER="grug"
- BOOTLOADERDIR="grubMBR"
+ BOOTLOADER="grub"
+ BOOTLOADERDIR="boot/grubMBR"
CFGFILE="$PART/boot/grubMBR/boot/grub/grub.cfg"
ogRaiseError $OG_ERR_FORMAT "ogGrubSetTheme not sopported"
return $?
;;
ogBurgSetTheme)
BOOTLOADER="burg"
- BOOTLOADERDIR="burg"
+ BOOTLOADERDIR="boot/burg"
CFGFILE="$PART/boot/burg/burg.cfg"
;;
+ ogRefindSetTheme)
+ BOOTLOADER="refind"
+ BOOTLOADERDIR="EFI/refind"
+ CFGFILE="$PART/EFI/refind/refind.conf"
+ ;;
*)
- ogRaiseError $OG_ERR_FORMAT "Use ogGrubSetTheme or ogBurgSetTheme."
+ ogRaiseError $OG_ERR_FORMAT "Use ogGrubSetTheme, ogBurgSetTheme or ogRefindSetTheme."
return $?
;;
esac
@@ -1894,22 +2193,29 @@ esac
# Detectamos cual es el tema asignado
THEME=$(grep "set theme_name=" $CFGFILE | grep ^set | cut -d= -f2)
-
# Si no existe entrada de theme_name nos salimos
[ -z "$THEME" ] && (ogRaiseError $OG_ERR_NOTFOUND "theme_name in $CFGFILE" || return $?)
#Actualizamos el tema del servidor a la particion
if [ -d $OGLIB/$BOOTLOADER/themes/$NEWTHEME ]; then
- cp -pr $OGLIB/$BOOTLOADER/themes/$NEWTHEME $PART/boot/$BOOTLOADERDIR/themes/
+ # Para refind es necesario que exista theme.conf en el directorio del tema.
+ if [ "$BOOTLOADER" == "refind" ]; then
+ NEWTHEMECFG="$OGLIB/$BOOTLOADER/themes/$NEWTHEME/theme.conf"
+ [ -f $NEWTHEMECFG ] || ogRaiserError $OG_ERR_NOTFOUND "theme.conf" || return $?
+ grep -v "^#" $NEWTHEMECFG >> $CFGFILE
+ # eliminamos "set theme" es de grub y no de refind
+ sed -i '/theme_name/d' $CFGFILE
+ fi
+ cp -pr $OGLIB/$BOOTLOADER/themes/$NEWTHEME $PART/$BOOTLOADERDIR/themes/
fi
#Verificamos que el tema esta en la particion
-if ! [ -d $PART/boot/$BOOTLOADERDIR/themes/$NEWTHEME ]; then
- ogRaiseError $OG_ERR_NOTFOUND "theme_name=$NEWTHEME in $PART/boot/$BOOTLOADERDIR/themes/" || return $?
+if ! [ -d $PART/$BOOTLOADERDIR/themes/$NEWTHEME ]; then
+ ogRaiseError $OG_ERR_NOTFOUND "theme_name=$NEWTHEME in $PART/$BOOTLOADERDIR/themes/" || return $?
fi
#Cambiamos la entrada el fichero de configuración.
-sed --regexp-extended -i s/"$THEME"/"$NEWTHEME"/g $CFGFILE
+sed --regexp-extended -i s/"set theme_name=$THEME"/"set theme_name=$NEWTHEME"/g $CFGFILE
}
@@ -1993,7 +2299,7 @@ PART=$(ogMount $1 $2) || return $?
# La función debe ser llamanda desde ogGrubSetAdminKeys or ogBurgSetAdminKeys.
case "$FUNC" in
ogGrubSetAdminKeys)
- BOOTLOADER="grug"
+ BOOTLOADER="grub"
BOOTLOADERDIR="grubMBR"
CFGFILE="$PART/boot/grubMBR/boot/grub/grub.cfg"
ogRaiseError $OG_ERR_FORMAT "ogGrubSetAdminKeys not sopported"
@@ -2068,6 +2374,25 @@ function ogBurgSetTimeOut ()
}
+#/**
+# ogRefindSetTimeOut int_timeout_second
+#@brief ver ogBootLoaderSetTimeOut
+#@see ogBootLoaderSetTimeOut
+#*/ ##
+function ogRefindSetTimeOut ()
+{
+ local EFIDISK EFIPART
+ # Si se solicita, mostrar ayuda.
+ if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME int_timeout_seconds" \
+ "$FUNCNAME 50"
+ return
+ fi
+
+ read EFIDISK EFIPART <<< $(ogGetEsp)
+ ogBootLoaderSetTimeOut $EFIDISK $EFIPART $@
+ return $?
+}
#/**
# ogBootLoaderSetTimeOut
@@ -2092,7 +2417,7 @@ local FUNC PART CFGFILE TIMEOUT BOOTLOADER BOOTLOADERDIR CFGFILE MSG
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
- ogHelp "$FUNCNAME" "$MSG_SEE ogGrubSetTimeOut ogBurgSetTimeOut"
+ ogHelp "$FUNCNAME" "$MSG_SEE ogGrubSetTimeOut, ogBurgSetTimeOut or ogRefindSetTimeOut"
return
fi
@@ -2107,20 +2432,25 @@ FUNC="${FUNC%%\ *}"
# Error si no puede montar sistema de archivos.
PART=$(ogMount $1 $2) || return $?
-# La función debe ser llamanda desde ogGrubSetTimeOut or ogBurgSetTimeOut.
+# La función debe ser llamanda desde ogGrubSetTimeOut, ogBurgSetTimeOut or ogRefindSetTimeOut.
case "$FUNC" in
ogGrubSetTimeOut)
- BOOTLOADER="grug"
- BOOTLOADERDIR="grubMBR"
+ BOOTLOADER="grub"
+ BOOTLOADERDIR="boot/grubMBR"
CFGFILE="$PART/boot/grubMBR/boot/grub/grub.cfg"
;;
ogBurgSetTimeOut)
BOOTLOADER="burg"
- BOOTLOADERDIR="burg"
+ BOOTLOADERDIR="boot/burg"
CFGFILE="$PART/boot/burg/burg.cfg"
;;
+ ogRefindSetTimeOut)
+ BOOTLOADER="refind"
+ BOOTLOADERDIR="EFI/refind"
+ CFGFILE="$PART/EFI/refind/refind.conf"
+ ;;
*)
- ogRaiseError $OG_ERR_FORMAT "Use ogGrubSetTimeOut"
+ ogRaiseError $OG_ERR_FORMAT "Use ogGrubSetTimeOut, ogBurgSetTimeOut or ogRefindSetTimeOut."
return $?
;;
esac
@@ -2129,7 +2459,11 @@ esac
[ -f $CFGFILE ] || ogRaiseError $OG_ERR_NOTFOUND "$CFGFILE" || return $?
# Asignamos el timeOut.
-sed -i s/timeout=.*$/timeout=$TIMEOUT/g $CFGFILE
+if [ "$BOOTLOADER" == "refind" ]; then
+ sed -i s/timeout.*$/"timeout $TIMEOUT"/g $CFGFILE
+else
+ sed -i s/timeout=.*$/timeout=$TIMEOUT/g $CFGFILE
+fi
}
@@ -2195,7 +2529,7 @@ local FUNC PART CFGFILE RESOLUTION NEWRESOLUTION DEFAULTRESOLUTION BOOTLOADER BO
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
- ogHelp "$FUNCNAME" "$MSG_SEE ogGrubSetResolution ogBurgSetResolution"
+ ogHelp "$FUNCNAME" "$MSG_SEE ogGrubSetResolution, ogBurgSetResolution or ogRefindSetResolution."
return
fi
@@ -2210,10 +2544,10 @@ FUNC="${FUNC%%\ *}"
# Error si no puede montar sistema de archivos.
PART=$(ogMount $1 $2) || return $?
-# La función debe ser llamanda desde oogGrugSetResolution or ogBurgSetResolution.
+# La función debe ser llamanda desde ogGrugSetResolution, ogBurgSetResolution or ogRefindSetResolution.
case "$FUNC" in
ogGrubSetResolution)
- BOOTLOADER="grug"
+ BOOTLOADER="grub"
BOOTLOADERDIR="grubMBR"
CFGFILE="$PART/boot/grubMBR/boot/grub/grub.cfg"
ogRaiseError $OG_ERR_FORMAT "ogGrubSetResolution not sopported"
@@ -2225,7 +2559,7 @@ case "$FUNC" in
CFGFILE="$PART/boot/burg/burg.cfg"
;;
*)
- ogRaiseError $OG_ERR_FORMAT "Use ogBootLoaderSetResolution"
+ ogRaiseError $OG_ERR_FORMAT "Use GrugSetResolution, ogBurgSetResolution or ogRefindSetResolution."
return $?
;;
esac
@@ -2271,61 +2605,190 @@ fi
sed -i s/gfxmode=.*$/gfxmode=$NEWRESOLUTION/g $CFGFILE
}
+
+
+
#/**
-# ogRefindInstall int_ndisk bool_autoconfig
+# ogBootLoaderSetResolution
+#@brief Define la resolucion que usuara el thema del gestor de arranque
+#@param int_resolution1
+#@param int_resolution2 (Opcional)
+#@return
+#@exception OG_ERR_FORMAT Formato incorrecto.
+#@exception OG_ERR_PARTITION Partición errónea o desconocida (ogMount).
+#@exception OG_ERR_NOTFOUND Fichero de configuración no encontrado: grub.cfg burg.cfg.
+#*/ ##
+function ogRefindSetResolution () {
+local PART CFGFILE
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME int_resolution1 [int_resolution2]" \
+ "$FUNCNAME 1366 768" \
+ "$FUNCNAME 1"
+ return
+fi
+
+ # Error si no se reciben 2 parametros.
+[ $# -ge 1 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_resolution1 [int_resolution2]" || return $?
+
+# Error si no puede montar sistema de archivos.
+PART=$(ogMount $(ogGetEsp)) || return $?
+
+# Comprobamos que exista fichero de configuración
+CFGFILE=$PART/EFI/refind/refind.conf
+[ -f $CFGFILE ] || ogRaiseError $OG_ERR_NOTFOUND "$CFGFILE" || return $?
+
+# Borramos resolucion anterior y configuramos la nueva
+sed -i /^resolution/d $CFGFILE
+
+sed -i "1 i\resolution $1 $2" $CFGFILE
+}
+
+# ogRefindInstall bool_autoconfig
#@brief Instala y actualiza el gestor rEFInd en la particion EFI
-#@param int_ndisk
#@param bolean_Check__auto_config true | false[default]
#@return
#@exception OG_ERR_FORMAT Formato incorrecto.
+#@exception OG_ERR_NOTFOUND No se encuentra la partición ESP.
+#@exception OG_ERR_NOTFOUND No se encuentra shimx64.efi.signed.
+#@exception OG_ERR_NOTFOUND No se encuentra refind-install o refind en OGLIB
+#@exception OG_ERR_PARTITION No se puede montar la partición ESP.
+#@note Refind debe estar instalado en el ogLive o compartido en OGLIB
#@version 1.1.0 - Primeras pruebas.
#@author Juan Carlos Garcia. Universidad de ZAragoza.
#@date 2017-06-26
+#@version 1.1.1 - Usa refind-install. Obtiene partición con ogGetEsp. Configura Part-X-Y y ogLive.
+#@author Irina Gomez. Universidad de Sevilla.
+#@date 2019-03-22
#*/ ##
-function ogRefindInstall ()
-{
-
+function ogRefindInstall () {
# Variables locales.
-local DISK EFIDIR CONFIG EFIPARTITIONID
-
+local CONFIG EFIDISK EFIPART EFIDEVICE EFIMNT EFIDIR SHIM REFINDDIR
+local CACHEDEVICE OGLIVE OGLIVEDIR CMDLINE OGICON CFGFILE DEVICES
+local LNXCFGFILE NUMENTRY DIR
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
- ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk boolean_autoconfig " \
- "$FUNCNAME 1 TRUE"
+ ogHelp "$FUNCNAME" "$FUNCNAME boolean_autoconfig " \
+ "$FUNCNAME TRUE"
return
fi
-# Error si no se recibe 1 parámetro.
-[ $# -ge 1 ] || return $(ogRaiseError $OG_ERR_FORMAT; echo $?)
-
-
-DISK=$1
-EFIDIR=/mnt/$(ogDiskToDev $1 1 | cut -c 6-8)$1/EFI
-CONFIG=${2:-"FALSE"}
-EFIPARTITIONID=$(ogGetPartitionId $1 1)
-if [ "$EFIPARTITIONID" == "EF00" ] || [ "$EFIPARTITIONID" == "ef00" ]; then
- cp -pr /opt/opengnsys/lib/refind ${EFIDIR}
- case "$CONFIG" in
- FALSE)
- if [ -a ${EFIDIR}/ubuntu ]; then
- echo "menuentry \"Ubuntu\" {" >> ${EFIDIR}/refind/refind.conf
- echo "loader /EFI/ubuntu/grubx64.efi" >> ${EFIDIR}/refind/refind.conf
- echo "icon /EFI/refind/icons/os_linux.png" >> ${EFIDIR}/refind/refind.conf
- echo "}" >> ${EFIDIR}/refind/refind.conf
- fi
- if [ -a ${EFIDIR}/Microsoft ]; then
- echo "menuentry \"Windows\" {" >> ${EFIDIR}/refind/refind.conf
- echo "loader /EFI/Microsoft/Boot/bootmgfw.efi" >> ${EFIDIR}/refind/refind.conf
- echo "}" >> ${EFIDIR}/refind/refind.conf
- fi
- ;;
- TRUE)
- cp ${EFIDIR}/refind/refind.conf.auto ${EFIDIR}/refind/refind.conf
- ;;
- esac
+# Recogemos parametros
+CONFIG=${1:-"FALSE"}
+
+read -e EFIDISK EFIPART <<< $(ogGetEsp)
+EFIDEVICE=$(ogDiskToDev $EFIDISK $EFIPART) || ogRaiseError $OG_ERR_NOTFOUND "ESP" || return $?
+EFIMNT=$(ogMount $EFIDISK $EFIPART) || ogRaiseError $OG_ERR_PARTITION "$MSG_ERROR mount ESP" || return $?
+EFIDIR="$EFIMNT/EFI"
+[ -d $EFIDIR ] || mkdir $EFIDIR
+
+# Comprobamos que exista shimx64
+SHIM=$(ogGetPath /usr/lib/shim/shimx64.efi.signed)
+[ "$SHIM" == "" ] && return $(ogRaiseError $OG_ERR_NOTFOUND "shimx64.efi.signed")
+
+# Si existe configuración anterior de refind la borro
+[ -d "$EFIDIR/refind" ] && rm -rf $EFIDIR/refind
+
+# Instalamos rEFInd.
+refind-install --yes --alldrivers --root $EFIMNT --shim $SHIM
+
+# Firmo refind con certificado de OpenGnsys
+mv $EFIDIR/refind/grubx64.efi $EFIDIR/refind/grubx64.efi-unsigned
+sbsign --key $OGETC/ssl/private/opengnsys.key --cert $OGETC/ssl/certs/opengnsys.crt --output $EFIDIR/refind/grubx64.efi $EFIDIR/refind/grubx64.efi-unsigned
+
+# Copio los certificados
+cp /etc/refind.d/keys/* $EFIDIR/refind/keys
+# Copio certificado opengnsys
+cp $OGETC/ssl/certs/opengnsys.* $EFIDIR/refind/keys
+
+# Ponemos la entrada en NVRAM en el segundo lugar del orden de arranque
+NEWORDER="$(ogNvramGetOrder|awk '{gsub(",", " "); printf "%x %x %s\n", $2, $1, substr($0, index($0,$3))}')"
+ogNvramSetOrder $NEWORDER
+
+# Borramos configuración linux
+[ -f $EFIMNT/boot/refind_linux.conf ] && mv $EFIMNT/boot/refind_linux.conf{,.ogbackup}
+
+# Eliminamos punto de motaje (por si ejecutamos más de una vez)
+umount $EFIMNT/boot/efi
+
+# Para la configuración del ogLive
+ogMountCache &>/dev/null
+if [ $? -eq 0 ]; then
+ # Detectamos si hay ogLive
+ CACHEDEVICE=$(ogDiskToDev $(ogFindCache))
+ OGLIVE=$(find $OGCAC/boot -name ogvmlinuz|head -1)
+ # Obtenemos parametros del kernel y sustituimos root
+ # La línea de opciones no puede contener la cadena initrd.
+ CMDLINE="$(cat /proc/cmdline|sed -e 's/^.*ogvmlinuz.efi //g' -e 's/^.*ogvmlinuz //g' -e 's|root=/dev/[a-z]* ||g' \
+ -e 's/ogupdateinitrd=[a-z]* //g')"
+ CMDLINE="root=$CACHEDEVICE ${CMDLINE#*ogvmlinuz}"
+
+ # Icono para la entrada de menú
+ OGICON=$(ls $OGLIB/refind/icons/so_opengnsys.png 2>/dev/null)
+ [ "$OGICON" == "" ] && OGICON="${EFIDIR}/refind/icons/os_unknown.png"
+ cp "$OGICON" "$OGCAC/.VolumeIcon.png"
+fi
+
+# Configuramos rEFInd si es necesario
+CFGFILE="${EFIDIR}/refind/refind.conf"
+if [ "$CONFIG" == "TRUE" ]; then
+ echo -e "\n\n# Configuración OpenGnsys" >> $CFGFILE
+ # Excluimos dispositivos distintos de ESP y CACHE
+ DEVICES=$(blkid -s PARTUUID |awk -v D=$EFIDEVICE -v C=$CACHEDEVICE '$1!=D":" && $1!=C":" {gsub(/PARTUUID=/,"");gsub(/"/,""); aux = aux" "$2","} END {print aux}')
+ echo "dont_scan_volumes $DEVICES" >> $CFGFILE
+ # Excluimos en la ESP los directorios de los sistemas operativos
+ echo "dont_scan_dirs EFI/microsoft,EFI/ubuntu,EFI/grub" >> $CFGFILE
+ echo "use_graphics_for osx,linux,windows" >> $CFGFILE
+ echo "showtools reboot, shutdown" >> $CFGFILE
+
+ # Configuramos ogLive
+ if [ "$OGLIVE" != "" ]; then
+ # Cambiamos nombre de kernel e initrd para que lo detecte refind
+ OGLIVEDIR="$(dirname $OGLIVE)"
+ cp "$OGLIVE" "${OGLIVE}.efi"
+ cp "$OGLIVEDIR/oginitrd.img" "$OGLIVEDIR/initrd.img"
+
+ # Incluimos el directorio de ogLive.
+ echo "also_scan_dirs +,boot/$(basename $OGLIVEDIR)" >> $CFGFILE
+ # Fichero de configuración de refind para kernel de linux.
+ LNXCFGFILE="$OGLIVEDIR/refind_linux.conf"
+ echo "\"OpenGnsys Live\" \"$CMDLINE\"" > $LNXCFGFILE
+
+ # Ponemos ogLive como la entrada por defecto
+ NUMENTRY=$(ls -d $EFIDIR/Part-??-??|wc -l)
+ echo "default_selection $((NUMENTRY+1))" >> $CFGFILE
+ fi
else
-$(ogRaiseError $OG_ERR_FORMAT; echo $?)
+ # Renombramos la configuración por defecto
+ mv $CFGFILE ${CFGFILE}.auto
+
+ # Creamos nueva configuración
+ echo "# Configuración OpenGnsys" >> $CFGFILE
+ echo "timeout 20" > $CFGFILE
+ echo "showtools reboot, shutdown" >> $CFGFILE
+ echo -e "scanfor manual\n" >> $CFGFILE
+ # Configuración para sistemas restaurados con OpenGnsys
+ for DIR in $(ls -d /mnt/sda1/EFI/Part-*-* 2>/dev/null); do
+ echo "menuentry \"${DIR##*/}\" {" >> $CFGFILE
+ echo " loader /EFI/${DIR##*/}/Boot/ogloader.efi" >> $CFGFILE
+ [ -f $DIR/Boot/bootmgfw.efi ] && echo " icon /EFI/refind/icons/os_win8.png" >> $CFGFILE
+ [ -f $DIR/Boot/grubx64.efi ] && echo " icon /EFI/refind/icons/os_linux.png" >> $CFGFILE
+ echo "}" >> $CFGFILE
+ done
+ # Configuración ogLive
+ # Comantamos temporalmente: Con la versión nueva de refind falla
+ #if [ "$OGLIVE" != "" ]; then
+ # echo "menuentry \"OpenGnsys Live\" {" >> $CFGFILE
+ # echo " volume CACHE" >> $CFGFILE
+ # echo " ostype Linux" >> $CFGFILE
+ # echo " loader /boot/$(basename ${OGLIVE%/*})/ogvmlinuz" >> $CFGFILE
+ # echo " initrd /boot/$(basename ${OGLIVE%/*})/oginitrd.img" >> $CFGFILE
+ # echo " options \"$CMDLINE\"" >> $CFGFILE
+ # echo "}" >> $CFGFILE
+
+ # # Ponemos ogLive como la entrada por defecto
+ # sed -i '1 i\default_selection "OpenGnsys Live"' $CFGFILE
+ #fi
fi
}
-