From 45a34aecafa64a666976e3d3d7944f8c8ff1e058 Mon Sep 17 00:00:00 2001
From: Andrew Ammerlaan <andrewammerl...@gentoo.org>
Date: Tue, 25 Jun 2024 16:32:42 +0200
Subject: [PATCH] sys-kernel/linux-firmware: complain less when /boot is not
 mounted

when using dist-kernel we can correct the problem and then
emerge --config ...

Signed-off-by: Andrew Ammerlaan <andrewammerl...@gentoo.org>
---
 .../linux-firmware-20240410.ebuild            | 21 +++++++++++++------
 .../linux-firmware-20240513.ebuild            | 21 +++++++++++++------
 .../linux-firmware-20240610.ebuild            | 21 +++++++++++++------
 .../linux-firmware-99999999.ebuild            | 21 +++++++++++++------
 4 files changed, 60 insertions(+), 24 deletions(-)

diff --git a/sys-kernel/linux-firmware/linux-firmware-20240410.ebuild b/sys-kernel/linux-firmware/linux-firmware-20240410.ebuild
index 1bb6954d00c88..b8bbed17f1a6d 100644
--- a/sys-kernel/linux-firmware/linux-firmware-20240410.ebuild
+++ b/sys-kernel/linux-firmware/linux-firmware-20240410.ebuild
@@ -69,7 +69,15 @@ QA_PREBUILT="*"
 PATCHES=( "${FILESDIR}"/${PN}-copy-firmware-r4.patch )

 pkg_pretend() {
-       use initramfs && mount-boot_pkg_pretend
+       if use initramfs; then
+               if [[ -z ${ROOT} ]] && use dist-kernel; then
+                       # Check, but don't die because we can fix the problem 
and then
+                       # emerge --config ... to re-run installation.
+                       nonfatal mount-boot_check_status
+               else
+                       mount-boot_pkg_pretend
+               fi
+       fi
 }

 pkg_setup() {
@@ -379,7 +387,7 @@ pkg_preinst() {
        fi

        # Make sure /boot is available if needed.
-       use initramfs && mount-boot_pkg_preinst
+       use initramfs && ! use dist-kernel && mount-boot_pkg_preinst
 }

 pkg_postinst() {
@@ -397,21 +405,22 @@ pkg_postinst() {
                fi
        done

-       # Don't forget to umount /boot if it was previously mounted by us.
        if use initramfs; then
                if [[ -z ${ROOT} ]] && use dist-kernel; then
                        dist-kernel_reinstall_initramfs "${KV_DIR}" "${KV_FULL}"
+               else
+                       # Don't forget to umount /boot if it was previously 
mounted by us.
+                       mount-boot_pkg_postinst
                fi
-               mount-boot_pkg_postinst
        fi
 }

 pkg_prerm() {
        # Make sure /boot is mounted so that we can remove /boot/amd-uc.img!
-       use initramfs && mount-boot_pkg_prerm
+       use initramfs && ! use dist-kernel && mount-boot_pkg_prerm
 }

 pkg_postrm() {
        # Don't forget to umount /boot if it was previously mounted by us.
-       use initramfs && mount-boot_pkg_postrm
+       use initramfs && ! use dist-kernel && mount-boot_pkg_postrm
 }
diff --git a/sys-kernel/linux-firmware/linux-firmware-20240513.ebuild b/sys-kernel/linux-firmware/linux-firmware-20240513.ebuild
index 1bb6954d00c88..b8bbed17f1a6d 100644
--- a/sys-kernel/linux-firmware/linux-firmware-20240513.ebuild
+++ b/sys-kernel/linux-firmware/linux-firmware-20240513.ebuild
@@ -69,7 +69,15 @@ QA_PREBUILT="*"
 PATCHES=( "${FILESDIR}"/${PN}-copy-firmware-r4.patch )

 pkg_pretend() {
-       use initramfs && mount-boot_pkg_pretend
+       if use initramfs; then
+               if [[ -z ${ROOT} ]] && use dist-kernel; then
+                       # Check, but don't die because we can fix the problem 
and then
+                       # emerge --config ... to re-run installation.
+                       nonfatal mount-boot_check_status
+               else
+                       mount-boot_pkg_pretend
+               fi
+       fi
 }

 pkg_setup() {
@@ -379,7 +387,7 @@ pkg_preinst() {
        fi

        # Make sure /boot is available if needed.
-       use initramfs && mount-boot_pkg_preinst
+       use initramfs && ! use dist-kernel && mount-boot_pkg_preinst
 }

 pkg_postinst() {
@@ -397,21 +405,22 @@ pkg_postinst() {
                fi
        done

-       # Don't forget to umount /boot if it was previously mounted by us.
        if use initramfs; then
                if [[ -z ${ROOT} ]] && use dist-kernel; then
                        dist-kernel_reinstall_initramfs "${KV_DIR}" "${KV_FULL}"
+               else
+                       # Don't forget to umount /boot if it was previously 
mounted by us.
+                       mount-boot_pkg_postinst
                fi
-               mount-boot_pkg_postinst
        fi
 }

 pkg_prerm() {
        # Make sure /boot is mounted so that we can remove /boot/amd-uc.img!
-       use initramfs && mount-boot_pkg_prerm
+       use initramfs && ! use dist-kernel && mount-boot_pkg_prerm
 }

 pkg_postrm() {
        # Don't forget to umount /boot if it was previously mounted by us.
-       use initramfs && mount-boot_pkg_postrm
+       use initramfs && ! use dist-kernel && mount-boot_pkg_postrm
 }
diff --git a/sys-kernel/linux-firmware/linux-firmware-20240610.ebuild b/sys-kernel/linux-firmware/linux-firmware-20240610.ebuild
index 1bb6954d00c88..b8bbed17f1a6d 100644
--- a/sys-kernel/linux-firmware/linux-firmware-20240610.ebuild
+++ b/sys-kernel/linux-firmware/linux-firmware-20240610.ebuild
@@ -69,7 +69,15 @@ QA_PREBUILT="*"
 PATCHES=( "${FILESDIR}"/${PN}-copy-firmware-r4.patch )

 pkg_pretend() {
-       use initramfs && mount-boot_pkg_pretend
+       if use initramfs; then
+               if [[ -z ${ROOT} ]] && use dist-kernel; then
+                       # Check, but don't die because we can fix the problem 
and then
+                       # emerge --config ... to re-run installation.
+                       nonfatal mount-boot_check_status
+               else
+                       mount-boot_pkg_pretend
+               fi
+       fi
 }

 pkg_setup() {
@@ -379,7 +387,7 @@ pkg_preinst() {
        fi

        # Make sure /boot is available if needed.
-       use initramfs && mount-boot_pkg_preinst
+       use initramfs && ! use dist-kernel && mount-boot_pkg_preinst
 }

 pkg_postinst() {
@@ -397,21 +405,22 @@ pkg_postinst() {
                fi
        done

-       # Don't forget to umount /boot if it was previously mounted by us.
        if use initramfs; then
                if [[ -z ${ROOT} ]] && use dist-kernel; then
                        dist-kernel_reinstall_initramfs "${KV_DIR}" "${KV_FULL}"
+               else
+                       # Don't forget to umount /boot if it was previously 
mounted by us.
+                       mount-boot_pkg_postinst
                fi
-               mount-boot_pkg_postinst
        fi
 }

 pkg_prerm() {
        # Make sure /boot is mounted so that we can remove /boot/amd-uc.img!
-       use initramfs && mount-boot_pkg_prerm
+       use initramfs && ! use dist-kernel && mount-boot_pkg_prerm
 }

 pkg_postrm() {
        # Don't forget to umount /boot if it was previously mounted by us.
-       use initramfs && mount-boot_pkg_postrm
+       use initramfs && ! use dist-kernel && mount-boot_pkg_postrm
 }
diff --git a/sys-kernel/linux-firmware/linux-firmware-99999999.ebuild b/sys-kernel/linux-firmware/linux-firmware-99999999.ebuild
index dc02d051d7ea4..88c5398099a38 100644
--- a/sys-kernel/linux-firmware/linux-firmware-99999999.ebuild
+++ b/sys-kernel/linux-firmware/linux-firmware-99999999.ebuild
@@ -84,7 +84,15 @@ pkg_setup() {
 }

 pkg_pretend() {
-       use initramfs && mount-boot_pkg_pretend
+       if use initramfs; then
+               if [[ -z ${ROOT} ]] && use dist-kernel; then
+                       # Check, but don't die because we can fix the problem 
and then
+                       # emerge --config ... to re-run installation.
+                       nonfatal mount-boot_check_status
+               else
+                       mount-boot_pkg_pretend
+               fi
+       fi
 }

 src_unpack() {
@@ -379,7 +387,7 @@ pkg_preinst() {
        fi

        # Make sure /boot is available if needed.
-       use initramfs && mount-boot_pkg_preinst
+       use initramfs && ! use dist-kernel && mount-boot_pkg_preinst
 }

 pkg_postinst() {
@@ -397,21 +405,22 @@ pkg_postinst() {
                fi
        done

-       # Don't forget to umount /boot if it was previously mounted by us.
        if use initramfs; then
                if [[ -z ${ROOT} ]] && use dist-kernel; then
                        dist-kernel_reinstall_initramfs "${KV_DIR}" "${KV_FULL}"
+               else
+                       # Don't forget to umount /boot if it was previously 
mounted by us.
+                       mount-boot_pkg_postinst
                fi
-               mount-boot_pkg_postinst
        fi
 }

 pkg_prerm() {
        # Make sure /boot is mounted so that we can remove /boot/amd-uc.img!
-       use initramfs && mount-boot_pkg_prerm
+       use initramfs && ! use dist-kernel && mount-boot_pkg_prerm
 }

 pkg_postrm() {
        # Don't forget to umount /boot if it was previously mounted by us.
-       use initramfs && mount-boot_pkg_postrm
+       use initramfs && ! use dist-kernel && mount-boot_pkg_postrm
 }


Reply via email to