aboutsummaryrefslogtreecommitdiff
path: root/gnu/bootloader
diff options
context:
space:
mode:
Diffstat (limited to 'gnu/bootloader')
-rw-r--r--gnu/bootloader/depthcharge.scm107
-rw-r--r--gnu/bootloader/grub.scm35
-rw-r--r--gnu/bootloader/u-boot.scm2
3 files changed, 143 insertions, 1 deletions
diff --git a/gnu/bootloader/depthcharge.scm b/gnu/bootloader/depthcharge.scm
new file mode 100644
index 0000000000..58cc3f3932
--- /dev/null
+++ b/gnu/bootloader/depthcharge.scm
@@ -0,0 +1,107 @@
+;;; GNU Guix --- Functional package management for GNU
+;;; Copyright © 2019 Timothy Sample <samplet@ngyro.com>
+;;;
+;;; This file is part of GNU Guix.
+;;;
+;;; GNU Guix is free software; you can redistribute it and/or modify it
+;;; under the terms of the GNU General Public License as published by
+;;; the Free Software Foundation; either version 3 of the License, or (at
+;;; your option) any later version.
+;;;
+;;; GNU Guix is distributed in the hope that it will be useful, but
+;;; WITHOUT ANY WARRANTY; without even the implied warranty of
+;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+;;; GNU General Public License for more details.
+;;;
+;;; You should have received a copy of the GNU General Public License
+;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
+
+(define-module (gnu bootloader depthcharge)
+ #:use-module (gnu bootloader extlinux)
+ #:use-module (gnu bootloader)
+ #:use-module (gnu packages bootloaders)
+ #:use-module (guix gexp)
+ #:use-module (guix utils)
+ #:use-module (ice-9 match)
+ #:export (depthcharge-bootloader))
+
+(define (signed-kernel kernel kernel-arguments initrd)
+ (define builder
+ (with-imported-modules '((guix build utils))
+ #~(begin
+ (use-modules (guix build utils)
+ (ice-9 binary-ports)
+ (rnrs bytevectors))
+ (set-path-environment-variable "PATH" '("bin") (list #$dtc))
+
+ ;; TODO: These files have to be writable, so we copy them.
+ ;; This can probably be fixed by using a ".its" file, just
+ ;; be careful not to break initrd loading.
+ (copy-file #$kernel "zImage")
+ (chmod "zImage" #o755)
+ (copy-file (string-append (dirname #$kernel) "/lib/dtbs/"
+ "rk3288-veyron-speedy.dtb")
+ "rk3288-veyron-speedy.dtb")
+ (chmod "rk3288-veyron-speedy.dtb" #o644)
+ (copy-file #$initrd "initrd")
+ (chmod "initrd" #o644)
+
+ (invoke (string-append #$u-boot-tools "/bin/mkimage")
+ "-D" "-I dts -O dtb -p 2048"
+ "-f" "auto"
+ "-A" "arm"
+ "-O" "linux"
+ "-T" "kernel"
+ "-C" "None"
+ "-d" "zImage"
+ "-a" "0"
+ "-b" "rk3288-veyron-speedy.dtb"
+ "-i" "initrd"
+ "image.itb")
+ (call-with-output-file "bootloader.bin"
+ (lambda (port)
+ (put-bytevector port (make-bytevector 512 0))))
+ (with-output-to-file "kernel-arguments"
+ (lambda ()
+ (display (string-join (list #$@kernel-arguments)))))
+ (invoke (string-append #$vboot-utils "/bin/vbutil_kernel")
+ "--pack" #$output
+ "--version" "1"
+ "--vmlinuz" "image.itb"
+ "--arch" "arm"
+ "--keyblock" (string-append #$vboot-utils
+ "/share/vboot-utils/devkeys/"
+ "kernel.keyblock")
+ "--signprivate" (string-append #$vboot-utils
+ "/share/vboot-utils/devkeys/"
+ "kernel_data_key.vbprivk")
+ "--config" "kernel-arguments"
+ "--bootloader" "bootloader.bin"))))
+ (computed-file "vmlinux.kpart" builder))
+
+(define* (depthcharge-configuration-file config entries
+ #:key
+ (system (%current-system))
+ (old-entries '()))
+ (match entries
+ ((entry)
+ (let ((kernel (menu-entry-linux entry))
+ (kernel-arguments (menu-entry-linux-arguments entry))
+ (initrd (menu-entry-initrd entry)))
+ ;; XXX: Make this a symlink.
+ (signed-kernel kernel kernel-arguments initrd)))
+ (_ (error "Too many bootloader menu entries!"))))
+
+(define install-depthcharge
+ #~(lambda (bootloader device mount-point)
+ (let ((kpart (string-append mount-point
+ "/boot/depthcharge/vmlinux.kpart")))
+ (write-file-on-device kpart (stat:size (stat kpart)) device 0))))
+
+(define depthcharge-bootloader
+ (bootloader
+ (name 'depthcharge)
+ (package #f)
+ (installer install-depthcharge)
+ (configuration-file "/boot/depthcharge/vmlinux.kpart")
+ (configuration-file-generator depthcharge-configuration-file)))
diff --git a/gnu/bootloader/grub.scm b/gnu/bootloader/grub.scm
index 14aede72c5..e97a17b3e2 100644
--- a/gnu/bootloader/grub.scm
+++ b/gnu/bootloader/grub.scm
@@ -27,8 +27,10 @@
#:use-module (gnu bootloader)
#:use-module (gnu system uuid)
#:use-module (gnu system file-systems)
+ #:use-module (gnu system keyboard)
#:autoload (gnu packages bootloaders) (grub)
#:autoload (gnu packages gtk) (guile-cairo guile-rsvg)
+ #:autoload (gnu packages xorg) (xkeyboard-config)
#:use-module (ice-9 match)
#:use-module (ice-9 regex)
#:use-module (srfi srfi-1)
@@ -219,6 +221,26 @@ fi~%"
;;; Configuration file.
;;;
+(define* (keyboard-layout-file layout
+ #:key
+ (grub grub))
+ "Process the X keyboard layout description LAYOUT, a <keyboard-layout> record,
+and return a file in the format for GRUB keymaps. LAYOUT must be present in
+the 'share/X11/xkb/symbols/' directory of 'xkeyboard-config'."
+ (define builder
+ (with-imported-modules '((guix build utils))
+ #~(begin
+ (use-modules (guix build utils))
+
+ ;; 'grub-kbdcomp' passes all its arguments but '-o' to 'ckbcomp'
+ ;; (from the 'console-setup' package).
+ (invoke #$(file-append grub "/bin/grub-mklayout")
+ "-i" #+(keyboard-layout->console-keymap layout)
+ "-o" #$output))))
+
+ (computed-file (string-append "grub-keymap." (keyboard-layout-name layout))
+ builder))
+
(define (grub-setup-io config)
"Return GRUB commands to configure the input / output interfaces. The result
is a string that can be inserted in grub.cfg."
@@ -330,6 +352,18 @@ entries corresponding to old generations of the system."
#:system system
#:port #~port))
+ (define keyboard-layout-config
+ (let ((layout (bootloader-configuration-keyboard-layout config))
+ (grub (bootloader-package
+ (bootloader-configuration-bootloader config))))
+ #~(let ((keymap #$(and layout
+ (keyboard-layout-file layout #:grub grub))))
+ (when keymap
+ (format port "\
+terminal_input at_keyboard
+insmod keylayouts
+keymap ~a~%" keymap)))))
+
(define builder
#~(call-with-output-file #$output
(lambda (port)
@@ -338,6 +372,7 @@ entries corresponding to old generations of the system."
# will be lost upon reconfiguration.
")
#$sugar
+ #$keyboard-layout-config
(format port "
set default=~a
set timeout=~a~%"
diff --git a/gnu/bootloader/u-boot.scm b/gnu/bootloader/u-boot.scm
index 1c6f322bc4..54abfe1c69 100644
--- a/gnu/bootloader/u-boot.scm
+++ b/gnu/bootloader/u-boot.scm
@@ -106,7 +106,7 @@
(define u-boot-beaglebone-black-bootloader
(bootloader
(inherit u-boot-bootloader)
- (package u-boot-beagle-bone-black)
+ (package u-boot-am335x-boneblack)
(installer install-beaglebone-black-u-boot)))
(define u-boot-allwinner-bootloader