refs #1217 do not translate grubSyntax to python
parent
66e3150b1a
commit
b54877528c
|
@ -0,0 +1,486 @@
|
||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
#grubSyntax
|
||||||
|
#version 1.1.0
|
||||||
|
#autoconfigurador de items de menu para grub/brg
|
||||||
|
#basado en scripts del paquete de grub
|
||||||
|
#Antonio Doblas Viso
|
||||||
|
#Universidad de Málaga
|
||||||
|
#@version 1.1.1 - En los parámetros del kernel se sustituye el UUID por el dispositivo.
|
||||||
|
#@version 1.1.1 - Detecta cargador de Windows en directorio Part-xx-yy dentro de ESP (#802 #888)
|
||||||
|
|
||||||
|
export PYTHONPATH=/opt/opengnsys/lib/engine/bin/
|
||||||
|
|
||||||
|
DISK=
|
||||||
|
PART=
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if [ $# == 3 ]; then
|
||||||
|
DISK=$1;PART=$2;KERNELPARAM=$3
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $# == 2 ]; then
|
||||||
|
DISK=$1;PART=$2
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $# == 1 ]; then
|
||||||
|
KERNELPARAM=$1
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
#Versión de scripts compatible con la versión 1.99 de grub-probe
|
||||||
|
#Uso del grub-probe 1.99 según arquitectura
|
||||||
|
grub_probe=${grub_probe:-$OGBIN/grub-probe1.99_$(arch)}
|
||||||
|
|
||||||
|
#librerias del osProber para kernel antiguos: detecta e identifica sistema operativos.
|
||||||
|
if grub-install --version | grep 1.99 ; then
|
||||||
|
cp -r /opt/opengnsys/lib/os-probes/* /usr/lib/os-probes/
|
||||||
|
else
|
||||||
|
# Librería os-probe para cargador de microsoft en dir part-x-y (uefi)
|
||||||
|
OSPROBE_MS_PART="/opt/opengnsys/lib/os-probes/mounted/efi/31part-x-y"
|
||||||
|
[ -f $OSPROBE_MS_PART ] && cp $OSPROBE_MS_PART /usr/lib/os-probes/mounted/efi
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
#Autoreconocimiento del ogLive en cache
|
||||||
|
#fichero de reconocimeinto de grub
|
||||||
|
#fichero de lsb-release en la cache (al final de este scripts se elimina esta entrada para que el browser no lo muestre
|
||||||
|
|
||||||
|
if [ $(ls /opt/opengnsys/cache/boot/$oglivedir/ogvmlinuz 2>/dev/null) ]; then
|
||||||
|
sed -i 's|/boot/\${oglivedir}/ogvmlinuz |/vmlinuz |i' /usr/lib/linux-boot-probes/mounted/90fallback
|
||||||
|
sed -i 's|/vmlinuz |/vmlinuz /boot/\${oglivedir}/ogvmlinuz |1' /usr/lib/linux-boot-probes/mounted/90fallback
|
||||||
|
mkdir -p /opt/opengnsys/cache/etc/
|
||||||
|
echo "DISTRIB_ID=Ubuntu" > /opt/opengnsys/cache/etc/lsb-release
|
||||||
|
echo "DISTRIB_RELEASE= " >> /opt/opengnsys/cache/etc/lsb-release
|
||||||
|
echo $oglivedir | awk -F- ' {print "DISTRIB_CODENAME="$2 }' >> /opt/opengnsys/cache/etc/lsb-release
|
||||||
|
echo "DISTRIB_DESCRIPTION=OpenGnsys Live" >> /opt/opengnsys/cache/etc/lsb-release
|
||||||
|
fi
|
||||||
|
|
||||||
|
#ver linea 195 detección de los os en variable OSPROBED
|
||||||
|
|
||||||
|
OG_prepare_grub_to_access_device ()
|
||||||
|
{
|
||||||
|
device="$1"
|
||||||
|
loop_file=
|
||||||
|
case ${device} in
|
||||||
|
/dev/loop/*|/dev/loop[0-9])
|
||||||
|
grub_loop_device="${device#/dev/}"
|
||||||
|
loop_file=`losetup "${device}" | sed -e "s/^[^(]*(\([^)]\+\)).*/\1/"`
|
||||||
|
case $loop_file in
|
||||||
|
/dev/*) ;;
|
||||||
|
*)
|
||||||
|
loop_device="${device}"
|
||||||
|
device=`"${grub_probe}" --target=device "${loop_file}"` || return 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
if dmsetup status $device 2>/dev/null | grep -q 'crypt[[:space:]]$'; then
|
||||||
|
grub_warn \
|
||||||
|
"$device is a crypto device, which GRUB cannot read directly. Some" \
|
||||||
|
"necessary modules may be missing from /boot/grub/grub.cfg. You may" \
|
||||||
|
"need to list them in GRUB_PRELOAD_MODULES in /etc/default/grub. See" \
|
||||||
|
"http://bugs.debian.org/542165 for details."
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
# Abstraction modules aren't auto-loaded.
|
||||||
|
abstraction="`"${grub_probe}" --device "${device}" --target=abstraction`"
|
||||||
|
for module in ${abstraction} ; do
|
||||||
|
echo "insmod ${module}"
|
||||||
|
done
|
||||||
|
partmap="`"${grub_probe}" --device "${device}" --target=partmap`"
|
||||||
|
for module in ${partmap} ; do
|
||||||
|
case "${module}" in
|
||||||
|
netbsd | openbsd)
|
||||||
|
echo "insmod part_bsd";;
|
||||||
|
*)
|
||||||
|
echo "insmod part_${module}";;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
fs="`"${grub_probe}" --device "${device}" --target=fs`"
|
||||||
|
for module in ${fs} ; do
|
||||||
|
echo "insmod ${module}"
|
||||||
|
done
|
||||||
|
# If there's a filesystem UUID that GRUB is capable of identifying, use it;
|
||||||
|
# otherwise set root as per value in device.map.
|
||||||
|
#OG modificacion
|
||||||
|
# PARCHE UHU ...SI el disco es nvme se cambia su nomenclatura, ya que grub_probe no funciona bien
|
||||||
|
if [[ $DEVICE == *"nvme"* ]]; then
|
||||||
|
#DEVICE=`echo $DEVICE | sed -e "s/\/dev\/nvme/hd/g" | sed -e "s/n.*p/,gpt/g"`
|
||||||
|
#TODO Detectar si es GPT o no...
|
||||||
|
read -r D P <<< $(python3 -c 'import DiskLib; d = DiskLib.ogDevToDisk ("'$DEVICE'"); print (d)')
|
||||||
|
PTT = $(python3 -c 'import DiskLib; t = DiskLib.ogGetPartitionTableType ("'$D'"); print (t)')
|
||||||
|
if [ "$PTT" == "GPT" ]; then
|
||||||
|
# Si es gpt se sustituye por "hd(X-1),gptY"
|
||||||
|
#device=`echo $device | sed -e "s/\/dev\/nvme/hd/g" | sed -e "s/n.*p/,gpt/g"`
|
||||||
|
nvmeDevice=`echo "hd"$(expr $D - 1)",gpt$P"`
|
||||||
|
|
||||||
|
else
|
||||||
|
# Sino se sustituye por hd(X-1),(Y-1)
|
||||||
|
nvmeDevice=`echo "hd"$(expr $D - 1)","$(expr $P - 1)`
|
||||||
|
fi
|
||||||
|
echo "set root='$nvmeDevice'"
|
||||||
|
else
|
||||||
|
echo "set root='`"${grub_probe}" --device "${device}" --target=drive`'"
|
||||||
|
fi
|
||||||
|
|
||||||
|
#if fs_uuid="`"${grub_probe}" --device "${device}" --target=fs_uuid 2> /dev/null`" ; then
|
||||||
|
# echo "search --no-floppy --fs-uuid --set=root ${fs_uuid}"
|
||||||
|
#fi
|
||||||
|
|
||||||
|
if [ "x${loop_file}" != x ]; then
|
||||||
|
loop_mountpoint="$(awk '"'${loop_file}'" ~ "^"$2 && $2 != "/" { print $2 }' /proc/mounts | tail -n1)"
|
||||||
|
if [ "x${loop_mountpoint}" != x ]; then
|
||||||
|
echo "loopback ${grub_loop_device} ${loop_file#$loop_mountpoint}"
|
||||||
|
echo "set root=(${grub_loop_device})"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# grub-mkconfig helper script.
|
||||||
|
# Copyright (C) 2006,2007,2008,2009 Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# GRUB is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# GRUB is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with GRUB. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
|
||||||
|
prefix=/usr
|
||||||
|
exec_prefix=${prefix}
|
||||||
|
libdir=${exec_prefix}/lib
|
||||||
|
|
||||||
|
. ${libdir}/grub/grub-mkconfig_lib
|
||||||
|
|
||||||
|
found_other_os=
|
||||||
|
|
||||||
|
make_timeout () {
|
||||||
|
if [ "x${found_other_os}" = "x" ] ; then
|
||||||
|
if [ "x${1}" != "x" ] ; then
|
||||||
|
if [ "x${GRUB_HIDDEN_TIMEOUT_QUIET}" = "xtrue" ] ; then
|
||||||
|
verbose=
|
||||||
|
else
|
||||||
|
verbose=" --verbose"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "x${1}" = "x0" ] ; then
|
||||||
|
cat <<EOF
|
||||||
|
if [ "x\${timeout}" != "x-1" ]; then
|
||||||
|
if keystatus; then
|
||||||
|
if keystatus --shift; then
|
||||||
|
set timeout=-1
|
||||||
|
else
|
||||||
|
set timeout=0
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
if sleep$verbose --interruptible 3 ; then
|
||||||
|
set timeout=0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
EOF
|
||||||
|
else
|
||||||
|
cat << EOF
|
||||||
|
if [ "x\${timeout}" != "x-1" ]; then
|
||||||
|
if sleep$verbose --interruptible ${GRUB_HIDDEN_TIMEOUT} ; then
|
||||||
|
set timeout=0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
adjust_timeout () {
|
||||||
|
if [ "x$GRUB_BUTTON_CMOS_ADDRESS" != "x" ]; then
|
||||||
|
cat <<EOF
|
||||||
|
if cmostest $GRUB_BUTTON_CMOS_ADDRESS ; then
|
||||||
|
EOF
|
||||||
|
make_timeout "${GRUB_HIDDEN_TIMEOUT_BUTTON}" "${GRUB_TIMEOUT_BUTTON}"
|
||||||
|
echo else
|
||||||
|
make_timeout "${GRUB_HIDDEN_TIMEOUT}" "${GRUB_TIMEOUT}"
|
||||||
|
echo fi
|
||||||
|
else
|
||||||
|
make_timeout "${GRUB_HIDDEN_TIMEOUT}" "${GRUB_TIMEOUT}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ "x${GRUB_DISABLE_OS_PROBER}" = "xtrue" ]; then
|
||||||
|
adjust_timeout
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "`which os-prober 2> /dev/null`" -o -z "`which linux-boot-prober 2> /dev/null`" ] ; then
|
||||||
|
# missing os-prober and/or linux-boot-prober
|
||||||
|
adjust_timeout
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
|
||||||
|
|
||||||
|
esac
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# ADV OSPROBED
|
||||||
|
if [ -n "${DISK}" ]; then
|
||||||
|
#Si $DISK esta definido buscar en el disco y la particion parametro 1 y 2
|
||||||
|
OSSEARCH=$(python3 -c 'import DiskLib; d = DiskLib.ogDiskToDev ("'$DISK'", "'$PART'"); print (d)')
|
||||||
|
OSPROBED="`os-prober | grep $OSSEARCH | tr ' ' '^' | paste -s -d ' '`"
|
||||||
|
else
|
||||||
|
#si no esta definido
|
||||||
|
OSPROBED="`os-prober | tr ' ' '^' | paste -s -d ' '`"
|
||||||
|
fi
|
||||||
|
|
||||||
|
#DISK=${DISK:-"1"}
|
||||||
|
#echo $OSSEARCH
|
||||||
|
#echo "$OSPROBED"
|
||||||
|
|
||||||
|
|
||||||
|
if [ -z "${OSPROBED}" ] ; then
|
||||||
|
# empty os-prober output, nothing doing
|
||||||
|
adjust_timeout
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
osx_entry() {
|
||||||
|
found_other_os=1
|
||||||
|
cat << EOF
|
||||||
|
menuentry "${LONGNAME} (${2}-bit) (on ${DEVICE})" --class osx --class darwin --class os {
|
||||||
|
EOF
|
||||||
|
save_default_entry | sed -e "s/^/\t/"
|
||||||
|
prepare_grub_to_access_device ${DEVICE} | sed -e "s/^/\t/"
|
||||||
|
cat << EOF
|
||||||
|
load_video
|
||||||
|
set do_resume=0
|
||||||
|
if [ /var/vm/sleepimage -nt10 / ]; then
|
||||||
|
if xnu_resume /var/vm/sleepimage; then
|
||||||
|
set do_resume=1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [ \$do_resume = 0 ]; then
|
||||||
|
xnu_uuid ${OSXUUID} uuid
|
||||||
|
if [ -f /Extra/DSDT.aml ]; then
|
||||||
|
acpi -e /Extra/DSDT.aml
|
||||||
|
fi
|
||||||
|
$1 /mach_kernel boot-uuid=\${uuid} rd=*uuid
|
||||||
|
if [ /System/Library/Extensions.mkext -nt /System/Library/Extensions ]; then
|
||||||
|
xnu_mkext /System/Library/Extensions.mkext
|
||||||
|
else
|
||||||
|
xnu_kextdir /System/Library/Extensions
|
||||||
|
fi
|
||||||
|
if [ -f /Extra/Extensions.mkext ]; then
|
||||||
|
xnu_mkext /Extra/Extensions.mkext
|
||||||
|
fi
|
||||||
|
if [ -d /Extra/Extensions ]; then
|
||||||
|
xnu_kextdir /Extra/Extensions
|
||||||
|
fi
|
||||||
|
if [ -f /Extra/devprop.bin ]; then
|
||||||
|
xnu_devprop_load /Extra/devprop.bin
|
||||||
|
fi
|
||||||
|
if [ -f /Extra/splash.jpg ]; then
|
||||||
|
insmod jpeg
|
||||||
|
xnu_splash /Extra/splash.jpg
|
||||||
|
fi
|
||||||
|
if [ -f /Extra/splash.png ]; then
|
||||||
|
insmod png
|
||||||
|
xnu_splash /Extra/splash.png
|
||||||
|
fi
|
||||||
|
if [ -f /Extra/splash.tga ]; then
|
||||||
|
insmod tga
|
||||||
|
xnu_splash /Extra/splash.tga
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
wubi=
|
||||||
|
|
||||||
|
for OS in ${OSPROBED} ; do
|
||||||
|
DEVICE="`echo ${OS} | cut -d ':' -f 1`"
|
||||||
|
LONGNAME="`echo ${OS} | cut -d ':' -f 2 | tr '^' ' '`"
|
||||||
|
LABEL="`echo ${OS} | cut -d ':' -f 3 | tr '^' ' '`"
|
||||||
|
BOOT="`echo ${OS} | cut -d ':' -f 4`"
|
||||||
|
|
||||||
|
if [ -z "${LONGNAME}" ] ; then
|
||||||
|
LONGNAME="${LABEL}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Found ${LONGNAME} on ${DEVICE}" >&2
|
||||||
|
|
||||||
|
case ${BOOT} in
|
||||||
|
chain)
|
||||||
|
|
||||||
|
case ${LONGNAME} in
|
||||||
|
Windows*)
|
||||||
|
if [ -z "$wubi" ]; then
|
||||||
|
if [ -x /usr/share/lupin-support/grub-mkimage ] && \
|
||||||
|
/usr/share/lupin-support/grub-mkimage --test; then
|
||||||
|
wubi=yes
|
||||||
|
else
|
||||||
|
wubi=no
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [ "$wubi" = yes ]; then
|
||||||
|
echo "Skipping ${LONGNAME} on Wubi system" >&2
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
#adv
|
||||||
|
LABELCLASS=$(echo "${LONGNAME}" | awk '{print tolower($1$2);}')
|
||||||
|
|
||||||
|
found_other_os=1
|
||||||
|
cat << EOF
|
||||||
|
menuentry "${LONGNAME} (on ${DEVICE})" --class $LABELCLASS --class windows {
|
||||||
|
EOF
|
||||||
|
save_default_entry | sed -e "s/^/\t/"
|
||||||
|
#ADV prepare_grub_to_access_device ${DEVICE} | sed -e "s/^/\t/"
|
||||||
|
OG_prepare_grub_to_access_device ${DEVICE} | sed -e "s/^/\t/"
|
||||||
|
|
||||||
|
case ${LONGNAME} in
|
||||||
|
Windows\ Vista*|Windows\ 7*|Windows\ Server\ 2008*)
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
#ADV cat << EOF
|
||||||
|
#ADV drivemap -s (hd0) \${root}
|
||||||
|
#ADV EOF
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
cat <<EOF
|
||||||
|
chainloader +1
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
efi)
|
||||||
|
|
||||||
|
found_other_os=1
|
||||||
|
EFIPATH=${DEVICE#*@}
|
||||||
|
DEVICE=${DEVICE%@*}
|
||||||
|
onstr="$(gettext_printf "(on %s)" "${DEVICE}")"
|
||||||
|
cat << EOF
|
||||||
|
menuentry '$(echo "${LONGNAME} $onstr" | grub_quote)' --class windows --class os \$menuentry_id_option 'osprober-efi-$(grub_get_device_id "${DEVICE}")' {
|
||||||
|
EOF
|
||||||
|
save_default_entry | sed -e "s/^/\t/"
|
||||||
|
#ADV prepare_grub_to_access_device ${DEVICE} | sed -e "s/^/\t/"
|
||||||
|
OG_prepare_grub_to_access_device ${DEVICE} | sed -e "s/^/\t/"
|
||||||
|
|
||||||
|
cat <<EOF
|
||||||
|
chainloader ${EFIPATH}
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
linux)
|
||||||
|
KERNELPARAM=""
|
||||||
|
#linuxprobed detecta todos los kernels de una partición.
|
||||||
|
LINUXPROBED="`linux-boot-prober ${DEVICE} 2> /dev/null | tr ' ' '^' | paste -s -d ' '`"
|
||||||
|
#esta opcion de linuxprobe solo interpreta el primer kernel detectado de la partición
|
||||||
|
#Si queremos que autoincluya todos los kernels hay que comentar esta filtrado de LINUXPROBED
|
||||||
|
LINUXPROBED=$(echo $LINUXPROBED | awk '{ print $1}')
|
||||||
|
prepare_boot_cache=
|
||||||
|
# echo "ADV listado de los kerenel encontrados linux-boot-prober ${DEVICE} $LINUXPROBED"
|
||||||
|
for LINUX in ${LINUXPROBED} ; do
|
||||||
|
LINUX=$LINUXPROBED
|
||||||
|
LROOT="`echo ${LINUX} | cut -d ':' -f 1`"
|
||||||
|
LBOOT="`echo ${LINUX} | cut -d ':' -f 2`"
|
||||||
|
LLABEL="`echo ${LINUX} | cut -d ':' -f 3 | tr '^' ' '`"
|
||||||
|
LKERNEL="`echo ${LINUX} | cut -d ':' -f 4`"
|
||||||
|
LINITRD="`echo ${LINUX} | cut -d ':' -f 5`"
|
||||||
|
LPARAMS="`echo ${LINUX} | cut -d ':' -f 6- | tr '^' ' '`"
|
||||||
|
# En los parámetros cambiamos el UUID por el valor de LROOT
|
||||||
|
UUID=$(blkid -s UUID -o value $LROOT)
|
||||||
|
LPARAMS="$(echo $LPARAMS | sed "s|UUID=$UUID|$LROOT|g")"
|
||||||
|
if [ -z "${LLABEL}" ] ; then
|
||||||
|
LLABEL="${LONGNAME}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "${LROOT}" != "${LBOOT}" ]; then
|
||||||
|
LKERNEL="${LKERNEL#/boot}"
|
||||||
|
LINITRD="${LINITRD#/boot}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
found_other_os=1
|
||||||
|
LABELCLASS=$(echo "${LLABEL}" | awk '{print tolower($1);}')
|
||||||
|
cat << EOF
|
||||||
|
menuentry "${LLABEL} (on ${DEVICE})" --class $LABELCLASS --class linux --class os {
|
||||||
|
EOF
|
||||||
|
save_default_entry | sed -e "s/^/\t/"
|
||||||
|
if [ -z "${prepare_boot_cache}" ]; then
|
||||||
|
#ADV prepare_boot_cache="$(prepare_grub_to_access_device ${LBOOT} | sed -e "s/^/\t/")"
|
||||||
|
prepare_boot_cache="$(OG_prepare_grub_to_access_device ${LBOOT} | sed -e "s/^/\t/")"
|
||||||
|
fi
|
||||||
|
printf '%s\n' "${prepare_boot_cache}"
|
||||||
|
if [ "$LABELCLASS" == "opengnsys" ]; then
|
||||||
|
KERNELPARAM=$(cat /proc/cmdline)
|
||||||
|
fi
|
||||||
|
cat << EOF
|
||||||
|
linux ${LKERNEL} ${LPARAMS} ${KERNELPARAM}
|
||||||
|
EOF
|
||||||
|
if [ -n "${LINITRD}" ] ; then
|
||||||
|
cat << EOF
|
||||||
|
initrd ${LINITRD}
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
cat << EOF
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
done
|
||||||
|
;;
|
||||||
|
macosx)
|
||||||
|
OSXUUID="`grub-probe --target=fs_uuid --device ${DEVICE} 2> /dev/null`"
|
||||||
|
osx_entry xnu_kernel 32
|
||||||
|
osx_entry xnu_kernel64 64
|
||||||
|
;;
|
||||||
|
hurd)
|
||||||
|
found_other_os=1
|
||||||
|
cat << EOF
|
||||||
|
menuentry "${LONGNAME} (on ${DEVICE})" --class hurd --class gnu --class os {
|
||||||
|
EOF
|
||||||
|
save_default_entry | sed -e "s/^/\t/"
|
||||||
|
prepare_grub_to_access_device ${DEVICE} | sed -e "s/^/\t/"
|
||||||
|
grub_device="`${grub_probe} --device ${DEVICE} --target=drive`"
|
||||||
|
mach_device="`echo "${grub_device}" | sed -e 's/(\(hd.*\),msdos\(.*\))/\1s\2/'`"
|
||||||
|
grub_fs="`${grub_probe} --device ${DEVICE} --target=fs`"
|
||||||
|
case "${grub_fs}" in
|
||||||
|
*fs) hurd_fs="${grub_fs}" ;;
|
||||||
|
*) hurd_fs="${grub_fs}fs" ;;
|
||||||
|
esac
|
||||||
|
cat << EOF
|
||||||
|
multiboot /boot/gnumach.gz root=device:${mach_device}
|
||||||
|
module /hurd/${hurd_fs}.static ${hurd_fs} --readonly \\
|
||||||
|
--multiboot-command-line='\${kernel-command-line}' \\
|
||||||
|
--host-priv-port='\${host-port}' \\
|
||||||
|
--device-master-port='\${device-port}' \\
|
||||||
|
--exec-server-task='\${exec-task}' -T typed '\${root}' \\
|
||||||
|
'\$(task-create)' '\$(task-resume)'
|
||||||
|
module /lib/ld.so.1 exec /hurd/exec '\$(exec-task=task-create)'
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo " ${LONGNAME} is not yet supported by grub-mkconfig." >&2
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
adjust_timeout
|
||||||
|
|
||||||
|
rm /opt/opengnsys/cache/etc/lsb-release &>/dev/null
|
|
@ -1,197 +0,0 @@
|
||||||
import os
|
|
||||||
import subprocess
|
|
||||||
import sys
|
|
||||||
import DiskLib
|
|
||||||
|
|
||||||
#!/usr/bin/env python3
|
|
||||||
|
|
||||||
def run_command(command):
|
|
||||||
result = subprocess.run(command, shell=True, capture_output=True, text=True)
|
|
||||||
return result.stdout.strip()
|
|
||||||
|
|
||||||
def copy_files(src, dest):
|
|
||||||
if os.path.exists(src):
|
|
||||||
subprocess.run(f"cp -r {src} {dest}", shell=True)
|
|
||||||
|
|
||||||
def prepare_grub_to_access_device(device):
|
|
||||||
loop_file = None
|
|
||||||
if device.startswith("/dev/loop"):
|
|
||||||
grub_loop_device = device.split('/')[-1]
|
|
||||||
loop_file = run_command(f"losetup {device} | sed -e 's/^[^(]*(\\([^)]\\+\\)).*/\\1/'")
|
|
||||||
if not loop_file.startswith("/dev"):
|
|
||||||
loop_device = device
|
|
||||||
device = run_command(f"{grub_probe} --target=device {loop_file}")
|
|
||||||
|
|
||||||
if "crypt" in run_command(f"dmsetup status {device}"):
|
|
||||||
print(f"{device} is a crypto device, which GRUB cannot read directly.")
|
|
||||||
return
|
|
||||||
|
|
||||||
abstraction = run_command(f"{grub_probe} --device {device} --target=abstraction")
|
|
||||||
for module in abstraction.split():
|
|
||||||
print(f"insmod {module}")
|
|
||||||
|
|
||||||
partmap = run_command(f"{grub_probe} --device {device} --target=partmap")
|
|
||||||
for module in partmap.split():
|
|
||||||
if module in ["netbsd", "openbsd"]:
|
|
||||||
print("insmod part_bsd")
|
|
||||||
else:
|
|
||||||
print(f"insmod part_{module}")
|
|
||||||
|
|
||||||
fs = run_command(f"{grub_probe} --device {device} --target=fs")
|
|
||||||
for module in fs.split():
|
|
||||||
print(f"insmod {module}")
|
|
||||||
|
|
||||||
if "nvme" in device:
|
|
||||||
d, p = DiskLib.ogDevToDisk(device)
|
|
||||||
if DiskLib.ogGetPartitionTableType(d) == "GPT":
|
|
||||||
nvme_device = f"hd{d-1},gpt{p}"
|
|
||||||
else:
|
|
||||||
nvme_device = f"hd{d-1},{p-1}"
|
|
||||||
print(f"set root='{nvme_device}'")
|
|
||||||
else:
|
|
||||||
print(f"set root='{run_command(f'{grub_probe} --device {device} --target=drive')}'")
|
|
||||||
|
|
||||||
if loop_file:
|
|
||||||
loop_mountpoint = run_command(f"awk '{loop_file} ~ \"^\"$2 && $2 != \"/\" {{ print $2 }}' /proc/mounts | tail -n1")
|
|
||||||
if loop_mountpoint:
|
|
||||||
print(f"loopback {grub_loop_device} {loop_file[len(loop_mountpoint):]}")
|
|
||||||
print(f"set root=({grub_loop_device})")
|
|
||||||
|
|
||||||
def main():
|
|
||||||
disk = part = kernel_param = None
|
|
||||||
if len(sys.argv) == 4:
|
|
||||||
disk, part, kernel_param = sys.argv[1:4]
|
|
||||||
elif len(sys.argv) == 3:
|
|
||||||
disk, part = sys.argv[1:3]
|
|
||||||
elif len(sys.argv) == 2:
|
|
||||||
kernel_param = sys.argv[1]
|
|
||||||
|
|
||||||
grub_probe = os.getenv("grub_probe", f"{os.getenv('OGBIN')}/grub-probe1.99_{os.uname().machine}")
|
|
||||||
|
|
||||||
if "1.99" in run_command("grub-install --version"):
|
|
||||||
copy_files("/opt/opengnsys/lib/os-probes/*", "/usr/lib/os-probes/")
|
|
||||||
else:
|
|
||||||
osprobe_ms_part = "/opt/opengnsys/lib/os-probes/mounted/efi/31part-x-y"
|
|
||||||
if os.path.isfile(osprobe_ms_part):
|
|
||||||
copy_files(osprobe_ms_part, "/usr/lib/os-probes/mounted/efi")
|
|
||||||
|
|
||||||
if os.path.exists(f"/opt/opengnsys/cache/boot/{oglivedir}/ogvmlinuz"):
|
|
||||||
subprocess.run(f"sed -i 's|/boot/{{oglivedir}}/ogvmlinuz |/vmlinuz |i' /usr/lib/linux-boot-probes/mounted/90fallback", shell=True)
|
|
||||||
subprocess.run(f"sed -i 's|/vmlinuz |/vmlinuz /boot/{{oglivedir}}/ogvmlinuz |1' /usr/lib/linux-boot-probes/mounted/90fallback", shell=True)
|
|
||||||
os.makedirs("/opt/opengnsys/cache/etc/", exist_ok=True)
|
|
||||||
with open("/opt/opengnsys/cache/etc/lsb-release", "w") as f:
|
|
||||||
f.write("DISTRIB_ID=Ubuntu\n")
|
|
||||||
f.write("DISTRIB_RELEASE= \n")
|
|
||||||
f.write(f"DISTRIB_CODENAME={oglivedir.split('-')[1]}\n")
|
|
||||||
f.write("DISTRIB_DESCRIPTION=OpenGnsys Live\n")
|
|
||||||
|
|
||||||
if disk:
|
|
||||||
os_search = DiskLib.ogDiskToDev(disk, part)
|
|
||||||
os_probed = run_command(f"os-prober | grep {os_search} | tr ' ' '^' | paste -s -d ' '")
|
|
||||||
else:
|
|
||||||
os_probed = run_command("os-prober | tr ' ' '^' | paste -s -d ' '")
|
|
||||||
|
|
||||||
if not os_probed:
|
|
||||||
adjust_timeout()
|
|
||||||
sys.exit(0)
|
|
||||||
|
|
||||||
for os_entry in os_probed.split():
|
|
||||||
device, longname, label, boot = os_entry.split(':')
|
|
||||||
longname = longname.replace('^', ' ')
|
|
||||||
label = label.replace('^', ' ')
|
|
||||||
if not longname:
|
|
||||||
longname = label
|
|
||||||
|
|
||||||
print(f"Found {longname} on {device}", file=sys.stderr)
|
|
||||||
|
|
||||||
if boot == "chain":
|
|
||||||
if "Windows" in longname:
|
|
||||||
if not wubi:
|
|
||||||
if os.path.exists("/usr/share/lupin-support/grub-mkimage") and run_command("/usr/share/lupin-support/grub-mkimage --test"):
|
|
||||||
wubi = "yes"
|
|
||||||
else:
|
|
||||||
wubi = "no"
|
|
||||||
if wubi == "yes":
|
|
||||||
print(f"Skipping {longname} on Wubi system", file=sys.stderr)
|
|
||||||
continue
|
|
||||||
|
|
||||||
label_class = ''.join(longname.lower().split()[:2])
|
|
||||||
print(f"menuentry \"{longname} (on {device})\" --class {label_class} --class windows {{")
|
|
||||||
save_default_entry()
|
|
||||||
prepare_grub_to_access_device(device)
|
|
||||||
if "Windows Vista" in longname or "Windows 7" in longname or "Windows Server 2008" in longname:
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
pass
|
|
||||||
print("chainloader +1")
|
|
||||||
print("}")
|
|
||||||
|
|
||||||
elif boot == "efi":
|
|
||||||
efipath = device.split('@')[1]
|
|
||||||
device = device.split('@')[0]
|
|
||||||
onstr = f"(on {device})"
|
|
||||||
print(f"menuentry '{longname} {onstr}' --class windows --class os {{")
|
|
||||||
save_default_entry()
|
|
||||||
prepare_grub_to_access_device(device)
|
|
||||||
print(f"chainloader {efipath}")
|
|
||||||
print("}")
|
|
||||||
|
|
||||||
elif boot == "linux":
|
|
||||||
linux_probed = run_command(f"linux-boot-prober {device} 2> /dev/null | tr ' ' '^' | paste -s -d ' '")
|
|
||||||
linux_probed = linux_probed.split()[0]
|
|
||||||
prepare_boot_cache = None
|
|
||||||
for linux_entry in linux_probed.split():
|
|
||||||
lroot, lboot, llabel, lkernel, linitrd, lparams = linux_entry.split(':')
|
|
||||||
llabel = llabel.replace('^', ' ')
|
|
||||||
lparams = lparams.replace('^', ' ')
|
|
||||||
uuid = run_command(f"blkid -s UUID -o value {lroot}")
|
|
||||||
lparams = lparams.replace(f"UUID={uuid}", lroot)
|
|
||||||
if not llabel:
|
|
||||||
llabel = longname
|
|
||||||
if lroot != lboot:
|
|
||||||
lkernel = lkernel.replace('/boot', '')
|
|
||||||
linitrd = linitrd.replace('/boot', '')
|
|
||||||
label_class = llabel.split()[0].lower()
|
|
||||||
print(f"menuentry \"{llabel} (on {device})\" --class {label_class} --class linux --class os {{")
|
|
||||||
save_default_entry()
|
|
||||||
if not prepare_boot_cache:
|
|
||||||
prepare_boot_cache = prepare_grub_to_access_device(lboot)
|
|
||||||
print(prepare_boot_cache)
|
|
||||||
if label_class == "opengnsys":
|
|
||||||
kernel_param = run_command("cat /proc/cmdline")
|
|
||||||
print(f"linux {lkernel} {lparams} {kernel_param}")
|
|
||||||
if linitrd:
|
|
||||||
print(f"initrd {linitrd}")
|
|
||||||
print("}")
|
|
||||||
|
|
||||||
elif boot == "macosx":
|
|
||||||
osx_uuid = run_command(f"grub-probe --target=fs_uuid --device {device} 2> /dev/null")
|
|
||||||
osx_entry("xnu_kernel", 32, device, longname, osx_uuid)
|
|
||||||
osx_entry("xnu_kernel64", 64, device, longname, osx_uuid)
|
|
||||||
|
|
||||||
elif boot == "hurd":
|
|
||||||
print(f"menuentry \"{longname} (on {device})\" --class hurd --class gnu --class os {{")
|
|
||||||
save_default_entry()
|
|
||||||
prepare_grub_to_access_device(device)
|
|
||||||
grub_device = run_command(f"{grub_probe} --device {device} --target=drive")
|
|
||||||
mach_device = grub_device.replace("(hd", "").replace(",msdos", "s")
|
|
||||||
grub_fs = run_command(f"{grub_probe} --device {device} --target=fs")
|
|
||||||
hurd_fs = grub_fs if grub_fs.endswith("fs") else f"{grub_fs}fs"
|
|
||||||
print(f"multiboot /boot/gnumach.gz root=device:{mach_device}")
|
|
||||||
print(f"module /hurd/{hurd_fs}.static {hurd_fs} --readonly \\")
|
|
||||||
print(f" --multiboot-command-line='{{kernel-command-line}}' \\")
|
|
||||||
print(f" --host-priv-port='{{host-port}}' \\")
|
|
||||||
print(f" --device-master-port='{{device-port}}' \\")
|
|
||||||
print(f" --exec-server-task='{{exec-task}}' -T typed '{{root}}' \\")
|
|
||||||
print(f" '{{task-create}}' '{{task-resume}}'")
|
|
||||||
print(f"module /lib/ld.so.1 exec /hurd/exec '{{exec-task=task-create}}'")
|
|
||||||
print("}")
|
|
||||||
|
|
||||||
else:
|
|
||||||
print(f" {longname} is not yet supported by grub-mkconfig.", file=sys.stderr)
|
|
||||||
|
|
||||||
adjust_timeout()
|
|
||||||
os.remove("/opt/opengnsys/cache/etc/lsb-release")
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
main()
|
|
Loading…
Reference in New Issue