gnu: icecat: Update to 68.4.0-guix0-preview1 [security fixes].
[jackhill/guix/guix.git] / gnu / packages / bootloaders.scm
CommitLineData
65d8b777 1;;; GNU Guix --- Functional package management for GNU
ab100b90 2;;; Copyright © 2013, 2014, 2015, 2016, 2017, 2018, 2019 Ludovic Courtès <ludo@gnu.org>
0a2a7053 3;;; Copyright © 2015, 2018 Mark H Weaver <mhw@netris.org>
f0150f87 4;;; Copyright © 2015 Leo Famulari <leo@famulari.name>
4c726001 5;;; Copyright © 2016 Jan Nieuwenhuizen <janneke@gnu.org>
a60f1319 6;;; Copyright © 2016, 2017, 2018 Marius Bakke <mbakke@fastmail.com>
862e38d5
DC
7;;; Copyright © 2016, 2017 Danny Milosavljevic <dannym@scratchpost.org>
8;;; Copyright © 2016, 2017 David Craven <david@craven.ch>
db34d4bb 9;;; Copyright © 2017, 2018 Efraim Flashner <efraim@flashner.co.il>
e9bdef5f 10;;; Copyright © 2018, 2019 Tobias Geerinckx-Rice <me@tobias.gr>
ab100b90 11;;; Copyright © 2019 nee <nee@cock.li>
af58b275 12;;; Copyright © 2019 Mathieu Othacehe <m.othacehe@gmail.com>
5664a471 13;;; Copyright © 2020 Björn Höfling <bjoern.hoefling@bjoernhoefling.de>
65d8b777
LC
14;;;
15;;; This file is part of GNU Guix.
16;;;
17;;; GNU Guix is free software; you can redistribute it and/or modify it
18;;; under the terms of the GNU General Public License as published by
19;;; the Free Software Foundation; either version 3 of the License, or (at
20;;; your option) any later version.
21;;;
22;;; GNU Guix is distributed in the hope that it will be useful, but
23;;; WITHOUT ANY WARRANTY; without even the implied warranty of
24;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
25;;; GNU General Public License for more details.
26;;;
27;;; You should have received a copy of the GNU General Public License
28;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
29
862e38d5 30(define-module (gnu packages bootloaders)
65d8b777 31 #:use-module (gnu packages)
862e38d5 32 #:use-module (gnu packages admin)
178e5500 33 #:use-module (gnu packages algebra)
862e38d5 34 #:use-module (gnu packages assembly)
a60f1319 35 #:use-module (gnu packages base)
7febe3a2 36 #:use-module (gnu packages disk)
65d8b777 37 #:use-module (gnu packages bison)
862e38d5 38 #:use-module (gnu packages cdrom)
65212c42 39 #:use-module (gnu packages check)
0c7707d5 40 #:use-module (gnu packages compression)
862e38d5
DC
41 #:use-module (gnu packages cross-base)
42 #:use-module (gnu packages disk)
29be6cfb 43 #:use-module (gnu packages firmware)
862e38d5 44 #:use-module (gnu packages flex)
a86177d6 45 #:use-module (gnu packages fontutils)
f074f5e8 46 #:use-module (gnu packages gcc)
862e38d5 47 #:use-module (gnu packages gettext)
65d8b777 48 #:use-module (gnu packages linux)
862e38d5 49 #:use-module (gnu packages man)
444f9dcc 50 #:use-module (gnu packages mtools)
862e38d5 51 #:use-module (gnu packages ncurses)
96b714f5 52 #:use-module (gnu packages perl)
a60f1319 53 #:use-module (gnu packages pkg-config)
96b714f5 54 #:use-module (gnu packages python)
58301666 55 #:use-module (gnu packages texinfo)
a60f1319 56 #:use-module (gnu packages tls)
65212c42 57 #:use-module (gnu packages sdl)
12c613b5 58 #:use-module (gnu packages swig)
5d706f18 59 #:use-module (gnu packages valgrind)
59132b80 60 #:use-module (gnu packages virtualization)
ab100b90 61 #:use-module (gnu packages xorg)
a60f1319 62 #:use-module (gnu packages web)
862e38d5
DC
63 #:use-module (guix build-system gnu)
64 #:use-module (guix download)
65 #:use-module (guix git-download)
66 #:use-module ((guix licenses) #:prefix license:)
67 #:use-module (guix packages)
63087721
EF
68 #:use-module (guix utils)
69 #:use-module (srfi srfi-1)
a7c87169
MW
70 #:use-module (srfi srfi-26)
71 #:use-module (ice-9 regex))
65d8b777 72
9b24c768
LC
73(define unifont
74 ;; GNU Unifont, <http://gnu.org/s/unifont>.
75 ;; GRUB needs it for its graphical terminal, gfxterm.
76 (origin
77 (method url-fetch)
78 (uri
79 "http://unifoundry.com/pub/unifont-7.0.06/font-builds/unifont-7.0.06.bdf.gz")
80 (sha256
81 (base32
82 "0p2vhnc18cnbmb39vq4m7hzv4mhnm2l0a2s7gx3ar277fwng3hys"))))
83
65d8b777
LC
84(define-public grub
85 (package
86 (name "grub")
069ab3bb 87 (version "2.04")
65d8b777
LC
88 (source (origin
89 (method url-fetch)
3586a3e9 90 (uri (string-append "mirror://gnu/grub/grub-" version ".tar.xz"))
65d8b777
LC
91 (sha256
92 (base32
069ab3bb
TGR
93 "0zgp5m3hmc9jh8wpjx6czzkh5id2y8n1k823x2mjvm2sk6b28ag5"))
94 (patches (search-patches "grub-efi-fat-serial-number.patch"))))
65d8b777
LC
95 (build-system gnu-build-system)
96 (arguments
069ab3bb
TGR
97 `(#:configure-flags
98 ;; Counterintuitively, this *disables* a spurious Python dependency by
99 ;; calling the ‘true’ binary instead. Python is only needed during
100 ;; bootstrapping (for genptl.py), not when building from a release.
101 (list "PYTHON=true")
102 #:phases (modify-phases %standard-phases
358db004 103 (add-after 'unpack 'patch-stuff
7c353424 104 (lambda* (#:key native-inputs inputs #:allow-other-keys)
04e0eac1
MW
105 (substitute* "grub-core/Makefile.in"
106 (("/bin/sh") (which "sh")))
65d8b777 107
358db004
LC
108 ;; Give the absolute file name of 'mdadm', used to
109 ;; determine the root file system when it's a RAID
110 ;; device. Failing to do that, 'grub-probe' silently
111 ;; fails if 'mdadm' is not in $PATH.
112 (substitute* "grub-core/osdep/linux/getroot.c"
113 (("argv\\[0\\] = \"mdadm\"")
114 (string-append "argv[0] = \""
115 (assoc-ref inputs "mdadm")
116 "/sbin/mdadm\"")))
117
04e0eac1 118 ;; Make the font visible.
7c353424
MO
119 (copy-file (assoc-ref (or native-inputs inputs)
120 "unifont")
121 "unifont.bdf.gz")
04e0eac1 122 (system* "gunzip" "unifont.bdf.gz")
ab100b90 123
124 ;; Give the absolute file name of 'ckbcomp'.
125 (substitute* "util/grub-kbdcomp.in"
126 (("^ckbcomp ")
127 (string-append (assoc-ref inputs "console-setup")
128 "/bin/ckbcomp ")))
23a53a95
LF
129 #t))
130 (add-before 'check 'disable-flaky-test
131 (lambda _
132 ;; This test is unreliable. For more information, see:
133 ;; <https://bugs.gnu.org/26936>.
134 (substitute* "Makefile.in"
135 (("grub_cmd_date grub_cmd_set_date grub_cmd_sleep")
136 "grub_cmd_date grub_cmd_sleep"))
069ab3bb
TGR
137 #t))
138 (add-before 'check 'disable-pixel-perfect-test
139 (lambda _
140 ;; This test compares many screenshots rendered with an
141 ;; older Unifont (9.0.06) than that packaged in Guix.
142 (substitute* "Makefile.in"
143 (("test_unset grub_func_test")
144 "test_unset"))
56f0feb6 145 #t)))
63087721
EF
146 ;; Disable tests on ARM and AARCH64 platforms.
147 #:tests? ,(not (any (cute string-prefix? <> (or (%current-target-system)
148 (%current-system)))
149 '("arm" "aarch64")))))
65d8b777 150 (inputs
10da75df
LC
151 `(("gettext" ,gettext-minimal)
152
153 ;; Depend on LVM2 for libdevmapper, used by 'grub-probe' and
154 ;; 'grub-install' to recognize mapped devices (LUKS, etc.)
155 ("lvm2" ,lvm2)
156
157 ;; Depend on mdadm, which is invoked by 'grub-probe' and 'grub-install'
158 ;; to determine whether the root file system is RAID.
358db004 159 ("mdadm" ,mdadm)
10da75df 160
ab100b90 161 ;; Console-setup's ckbcomp is invoked by grub-kbdcomp. It is required
162 ;; for generating alternative keyboard layouts.
163 ("console-setup" ,console-setup)
164
35014c40
TGR
165 ;; Needed for ‘grub-mount’, the only reliable way to tell whether a given
166 ;; file system will be readable by GRUB without rebooting.
167 ("fuse" ,fuse)
168
65d8b777
LC
169 ("freetype" ,freetype)
170 ;; ("libusb" ,libusb)
01eafd38 171 ("ncurses" ,ncurses)))
65d8b777 172 (native-inputs
0a2a7053
MW
173 `(("pkg-config" ,pkg-config)
174 ("unifont" ,unifont)
9b24c768 175 ("bison" ,bison)
0a3aca47
LF
176 ;; Due to a bug in flex >= 2.6.2, GRUB must be built with an older flex:
177 ;; <http://lists.gnu.org/archive/html/grub-devel/2017-02/msg00133.html>
178 ;; TODO Try building with flex > 2.6.4.
179 ("flex" ,flex-2.6.1)
58301666
MW
180 ("texinfo" ,texinfo)
181 ("help2man" ,help2man)
65d8b777 182
a7c87169
MW
183 ;; XXX: When building GRUB 2.02 on 32-bit x86, we need a binutils
184 ;; capable of assembling 64-bit instructions. However, our default
185 ;; binutils on 32-bit x86 is not 64-bit capable.
186 ,@(if (string-match "^i[3456]86-" (%current-system))
187 (let ((binutils (package/inherit
188 binutils
189 (name "binutils-i386")
190 (arguments
191 (substitute-keyword-arguments (package-arguments binutils)
192 ((#:configure-flags flags ''())
193 `(cons "--enable-64-bit-bfd" ,flags)))))))
194 `(("ld-wrapper" ,(make-ld-wrapper "ld-wrapper-i386"
195 #:binutils binutils))
196 ("binutils" ,binutils)))
197 '())
198
65d8b777
LC
199 ;; Dependencies for the test suite. The "real" QEMU is needed here,
200 ;; because several targets are used.
7febe3a2 201 ("parted" ,parted)
d64bcccf 202 ("qemu" ,qemu-minimal-2.10)
65d8b777 203 ("xorriso" ,xorriso)))
175b259c 204 (home-page "https://www.gnu.org/software/grub/")
79c311b8 205 (synopsis "GRand Unified Boot loader")
65d8b777 206 (description
a22dc0c4 207 "GRUB is a multiboot bootloader. It is used for initially loading the
35b9e423 208kernel of an operating system and then transferring control to it. The kernel
c5779c93 209then goes on to load the rest of the operating system. As a multiboot
574e86f9
LC
210bootloader, GRUB handles the presence of multiple operating systems installed
211on the same computer; upon booting the computer, the user is presented with a
a22dc0c4 212menu to select one of the installed operating systems.")
3f73aa1a 213 (license license:gpl3+)
99effc8f 214 (properties '((cpe-name . "grub2")))))
acb5f7c3
MB
215
216(define-public grub-efi
217 (package
218 (inherit grub)
219 (name "grub-efi")
220 (synopsis "GRand Unified Boot loader (UEFI version)")
221 (inputs
222 `(("efibootmgr" ,efibootmgr)
c695fb76 223 ("mtools" ,mtools)
acb5f7c3
MB
224 ,@(package-inputs grub)))
225 (arguments
226 `(;; TODO: Tests need a UEFI firmware for qemu. There is one at
227 ;; https://github.com/tianocore/edk2/tree/master/OvmfPkg .
228 ;; Search for 'OVMF' in "tests/util/grub-shell.in".
acb5f7c3 229 ,@(substitute-keyword-arguments (package-arguments grub)
46ff2dbb 230 ((#:tests? _ #f) #f)
ef753a1a
LC
231 ((#:configure-flags flags ''())
232 `(cons "--with-platform=efi" ,flags))
acb5f7c3
MB
233 ((#:phases phases)
234 `(modify-phases ,phases
235 (add-after 'patch-stuff 'use-absolute-efibootmgr-path
236 (lambda* (#:key inputs #:allow-other-keys)
237 (substitute* "grub-core/osdep/unix/platform.c"
238 (("efibootmgr")
239 (string-append (assoc-ref inputs "efibootmgr")
240 "/sbin/efibootmgr")))
444f9dcc
DM
241 #t))
242 (add-after 'patch-stuff 'use-absolute-mtools-path
243 (lambda* (#:key inputs #:allow-other-keys)
244 (let ((mtools (assoc-ref inputs "mtools")))
245 (substitute* "util/grub-mkrescue.c"
246 (("\"mformat\"")
247 (string-append "\"" mtools
248 "/bin/mformat\"")))
249 (substitute* "util/grub-mkrescue.c"
250 (("\"mcopy\"")
251 (string-append "\"" mtools
252 "/bin/mcopy\"")))
253 #t))))))))))
96b714f5 254
dd4b7476
DM
255;; Because grub searches hardcoded paths it's easiest to just build grub
256;; again to make it find both grub-pc and grub-efi. There is a command
257;; line argument which allows you to specify ONE platform - but
258;; grub-mkrescue will use multiple platforms if they are available
259;; in the installation directory (without command line argument).
260(define-public grub-hybrid
261 (package
262 (inherit grub-efi)
263 (name "grub-hybrid")
264 (synopsis "GRand Unified Boot loader (hybrid version)")
265 (inputs
266 `(("grub" ,grub)
267 ,@(package-inputs grub-efi)))
268 (arguments
269 (substitute-keyword-arguments (package-arguments grub-efi)
270 ((#:modules modules `((guix build utils) (guix build gnu-build-system)))
271 `((ice-9 ftw) ,@modules))
272 ((#:phases phases)
273 `(modify-phases ,phases
274 (add-after 'install 'install-non-efi
275 (lambda* (#:key inputs outputs #:allow-other-keys)
276 (let ((input-dir (string-append (assoc-ref inputs "grub")
277 "/lib/grub"))
278 (output-dir (string-append (assoc-ref outputs "out")
279 "/lib/grub")))
280 (for-each
281 (lambda (basename)
db34d4bb
EF
282 (if (not (or (string-prefix? "." basename)
283 (file-exists? (string-append output-dir "/" basename))))
dd4b7476
DM
284 (symlink (string-append input-dir "/" basename)
285 (string-append output-dir "/" basename))))
286 (scandir input-dir))
287 #t)))))))))
288
96b714f5
DC
289(define-public syslinux
290 (let ((commit "bb41e935cc83c6242de24d2271e067d76af3585c"))
291 (package
292 (name "syslinux")
293 (version (git-version "6.04-pre" "1" commit))
294 (source (origin
295 (method git-fetch)
296 (uri (git-reference
297 (url "https://github.com/geneC/syslinux")
298 (commit commit)))
299 (file-name (git-file-name name version))
300 (sha256
301 (base32
302 "0k8dvafd6410kqxf3kyr4y8jzmpmrih6wbjqg6gklak7945yflrc"))))
303 (build-system gnu-build-system)
304 (native-inputs
305 `(("nasm" ,nasm)
306 ("perl" ,perl)
307 ("python-2" ,python-2)))
308 (inputs
0b4dbb40
LC
309 `(("libuuid" ,util-linux)
310 ("mtools" ,mtools)))
96b714f5
DC
311 (arguments
312 `(#:parallel-build? #f
313 #:make-flags
314 (list (string-append "BINDIR=" %output "/bin")
315 (string-append "SBINDIR=" %output "/sbin")
316 (string-append "LIBDIR=" %output "/lib")
317 (string-append "INCDIR=" %output "/include")
318 (string-append "DATADIR=" %output "/share")
319 (string-append "MANDIR=" %output "/share/man")
320 "PERL=perl"
321 "bios")
322 #:phases
323 (modify-phases %standard-phases
324 (add-after 'unpack 'patch-files
0b4dbb40 325 (lambda* (#:key inputs #:allow-other-keys)
96b714f5
DC
326 (substitute* (find-files "." "Makefile.*|ppmtolss16")
327 (("/bin/pwd") (which "pwd"))
328 (("/bin/echo") (which "echo"))
329 (("/usr/bin/perl") (which "perl")))
0b4dbb40
LC
330 (let ((mtools (assoc-ref inputs "mtools")))
331 (substitute* (find-files "." "\\.c$")
332 (("mcopy")
333 (string-append mtools "/bin/mcopy"))
334 (("mattrib")
335 (string-append mtools "/bin/mattrib"))))
96b714f5
DC
336 #t))
337 (delete 'configure)
338 (add-before 'build 'set-permissions
339 (lambda _
60d8db74 340 (invoke "chmod" "a+w" "utils/isohybrid.in")))
96b714f5
DC
341 (replace 'check
342 (lambda _
343 (setenv "CC" "gcc")
344 (substitute* "tests/unittest/include/unittest/unittest.h"
345 ;; Don't look up headers under /usr.
346 (("/usr/include/") ""))
60d8db74 347 (invoke "make" "unittest"))))))
0f304ba7 348 (home-page "https://www.syslinux.org")
96b714f5
DC
349 (synopsis "Lightweight Linux bootloader")
350 (description "Syslinux is a lightweight Linux bootloader.")
8d3f604d
EF
351 ;; The Makefile specifically targets i386 and x86_64 using nasm.
352 (supported-systems '("i686-linux" "x86_64-linux"))
96b714f5
DC
353 (license (list license:gpl2+
354 license:bsd-3 ; gnu-efi/*
355 license:bsd-4 ; gnu-efi/inc/* gnu-efi/lib/*
356 ;; Also contains:
357 license:expat license:isc license:zlib)))))
862e38d5
DC
358
359(define-public dtc
360 (package
361 (name "dtc")
91af1031 362 (version "1.5.1")
862e38d5
DC
363 (source (origin
364 (method url-fetch)
365 (uri (string-append
3b4efb1f 366 "mirror://kernel.org/software/utils/dtc/"
862e38d5
DC
367 "dtc-" version ".tar.xz"))
368 (sha256
369 (base32
91af1031 370 "07q3mdsvl4smbiakriq3hnsyyd0q344lsm306q0kgz4hjq1p82v6"))))
862e38d5
DC
371 (build-system gnu-build-system)
372 (native-inputs
373 `(("bison" ,bison)
12c613b5 374 ("flex" ,flex)
8cd10b22
VC
375 ("libyaml" ,libyaml)
376 ("pkg-config" ,pkg-config)
5d706f18
VC
377 ("swig" ,swig)
378 ("valgrind" ,valgrind)))
12c613b5 379 (inputs
5664a471 380 `(("python" ,python)))
862e38d5
DC
381 (arguments
382 `(#:make-flags
383 (list "CC=gcc"
91af1031
TGR
384
385 ;; /bin/fdt{get,overlay,put} need help finding libfdt.so.1.
386 (string-append "LDFLAGS=-Wl,-rpath="
387 (assoc-ref %outputs "out") "/lib")
388
862e38d5 389 (string-append "PREFIX=" (assoc-ref %outputs "out"))
12c613b5 390 (string-append "SETUP_PREFIX=" (assoc-ref %outputs "out"))
862e38d5
DC
391 "INSTALL=install")
392 #:phases
393 (modify-phases %standard-phases
d95bb295 394 (delete 'configure)))) ; no configure script
862e38d5
DC
395 (home-page "https://www.devicetree.org")
396 (synopsis "Compiles device tree source files")
397 (description "@command{dtc} compiles
398@uref{http://elinux.org/Device_Tree_Usage, device tree source files} to device
399tree binary files. These are board description files used by Linux and BSD.")
400 (license license:gpl2+)))
401
402(define u-boot
403 (package
404 (name "u-boot")
6b99afee 405 (version "2019.04")
862e38d5
DC
406 (source (origin
407 (method url-fetch)
408 (uri (string-append
409 "ftp://ftp.denx.de/pub/u-boot/"
410 "u-boot-" version ".tar.bz2"))
411 (sha256
412 (base32
6b99afee
VC
413 "1vwv4bgbl7fjcm073zrphn17hnz5h5h778f88ivdsgbb2lnpgdvn"))
414 (patches
415 (search-patches
416 "u-boot-fix-mkimage-header-verification.patch"))))
862e38d5
DC
417 (native-inputs
418 `(("bc" ,bc)
336c4a4b 419 ("bison" ,bison)
53e290df 420 ("dtc" ,dtc)
336c4a4b 421 ("flex" ,flex)
0c7707d5 422 ("lz4" ,lz4)
f074f5e8 423 ("python-2" ,python-2)
65212c42
DM
424 ("python2-coverage" ,python2-coverage)
425 ("python2-pytest" ,python2-pytest)
426 ("sdl" ,sdl)
f074f5e8 427 ("swig" ,swig)))
862e38d5 428 (build-system gnu-build-system)
3e63a83c 429 (home-page "https://www.denx.de/wiki/U-Boot/")
862e38d5
DC
430 (synopsis "ARM bootloader")
431 (description "U-Boot is a bootloader used mostly for ARM boards. It
432also initializes the boards (RAM etc).")
433 (license license:gpl2+)))
434
fa747018
CN
435(define u-boot-2019.10
436 (package
437 (inherit u-boot)
438 (version "2019.10")
439 (source (origin
440 (method url-fetch)
441 (uri (string-append
442 "ftp://ftp.denx.de/pub/u-boot/"
443 "u-boot-" version ".tar.bz2"))
444 (sha256
445 (base32
446 "053hcrwwlacqh2niisn0zas95zkbffw5aw5sdhixs8lmfdq60vcd"))))))
447
2676628f
DM
448(define-public u-boot-tools
449 (package
450 (inherit u-boot)
451 (name "u-boot-tools")
452 (arguments
65212c42
DM
453 `(#:make-flags '("HOSTCC=gcc")
454 #:test-target "tests"
2676628f
DM
455 #:phases
456 (modify-phases %standard-phases
65212c42
DM
457 (add-after 'unpack 'patch
458 (lambda* (#:key inputs #:allow-other-keys)
459 (substitute* "Makefile"
460 (("/bin/pwd") (which "pwd"))
461 (("/bin/false") (which "false")))
462 (substitute* "tools/dtoc/fdt_util.py"
463 (("'cc'") "'gcc'"))
e1d1ec14
VC
464 (substitute* "tools/patman/test_util.py"
465 ;; python-coverage is simply called coverage in guix.
466 (("python-coverage") "coverage")
467 ;; XXX Allow for only 99% test coverage.
468 ;; TODO: Find out why that is needed.
469 (("if coverage != '100%':") "if not int(coverage.rstrip('%')) >= 99:"))
65212c42
DM
470 (substitute* "test/run"
471 ;; Make it easier to find test failures.
472 (("#!/bin/bash") "#!/bin/bash -x")
473 ;; pytest doesn't find it otherwise.
474 (("test/py/tests/test_ofplatdata.py")
475 "tests/test_ofplatdata.py")
476 ;; This test would require git.
477 (("\\./tools/patman/patman") (which "true"))
478 ;; This test would require internet access.
479 (("\\./tools/buildman/buildman") (which "true")))
480 (substitute* "test/py/tests/test_sandbox_exit.py"
481 (("def test_ctrl_c")
482 "@pytest.mark.skip(reason='Guix has problems with SIGINT')
483def test_ctrl_c"))
6f5be83c
VC
484 ;; Test against the tools being installed rather than tools built
485 ;; for "sandbox" target.
486 (substitute* "test/image/test-imagetools.sh"
487 (("BASEDIR=sandbox") "BASEDIR=."))
4da4e952
VC
488 (for-each (lambda (file)
489 (substitute* file
fb0aeaac
VC
490 ;; Disable signatures, due to GPL/Openssl
491 ;; license incompatibilities. See
492 ;; https://bugs.gnu.org/34717 for details.
493 (("CONFIG_FIT_SIGNATURE=y") "CONFIG_FIT_SIGNATURE=n")
494 ;; This test requires a sound system, which is un-used
495 ;; in u-boot-tools.
4da4e952
VC
496 (("CONFIG_SOUND=y") "CONFIG_SOUND=n")))
497 (find-files "configs" "sandbox_.*defconfig$"))
65212c42 498 #t))
2676628f
DM
499 (replace 'configure
500 (lambda* (#:key make-flags #:allow-other-keys)
501 (call-with-output-file "configs/tools_defconfig"
502 (lambda (port)
503 (display "CONFIG_SYS_TEXT_BASE=0\n" port)))
504 (apply invoke "make" "tools_defconfig" make-flags)))
505 (replace 'build
506 (lambda* (#:key inputs make-flags #:allow-other-keys)
9e84a4d6 507 (apply invoke "make" "tools-all" make-flags)))
2676628f
DM
508 (replace 'install
509 (lambda* (#:key outputs #:allow-other-keys)
510 (let* ((out (assoc-ref outputs "out"))
511 (bin (string-append out "/bin")))
512 (for-each (lambda (name)
513 (install-file name bin))
514 '("tools/netconsole"
515 "tools/jtagconsole"
516 "tools/gen_eth_addr"
517 "tools/gen_ethaddr_crc"
518 "tools/img2srec"
519 "tools/mkenvimage"
520 "tools/dumpimage"
521 "tools/mkimage"
522 "tools/proftool"
523 "tools/fdtgrep"
10186ee2
DM
524 "tools/env/fw_printenv"
525 "tools/sunxi-spl-image-builder"))
65212c42
DM
526 #t)))
527 (delete 'check)
528 (add-after 'install 'check
529 (lambda* (#:key make-flags test-target #:allow-other-keys)
6f5be83c
VC
530 (invoke "test/image/test-imagetools.sh")))
531 ;; Only run full test suite on x86_64 systems, as many tests
532 ;; assume x86_64.
533 ,@(if (string-match "^x86_64-linux"
534 (or (%current-target-system)
535 (%current-system)))
536 '((add-after 'check 'check-x86
537 (lambda* (#:key make-flags test-target #:allow-other-keys)
538 (apply invoke "make" "mrproper" make-flags)
539 (setenv "SDL_VIDEODRIVER" "dummy")
540 (setenv "PAGER" "cat")
541 (apply invoke "make" test-target make-flags))))
542 '()))))
2676628f
DM
543 (description "U-Boot is a bootloader used mostly for ARM boards. It
544also initializes the boards (RAM etc). This package provides its
545board-independent tools.")))
546
4ce4fc50 547(define-public (make-u-boot-package board triplet)
862e38d5 548 "Returns a u-boot package for BOARD cross-compiled for TRIPLET."
6bfcb729
LC
549 (let ((same-arch? (lambda ()
550 (string=? (%current-system)
551 (gnu-triplet->nix-system triplet)))))
3bfee8ff
EF
552 (package
553 (inherit u-boot)
df8a9096
DM
554 (name (string-append "u-boot-"
555 (string-replace-substring (string-downcase board)
556 "_" "-")))
3bfee8ff 557 (native-inputs
6bfcb729 558 `(,@(if (not (same-arch?))
b8806e13 559 `(("cross-gcc" ,(cross-gcc triplet))
3bfee8ff 560 ("cross-binutils" ,(cross-binutils triplet)))
b8806e13 561 `())
3bfee8ff
EF
562 ,@(package-native-inputs u-boot)))
563 (arguments
37297674
EF
564 `(#:modules ((ice-9 ftw)
565 (srfi srfi-1)
566 (guix build utils)
567 (guix build gnu-build-system))
3bfee8ff
EF
568 #:test-target "test"
569 #:make-flags
570 (list "HOSTCC=gcc"
6bfcb729 571 ,@(if (not (same-arch?))
3bfee8ff
EF
572 `((string-append "CROSS_COMPILE=" ,triplet "-"))
573 '()))
574 #:phases
575 (modify-phases %standard-phases
576 (replace 'configure
577 (lambda* (#:key outputs make-flags #:allow-other-keys)
578 (let ((config-name (string-append ,board "_defconfig")))
579 (if (file-exists? (string-append "configs/" config-name))
8f43bdd9 580 (apply invoke "make" `(,@make-flags ,config-name))
3bfee8ff 581 (begin
ac30d18c
DM
582 (display "Invalid board name. Valid board names are:"
583 (current-error-port))
30ef146c
DM
584 (let ((suffix-len (string-length "_defconfig"))
585 (entries (scandir "configs")))
586 (for-each (lambda (file-name)
587 (when (string-suffix? "_defconfig" file-name)
ac30d18c 588 (format (current-error-port)
30ef146c
DM
589 "- ~A\n"
590 (string-drop-right file-name
591 suffix-len))))
ee3c8fbe 592 (sort entries string-ci<)))
bdd235b3 593 (error "Invalid boardname ~s." ,board))))))
3bfee8ff 594 (replace 'install
9b94ced4 595 (lambda* (#:key outputs #:allow-other-keys)
3bfee8ff
EF
596 (let* ((out (assoc-ref outputs "out"))
597 (libexec (string-append out "/libexec"))
dd208b93 598 (uboot-files (append
a9446dde
DM
599 (remove
600 ;; Those would not be reproducible
601 ;; because of the randomness used
602 ;; to produce them.
603 ;; It's expected that the user will
604 ;; use u-boot-tools to generate them
605 ;; instead.
606 (lambda (name)
607 (string-suffix?
608 "sunxi-spl-with-ecc.bin"
609 name))
610 (find-files "." ".*\\.(bin|efi|img|spl|itb|dtb|rksd)$"))
fd0b21d5 611 (find-files "." "^(MLO|SPL)$"))))
3bfee8ff 612 (mkdir-p libexec)
a32f9b59 613 (install-file ".config" libexec)
0fcfed39
DM
614 ;; Useful for "qemu -kernel".
615 (install-file "u-boot" libexec)
3bfee8ff
EF
616 (for-each
617 (lambda (file)
618 (let ((target-file (string-append libexec "/" file)))
619 (mkdir-p (dirname target-file))
620 (copy-file file target-file)))
d1af9a8c
DM
621 uboot-files)
622 #t)))))))))
862e38d5
DC
623
624(define-public u-boot-vexpress
625 (make-u-boot-package "vexpress_ca9x4" "arm-linux-gnueabihf"))
626
627(define-public u-boot-malta
628 (make-u-boot-package "malta" "mips64el-linux-gnuabi64"))
629
6b99afee
VC
630(define-public u-boot-am335x-boneblack
631 (let ((base (make-u-boot-package "am335x_evm" "arm-linux-gnueabihf")))
632 (package
633 (inherit base)
634 (name "u-boot-am335x-boneblack")
635 (description "U-Boot is a bootloader used mostly for ARM boards. It
636also initializes the boards (RAM etc).
637
638This U-Boot is built for the BeagleBone Black, which was removed upstream,
639adjusted from the am335x_evm build with several device trees removed so that
640it fits within common partitioning schemes.")
641 (arguments
642 (substitute-keyword-arguments (package-arguments base)
643 ((#:phases phases)
644 `(modify-phases ,phases
645 (add-after 'unpack 'patch-defconfig
646 ;; Patch out other devicetrees to build image small enough to
647 ;; fit within typical partitioning schemes where the first
648 ;; partition begins at sector 2048.
649 (lambda _
650 (substitute* "configs/am335x_evm_defconfig"
651 (("CONFIG_OF_LIST=.*$") "CONFIG_OF_LIST=\"am335x-evm am335x-boneblack\"\n"))
652 #t)))))))))
653
654(define-public u-boot-am335x-evm
655 (make-u-boot-package "am335x_evm" "arm-linux-gnueabihf"))
4adeb3f6 656
0da3526d
VC
657(define-public (make-u-boot-sunxi64-package board triplet)
658 (let ((base (make-u-boot-package board triplet)))
29be6cfb
EF
659 (package
660 (inherit base)
661 (arguments
662 (substitute-keyword-arguments (package-arguments base)
663 ((#:phases phases)
664 `(modify-phases ,phases
665 (add-after 'unpack 'set-environment
db78fc06
MO
666 (lambda* (#:key native-inputs inputs #:allow-other-keys)
667 (let ((bl31
668 (string-append
669 (assoc-ref (or native-inputs inputs) "firmware")
670 "/bl31.bin")))
29be6cfb 671 (setenv "BL31" bl31)
35e427d1
DM
672 ;; This is necessary when we're using the bundled dtc.
673 ;(setenv "PATH" (string-append (getenv "PATH") ":"
674 ; "scripts/dtc"))
675 )
29be6cfb
EF
676 #t))))))
677 (native-inputs
95d91986 678 `(("firmware" ,arm-trusted-firmware-sun50i-a64)
29be6cfb
EF
679 ,@(package-native-inputs base))))))
680
0da3526d
VC
681(define-public u-boot-pine64-plus
682 (make-u-boot-sunxi64-package "pine64_plus" "aarch64-linux-gnu"))
683
af58b275
MO
684(define-public u-boot-pine64-lts
685 (make-u-boot-sunxi64-package "pine64-lts" "aarch64-linux-gnu"))
686
74e35e8c 687(define-public u-boot-pinebook
4da4e952 688 (make-u-boot-sunxi64-package "pinebook" "aarch64-linux-gnu"))
74e35e8c 689
e830c9d0 690(define-public u-boot-bananapi-m2-ultra
30aeb846
DM
691 (make-u-boot-package "Bananapi_M2_Ultra" "arm-linux-gnueabihf"))
692
c55c6985
DM
693(define-public u-boot-a20-olinuxino-lime
694 (make-u-boot-package "A20-OLinuXino-Lime" "arm-linux-gnueabihf"))
695
4b9e9abb
DM
696(define-public u-boot-a20-olinuxino-lime2
697 (make-u-boot-package "A20-OLinuXino-Lime2" "arm-linux-gnueabihf"))
698
a7bb327e
DM
699(define-public u-boot-a20-olinuxino-micro
700 (make-u-boot-package "A20-OLinuXino_MICRO" "arm-linux-gnueabihf"))
701
84ee3378
DM
702(define-public u-boot-nintendo-nes-classic-edition
703 (make-u-boot-package "Nintendo_NES_Classic_Edition" "arm-linux-gnueabihf"))
704
95a3422e
VC
705(define-public u-boot-wandboard
706 (make-u-boot-package "wandboard" "arm-linux-gnueabihf"))
707
adc61d72
VC
708(define-public u-boot-mx6cuboxi
709 (make-u-boot-package "mx6cuboxi" "arm-linux-gnueabihf"))
710
1b960787 711(define-public u-boot-novena
6e2bad00
VC
712 (let ((base (make-u-boot-package "novena" "arm-linux-gnueabihf")))
713 (package
714 (inherit base)
715 (description "U-Boot is a bootloader used mostly for ARM boards. It
716also initializes the boards (RAM etc).
717
718This U-Boot is built for Novena. Be advised that this version, contrary
6b99afee 719to Novena upstream, does not load u-boot.img from the first partition.")
6e2bad00
VC
720 (arguments
721 (substitute-keyword-arguments (package-arguments base)
722 ((#:phases phases)
723 `(modify-phases ,phases
724 (add-after 'unpack 'patch-novena-defconfig
725 ;; Patch configuration to disable loading u-boot.img from FAT partition,
726 ;; allowing it to be installed at a device offset.
727 (lambda _
728 (substitute* "configs/novena_defconfig"
6b99afee 729 (("CONFIG_SPL_FS_FAT=y") "# CONFIG_SPL_FS_FAT is not set"))
6e2bad00 730 #t)))))))))
1b960787 731
dd4fe0c2
DM
732(define-public u-boot-cubieboard
733 (make-u-boot-package "Cubieboard" "arm-linux-gnueabihf"))
734
a7d5ce94
JL
735(define-public u-boot-cubietruck
736 (make-u-boot-package "Cubietruck" "arm-linux-gnueabihf"))
737
6fe16577
VC
738(define-public u-boot-puma-rk3399
739 (let ((base (make-u-boot-package "puma-rk3399" "aarch64-linux-gnu")))
740 (package
741 (inherit base)
742 (arguments
743 (substitute-keyword-arguments (package-arguments base)
744 ((#:phases phases)
745 `(modify-phases ,phases
746 (add-after 'unpack 'set-environment
747 (lambda* (#:key inputs #:allow-other-keys)
748 ;; Need to copy the firmware into u-boot build
749 ;; directory.
750 (copy-file (string-append (assoc-ref inputs "firmware")
751 "/bl31.bin") "bl31-rk3399.bin")
752 (copy-file (string-append (assoc-ref inputs "firmware-m0")
753 "/rk3399m0.bin") "rk3399m0.bin")
754 #t))
755 (add-after 'build 'build-itb
756 (lambda* (#:key make-flags #:allow-other-keys)
757 ;; The u-boot.itb is not built by default.
758 (apply invoke "make" `(,@make-flags ,"u-boot.itb"))))
759 (add-after 'build-itb 'build-rksd
760 (lambda* (#:key inputs #:allow-other-keys)
761 ;; Build Rockchip SD card images.
762 (invoke "./tools/mkimage" "-T" "rksd" "-n" "rk3399" "-d"
763 "spl/u-boot-spl.bin" "u-boot-spl.rksd")))))))
764 (native-inputs
765 `(("firmware" ,arm-trusted-firmware-puma-rk3399)
766 ("firmware-m0" ,rk3399-cortex-m0)
767 ,@(package-native-inputs base))))))
768
2fce14af
VC
769(define-public u-boot-rock64-rk3328
770 (let ((base (make-u-boot-package "rock64-rk3328" "aarch64-linux-gnu")))
771 (package
772 (inherit base)
773 (version (package-version u-boot-2019.10))
774 (source (package-source u-boot-2019.10))
775 (arguments
776 (substitute-keyword-arguments (package-arguments base)
777 ((#:phases phases)
778 `(modify-phases ,phases
779 (add-after 'unpack 'set-environment
780 (lambda* (#:key inputs #:allow-other-keys)
781 (let ((bl31 (string-append (assoc-ref inputs "firmware")
782 "/bl31.elf")))
783 (setenv "BL31" bl31))
784 #t))
785 (add-after 'unpack 'add-u-boot-itb
786 (lambda _
787 (substitute* "Kconfig"
788 (("default .u-boot.itb. if SPL_LOAD_FIT && .ROCKCHIP_RK3399")
789 "default \"u-boot.itb\" if SPL_LOAD_FIT && (ARCH_ROCKCHIP"))
790 #t))))))
791 (native-inputs
792 `(("firmware" ,arm-trusted-firmware-rk3328)
793 ,@(package-native-inputs base))))))
794
545ff7b7
VC
795(define-public u-boot-firefly-rk3399
796 (let ((base (make-u-boot-package "firefly-rk3399" "aarch64-linux-gnu")))
797 (package
798 (inherit base)
799 (version (package-version u-boot-2019.10))
800 (source (package-source u-boot-2019.10))
801 (arguments
802 (substitute-keyword-arguments (package-arguments base)
803 ((#:phases phases)
804 `(modify-phases ,phases
805 (add-after 'unpack 'set-environment
806 (lambda* (#:key inputs #:allow-other-keys)
807 (setenv "BL31" (string-append (assoc-ref inputs "firmware")
808 "/bl31.elf"))
809 #t))
810 ;; Phases do not succeed on the bl31 ELF.
811 (delete 'strip)
812 (delete 'validate-runpath)))))
813 (native-inputs
814 `(("firmware" ,arm-trusted-firmware-rk3399)
815 ,@(package-native-inputs base))))))
816
fa747018
CN
817(define-public u-boot-rockpro64-rk3399
818 (let ((base (make-u-boot-package "rockpro64-rk3399" "aarch64-linux-gnu")))
819 (package
820 (inherit base)
821 (version (package-version u-boot-2019.10))
822 (source (package-source u-boot-2019.10))
823 (arguments
824 (substitute-keyword-arguments (package-arguments base)
825 ((#:phases phases)
826 `(modify-phases ,phases
827 (add-after 'unpack 'set-environment
828 (lambda* (#:key inputs #:allow-other-keys)
829 (setenv "BL31" (string-append (assoc-ref inputs "firmware")
830 "/bl31.elf"))
831 #t))
832 ;; Phases do not succeed on the bl31 ELF.
833 (delete 'strip)
834 (delete 'validate-runpath)))))
835 (native-inputs
836 `(("firmware" ,arm-trusted-firmware-rk3399)
837 ,@(package-native-inputs base))))))
838
a60f1319
MB
839(define-public vboot-utils
840 (package
841 (name "vboot-utils")
842 (version "R63-10032.B")
843 (source (origin
844 ;; XXX: Snapshots are available but changes timestamps every download.
845 (method git-fetch)
846 (uri (git-reference
847 (url (string-append "https://chromium.googlesource.com"
848 "/chromiumos/platform/vboot_reference"))
849 (commit (string-append "release-" version))))
850 (file-name (string-append name "-" version "-checkout"))
851 (sha256
852 (base32
b634b5c2
KK
853 "0h0m3l69vp9dr6xrs1p6y7ilkq3jq8jraw2z20kqfv7lvc9l1lxj"))
854 (patches
855 (search-patches "vboot-utils-skip-test-workbuf.patch"
856 "vboot-utils-fix-tests-show-contents.patch"
857 "vboot-utils-fix-format-load-address.patch"))))
a60f1319
MB
858 (build-system gnu-build-system)
859 (arguments
860 `(#:make-flags (list "CC=gcc"
b634b5c2
KK
861 ;; On ARM, we must pass "HOST_ARCH=arm" so that the
862 ;; ${HOST_ARCH} and ${ARCH} variables in the makefile
863 ;; match. Otherwise, ${HOST_ARCH} will be assigned
864 ;; "armv7l", the value of `uname -m`, and will not
865 ;; match ${ARCH}, which will make the tests require
866 ;; QEMU for testing.
867 ,@(if (string-prefix? "arm"
868 (or (%current-target-system)
869 (%current-system)))
870 '("HOST_ARCH=arm")
871 '())
a60f1319
MB
872 (string-append "DESTDIR=" (assoc-ref %outputs "out")))
873 #:phases (modify-phases %standard-phases
874 (add-after 'unpack 'patch-hard-coded-paths
875 (lambda* (#:key inputs outputs #:allow-other-keys)
876 (let ((coreutils (assoc-ref inputs "coreutils"))
877 (diffutils (assoc-ref inputs "diffutils")))
878 (substitute* "futility/misc.c"
879 (("/bin/cp") (string-append coreutils "/bin/cp")))
880 (substitute* "tests/bitmaps/TestBmpBlock.py"
881 (("/usr/bin/cmp") (string-append diffutils "/bin/cmp")))
882 (substitute* "vboot_host.pc.in"
883 (("prefix=/usr")
884 (string-append "prefix=" (assoc-ref outputs "out"))))
885 #t)))
886 (delete 'configure)
887 (add-before 'check 'patch-tests
888 (lambda _
889 ;; These tests compare diffs against known-good values.
890 ;; Patch the paths to match those in the build container.
891 (substitute* (find-files "tests/futility/expect_output")
892 (("/mnt/host/source/src/platform/vboot_reference")
893 (string-append "/tmp/guix-build-" ,name "-" ,version
894 ".drv-0/source")))
895 ;; Tests require write permissions to many of these files.
896 (for-each make-file-writable (find-files "tests/futility"))
71f2b4b8
KK
897 #t))
898 (add-after 'install 'install-devkeys
899 (lambda* (#:key outputs #:allow-other-keys)
900 (let* ((out (assoc-ref outputs "out"))
901 (share (string-append out "/share/vboot-utils")))
902 (copy-recursively "tests/devkeys"
903 (string-append share "/devkeys"))
904 #t))))
a60f1319
MB
905 #:test-target "runtests"))
906 (native-inputs
907 `(("pkg-config" ,pkg-config)
908
909 ;; For tests.
910 ("diffutils" ,diffutils)
911 ("python@2" ,python-2)))
912 (inputs
913 `(("coreutils" ,coreutils)
914 ("libyaml" ,libyaml)
915 ("openssl" ,openssl)
916 ("openssl:static" ,openssl "static")
917 ("util-linux" ,util-linux)))
918 (home-page
919 "https://dev.chromium.org/chromium-os/chromiumos-design-docs/verified-boot")
920 (synopsis "ChromiumOS verified boot utilities")
921 (description
922 "vboot-utils is a collection of tools to facilitate booting of
923Chrome-branded devices. This includes the @command{cgpt} partitioning
924program, the @command{futility} and @command{crossystem} firmware management
925tools, and more.")
926 (license license:bsd-3)))
927
aa90375a
AI
928(define-public os-prober
929 (package
930 (name "os-prober")
e9bdef5f 931 (version "1.77")
aa90375a
AI
932 (source
933 (origin
934 (method url-fetch)
935 (uri (string-append "mirror://debian/pool/main/o/os-prober/os-prober_"
936 version ".tar.xz"))
937 (sha256
938 (base32
e9bdef5f 939 "0pvhrw4h05n21zw7ig3a3bi8aqdh6zxs0x1znz4g7vhspsps93ld"))))
aa90375a
AI
940 (build-system gnu-build-system)
941 (arguments
942 `(#:modules ((guix build gnu-build-system)
943 (guix build utils)
e9bdef5f
TGR
944 (ice-9 regex) ; for string-match
945 (srfi srfi-26)) ; for cut
aa90375a 946 #:make-flags (list "CC=gcc")
e9bdef5f 947 #:tests? #f ; no tests
aa90375a
AI
948 #:phases
949 (modify-phases %standard-phases
950 (replace 'configure
951 (lambda* (#:key outputs #:allow-other-keys)
952 (substitute* (find-files ".")
953 (("/usr") (assoc-ref outputs "out")))
954 (substitute* (find-files "." "50mounted-tests$")
955 (("mkdir") "mkdir -p"))
956 #t))
957 (replace 'install
958 (lambda* (#:key outputs #:allow-other-keys)
959 (define (find-files-non-recursive directory)
960 (find-files directory
961 (lambda (file stat)
962 (string-match (string-append "^" directory "/[^/]*$")
963 file))
964 #:directories? #t))
965
966 (let* ((out (assoc-ref outputs "out"))
967 (bin (string-append out "/bin"))
968 (lib (string-append out "/lib"))
969 (share (string-append out "/share")))
970 (for-each (cut install-file <> bin)
971 (list "linux-boot-prober" "os-prober"))
972 (install-file "newns" (string-append lib "/os-prober"))
973 (install-file "common.sh" (string-append share "/os-prober"))
974 (install-file "os-probes/mounted/powerpc/20macosx"
975 (string-append lib "/os-probes/mounted"))
976 (for-each
977 (lambda (directory)
978 (for-each
979 (lambda (file)
980 (let ((destination (string-append lib "/" directory
981 "/" (basename file))))
982 (mkdir-p (dirname destination))
983 (copy-recursively file destination)))
984 (append (find-files-non-recursive (string-append directory "/common"))
985 (find-files-non-recursive (string-append directory "/x86")))))
986 (list "os-probes" "os-probes/mounted" "os-probes/init"
987 "linux-boot-probes" "linux-boot-probes/mounted"))
988 #t))))))
989 (home-page "https://joeyh.name/code/os-prober")
990 (synopsis "Detect other operating systems")
991 (description "os-prober probes disks on the system for other operating
992systems so that they can be added to the bootloader. It also works out how to
993boot existing GNU/Linux systems and detects what distribution is installed in
994order to add a suitable bootloader menu entry.")
995 (license license:gpl2+)))