Working ISO configs for ArchLinux and TinyCore
This commit is contained in:
parent
2ac9f558dd
commit
b17f2a6268
4 changed files with 141 additions and 3 deletions
|
@ -1,4 +1,6 @@
|
||||||
# Load ISO configuration files
|
# Load ISO configuration files
|
||||||
|
#
|
||||||
|
insmod regexp
|
||||||
|
|
||||||
set isopath="/boot/isos"
|
set isopath="/boot/isos"
|
||||||
export isopath
|
export isopath
|
||||||
|
@ -8,10 +10,22 @@ export isoconfdir
|
||||||
|
|
||||||
if [ -d "${isoconfdir}" ]; then
|
if [ -d "${isoconfdir}" ]; then
|
||||||
echo "${isoconfdir} is a directory"
|
echo "${isoconfdir} is a directory"
|
||||||
for conf in isoconfdir/*.cfg; do
|
for conf in ${isoconfdir}/*.cfg; do
|
||||||
|
if [ ! -f "$conf" ]; then
|
||||||
|
echo "No valid configuration to read"
|
||||||
|
break;
|
||||||
|
fi
|
||||||
|
|
||||||
echo "Sourcing $conf "
|
echo "Sourcing $conf "
|
||||||
source "$conf"
|
source "${conf}"
|
||||||
done
|
done
|
||||||
|
|
||||||
|
menuentry ' ' { true }
|
||||||
|
|
||||||
|
menuentry "[Esc] Back to Menu" {
|
||||||
|
configfile "${prefix}/grub.cfg"
|
||||||
|
}
|
||||||
else
|
else
|
||||||
echo "Cannot read ${isoconfdir}"
|
echo "Cannot read ${isoconfdir}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
50
boot/isos.cfg.d/archlinux.cfg
Normal file
50
boot/isos.cfg.d/archlinux.cfg
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
# This is the ArchLinux Grub config
|
||||||
|
# from GLIM
|
||||||
|
|
||||||
|
set isopath_archlinux="${isopath}/archlinux"
|
||||||
|
export isopath_archlinux
|
||||||
|
|
||||||
|
# abuse for to check for existence
|
||||||
|
for isofile in $isopath_archlinux/archlinux*.iso $isopath_archlinux/ipxe*; do
|
||||||
|
if [ ! -e "$isofile" ]; then break; fi
|
||||||
|
|
||||||
|
submenu "ArchLinux >" --class arch {
|
||||||
|
|
||||||
|
menuentry "ArchLinux BIOS netboot" --class arch {
|
||||||
|
echo "Booting ArchLinux BIOS netboot"
|
||||||
|
linux16 $isopath_archlinux/ipxe.419cd003a298.lkrn
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ ${grub_platform} == "efi" ]; then
|
||||||
|
menuentry "ArchLinux EFI netboot" --class arch {
|
||||||
|
echo "Booting ArchLinux EFI netboot"
|
||||||
|
chainloader $isopath_archlinux/ipxe.176077d7fccb.efi
|
||||||
|
}
|
||||||
|
fi
|
||||||
|
|
||||||
|
menuentry "" { true }
|
||||||
|
|
||||||
|
for isofile in $isopath_archlinux/archlinux-*.iso; do
|
||||||
|
if [ ! -e "$isofile" ]; then break; fi
|
||||||
|
|
||||||
|
regexp \
|
||||||
|
--set 1:isoname \
|
||||||
|
--set 2:version \
|
||||||
|
--set 3:arch \
|
||||||
|
"^${isopath_archlinux}/(archlinux-([^-]+)-([^-]+)\.iso)\$" "${isofile}"
|
||||||
|
|
||||||
|
menuentry "Arch Linux ${version} ${arch}" "${isofile}" "${isoname}" --class arch {
|
||||||
|
set isofile=$2
|
||||||
|
set isoname=$3
|
||||||
|
echo "Using ${isoname}..."
|
||||||
|
loopback loop $isofile
|
||||||
|
linux (loop)/arch/boot/x86_64/vmlinuz-linux img_dev=/dev/disk/by-uuid/${rootuuid} img_loop=${isofile}
|
||||||
|
initrd (loop)/arch/boot/intel-ucode.img (loop)/arch/boot/amd-ucode.img (loop)/arch/boot/x86_64/initramfs-linux.img
|
||||||
|
}
|
||||||
|
done
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
# kill for loop
|
||||||
|
break
|
||||||
|
done
|
37
boot/isos.cfg.d/tails.cfg
Normal file
37
boot/isos.cfg.d/tails.cfg
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
# Tails Grub config
|
||||||
|
# from GLIM
|
||||||
|
|
||||||
|
set isopath_tails="${isopath}/tails"
|
||||||
|
export isopath_tails
|
||||||
|
|
||||||
|
# abuse for to check for existence
|
||||||
|
for isofile in $isopath_tails/tails-*.iso; do
|
||||||
|
if [ ! -e "$isofile" ]; then break; fi
|
||||||
|
|
||||||
|
submenu "Tails" --class tails {
|
||||||
|
|
||||||
|
for isofile in $isopath_tails/tails-*.iso; do
|
||||||
|
if [ ! -e "$isofile" ]; then break; fi
|
||||||
|
echo "$isofile exists"
|
||||||
|
|
||||||
|
regexp \
|
||||||
|
--set 1:isoname \
|
||||||
|
--set 2:arch \
|
||||||
|
--set 3:version \
|
||||||
|
"^${isopath_tails}/(tails-([^-]+)-([^-]+)\.iso)\$" "${isofile}"
|
||||||
|
|
||||||
|
menuentry "Tails ${version} ${arch}" "${isofile}" "${isoname}" --class tails {
|
||||||
|
set isofile=$2
|
||||||
|
set isoname=$3
|
||||||
|
echo "Using ${isoname}..."
|
||||||
|
loopback loop $isofile
|
||||||
|
linux (loop)/live/vmlinuz boot=live live-media=removable findiso=${isofile} config apparmor=1 security=apparmor nopersistence noprompt timezone=Etc/UTC block.events_dfl_poll_msecs=1000 splash noautologin module=Tails kaslr slab_nomerge slub_debug=FZP mce=0 vsyscall=none page_poison=1 union=aufs quiet
|
||||||
|
initrd (loop)/live/initrd.img
|
||||||
|
}
|
||||||
|
done
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
# kill for loop
|
||||||
|
break
|
||||||
|
done
|
37
boot/isos.cfg.d/tinycore.cfg
Normal file
37
boot/isos.cfg.d/tinycore.cfg
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
# TinyCore Grub Config
|
||||||
|
|
||||||
|
|
||||||
|
set isopath_tinycore="${isopath}/tinycore"
|
||||||
|
export isopath_tinycore
|
||||||
|
|
||||||
|
# abuse for to check for existence
|
||||||
|
for isofile in $isopath_tinycore/*.iso; do
|
||||||
|
if [ ! -e "$isofile" ]; then break; fi
|
||||||
|
|
||||||
|
submenu "TinyCore Linux >" --class tinycore {
|
||||||
|
|
||||||
|
for isofile in ${isopath_tinycore}/*Core*.iso; do
|
||||||
|
if [ ! -e "$isofile" ]; then break; fi
|
||||||
|
|
||||||
|
regexp \
|
||||||
|
--set 1:isoname \
|
||||||
|
--set 2:variant \
|
||||||
|
--set 3:version \
|
||||||
|
"^${isopath_tinycore}/((.*Core[^-]*)-(.+)\.iso)\$" "${isofile}"
|
||||||
|
|
||||||
|
menuentry "${variant} ${version}" "${isofile}" "${isoname}" --class tinycore {
|
||||||
|
set isofile=$2
|
||||||
|
set isoname=$3
|
||||||
|
echo "Using ${isoname}..."
|
||||||
|
loopback loop $isofile
|
||||||
|
# ideas to add for CorePlus: loglevel=3 cde showapps desktop=flwm_topside
|
||||||
|
linux (loop)/boot/vmlinuz
|
||||||
|
initrd (loop)/boot/core.gz
|
||||||
|
}
|
||||||
|
done
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
# kill for loop
|
||||||
|
break
|
||||||
|
done
|
Loading…
Reference in a new issue