Page 1 of 1

I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 1:22 pm
by Byteria
Installed MX Linux 23 "Libretto" yesterday, then added to /etc/fstab the line /home from previous installation (MX 21) in order to keep previous user's configurations, and MX23 is working fine.

The only problem I have found so far, is that I cannot disable os-prober, anyway.

I did try "MX Tools >> Boot Options", , both "Yes" and "No", but it didn't disable os-prober.

In /etc/default/grub, I have set GRUB_DISABLE_OS_PROBER=true, then GRUB_DISABLE_OS_PROBER="true".

I have also edited /etc/default/grub.mx-defaults, and then renamed it to grub.mx-defaults.txt

Then, in /etc/default/grub, I have disabled all this block, still without results:

Code: Select all

# GRUB_DISABLE_OS_PROBER=true
# if [ -e /etc/default/grub.mx-defaults ]; then
#      .  /etc/default/grub.mx-defaults
# fi
# GRUB_DISABLE_OS_PROBER=true
My system:

Code: Select all

System:
  Kernel: 6.1.0-10-amd64 [6.1.38-2] arch: x86_64 bits: 64 compiler: gcc v: 12.2.0
    parameters: BOOT_IMAGE=/boot/vmlinuz-6.1.0-10-amd64 root=UUID=<filter> ro quiet splash
  Desktop: KDE Plasma v: 5.27.5 wm: kwin_x11 vt: 7 dm: SDDM Distro: MX-23_KDE_x64 Libretto July
    31 2023 base: Debian GNU/Linux 12 (bookworm)
Machine:
  Type: Desktop Mobo: ASUSTeK model: TUF B360M-PLUS GAMING/BR v: Rev X.0x
    serial: <superuser required> UEFI: American Megatrends v: 2401 date: 03/22/2019
CPU:
  Info: model: Intel Core i5-9400 bits: 64 type: MCP arch: Coffee Lake gen: core 9 level: v3
    note: check built: 2018 process: Intel 14nm family: 6 model-id: 0x9E (158) stepping: 0xA (10)
    microcode: 0xF2
  Topology: cpus: 1x cores: 6 smt: <unsupported> cache: L1: 384 KiB desc: d-6x32 KiB; i-6x32 KiB
    L2: 1.5 MiB desc: 6x256 KiB L3: 9 MiB desc: 1x9 MiB
  Speed (MHz): avg: 1850 high: 2900 min/max: 800/4100 scaling: driver: intel_pstate
    governor: powersave cores: 1: 2900 2: 800 3: 2900 4: 800 5: 800 6: 2900 bogomips: 34798
  Flags: avx avx2 ht lm nx pae sse sse2 sse3 sse4_1 sse4_2 ssse3
  Vulnerabilities:
  Type: itlb_multihit status: KVM: VMX unsupported
  Type: l1tf mitigation: PTE Inversion
  Type: mds mitigation: Clear CPU buffers; SMT disabled
  Type: meltdown mitigation: PTI
  Type: mmio_stale_data mitigation: Clear CPU buffers; SMT disabled
  Type: retbleed mitigation: IBRS
  Type: spec_store_bypass mitigation: Speculative Store Bypass disabled via prctl
  Type: spectre_v1 mitigation: usercopy/swapgs barriers and __user pointer sanitization
  Type: spectre_v2 mitigation: IBRS, IBPB: conditional, STIBP: disabled, RSB filling,
    PBRSB-eIBRS: Not affected
  Type: srbds mitigation: Microcode
  Type: tsx_async_abort status: Not affected
Graphics:
  Device-1: Intel CoffeeLake-S GT2 [UHD Graphics 630] vendor: ASUSTeK driver: i915 v: kernel
    arch: Gen-9.5 process: Intel 14nm built: 2016-20 ports: active: HDMI-A-2 empty: HDMI-A-1
    bus-ID: 00:02.0 chip-ID: 8086:3e92 class-ID: 0300
  Display: x11 server: X.Org v: 1.21.1.7 with: Xwayland v: 22.1.9 compositor: kwin_x11 driver: X:
    loaded: modesetting unloaded: fbdev,vesa dri: iris gpu: i915 display-ID: :0 screens: 1
  Screen-1: 0 s-res: 1920x1080 s-dpi: 96 s-size: 508x285mm (20.00x11.22") s-diag: 582mm (22.93")
  Monitor-1: HDMI-A-2 mapped: HDMI-2 model: Acer V246HL serial: <filter> built: 2019
    res: 1920x1080 hz: 60 dpi: 92 gamma: 1.2 size: 531x299mm (20.91x11.77") diag: 609mm (24")
    ratio: 16:9 modes: max: 1920x1080 min: 720x400
  API: OpenGL v: 4.6 Mesa 22.3.6 renderer: Mesa Intel UHD Graphics 630 (CFL GT2)
    direct-render: Yes
Audio:
  Device-1: Intel Cannon Lake PCH cAVS vendor: ASUSTeK driver: snd_hda_intel v: kernel
    alternate: snd_soc_skl,snd_sof_pci_intel_cnl bus-ID: 00:1f.3 chip-ID: 8086:a348 class-ID: 0403
  API: ALSA v: k6.1.0-10-amd64 status: kernel-api tools: alsamixer,amixer
  Server-1: PipeWire v: 0.3.65 status: active with: 1: pipewire-pulse status: active
    2: wireplumber status: active 3: pipewire-alsa type: plugin 4: pw-jack type: plugin
    tools: pactl,pw-cat,pw-cli,wpctl
Network:
  Device-1: Intel Ethernet I219-V vendor: ASUSTeK driver: e1000e v: kernel port: N/A
    bus-ID: 00:1f.6 chip-ID: 8086:15bc class-ID: 0200
  IF: eth0 state: up speed: 1000 Mbps duplex: full mac: <filter>
Drives:
  Local Storage: total: 894.26 GiB used: 272.16 GiB (30.4%)
  SMART Message: Unable to run smartctl. Root privileges required.
  ID-1: /dev/sda maj-min: 8:0 vendor: Western Digital model: WD Green 2.5 480GB size: 447.13 GiB
    block-size: physical: 512 B logical: 512 B speed: 6.0 Gb/s type: SSD serial: <filter> rev: 9100
    scheme: GPT
  ID-2: /dev/sdb maj-min: 8:16 vendor: Kingston model: SA400S37480G size: 447.13 GiB block-size:
    physical: 512 B logical: 512 B speed: 6.0 Gb/s type: SSD serial: <filter> rev: B1D1 scheme: GPT
Partition:
  ID-1: / raw-size: 30 GiB size: 29.36 GiB (97.87%) used: 8.12 GiB (27.7%) fs: ext4 dev: /dev/sda6
    maj-min: 8:6
  ID-2: /boot/efi raw-size: 2 GiB size: 2 GiB (99.80%) used: 33 MiB (1.6%) fs: vfat
    dev: /dev/sdb1 maj-min: 8:17
  ID-3: /home raw-size: 15 GiB size: 14.66 GiB (97.75%) used: 5.34 GiB (36.4%) fs: ext4
    dev: /dev/sda12 maj-min: 8:12
Swap:
  Kernel: swappiness: 15 (default 60) cache-pressure: 100 (default)
  ID-1: swap-1 type: partition size: 11 GiB used: 0 KiB (0.0%) priority: -2 dev: /dev/sdb13
    maj-min: 8:29
Sensors:
  System Temperatures: cpu: 40.0 C mobo: N/A
  Fan Speeds (RPM): N/A
Repos:
  Packages: pm: dpkg pkgs: 2434 libs: 1340 tools: apt,apt-get,aptitude,nala,synaptic pm: rpm
    pkgs: 0 pm: flatpak pkgs: 0
  No active apt repos in: /etc/apt/sources.list
  Active apt repos in: /etc/apt/sources.list.d/debian-stable-updates.list
    1: deb http://debian.c3sl.ufpr.br/debian/ bookworm-updates main contrib non-free non-free-firmware
  Active apt repos in: /etc/apt/sources.list.d/debian.list
    1: deb http://debian.c3sl.ufpr.br/debian/ bookworm main contrib non-free non-free-firmware
    2: deb http://security.debian.org/debian-security/ bookworm-security main contrib non-free non-free-firmware
  Active apt repos in: /etc/apt/sources.list.d/google-chrome.list
    1: deb [arch=amd64] https://dl.google.com/linux/chrome/deb/ stable main
  Active apt repos in: /etc/apt/sources.list.d/google-earth-pro.list
    1: deb [arch=amd64] http://dl.google.com/linux/earth/deb/ stable main
  Active apt repos in: /etc/apt/sources.list.d/mx.list
    1: deb https://mxlinux.c3sl.ufpr.br/mx-workspace/mx/repo/ bookworm main non-free
    2: deb https://mxlinux.c3sl.ufpr.br/mx-workspace/mx/repo/ bookworm ahs
Info:
  Processes: 313 Uptime: 1h 25m wakeups: 1 Memory: 15.47 GiB used: 3.09 GiB (20.0%) Init: SysVinit
  v: 3.06 runlevel: 5 default: graphical tool: systemctl Compilers: gcc: 12 Client: shell wrapper
  v: 5.2.15-release inxi: 3.3.26
Boot Mode: UEFI
Something more, that I could try, in order to disable os-prober?

Re: MX-23 Libretto

Posted: Tue Aug 01, 2023 1:50 pm
by Jerry3904
You might want to start your own thread so it can be seen more easil@Byteria

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 2:07 pm
by Eadwine Rose
Topic split off. @Byteria your topic is here.

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 2:16 pm
by BitterTruth
Are you doing sudo update-grub afterwards? MX Boot options should do it automatically though

Re: I cannot disable os-prober MX23  [Solved]

Posted: Tue Aug 01, 2023 2:17 pm
by dolphin_oracle
os-prober is enabled by default, so

Code: Select all

GRUB_DISABLE_OS_PROBER=true
# if [ -e /etc/default/grub.mx-defaults ]; then
#      .  /etc/default/grub.mx-defaults
# fi
should do it I think.

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 2:19 pm
by BitterTruth
Please post your /etc/default/grub file if you can.

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 4:50 pm
by Byteria
BitterTruth wrote: Tue Aug 01, 2023 2:19 pm Please post your /etc/default/grub file if you can.
It is so, now:

Code: Select all

# If you change this file, run 'update-grub' afterwards to update
# /boot/grub/grub.cfg.
# For full documentation of the options in this file, see:
#   info -f grub -n 'Simple configuration'

GRUB_DEFAULT=0
GRUB_TIMEOUT=5
GRUB_DISTRIBUTOR="$(unset PRETTY_NAME; (. /etc/lsb-release; echo ${PRETTY_NAME:?}) 2>/dev/null || echo Debian)"
GRUB_CMDLINE_LINUX_DEFAULT=""
GRUB_CMDLINE_LINUX=""

# Uncomment to enable BadRAM filtering, modify to suit your needs
# This works with Linux (no patch required) and with any kernel that obtains
# the memory map information from GRUB (GNU Mach, kernel of FreeBSD ...)
#GRUB_BADRAM="0x01234567,0xfefefefe,0x89abcdef,0xefefefef"

# Uncomment to disable graphical terminal (grub-pc only)
#GRUB_TERMINAL=console

# The resolution used on graphical terminal
# note that you can use only modes which your graphic card supports via VBE
# you can see them in real GRUB with the command `vbeinfo'
GRUB_GFXMODE=1024x768

# Uncomment if you don't want GRUB to pass "root=UUID=xxx" parameter to Linux
#GRUB_DISABLE_LINUX_UUID=true

# Uncomment to disable generation of recovery mode menu entries
GRUB_DISABLE_RECOVERY="true"

# Uncomment to get a beep at grub start
#GRUB_INIT_TUNE="480 440 1"

#run dpkg-reconfigure grub-pc to allow toggle of os-prober
GRUB_DISABLE_OS_PROBER="true"

# GRUB_DISABLE_OS_PROBER=true
# if [ -e /etc/default/grub.mx-defaults ]; then
#      .  /etc/default/grub.mx-defaults
# fi
# GRUB_DISABLE_OS_PROBER=true

GRUB_THEME="/boot/grub/themes/mx_linux/theme.txt"

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 5:00 pm
by fehlix
Byteria wrote: Tue Aug 01, 2023 1:22 pm Installed MX Linux 23 "Libretto" yesterday, then added to /etc/fstab the line /home from previous installation (MX 21) in order to keep previous user's configurations, and MX23 is working fine.

The only problem I have found so far, is that I cannot disable os-prober, anyway.

I did try "MX Tools >> Boot Options", , both "Yes" and "No", but it didn't disable os-prober.

In /etc/default/grub, I have set GRUB_DISABLE_OS_PROBER=true, then GRUB_DISABLE_OS_PROBER="true".

I have also edited /etc/default/grub.mx-defaults, and then renamed it to grub.mx-defaults.txt

Then, in /etc/default/grub, I have disabled all this block, still without results:

Code: Select all

# GRUB_DISABLE_OS_PROBER=true
# if [ -e /etc/default/grub.mx-defaults ]; then
#      .  /etc/default/grub.mx-defaults
# fi
# GRUB_DISABLE_OS_PROBER=true
I may suggest this:
Return the changes you made ( or may be keep them):
and run on the konsole this

Code: Select all

sudo debconf-set-selections <<<"grub-pc grub2/enable_os_prober boolean false"

followed by:

Code: Select all

sudo update-grub
would it still run os-prober?
Please try the above first and let us know, wehther this wokred.

Also after the above changes, you can revert the changes,
and try the "classical" way of disabling os-prober, which I think still works on Debian/bookworm,
which is just this:

Code: Select all

sudo chmod -x /etc/grub.d/30_os-prober

Please also let us know whether the classical way works for you.
Thanks
dolphin_oracle wrote: Tue Aug 01, 2023 2:17 pm os-prober is enabled by default, so

Code: Select all

GRUB_DISABLE_OS_PROBER=true
# if [ -e /etc/default/grub.mx-defaults ]; then
#      .  /etc/default/grub.mx-defaults
# fi
should do it I think.
I think we may adjust something here, b/c if grub2/enable_os_prober is set to true
os-prober would still run.
Suggest we tweak our os-prober adjusments a bit,
A)* so it will always enable/disable os-prober run depending on the debconf settings are true/false.

and
B)* maybe we adjust the comments a bit if the user really wants to tweak by himself

and
C)* we should consider to keep the current grub-live file in sync with /etc/grub.d,
which currently is not in resp. to os-prober (may be after A and B). Otherwise user installed from snapshot,
may wonder about this different ways of disabling os-prober.

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 5:01 pm
by BitterTruth
Thank you. Now, please post the terminal output after you do this:

Code: Select all

sudo update-grub

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 5:08 pm
by Byteria
BitterTruth wrote: Tue Aug 01, 2023 5:01 pm Thank you. Now, please post the terminal output after you do this:

Code: Select all

sudo update-grub

Code: Select all

$ date; sudo update-grub; date
Tue  1 Aug 13:51:31 -03 2023
Generating grub configuration file ...
Found theme: /boot/grub/themes/mx_linux/theme.txt
Found linux image: /boot/vmlinuz-6.1.0-10-amd64
Found initrd image: /boot/initrd.img-6.1.0-10-amd64
Found mtest-64.efi image: /boot/uefi-mt/mtest-64.efi
Found Mageia 9 (9) on /dev/sda1
Found Slackware 15.0 x86_64 on /dev/sda2
Found Void Linux on /dev/sda3
Found Manjaro Linux (23.0.0) on /dev/sda4
Found Redcore Linux Hardened - rolling (rolling) on /dev/sda5
Found openSUSE Tumbleweed on /dev/sdb2
Found Arch Linux (rolling) on /dev/sdb3
Found Debian GNU/Linux trixie/sid on /dev/sdb4
Found Fedora Linux 38 (KDE Plasma) on /dev/sdb5
Found KDE neon 5.27 (22.04) on /dev/sdb6
Found PCLinuxOS on /dev/sdb7
Adding boot menu entry for EFI firmware configuration
done
Tue  1 Aug 13:53:19 -03 2023

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 5:26 pm
by BitterTruth
That is strange. Normally at the end of that you should get this warning:

Code: Select all

Warning: os-prober will not be executed to detect other bootable partitions.
Systems on them will not be added to the GRUB boot configuration.
Check GRUB_DISABLE_OS_PROBER documentation entry.
The warning is generated by /etc/grub.d/30_os-prober. Open your file manager and navigate to the file. Right click and choose open with geany/featherpad.

Take a look at the lines 43 to 59:

Code: Select all

if [ "x${GRUB_DISABLE_OS_PROBER}" = "xtrue" ]; then
  grub_warn "$(gettext_printf "os-prober will not be executed to detect other bootable partitions.\nSystems on them will not be added to the GRUB boot configuration.\nCheck GRUB_DISABLE_OS_PROBER documentation entry.")"
  exit 0
elif [ "x${GRUB_DISABLE_OS_PROBER}" = "xauto" ]; then
  # UBUNTU: We do not want to disable os-prober on upgrades if we found items before.
  if test -e /boot/grub/grub.cfg && ! grep -q osprober /boot/grub/grub.cfg; then
    grub_warn "$(gettext_printf "os-prober will not be executed to detect other bootable partitions.\nSystems on them will not be added to the GRUB boot configuration.\nCheck GRUB_DISABLE_OS_PROBER documentation entry.")"
    exit 0
  fi
fi

if ! command -v os-prober > /dev/null || ! command -v linux-boot-prober > /dev/null ; then
  # missing os-prober and/or linux-boot-prober
  exit 0
fi

grub_warn "$(gettext_printf "os-prober will be executed to detect other bootable partitions.\nIts output will be used to detect bootable binaries on them and create new boot entries.")"
Yours will probably say (mine does too):

Code: Select all

if [ "x${GRUB_DISABLE_OS_PROBER}" = "xtrue" ]; then
  exit 0
fi
That's why you're (and me) are not seeing any confirmation. My guess is OS-prober is disabled, just not telling you. If you want to check try enabling it and do sudo update-grub to see if output is generated. My bet is it will be

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 5:32 pm
by fehlix
BitterTruth wrote: Tue Aug 01, 2023 5:26 pm That is strange. Normally at the end of that you should get this warning:

Code: Select all

Warning: os-prober will not be executed to detect other bootable partitions.
Systems on them will not be added to the GRUB boot configuration.
Check GRUB_DISABLE_OS_PROBER documentation entry.
Please don't get confused, we adjusted all those os-prober stuff a bit.
Let the OP first try the method described in the post above.
viewtopic.php?p=736357#p736357
Thanks

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 5:39 pm
by BitterTruth
grub_warn "$(gettext_printf "os-prober will not be executed to detect other bootable partitions.\nSystems on them will not be added to the GRUB boot configuration.\nCheck GRUB_DISABLE_OS_PROBER documentation entry.")"
exit 0
fi

This line is missing from his file. I think OS-Prober IS DISABLED. He is not getting a warning. That's all

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 5:45 pm
by BitterTruth
I just tested it because like the OP, I have Os prober disabled but do not get a warning when I do sudo update-grub. I checked on another machine and the warning is generated.
So, I just added the line to my file to print the warning if that condition is true and then I did sudo update-grub. Now I get the warning. This tells me that that if statement is TRUE and therefore the warning is printed to the screen.

@Byteria Please do you mind posting a copy of your /etc/grub.d/30_os-prober file or at least lines 43 -59.

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 6:14 pm
by Byteria
BitterTruth wrote: Tue Aug 01, 2023 5:45 pm I just tested it because like the OP, I have Os prober disabled but do not get a warning when I do sudo update-grub. I checked on another machine and the warning is generated.
So, I just added the line to my file to print the warning if that condition is true and then I did sudo update-grub. Now I get the warning. This tells me that that if statement is TRUE and therefore the warning is printed to the screen.

@Byteria Please do you mind posting a copy of your /etc/grub.d/30_os-prober file or at least lines 43 -59.
Lines from 43 to 59 are not the same as yours, so it is better to post the entire file:

Code: Select all

#! /bin/sh

#tag for mx-system update
#mx-system 20.11.02+4

export LVM_SUPPRESS_FD_WARNINGS=true

if [ "x$(debconf-get-selections |grep  '^grub-pc\sgrub2/enable_os_prober\sboolean\strue' | awk '{print $4}')" = "xtrue" ]; then
   export GRUB_DISABLE_OS_PROBER="false"
fi

set -e


# 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="/usr"
datarootdir="/usr/share"
quick_boot="0"

export TEXTDOMAIN=grub
export TEXTDOMAINDIR="${datarootdir}/locale"

. "$pkgdatadir/grub-mkconfig_lib"

found_other_os=

adjust_timeout () {
  if [ "$quick_boot" = 1 ] && [ "x${found_other_os}" != "x" ]; then
    cat << EOF
set timeout_style=menu
if [ "\${timeout}" = 0 ]; then
  set timeout=10
fi
EOF
  fi
}

if [ "x${GRUB_DISABLE_OS_PROBER}" = "xtrue" ]; then
  exit 0
fi

if [ -z "`which os-prober 2> /dev/null`" ] || [ -z "`which linux-boot-prober 2> /dev/null`" ] ; then
  # missing os-prober and/or linux-boot-prober
  exit 0
fi

OSPROBED="`os-prober | tr ' ' '^' | paste -s -d ' '`"
if [ -z "${OSPROBED}" ] ; then
  # empty os-prober output, nothing doing
  exit 0
fi

osx_entry() {
    found_other_os=1
    if [ x$2 = x32 ]; then
        # TRANSLATORS: it refers to kernel architecture (32-bit)
	bitstr="$(gettext "(32-bit)")"
    else
        # TRANSLATORS: it refers to kernel architecture (64-bit)
	bitstr="$(gettext "(64-bit)")"
    fi
    # TRANSLATORS: it refers on the OS residing on device %s
    onstr="$(gettext_printf "(on %s)" "${DEVICE}")"
        cat << EOF
menuentry '$(echo "${LONGNAME} $bitstr $onstr" | grub_quote)' --class osx --class darwin --class os \$menuentry_id_option 'osprober-xnu-$2-$(grub_get_device_id "${DEVICE}")'  {
EOF
	save_default_entry | grub_add_tab
	prepare_grub_to_access_device ${DEVICE} | grub_add_tab
	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
           if [ /kernelcache -nt /System/Library/Extensions ]; then
              $1 /kernelcache boot-uuid=\${uuid} rd=*uuid
           elif [ -f /System/Library/Kernels/kernel ]; then
              $1 /System/Library/Kernels/kernel boot-uuid=\${uuid} rd=*uuid
              xnu_kextdir /System/Library/Extensions
           else
              $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
           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
}

used_osprober_linux_ids=

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 UUID="`${grub_probe} --target=fs_uuid --device ${DEVICE%@*}`"; then
    EXPUUID="$UUID"

    if [ x"${DEVICE#*@}" != x ] ; then
      EXPUUID="${EXPUUID}@${DEVICE#*@}"
    fi

    if [ "x${GRUB_OS_PROBER_SKIP_LIST}" != "x" ] && [ "x`echo ${GRUB_OS_PROBER_SKIP_LIST} | grep -i -e '\b'${EXPUUID}'\b'`" != "x" ] ; then
      echo "Skipped ${LONGNAME} on ${DEVICE} by user request." >&2
      continue
    fi
  fi

  BTRFS="`echo ${OS} | cut -d ':' -f 5`"
  if [ "x$BTRFS" = "xbtrfs" ]; then
	BTRFSuuid="`echo ${OS} | cut -d ':' -f 6`"
	BTRFSsubvol="`echo ${OS} | cut -d ':' -f 7`"
  fi

  if [ -z "${LONGNAME}" ] ; then
    LONGNAME="${LABEL}"
  fi

  # os-prober returns text string followed by optional counter
  CLASS="--class $(echo "${LABEL}" | LC_ALL=C sed 's,[[:digit:]]*$,,' | cut -d' ' -f1 | tr 'A-Z' 'a-z' | LC_ALL=C sed 's,[^[:alnum:]_],_,g')"

  gettext_printf "Found %s on %s\n" "${LONGNAME}" "${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

      found_other_os=1
	  onstr="$(gettext_printf "(on %s)" "${DEVICE}")"
      cat << EOF
menuentry '$(echo "${LONGNAME} $onstr" | grub_quote)' $CLASS --class os \$menuentry_id_option 'osprober-chain-$(grub_get_device_id "${DEVICE}")' {
EOF
      save_default_entry | grub_add_tab
      prepare_grub_to_access_device ${DEVICE} | grub_add_tab

      if [ x"`${grub_probe} --device ${DEVICE} --target=partmap`" = xmsdos ]; then
	  cat << EOF
	parttool \${root} hidden-
EOF
      fi

      case ${LONGNAME} in
	Windows\ Vista*|Windows\ 7*|Windows\ Server\ 2008*)
	;;
	*)
	  cat << EOF
	drivemap -s (hd0) \${root}
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 --class os \$menuentry_id_option 'osprober-efi-$(grub_get_device_id "${DEVICE}")' {
EOF
      save_default_entry | sed -e "s/^/\t/"
      prepare_grub_to_access_device ${DEVICE} | sed -e "s/^/\t/"

      cat <<EOF
	chainloader ${EFIPATH}
}
EOF
    ;;
    linux)
      if [ "x$BTRFS" = "xbtrfs" ]; then
         LINUXPROBED="`linux-boot-prober btrfs ${BTRFSuuid} ${BTRFSsubvol}  2> /dev/null | tr ' ' '^' | paste -s -d ' '`"
      else
         LINUXPROBED="`linux-boot-prober ${DEVICE} 2> /dev/null | tr ' ' '^' | paste -s -d ' '`"
      fi
      prepare_boot_cache=
      boot_device_id=
      is_top_level=true
      title_correction_code=
      OS="${LONGNAME}"

      for LINUX in ${LINUXPROBED} ; do
        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  | tr '^' ' '`"
        LPARAMS="`echo ${LINUX} | cut -d ':' -f 6- | tr '^' ' '`"

        if [ -z "${LLABEL}" ] ; then
          LLABEL="${LONGNAME}"
        fi

	if [ "${LROOT}" != "${LBOOT}" ]; then
	  LKERNEL="${LKERNEL#/boot}"
	  LINITRD="${LINITRD#/boot}"
	fi

	if [ -z "${prepare_boot_cache}" ]; then
	  prepare_boot_cache="$(prepare_grub_to_access_device ${LBOOT} | grub_add_tab)"
	  [ "${prepare_boot_cache}" ] || continue
	fi

	found_other_os=1
	onstr="$(gettext_printf "(on %s)" "${DEVICE}")"
	recovery_params="$(echo "${LPARAMS}" | grep 'single\|recovery')" || true
	counter=1
	while echo "$used_osprober_linux_ids" | grep 'osprober-gnulinux-$LKERNEL-${recovery_params}-$counter-$boot_device_id' > /dev/null; do
	    counter=$((counter+1));
	done
	if [ -z "$boot_device_id" ]; then
	    boot_device_id="$(grub_get_device_id "${DEVICE}")"
	fi
	used_osprober_linux_ids="$used_osprober_linux_ids 'osprober-gnulinux-$LKERNEL-${recovery_params}-$counter-$boot_device_id'"

	if [ "x$is_top_level" = xtrue ] && [ "x${GRUB_DISABLE_SUBMENU}" != xy ]; then
            cat << EOF
menuentry '$(echo "$OS $onstr" | grub_quote)' $CLASS --class gnu-linux --class gnu --class os \$menuentry_id_option 'osprober-gnulinux-simple-$boot_device_id' {
EOF
	    save_default_entry | grub_add_tab
	    printf '%s\n' "${prepare_boot_cache}"
	    cat <<  EOF
	linux ${LKERNEL} ${LPARAMS}
EOF
            if [ -n "${LINITRD}" ] ; then
          cat << EOF
	initrd ${LINITRD}
EOF
            fi
        cat << EOF
}
EOF
	    echo "submenu '$(gettext_printf "Advanced options for %s" "${OS} $onstr" | grub_quote)' \$menuentry_id_option 'osprober-gnulinux-advanced-$boot_device_id' {"
	    is_top_level=false
	fi
	title="${LLABEL} $onstr"
        cat << EOF
	menuentry '$(echo "$title" | grub_quote)' --class gnu-linux --class gnu --class os \$menuentry_id_option 'osprober-gnulinux-$LKERNEL-${recovery_params}-$boot_device_id' {
EOF
	save_default_entry | sed -e "s/^/$grub_tab$grub_tab/"
	printf '%s\n' "${prepare_boot_cache}" | grub_add_tab
	cat <<  EOF
		linux ${LKERNEL} ${LPARAMS}
EOF
        if [ -n "${LINITRD}" ] ; then
            cat << EOF
		initrd ${LINITRD}
EOF
        fi
        cat << EOF
	}
EOF
	if [ x"$title" = x"$GRUB_ACTUAL_DEFAULT" ] || [ x"Previous Linux versions>$title" = x"$GRUB_ACTUAL_DEFAULT" ]; then
	    replacement_title="$(echo "Advanced options for ${OS} $onstr" | sed 's,>,>>,g')>$(echo "$title" | sed 's,>,>>,g')"
	    quoted="$(echo "$GRUB_ACTUAL_DEFAULT" | grub_quote)"
	    title_correction_code="${title_correction_code}if [ \"x\$default\" = '$quoted' ]; then default='$(echo "$replacement_title" | grub_quote)'; fi;"
	    grub_warn "$(gettext_printf "Please don't use old title \`%s' for GRUB_DEFAULT, use \`%s' (for versions before 2.00) or \`%s' (for 2.00 or later)" "$GRUB_ACTUAL_DEFAULT" "$replacement_title" "gnulinux-advanced-$boot_device_id>gnulinux-$version-$type-$boot_device_id")"
	fi
      done
      if [ x"$is_top_level" != xtrue ]; then
	  echo '}'
      fi
      echo "$title_correction_code"
    ;;
    macosx)
      if [ "${UUID}" ]; then
	OSXUUID="${UUID}"
	osx_entry xnu_kernel 32
	osx_entry xnu_kernel64 64
      fi
    ;;
    hurd)
      found_other_os=1
      onstr="$(gettext_printf "(on %s)" "${DEVICE}")"
      cat << EOF
menuentry '$(echo "${LONGNAME} $onstr" | grub_quote)' --class hurd --class gnu --class os \$menuentry_id_option 'osprober-gnuhurd-/boot/gnumach.gz-false-$(grub_get_device_id "${DEVICE}")' {
EOF
      save_default_entry | grub_add_tab
      prepare_grub_to_access_device ${DEVICE} | grub_add_tab
      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
    ;;
    minix)
	  cat << EOF
menuentry "${LONGNAME} (on ${DEVICE}, Multiboot)" {
EOF
         save_default_entry | sed -e "s/^/\t/"
         prepare_grub_to_access_device ${DEVICE} | sed -e "s/^/\t/"
	 cat << EOF
	multiboot /boot/image_latest
}
EOF
    ;;
    *)
      # TRANSLATORS: %s is replaced by OS name.
      gettext_printf "%s is not yet supported by grub-mkconfig.\n" "  ${LONGNAME}" >&2
    ;;
  esac
done

adjust_timeout

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 6:44 pm
by BitterTruth
Thank you. I think we might have solved it. You need to

1) First make a backup of this file in your home directory
2) edit the original as sudo to add the warning if os prober is disabled
3) do update-grub to make sure the changes are applied and check for the warning
4) test by enabling/disabling os prober in /etc/default/grub

After you make the backup, find line 54/55 of your original file:

Code: Select all

if [ "x${GRUB_DISABLE_OS_PROBER}" = "xtrue" ]; then
  exit 0
Copy this

Code: Select all

grub_warn "$(gettext_printf "os-prober will not be executed to detect other bootable partitions.\nSystems on them will not be added to the GRUB boot configuration.\nCheck GRUB_DISABLE_OS_PROBER documentation entry.")"
and paste it above exit 0 so that it looks like this:

Code: Select all

if [ "x${GRUB_DISABLE_OS_PROBER}" = "xtrue" ]; then
  grub_warn "$(gettext_printf "os-prober will not be executed to detect other bootable partitions.\nSystems on them will not be added to the GRUB boot configuration.\nCheck GRUB_DISABLE_OS_PROBER documentation entry.")"
  exit 0
Save it. Do sudo update-grub. You should now see the warning at the end of the output.

Testing:

edit the /etc/default/grub:

GRUB_DISABLE_OS_PROBER="true" =======> false

sudo update-grub. There should be no warning.
Change back to true. Warning visible.

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 7:11 pm
by Byteria
dolphin_oracle wrote: Tue Aug 01, 2023 2:17 pm os-prober is enabled by default, so

Code: Select all

GRUB_DISABLE_OS_PROBER=true
# if [ -e /etc/default/grub.mx-defaults ]; then
#      .  /etc/default/grub.mx-defaults
# fi
should do it I think.
Thank you, @dolphin_oracle -- It worked!

Code: Select all

changed in /etc/default/grub:
---------------------------------------------
#run dpkg-reconfigure grub-pc to allow toggle of os-prober
# GRUB_DISABLE_OS_PROBER=false

GRUB_DISABLE_OS_PROBER=true
# if [ -e /etc/default/grub.mx-defaults ]; then
#      .  /etc/default/grub.mx-defaults
# fi
GRUB_DISABLE_OS_PROBER=true
---------------------------------------------

$ date; sudo update-grub; date
Tue  1 Aug 19:58:34 -03 2023
Generating grub configuration file ...
Found theme: /boot/grub/themes/mx_linux/theme.txt
Found linux image: /boot/vmlinuz-6.1.0-10-amd64
Found initrd image: /boot/initrd.img-6.1.0-10-amd64
Found mtest-64.efi image: /boot/uefi-mt/mtest-64.efi
Adding boot menu entry for EFI firmware configuration
done
Tue  1 Aug 19:58:54 -03 2023
Eadwine Rose wrote: Tue Aug 01, 2023 2:07 pm Topic split off. @Byteria your topic is here.
Thank you, @Eadwine Rose

Sorry, I took some time to understand it, and see other answers that I was not seeing.

Thank you all guys, who helped me with this.

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 7:20 pm
by BitterTruth
Hahaha. DOH! I can see it myself now as well. It's the way that parameter is worded. Confusing.

You have it disabled twice now. Not taking any chances :)

I still think that warning needs to be included to let someone know if os-prober has been enabled/disabled. I wonder who thought it was a good idea to remove it.

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 8:05 pm
by Byteria
fehlix wrote: Tue Aug 01, 2023 5:00 pm
Byteria wrote: Tue Aug 01, 2023 1:22 pm Installed MX Linux 23 "Libretto" yesterday, then added to /etc/fstab the line /home from previous installation (MX 21) in order to keep previous user's configurations, and MX23 is working fine.

The only problem I have found so far, is that I cannot disable os-prober, anyway.

I did try "MX Tools >> Boot Options", , both "Yes" and "No", but it didn't disable os-prober.

In /etc/default/grub, I have set GRUB_DISABLE_OS_PROBER=true, then GRUB_DISABLE_OS_PROBER="true".

I have also edited /etc/default/grub.mx-defaults, and then renamed it to grub.mx-defaults.txt

Then, in /etc/default/grub, I have disabled all this block, still without results:

Code: Select all

# GRUB_DISABLE_OS_PROBER=true
# if [ -e /etc/default/grub.mx-defaults ]; then
#      .  /etc/default/grub.mx-defaults
# fi
# GRUB_DISABLE_OS_PROBER=true
I may suggest this:
Return the changes you made ( or may be keep them):
and run on the konsole this

Code: Select all

sudo debconf-set-selections <<<"grub-pc grub2/enable_os_prober boolean false"

followed by:

Code: Select all

sudo update-grub
would it still run os-prober?
Please try the above first and let us know, wehther this wokred.

Also after the above changes, you can revert the changes,
and try the "classical" way of disabling os-prober, which I think still works on Debian/bookworm,
which is just this:

Code: Select all

sudo chmod -x /etc/grub.d/30_os-prober

Please also let us know whether the classical way works for you.
Thanks
dolphin_oracle wrote: Tue Aug 01, 2023 2:17 pm os-prober is enabled by default, so

Code: Select all

GRUB_DISABLE_OS_PROBER=true
# if [ -e /etc/default/grub.mx-defaults ]; then
#      .  /etc/default/grub.mx-defaults
# fi
should do it I think.
I think we may adjust something here, b/c if grub2/enable_os_prober is set to true
os-prober would still run.
Suggest we tweak our os-prober adjusments a bit,
A)* so it will always enable/disable os-prober run depending on the debconf settings are true/false.

and
B)* maybe we adjust the comments a bit if the user really wants to tweak by himself

and
C)* we should consider to keep the current grub-live file in sync with /etc/grub.d,
which currently is not in resp. to os-prober (may be after A and B). Otherwise user installed from snapshot,
may wonder about this different ways of disabling os-prober.
Just in order to be exact...
I did try "MX Tools >> Boot Options", , both "Yes" and "No", but it didn't disable os-prober.
Really, not. What I had done, was running "sudo dpkg-reconfigure grub-pc", with both "Yes" and "No" in the little window that opened.

Before solving the problem, I did also run sudo debconf-set-selections <<<"grub-pc grub2/enable_os_prober boolean false" (after reverting previous changes), which didn't solve it, but I don't know what changed with this, or if it may contributed to solve later.

I did try sudo chmod -x /etc/grub.d/30_os-prober, too... but I didn't test after this, because I have seen other answers, which I had lost until back then.
BitterTruth wrote: Tue Aug 01, 2023 7:20 pm You have it disabled twice now. Not taking any chances :)
:happy:

Here we call it "surround the animal on all sides".

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 8:21 pm
by fehlix
Byteria wrote: Tue Aug 01, 2023 8:05 pm What I had done, was running "sudo dpkg-reconfigure grub-pc", with both "Yes" and "No" in the little window that opened.

Before solving the problem, I did also run sudo debconf-set-selections <<<"grub-pc grub2/enable_os_prober boolean false" (after reverting previous changes), which didn't solve it, but I don't know what changed with this, or if it may contributed to solve later.
I guess, it may have been a bit added some confusion, changing on to many different places...
When you run:

Code: Select all

sudo dpkg-reconfigure grub-pc
It may need to run twice, b/c the update-grub run triggers os-prober, which may take the old true or false
from debconf, b/c dpkg-reconfigure grub-pc might only set the value after the run was finished.
You can check, the change of true or false with:

Code: Select all

sudo debconf-get-selections | grep grub2/enable_os_prober

Re: I cannot disable os-prober MX23

Posted: Tue Aug 01, 2023 11:50 pm
by pbear
@fehlix, for what it's worth, I can't get debconf to work either. Ran multiple times as you suggest. dpkg-reconfigure shows the box unticked. get-selections confirms false. Still, os-prober runs.

On the bright side, to answer your other question, disabling 30_os-prober works fine in MX-23. To anyone considering the option, I suggest putting a comment in /etc/default/grub to remind yourself you've done it.

Re: I cannot disable os-prober MX23

Posted: Wed Aug 02, 2023 3:03 am
by BitterTruth
Since os-prober is just a program/utility, I thought why can't it just be uninstalled?

Code: Select all

~$ dpkg -s os-prober
Package: os-prober
Status: install ok installed
Priority: optional
Section: utils
Installed-Size: 108
Maintainer: Steven Pusser <stevep@mxlinux.org>
Architecture: amd64
Version: 1.77mx19+1
Depends: libc6 (>= 2.4), grub-common
Description: utility to detect other OSes on a set of drives
 This package detects other OSes available on a system and outputs the
 results in a generic machine-readable format.
Original-Maintainer: Debian Install System Team <debian-boot@lists.debian.org>
uninstall shows:

Code: Select all

~$ sudo apt-get remove os-prober
Reading package lists... Done
Building dependency tree       
Reading state information... Done
The following packages were automatically installed and are no longer required:
  fskbsetting gazelle-installer-data-mx grub-efi-amd64-bin grub-efi-ia32-bin
  linux-image-4.19.0-23-amd64 python-configobj python-gobject
Use 'sudo apt autoremove' to remove them.
The following packages will be REMOVED:
  mx-installer os-prober
0 upgraded, 0 newly installed, 2 to remove and 0 not upgraded.
After this operation, 2,355 kB disk space will be freed.
Do you want to continue? [Y/n] 
mx-installer has a dependancy on it. Is it safe to remove mx-installer? (mx-installer is not the same as mx-packageinstaller)

If it's safe to remove mx-installer as well then os-prober can just be uninstalled rather than messing around with scripts