3rdparty/os_probe: Better wording, fix Beta+ version parsing.

Add lots of comments explaining things in the code.  Also fix parsing
of Beta updates which have hrev version numbers with an extra bit at
the end, like hrev12345_67.  Include architecture in the GRUB menu
title, so you can tell 32 bit and 64 bit installs apart.  Switch
back to #!/usr/bin/sh, like all the other probes do.

Change-Id: Id47afe5029369c739d5177b1dd917c7d1d631ad6
Reviewed-on: https://review.haiku-os.org/c/haiku/+/4498
Reviewed-by: Alexander G. M. Smith <agmsmith@ncf.ca>
Reviewed-by: Adrien Destugues <pulkomandy@gmail.com>
This commit is contained in:
Alexander G. M. Smith 2021-09-27 17:19:41 -04:00 committed by Adrien Destugues
parent c09821c07d
commit 0b057a903f
2 changed files with 31 additions and 23 deletions

View File

@ -1,7 +1,11 @@
#!/bin/sh #!/usr/bin/sh
# Detects Haiku on BeFS partitions and FUSE mounted BeFS too. # Detects bootable Haiku OS on BeFS partitions and FUSE mounted BeFS too.
# Discussion at https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=732696 # If it doesn't find anything, try mounting the BeFS volumes in Linux.
# From version 42 (dated 20150811) updated by Jeroen Oortwijn at https://bazaar.launchpad.net/~idefix/ubuntu/trusty/os-prober/HaikuPM/files/head:/os-probes/mounted/x86 # Discussion of improvements and development history at
# https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=732696
# Adapted from version 42 (dated 20150811) updated by Jeroen Oortwijn at
# https://bazaar.launchpad.net/~idefix/ubuntu/trusty/os-prober/HaikuPM/files/head:/os-probes/mounted/x86
# Latest version now at https://git.haiku-os.org/haiku/tree/3rdparty/os_probe
. /usr/share/os-prober/common.sh . /usr/share/os-prober/common.sh
@ -9,15 +13,15 @@ partition="$1"
mpoint="$2" mpoint="$2"
type="$3" type="$3"
# Weed out stuff that doesn't apply to us # Weed out stuff that doesn't apply to us, needs to be a Be file system.
case "$type" in case "$type" in
bfs|befs) debug "$partition is a BeFS partition" ;; bfs|befs) debug "$partition is a BeFS partition." ;;
fuse|fuseblk) debug "$partition is a FUSE partition" ; mpoint="$mpoint/myfs" ;; # might be befs-fuse fuse|fuseblk) debug "$partition is a FUSE partition, maybe with BeFS on it." ; mpoint="$mpoint/myfs" ;;
*) debug "$partition is not a BeFS partition: exiting"; exit 1 ;; *) exit 1 ;; # Be quiet and just quit for irrelevant partitions.
esac esac
if head -c 512 "$partition" | grep -qs "haiku_loader"; then if head -c 512 "$partition" | grep -qs "haiku_loader"; then
debug "Haiku stage 1 bootloader found" debug "Haiku stage 1 bootloader found."
else else
debug "Haiku stage 1 bootloader not found: exiting" debug "Haiku stage 1 bootloader not found: exiting"
exit 1 exit 1
@ -25,12 +29,16 @@ fi
if system="$(item_in_dir "system" "$mpoint")" && if system="$(item_in_dir "system" "$mpoint")" &&
packages="$(item_in_dir "packages" "$mpoint/$system")" && packages="$(item_in_dir "packages" "$mpoint/$system")" &&
item_in_dir -q "haiku_loader-.*\.hpkg" "$mpoint/$system/$packages" && item_in_dir -q "haiku_loader-r[0-9].*\.hpkg" "$mpoint/$system/$packages" &&
rev="$(item_in_dir "haiku-.*\.hpkg" "$mpoint/$system/$packages")" rev="$(item_in_dir "haiku-r[0-9].*\.hpkg" "$mpoint/$system/$packages")"
then then
debug "Haiku PM stage 2 bootloader and kernel found" debug "Haiku Package Manager stage 2 bootloader and kernel ($rev) found."
label="$(count_next_label Haiku)" label="$(count_next_label Haiku)"
rev="$(echo "$rev" | sed 's/haiku-//;s/^\(r[0-9]\+\)./\U\1\E /;s/ \([a-z]\+[0-9]\+\)[_-]/ \1 /;s/ [a-z]*_\?\(hrev[0-9]\+\)\+-/ (\1) /;s/[^ ]\+.hpkg//;s/ $//')" # Convert kernel file name like haiku-r1~beta3_hrev55181_56-1-x86_64.hpkg
# or haiku-r1~alpha4_pm_hrev49856-1-x86_gcc2.hpkg into a readable version,
# like "Haiku R1 beta3 (hrev55181_56) 64". Seems to use a travelling space
# technique in the sed stream editor.
rev="$(echo "$rev" | sed 's/haiku-//;s/^\(r[0-9]\+\)./\U\1\E /;s/ \([a-z]\+[0-9]\+\)[_-]/ \1 /;s/ [a-z]*_\?\(hrev[0-9_]\+\)\+-/ (\1) /;s/) [^_]\+_\([a-z0-9]\+\)\.hpkg/) \1 /;s/[^ ]\+.hpkg//;s/ $//')"
long="Haiku $rev" long="Haiku $rev"
result "$partition:$long:$label:chain" result "$partition:$long:$label:chain"
exit 0 exit 0
@ -38,7 +46,7 @@ elif system="$(item_in_dir "system" "$mpoint")" &&
item_in_dir -q "haiku_loader" "$mpoint/$system" && item_in_dir -q "haiku_loader" "$mpoint/$system" &&
item_in_dir -q "kernel_.*" "$mpoint/$system" item_in_dir -q "kernel_.*" "$mpoint/$system"
then then
debug "Haiku non-PM stage 2 bootloader and kernel found" debug "Older non-package manager Haiku stage 2 bootloader and kernel found."
label="$(count_next_label Haiku)" label="$(count_next_label Haiku)"
result "$partition:Haiku:$label:chain" result "$partition:Haiku:$label:chain"
exit 0 exit 0

View File

@ -1,19 +1,19 @@
# os-probe for the Haiku Computer Operating System # os-probe for the Haiku Computer Operating System
This is the Linux "os-probes" file to detect Haiku OS and to automatically add This is the Linux "os-probes" file to detect Haiku OS and to automatically add
it to the GRUB boot menu. it to the GRUB boot menu. Mostly relevant for x86 BIOS based computers.
First make sure the Haiku volumes you want to boot are mounted in Linux Copy the 83haiku file to your Linux system in the os-probes subdirectory,
(otherwise nothing gets detected). Then copy the 83haiku file to your Linux usually (in Fedora at least) it will be /usr/libexec/os-probes/mounted/83haiku
system in the os-probes subdirectory, usually (in Fedora at least) it will be You can find older 83haiku versions in the repository history, though the
/usr/libexec/os-probes/mounted/83haiku You can find older 83haiku versions in latest should be able to detect older (pre-package manager) Haiku too.
the repository history, though the latest should be able to detect older
(pre-package manager) Haiku too.
Then regenerate the GRUB boot configuration file. This will happen Then regenerate the GRUB boot configuration file. This will happen
automatically the next time your kernel is updated. To do it manually, automatically the next time your kernel is updated. To do it manually,
for old school MBR BIOS boot computers, the command is for old school MBR BIOS boot computers, the command is
`grub2-mkconfig --output /boot/grub2/grub.cfg` `grub2-mkconfig --output /boot/grub2/grub.cfg`
If it doesn't find the Haiku partitions, try manually mounting them in Linux
and rerun the grub command.
Computers using the newer UEFI boot system have a EFI/HAIKU/BOOTX64.EFI file Computers using the newer UEFI boot system have a EFI/HAIKU/BOOTX64.EFI file
that you manually install to your EFI partition, and booting is done that you manually install to your EFI partition, and booting is done
@ -25,6 +25,6 @@ It's in the
[Debian os-prober package](https://packages.debian.org/search?keywords=os-prober). [Debian os-prober package](https://packages.debian.org/search?keywords=os-prober).
There's also a big discussion about updating it in There's also a big discussion about updating it in
[Debian Bug Report #732696](https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=732696). [Debian Bug Report #732696](https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=732696).
Latest version is now at https://git.haiku-os.org/haiku/tree/3rdparty/os_probe
_AGMS20210921_ _AGMS20210927_