mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-11 13:49:23 -05:00
image: Add support for 32bit UEFI.
* gnu/bootloader/grub.scm (grub-efi32-bootloader): New variable. (install-grub-efi32): New variable. * gnu/build/bootloader.scm (install-efi): Add a 'targets' keyword argument. (install-efi-loader): Likewise. * gnu/build/image.scm (initialize-efi32-partition): New procedure. * gnu/packages/bootloaders.scm (grub-efi32): New variable. * gnu/system/image.scm (esp32-partition): New variable (efi32-disk-image): New variable. (efi32-raw-image-type): New variable. (system-disk-image)[partition-image]: Set '#:grub-efi32' when calling the partition initializer. Signed-off-by: Mathieu Othacehe <othacehe@gnu.org>
This commit is contained in:
parent
242fad357e
commit
62c86c8391
5 changed files with 102 additions and 13 deletions
|
@ -8,6 +8,7 @@
|
||||||
;;; Copyright © 2020 Maxim Cournoyer <maxim.cournoyer@gmail.com>
|
;;; Copyright © 2020 Maxim Cournoyer <maxim.cournoyer@gmail.com>
|
||||||
;;; Copyright © 2020 Stefan <stefan-guix@vodafonemail.de>
|
;;; Copyright © 2020 Stefan <stefan-guix@vodafonemail.de>
|
||||||
;;; Copyright © 2022 Karl Hallsby <karl@hallsby.com>
|
;;; Copyright © 2022 Karl Hallsby <karl@hallsby.com>
|
||||||
|
;;; Copyright © 2022 Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -57,6 +58,7 @@ (define-module (gnu bootloader grub)
|
||||||
grub-bootloader
|
grub-bootloader
|
||||||
grub-efi-bootloader
|
grub-efi-bootloader
|
||||||
grub-efi-removable-bootloader
|
grub-efi-removable-bootloader
|
||||||
|
grub-efi32-bootloader
|
||||||
grub-efi-netboot-bootloader
|
grub-efi-netboot-bootloader
|
||||||
grub-mkrescue-bootloader
|
grub-mkrescue-bootloader
|
||||||
grub-minimal-bootloader
|
grub-minimal-bootloader
|
||||||
|
@ -636,6 +638,29 @@ (define install-grub-efi-removable
|
||||||
"--bootloader-id=Guix"
|
"--bootloader-id=Guix"
|
||||||
"--efi-directory" target-esp)))))
|
"--efi-directory" target-esp)))))
|
||||||
|
|
||||||
|
(define install-grub-efi32
|
||||||
|
#~(lambda (bootloader efi-dir mount-point)
|
||||||
|
;; There is nothing useful to do when called in the context of a disk
|
||||||
|
;; image generation.
|
||||||
|
(when efi-dir
|
||||||
|
;; Install GRUB onto the EFI partition mounted at EFI-DIR, for the
|
||||||
|
;; system whose root is mounted at MOUNT-POINT.
|
||||||
|
(let ((grub-install (string-append bootloader "/sbin/grub-install"))
|
||||||
|
(install-dir (string-append mount-point "/boot"))
|
||||||
|
;; When installing Guix, it's common to mount EFI-DIR below
|
||||||
|
;; MOUNT-POINT rather than /boot/efi on the live image.
|
||||||
|
(target-esp (if (file-exists? (string-append mount-point efi-dir))
|
||||||
|
(string-append mount-point efi-dir)
|
||||||
|
efi-dir)))
|
||||||
|
;; Tell 'grub-install' that there might be a LUKS-encrypted /boot or
|
||||||
|
;; root partition.
|
||||||
|
(setenv "GRUB_ENABLE_CRYPTODISK" "y")
|
||||||
|
(invoke/quiet grub-install "--boot-directory" install-dir
|
||||||
|
"--bootloader-id=Guix"
|
||||||
|
(cond ((target-x86?) "--target=i386-efi")
|
||||||
|
((target-arm?) "--target=arm-efi"))
|
||||||
|
"--efi-directory" target-esp)))))
|
||||||
|
|
||||||
(define (install-grub-efi-netboot subdir)
|
(define (install-grub-efi-netboot subdir)
|
||||||
"Define a grub-efi-netboot bootloader installer for installation in SUBDIR,
|
"Define a grub-efi-netboot bootloader installer for installation in SUBDIR,
|
||||||
which is usually efi/Guix or efi/boot."
|
which is usually efi/Guix or efi/boot."
|
||||||
|
@ -768,6 +793,13 @@ (define grub-efi-removable-bootloader
|
||||||
(name 'grub-efi-removable-bootloader)
|
(name 'grub-efi-removable-bootloader)
|
||||||
(installer install-grub-efi-removable)))
|
(installer install-grub-efi-removable)))
|
||||||
|
|
||||||
|
(define grub-efi32-bootloader
|
||||||
|
(bootloader
|
||||||
|
(inherit grub-efi-bootloader)
|
||||||
|
(installer install-grub-efi32)
|
||||||
|
(name 'grub-efi32)
|
||||||
|
(package grub-efi32)))
|
||||||
|
|
||||||
(define grub-efi-netboot-bootloader
|
(define grub-efi-netboot-bootloader
|
||||||
(bootloader
|
(bootloader
|
||||||
(inherit grub-efi-bootloader)
|
(inherit grub-efi-bootloader)
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
;;; GNU Guix --- Functional package management for GNU
|
;;; GNU Guix --- Functional package management for GNU
|
||||||
;;; Copyright © 2017 Mathieu Othacehe <m.othacehe@gmail.com>
|
;;; Copyright © 2017 Mathieu Othacehe <m.othacehe@gmail.com>
|
||||||
;;; Copyright © 2019 Ludovic Courtès <ludo@gnu.org>
|
;;; Copyright © 2019 Ludovic Courtès <ludo@gnu.org>
|
||||||
|
;;; Copyright © 2022 Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
|
||||||
|
;;; Copyright © 2022 Timothy Sample <samplet@ngyro.com>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -54,8 +56,12 @@ (define (write-file-on-device file size device offset)
|
||||||
;;; EFI bootloader.
|
;;; EFI bootloader.
|
||||||
;;;
|
;;;
|
||||||
|
|
||||||
(define (install-efi grub grub-config esp)
|
(define* (install-efi grub grub-config esp #:key targets)
|
||||||
"Write a self-contained GRUB EFI loader to the mounted ESP using GRUB-CONFIG."
|
"Write a self-contained GRUB EFI loader to the mounted ESP using
|
||||||
|
GRUB-CONFIG.
|
||||||
|
|
||||||
|
If TARGETS is set, use its car as the GRUB image format and its cdr as
|
||||||
|
the output filename. Otherwise, use defaults for the host platform."
|
||||||
(let* ((system %host-type)
|
(let* ((system %host-type)
|
||||||
;; Hard code the output location to a well-known path recognized by
|
;; Hard code the output location to a well-known path recognized by
|
||||||
;; compliant firmware. See "3.5.1.1 Removable Media Boot Behaviour":
|
;; compliant firmware. See "3.5.1.1 Removable Media Boot Behaviour":
|
||||||
|
@ -63,14 +69,15 @@ (define (install-efi grub grub-config esp)
|
||||||
(grub-mkstandalone (string-append grub "/bin/grub-mkstandalone"))
|
(grub-mkstandalone (string-append grub "/bin/grub-mkstandalone"))
|
||||||
(efi-directory (string-append esp "/EFI/BOOT"))
|
(efi-directory (string-append esp "/EFI/BOOT"))
|
||||||
;; Map grub target names to boot file names.
|
;; Map grub target names to boot file names.
|
||||||
(efi-targets (cond ((string-prefix? "x86_64" system)
|
(efi-targets (or targets
|
||||||
'("x86_64-efi" . "BOOTX64.EFI"))
|
(cond ((string-prefix? "x86_64" system)
|
||||||
((string-prefix? "i686" system)
|
'("x86_64-efi" . "BOOTX64.EFI"))
|
||||||
'("i386-efi" . "BOOTIA32.EFI"))
|
((string-prefix? "i686" system)
|
||||||
((string-prefix? "armhf" system)
|
'("i386-efi" . "BOOTIA32.EFI"))
|
||||||
'("arm-efi" . "BOOTARM.EFI"))
|
((string-prefix? "armhf" system)
|
||||||
((string-prefix? "aarch64" system)
|
'("arm-efi" . "BOOTARM.EFI"))
|
||||||
'("arm64-efi" . "BOOTAA64.EFI")))))
|
((string-prefix? "aarch64" system)
|
||||||
|
'("arm64-efi" . "BOOTAA64.EFI"))))))
|
||||||
;; grub-mkstandalone requires a TMPDIR to prepare the firmware image.
|
;; grub-mkstandalone requires a TMPDIR to prepare the firmware image.
|
||||||
(setenv "TMPDIR" esp)
|
(setenv "TMPDIR" esp)
|
||||||
|
|
||||||
|
@ -81,9 +88,12 @@ (define (install-efi grub grub-config esp)
|
||||||
;; Graft the configuration file onto the image.
|
;; Graft the configuration file onto the image.
|
||||||
(string-append "boot/grub/grub.cfg=" grub-config))))
|
(string-append "boot/grub/grub.cfg=" grub-config))))
|
||||||
|
|
||||||
(define (install-efi-loader grub-efi esp)
|
(define* (install-efi-loader grub-efi esp #:key targets)
|
||||||
"Install in ESP directory the given GRUB-EFI bootloader. Configure it to
|
"Install in ESP directory the given GRUB-EFI bootloader. Configure it to
|
||||||
load the Grub bootloader located in the 'Guix_image' root partition."
|
load the Grub bootloader located in the 'Guix_image' root partition.
|
||||||
|
|
||||||
|
If TARGETS is set, use its car as the GRUB image format and its cdr as
|
||||||
|
the output filename. Otherwise, use defaults for the host platform."
|
||||||
(let ((grub-config "grub.cfg"))
|
(let ((grub-config "grub.cfg"))
|
||||||
(call-with-output-file grub-config
|
(call-with-output-file grub-config
|
||||||
(lambda (port)
|
(lambda (port)
|
||||||
|
@ -97,5 +107,6 @@ (define (install-efi-loader grub-efi esp)
|
||||||
insmod part_gpt~@
|
insmod part_gpt~@
|
||||||
search --set=root --label Guix_image~@
|
search --set=root --label Guix_image~@
|
||||||
configfile /boot/grub/grub.cfg~%")))
|
configfile /boot/grub/grub.cfg~%")))
|
||||||
(install-efi grub-efi grub-config esp)
|
(install-efi grub-efi grub-config esp #:targets targets)
|
||||||
(delete-file grub-config)))
|
(delete-file grub-config)))
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@
|
||||||
;;; Copyright © 2020, 2022 Tobias Geerinckx-Rice <me@tobias.gr>
|
;;; Copyright © 2020, 2022 Tobias Geerinckx-Rice <me@tobias.gr>
|
||||||
;;; Copyright © 2020 Mathieu Othacehe <m.othacehe@gmail.com>
|
;;; Copyright © 2020 Mathieu Othacehe <m.othacehe@gmail.com>
|
||||||
;;; Copyright © 2022 Pavel Shlyak <p.shlyak@pantherx.org>
|
;;; Copyright © 2022 Pavel Shlyak <p.shlyak@pantherx.org>
|
||||||
|
;;; Copyright © 2022 Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -27,6 +28,7 @@ (define-module (gnu build image)
|
||||||
#:use-module (guix build syscalls)
|
#:use-module (guix build syscalls)
|
||||||
#:use-module (guix build utils)
|
#:use-module (guix build utils)
|
||||||
#:use-module (guix store database)
|
#:use-module (guix store database)
|
||||||
|
#:use-module (guix utils)
|
||||||
#:use-module (gnu build bootloader)
|
#:use-module (gnu build bootloader)
|
||||||
#:use-module (gnu build install)
|
#:use-module (gnu build install)
|
||||||
#:use-module (gnu build linux-boot)
|
#:use-module (gnu build linux-boot)
|
||||||
|
@ -41,6 +43,7 @@ (define-module (gnu build image)
|
||||||
convert-disk-image
|
convert-disk-image
|
||||||
genimage
|
genimage
|
||||||
initialize-efi-partition
|
initialize-efi-partition
|
||||||
|
initialize-efi32-partition
|
||||||
initialize-root-partition
|
initialize-root-partition
|
||||||
|
|
||||||
make-iso9660-image))
|
make-iso9660-image))
|
||||||
|
@ -169,6 +172,17 @@ (define* (initialize-efi-partition root
|
||||||
"Install in ROOT directory, an EFI loader using GRUB-EFI."
|
"Install in ROOT directory, an EFI loader using GRUB-EFI."
|
||||||
(install-efi-loader grub-efi root))
|
(install-efi-loader grub-efi root))
|
||||||
|
|
||||||
|
(define* (initialize-efi32-partition root
|
||||||
|
#:key
|
||||||
|
grub-efi32
|
||||||
|
#:allow-other-keys)
|
||||||
|
"Install in ROOT directory, an EFI 32bit loader using GRUB-EFI32."
|
||||||
|
(install-efi-loader grub-efi32 root
|
||||||
|
#:targets (cond ((target-x86?)
|
||||||
|
'("i386-efi" . "BOOTIA32.EFI"))
|
||||||
|
((target-arm?)
|
||||||
|
'("arm-efi" . "BOOTARM.EFI")))))
|
||||||
|
|
||||||
(define* (initialize-root-partition root
|
(define* (initialize-root-partition root
|
||||||
#:key
|
#:key
|
||||||
bootcfg
|
bootcfg
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
;;; Copyright © 2020, 2021 Pierre Langlois <pierre.langlois@gmx.com>
|
;;; Copyright © 2020, 2021 Pierre Langlois <pierre.langlois@gmx.com>
|
||||||
;;; Copyright © 2021 Vincent Legoll <vincent.legoll@gmail.com>
|
;;; Copyright © 2021 Vincent Legoll <vincent.legoll@gmail.com>
|
||||||
;;; Copyright © 2021 Brice Waegeneire <brice@waegenei.re>
|
;;; Copyright © 2021 Brice Waegeneire <brice@waegenei.re>
|
||||||
|
;;; Copyright © 2022 Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -332,6 +333,18 @@ (define-public grub-efi
|
||||||
"/bin/mcopy\"")))
|
"/bin/mcopy\"")))
|
||||||
#t))))))))))
|
#t))))))))))
|
||||||
|
|
||||||
|
(define-public grub-efi32
|
||||||
|
(package
|
||||||
|
(inherit grub-efi)
|
||||||
|
(name "grub-efi32")
|
||||||
|
(synopsis "GRand Unified Boot loader (UEFI 32bit version)")
|
||||||
|
(arguments
|
||||||
|
`(,@(substitute-keyword-arguments (package-arguments grub-efi)
|
||||||
|
((#:configure-flags flags
|
||||||
|
''()) `(cons* ,(cond ((target-x86?) "--target=i386")
|
||||||
|
((target-arm?) "--target=arm"))
|
||||||
|
,flags)))))))
|
||||||
|
|
||||||
;; Because grub searches hardcoded paths it's easiest to just build grub
|
;; Because grub searches hardcoded paths it's easiest to just build grub
|
||||||
;; again to make it find both grub-pc and grub-efi. There is a command
|
;; again to make it find both grub-pc and grub-efi. There is a command
|
||||||
;; line argument which allows you to specify ONE platform - but
|
;; line argument which allows you to specify ONE platform - but
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
;;; Copyright © 2020, 2021 Mathieu Othacehe <m.othacehe@gmail.com>
|
;;; Copyright © 2020, 2021 Mathieu Othacehe <m.othacehe@gmail.com>
|
||||||
;;; Copyright © 2020 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
|
;;; Copyright © 2020 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
|
||||||
;;; Copyright © 2022 Pavel Shlyak <p.shlyak@pantherx.org>
|
;;; Copyright © 2022 Pavel Shlyak <p.shlyak@pantherx.org>
|
||||||
|
;;; Copyright © 2022 Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -66,6 +67,7 @@ (define-module (gnu system image)
|
||||||
root-label
|
root-label
|
||||||
|
|
||||||
esp-partition
|
esp-partition
|
||||||
|
esp32-partition
|
||||||
root-partition
|
root-partition
|
||||||
|
|
||||||
efi-disk-image
|
efi-disk-image
|
||||||
|
@ -75,6 +77,7 @@ (define-module (gnu system image)
|
||||||
|
|
||||||
image-with-os
|
image-with-os
|
||||||
efi-raw-image-type
|
efi-raw-image-type
|
||||||
|
efi32-raw-image-type
|
||||||
qcow2-image-type
|
qcow2-image-type
|
||||||
iso-image-type
|
iso-image-type
|
||||||
uncompressed-iso-image-type
|
uncompressed-iso-image-type
|
||||||
|
@ -110,6 +113,11 @@ (define esp-partition
|
||||||
(flags '(esp))
|
(flags '(esp))
|
||||||
(initializer (gexp initialize-efi-partition))))
|
(initializer (gexp initialize-efi-partition))))
|
||||||
|
|
||||||
|
(define esp32-partition
|
||||||
|
(partition
|
||||||
|
(inherit esp-partition)
|
||||||
|
(initializer (gexp initialize-efi32-partition))))
|
||||||
|
|
||||||
(define root-partition
|
(define root-partition
|
||||||
(partition
|
(partition
|
||||||
(size 'guess)
|
(size 'guess)
|
||||||
|
@ -123,6 +131,11 @@ (define efi-disk-image
|
||||||
(format 'disk-image)
|
(format 'disk-image)
|
||||||
(partitions (list esp-partition root-partition))))
|
(partitions (list esp-partition root-partition))))
|
||||||
|
|
||||||
|
(define efi32-disk-image
|
||||||
|
(image
|
||||||
|
(format 'disk-image)
|
||||||
|
(partitions (list esp32-partition root-partition))))
|
||||||
|
|
||||||
(define iso9660-image
|
(define iso9660-image
|
||||||
(image
|
(image
|
||||||
(format 'iso9660)
|
(format 'iso9660)
|
||||||
|
@ -164,6 +177,11 @@ (define efi-raw-image-type
|
||||||
(name 'efi-raw)
|
(name 'efi-raw)
|
||||||
(constructor (cut image-with-os efi-disk-image <>))))
|
(constructor (cut image-with-os efi-disk-image <>))))
|
||||||
|
|
||||||
|
(define efi32-raw-image-type
|
||||||
|
(image-type
|
||||||
|
(name 'efi32-raw)
|
||||||
|
(constructor (cut image-with-os efi32-disk-image <>))))
|
||||||
|
|
||||||
(define qcow2-image-type
|
(define qcow2-image-type
|
||||||
(image-type
|
(image-type
|
||||||
(name 'qcow2)
|
(name 'qcow2)
|
||||||
|
@ -376,6 +394,7 @@ (define (partition-image partition)
|
||||||
#$(image-shared-store? image))
|
#$(image-shared-store? image))
|
||||||
#:system-directory #$os
|
#:system-directory #$os
|
||||||
#:grub-efi #+grub-efi
|
#:grub-efi #+grub-efi
|
||||||
|
#:grub-efi32 #+grub-efi32
|
||||||
#:bootloader-package
|
#:bootloader-package
|
||||||
#+(bootloader-package bootloader)
|
#+(bootloader-package bootloader)
|
||||||
#:bootloader-installer
|
#:bootloader-installer
|
||||||
|
|
Loading…
Reference in a new issue