mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2024-12-24 21:38:07 -05: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
|
@ -38,10 +38,13 @@ (define (write-file-on-device file size device offset)
|
|||
(lambda (input)
|
||||
(let ((bv (get-bytevector-n input size)))
|
||||
(call-with-port
|
||||
;; Do not use "call-with-output-file" that would truncate the file.
|
||||
(open-file-output-port device
|
||||
(file-options no-truncate no-create)
|
||||
(file-options no-truncate no-fail)
|
||||
(buffer-mode block)
|
||||
(native-transcoder))
|
||||
;; Use the binary-friendly ISO-8859-1
|
||||
;; encoding.
|
||||
(make-transcoder (latin-1-codec)))
|
||||
(lambda (output)
|
||||
(seek output offset SEEK_SET)
|
||||
(put-bytevector output bv)))))))
|
||||
|
|
|
@ -260,7 +260,9 @@ (define (generations-in-grub-cfg marionette)
|
|||
;; test suite, the bootloader installer script is omitted. 'grub-install'
|
||||
;; would attempt to write directly to the virtual disk if the
|
||||
;; installation script were run.
|
||||
(test (install-bootloader-program #f #f bootcfg bootcfg-file #f "/")))))
|
||||
(test
|
||||
(install-bootloader-program #f #f #f bootcfg bootcfg-file #f "/")))))
|
||||
|
||||
|
||||
(define %test-switch-to-system
|
||||
(system-test
|
||||
|
|
|
@ -204,7 +204,8 @@ (define target-services
|
|||
;;; 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 @@ (define (install-bootloader-program installer bootloader-package bootcfg
|
|||
;; 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 @@ (define* (install-bootloader eval configuration bootcfg
|
|||
(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…
Reference in a new issue