emacs-bug-tracker
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

bug#52498: closed ([PATCH] linux-modules: Ignore EINVAL in ‘modprobe’ mo


From: GNU bug Tracking System
Subject: bug#52498: closed ([PATCH] linux-modules: Ignore EINVAL in ‘modprobe’ mode.)
Date: Thu, 16 Dec 2021 18:00:06 +0000

Your message dated Thu, 16 Dec 2021 12:59:01 -0500
with message-id <Ybt+ZTOR5lEEUef5@jasmine.lan>
and subject line Re: [bug#52498] [PATCH] linux-modules: Ignore EINVAL in 
‘modprobe’ mode.
has caused the debbugs.gnu.org bug report #52498,
regarding [PATCH] linux-modules: Ignore EINVAL in ‘modprobe’ mode.
to be marked as done.

(If you believe you have received this mail in error, please contact
help-debbugs@gnu.org.)


-- 
52498: http://debbugs.gnu.org/cgi/bugreport.cgi?bug=52498
GNU Bug Tracking System
Contact help-debbugs@gnu.org with problems
--- Begin Message --- Subject: [PATCH] linux-modules: Ignore EINVAL in ‘modprobe’ mode. Date: Wed, 15 Dec 2021 01:47:04 +0100
Loading the framebuffer-coreboot module simply fails with EINVAL on a
non-Corebooted system.  Crashing the system with a kernel panic is not
a reasonable reaction to loading valid modules on unsupported hardware.
The kernel should log an error, which the user is expected to see.

Bogus module names will still be fatally reported by linux-modules.drv.

* gnu/build/linux-modules.scm (load-linux-module*):
Ignore EINVAL errors when operating recursively.
---
 gnu/build/linux-modules.scm | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)

diff --git a/gnu/build/linux-modules.scm b/gnu/build/linux-modules.scm
index 3a47322065..053720574b 100644
--- a/gnu/build/linux-modules.scm
+++ b/gnu/build/linux-modules.scm
@@ -354,11 +354,13 @@ (define (load-dependencies file)
              (close-fdes fd)
              #t)
            (lambda args
-             ;; If this module was already loaded and we're in modprobe style, 
ignore
-             ;; the error.
              (when fd (close-fdes fd))
-             (or (and recursive? (= EEXIST (system-error-errno args)))
-                 (apply throw args)))))))
+             (let ((errno (system-error-errno args)))
+               (or (and recursive?      ; we're operating in ‘modprobe’ style
+                        (member errno
+                                (list EEXIST    ; already loaded
+                                      EINVAL))) ; unsupported by hardware
+                   (apply throw args))))))))
 
 (define (load-linux-modules-from-directory modules directory)
   "Load MODULES and their dependencies from DIRECTORY, a directory containing
-- 
2.34.0




--- End Message ---
--- Begin Message --- Subject: Re: [bug#52498] [PATCH] linux-modules: Ignore EINVAL in ‘modprobe’ mode. Date: Thu, 16 Dec 2021 12:59:01 -0500
On Wed, Dec 15, 2021 at 01:47:04AM +0100, Tobias Geerinckx-Rice via 
Guix-patches via wrote:
> Loading the framebuffer-coreboot module simply fails with EINVAL on a
> non-Corebooted system.  Crashing the system with a kernel panic is not
> a reasonable reaction to loading valid modules on unsupported hardware.
> The kernel should log an error, which the user is expected to see.
> 
> Bogus module names will still be fatally reported by linux-modules.drv.
> 
> * gnu/build/linux-modules.scm (load-linux-module*):
> Ignore EINVAL errors when operating recursively.

Thanks, pushed as 13f13554433c9dd47503131107dfbdd8a8031832


--- End Message ---

reply via email to

[Prev in Thread] Current Thread [Next in Thread]