[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
bug#30760: guix system init broken on non GuixSD
From: |
Ludovic Courtès |
Subject: |
bug#30760: guix system init broken on non GuixSD |
Date: |
Mon, 12 Mar 2018 13:57:08 +0100 |
User-agent: |
Gnus/5.13 (Gnus v5.13) Emacs/25.3 (gnu/linux) |
Hello,
Danny Milosavljevic <address@hidden> skribis:
>> I'm afraid this is still not correct.
>>
>> # guix system init config.scm /mnt/mnt/
>> ...
>> config.scm:64:9: error: you may need these modules in the initrd for
>> /dev/nvme0n1p2: shpchp
>> hint: Try adding them to the `initrd-modules' field of your
>> `operating-system' declaration, along these lines:
>>
>> (operating-system
>> ;; ...
>> (initrd-modules (append (list "shpchp")
>> %base-initrd-modules)))
>>
>> I don't have `shpchp` as a module as I have it compiled into kernel
>> directly. Can I somehow disable the check?
Exactly what I feared. ;-)
> I think it's a good idea to add a command-line switch that disables the check.
>
> But then people will just disable the check always and it won't improve until
> it's correct. It's still a good idea to give people the choice.
>
> @Ludo: It would also be great to have a command-line switch to check the slow,
> correct, way. We'd also have to check modules.builtin of the new system's
> initrd
> - but we'd do it only when the option is passed :)
>
> I suggest to change it to:
>
>> # guix system init config.scm /mnt/mnt/
>> ...
>> config.scm:64:9: WARNING: you may need these modules in the initrd for
>> /dev/nvme0n1p2: shpchp
> ^^^ not error
I thought about making it a warning rather than an error back then, but
thought that it wouldn’t work well: the warning would immediately go
off-screen as build logs start scrolling by.
Thus I took the optimistic view that false positives like the one Tomáš
experienced should be rare because usually init/reconfigure are used on
GuixSD, with a kernel config very close to the target config.
Nevertheless, the risk of false-positives obviously exists, hence the
need for an escape hatch.
What about the attached patch?
Thanks,
Ludo’.
diff --git a/doc/guix.texi b/doc/guix.texi
index d3a7908f9..bcea89e07 100644
--- a/doc/guix.texi
+++ b/doc/guix.texi
@@ -20458,6 +20458,16 @@ of the image size as a function of the size of the
system declared in
Make @var{file} a symlink to the result, and register it as a garbage
collector root.
address@hidden --skip-checks
+Skip pre-installation safety checks.
+
+By default, @command{guix system init} and @command{guix system
+reconfigure} perform safety checks: they make sure the file systems that
+appear in the @code{operating-system} declaration actually exist
+(@pxref{File Systems}), and that any Linux kernel modules that may be
+needed at boot time are listed in @code{initrd-modules} (@pxref{Initial
+RAM Disk}). Passing this option skips these tests altogether.
+
@item address@hidden
Apply @var{strategy} when an error occurs when reading @var{file}.
@var{strategy} may be one of the following:
diff --git a/guix/scripts/system.scm b/guix/scripts/system.scm
index acfccce96..f0c4a2ba1 100644
--- a/guix/scripts/system.scm
+++ b/guix/scripts/system.scm
@@ -733,7 +733,8 @@ and TARGET arguments."
(#$installer #$bootloader #$device #$target))))))
(define* (perform-action action os
- #:key install-bootloader?
+ #:key skip-safety-checks?
+ install-bootloader?
dry-run? derivations-only?
use-substitutes? bootloader-target target
image-size file-system-type full-boot?
@@ -750,7 +751,10 @@ When DERIVATIONS-ONLY? is true, print the derivation file
name(s) without
building anything.
When GC-ROOT is a path, also make that path an indirect root of the build
-output when building a system derivation, such as a disk image."
+output when building a system derivation, such as a disk image.
+
+When SKIP-SAFETY-CHECKS? is true, skip the file system and initrd module
+static checks."
(define println
(cut format #t "~a~%" <>))
@@ -760,7 +764,8 @@ output when building a system derivation, such as a disk
image."
;; Check whether the declared file systems exist. This is better than
;; instantiating a broken configuration. Assume that we can only check if
;; running as root.
- (when (memq action '(init reconfigure))
+ (when (and (not skip-safety-checks?)
+ (memq action '(init reconfigure)))
(check-mapped-devices os)
(when (zero? (getuid))
(check-file-system-availability (operating-system-file-systems os))
@@ -933,6 +938,8 @@ Some ACTIONS support additional ARGS.\n"))
--expose=SPEC for 'vm', expose host file system according to SPEC"))
(display (G_ "
--full-boot for 'vm', make a full boot sequence"))
+ (display (G_ "
+ --skip-checks skip file system and initrd module safety checks"))
(newline)
(display (G_ "
-h, --help display this help and exit"))
@@ -974,6 +981,9 @@ Some ACTIONS support additional ARGS.\n"))
(option '("full-boot") #f #f
(lambda (opt name arg result)
(alist-cons 'full-boot? #t result)))
+ (option '("skip-checks") #f #f
+ (lambda (opt name arg result)
+ (alist-cons 'skip-safety-checks? #t result)))
(option '("share") #t #f
(lambda (opt name arg result)
@@ -1067,6 +1077,8 @@ resulting from command-line parsing."
#:derivations-only? (assoc-ref opts
'derivations-only?)
#:use-substitutes? (assoc-ref opts 'substitutes?)
+ #:skip-safety-checks?
+ (assoc-ref opts 'skip-safety-checks?)
#:file-system-type (assoc-ref opts
'file-system-type)
#:image-size (assoc-ref opts 'image-size)
#:full-boot? (assoc-ref opts 'full-boot?)
- bug#30760: guix system init broken on non GuixSD, Tomáš Čech, 2018/03/09
- bug#30760: guix system init broken on non GuixSD, Danny Milosavljevic, 2018/03/09
- bug#30760: guix system init broken on non GuixSD, Ludovic Courtès, 2018/03/09
- bug#30760: guix system init broken on non GuixSD, Danny Milosavljevic, 2018/03/09
- bug#30760: guix system init broken on non GuixSD, Ludovic Courtès, 2018/03/09
- bug#30760: guix system init broken on non GuixSD, Tomáš Čech, 2018/03/10
- bug#30760: guix system init broken on non GuixSD, Danny Milosavljevic, 2018/03/11
- Message not available
- Message not available
- bug#30760: guix system init broken on non GuixSD, Tomáš Čech, 2018/03/12
- bug#30760: guix system init broken on non GuixSD, Danny Milosavljevic, 2018/03/12
- bug#30760: guix system init broken on non GuixSD, Danny Milosavljevic, 2018/03/12
- bug#30760: guix system init broken on non GuixSD,
Ludovic Courtès <=
- bug#30760: guix system init broken on non GuixSD, Ludovic Courtès, 2018/03/15
- bug#30760: guix system init broken on non GuixSD, Tomáš Čech, 2018/03/12