mirror of
https://codeberg.org/guix/guix.git
synced 2025-10-02 02:15:12 +00:00
system: reconfigure: Use the disk-installer if provided.
Fixes: <https://issues.guix.gnu.org/44101>. * gnu/build/bootloader.scm (write-file-on-device): Pass 'no-fail flag instead of 'no-create. Use a latin-1 transcoder. * guix/scripts/system/reconfigure.scm (install-bootloader-program): Add a "disk-installer" argument and use it as a fallback. (install-bootloader): Adapt accordingly. * gnu/tests/reconfigure.scm (run-install-bootloader-test): Ditto.
This commit is contained in:
parent
25e811583f
commit
a38d861e57
3 changed files with 22 additions and 6 deletions
|
@ -204,7 +204,8 @@ services as defined by OS."
|
|||
;;; Bootloader configuration.
|
||||
;;;
|
||||
|
||||
(define (install-bootloader-program installer bootloader-package bootcfg
|
||||
(define (install-bootloader-program installer disk-installer
|
||||
bootloader-package bootcfg
|
||||
bootcfg-file device target)
|
||||
"Return an executable store item that, upon being evaluated, will install
|
||||
BOOTCFG to BOOTCFG-FILE, a target file name, on DEVICE, a file system device,
|
||||
|
@ -246,10 +247,17 @@ BOOTLOADER-PACKAGE."
|
|||
;; a broken installation.
|
||||
(switch-symlinks new-gc-root #$bootcfg)
|
||||
(install-boot-config #$bootcfg #$bootcfg-file #$target)
|
||||
(when #$installer
|
||||
(when (or #$installer #$disk-installer)
|
||||
(catch #t
|
||||
(lambda ()
|
||||
(#$installer #$bootloader-package #$device #$target))
|
||||
;; The bootloader might not support installation on a
|
||||
;; mounted directory using the BOOTLOADER-INSTALLER
|
||||
;; procedure. In that case, fallback to installing the
|
||||
;; bootloader directly on DEVICE using the
|
||||
;; BOOTLOADER-DISK-IMAGE-INSTALLER procedure.
|
||||
(if #$installer
|
||||
(#$installer #$bootloader-package #$device #$target)
|
||||
(#$disk-installer #$bootloader-package 0 #$device)))
|
||||
(lambda args
|
||||
(delete-file new-gc-root)
|
||||
(match args
|
||||
|
@ -272,11 +280,14 @@ additional configurations specified by MENU-ENTRIES can be selected."
|
|||
(let* ((bootloader (bootloader-configuration-bootloader configuration))
|
||||
(installer (and run-installer?
|
||||
(bootloader-installer bootloader)))
|
||||
(disk-installer (and run-installer?
|
||||
(bootloader-disk-image-installer bootloader)))
|
||||
(package (bootloader-package bootloader))
|
||||
(device (bootloader-configuration-target configuration))
|
||||
(bootcfg-file (bootloader-configuration-file bootloader)))
|
||||
(eval #~(parameterize ((current-warning-port (%make-void-port "w")))
|
||||
(primitive-load #$(install-bootloader-program installer
|
||||
disk-installer
|
||||
package
|
||||
bootcfg
|
||||
bootcfg-file
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue