mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-19 05:57:04 +01:00
gnu: bootstrap: Download the bootstrap bash, mkdir, tar, and xz binaries.
* gnu/packages/bootstrap.scm (%bootstrap-executables): New variable. (bootstrap-executable-url, bootstrap-executable): New procedure. (raw-build)[->store]: Use 'run-with-store' and 'origin->derivation'. Add calls to 'derivation->output-path', and remove the list of references passed to 'add-text-to-store' for BUILDER. Augment the list of #:inputs passed to 'derivation'. (package-from-tarball): Use 'bootstrap-executable' instead of 'search-bootstrap-binary'. (%bootstrap-glibc, %bootstrap-gcc, %bootstrap-mescc-tools) (%bootstrap-mes): Likewise. * guix/scripts/environment.scm (environment-bash): Use 'bootstrap-executable' instead of 'search-bootstrap-binary'. (guix-environment): Adjust CONTAINER? case accordingly. * po/guix/POTFILES.in: Add gnu/packages/bootstrap.scm.
This commit is contained in:
parent
267966f911
commit
836a85da0e
3 changed files with 107 additions and 27 deletions
|
@ -1,5 +1,5 @@
|
||||||
;;; GNU Guix --- Functional package management for GNU
|
;;; GNU Guix --- Functional package management for GNU
|
||||||
;;; Copyright © 2012, 2013, 2014, 2015, 2016, 2017, 2018 Ludovic Courtès <ludo@gnu.org>
|
;;; Copyright © 2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019 Ludovic Courtès <ludo@gnu.org>
|
||||||
;;; Copyright © 2014, 2015, 2018 Mark H Weaver <mhw@netris.org>
|
;;; Copyright © 2014, 2015, 2018 Mark H Weaver <mhw@netris.org>
|
||||||
;;; Copyright © 2017 Efraim Flashner <efraim@flashner.co.il>
|
;;; Copyright © 2017 Efraim Flashner <efraim@flashner.co.il>
|
||||||
;;; Copyright © 2018 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
|
;;; Copyright © 2018 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
|
||||||
|
@ -33,8 +33,11 @@ (define-module (gnu packages bootstrap)
|
||||||
#:select (derivation derivation->output-path))
|
#:select (derivation derivation->output-path))
|
||||||
#:use-module ((guix utils) #:select (gnu-triplet->nix-system))
|
#:use-module ((guix utils) #:select (gnu-triplet->nix-system))
|
||||||
#:use-module (guix memoization)
|
#:use-module (guix memoization)
|
||||||
|
#:use-module (guix i18n)
|
||||||
#:use-module (srfi srfi-1)
|
#:use-module (srfi srfi-1)
|
||||||
#:use-module (srfi srfi-26)
|
#:use-module (srfi srfi-26)
|
||||||
|
#:use-module (srfi srfi-34)
|
||||||
|
#:use-module (srfi srfi-35)
|
||||||
#:use-module (ice-9 match)
|
#:use-module (ice-9 match)
|
||||||
#:export (bootstrap-origin
|
#:export (bootstrap-origin
|
||||||
package-with-bootstrap-guile
|
package-with-bootstrap-guile
|
||||||
|
@ -60,6 +63,82 @@ (define-module (gnu packages bootstrap)
|
||||||
;;; Code:
|
;;; Code:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
;;;
|
||||||
|
;;; The bootstrap executables: 'bash', 'mkdir', 'tar', 'xz'. They allow us to
|
||||||
|
;;; extract the very first tarball.
|
||||||
|
;;;
|
||||||
|
|
||||||
|
(define %bootstrap-executables
|
||||||
|
;; List of bootstrap executables and their recursive hashes (as per 'guix
|
||||||
|
;; hash -r'), taking their executable bit into account.
|
||||||
|
`(("aarch64-linux"
|
||||||
|
("bash"
|
||||||
|
,(base32 "13aqhqb8nydlwq1ah9974q0iadx1pb95v13wzzyf7vgv6nasrwzr"))
|
||||||
|
("mkdir"
|
||||||
|
,(base32 "1pxhdp7ldwavmm71xbh9wc197cb2nr66acjn26yjx3732cixh9ws"))
|
||||||
|
("tar"
|
||||||
|
,(base32 "1j51gv08sfg277yxj73xd564wjq3f8xwd6s9rbcg8v9gms47m4cx"))
|
||||||
|
("xz"
|
||||||
|
,(base32 "1d779rwsrasphg5g3r37qppcqy3p7ay1jb1y83w7x4i3qsc7zjy2")))
|
||||||
|
("armhf-linux"
|
||||||
|
("bash"
|
||||||
|
,(base32 "0s6f1s26g4dsrrkl39zblvwpxmbzi6n9mgqf6vxsqz42gik6bgyn"))
|
||||||
|
("mkdir"
|
||||||
|
,(base32 "1r5rcp35niyxfkrdf00y2ba8ifrq9bi76cr63lwjf2l655j1i5p7"))
|
||||||
|
("tar"
|
||||||
|
,(base32 "0dksx5im3fv8ximz7368bsax9f26nn47ds74298flm5lnvpv9xly"))
|
||||||
|
("xz"
|
||||||
|
,(base32 "1cqqavghjfr0iwxqf61lrssv27wfigysgq2rs4rm1gkmn04yn1k3")))
|
||||||
|
("i686-linux"
|
||||||
|
("bash"
|
||||||
|
,(base32 "0rjaxyzjdllfkf1abczvgaf3cdcc7mmahyvdbkjmjzhgz92pv23g"))
|
||||||
|
("mkdir"
|
||||||
|
,(base32 "133ybmfpkmsnysrzbngwvbysqnsmfi8is8zifs7i7n6n600h4s1w"))
|
||||||
|
("tar"
|
||||||
|
,(base32 "07830bx29ad5i0l1ykj0g0b1jayjdblf01sr3ww9wbnwdbzinqms"))
|
||||||
|
("xz"
|
||||||
|
,(base32 "0i9kxdi17bm5gxfi2xzm0y73p3ii0cqxli1sbljm6rh2fjgyn90k")))
|
||||||
|
("mips64el-linux"
|
||||||
|
("bash"
|
||||||
|
,(base32 "1aw046dhda240k9pb9iaj5aqkm23gkvxa9j82n4k7fk87nbrixw6"))
|
||||||
|
("mkdir"
|
||||||
|
,(base32 "0c9j6qgyw84zxbry3ypifzll13gy8ax71w40kdk1h11jbgla3f5k"))
|
||||||
|
("tar"
|
||||||
|
,(base32 "06gmqdjq3rl8lr47b9fyx4ifnm5x56ymc8lyryp1ax1j2s4y5jb4"))
|
||||||
|
("xz"
|
||||||
|
,(base32 "09j1d69qr0hhhx4k4ih8wp00dfc9y4rp01hfg3vc15yxd0jxabh5")))))
|
||||||
|
|
||||||
|
(define (bootstrap-executable-url program system)
|
||||||
|
"Return the URL where PROGRAM can be found for SYSTEM."
|
||||||
|
(string-append
|
||||||
|
"https://git.savannah.gnu.org/cgit/guix.git/plain/gnu/packages/bootstrap/"
|
||||||
|
system "/" program
|
||||||
|
"?id=44f07d1dc6806e97c4e9ee3e6be883cc59dc666e"))
|
||||||
|
|
||||||
|
(define bootstrap-executable
|
||||||
|
(mlambda (program system)
|
||||||
|
"Return an origin for PROGRAM, a statically-linked bootstrap executable
|
||||||
|
built for SYSTEM."
|
||||||
|
(let ((system (if (string=? system "x86_64-linux")
|
||||||
|
"i686-linux"
|
||||||
|
system)))
|
||||||
|
(match (assoc-ref (assoc-ref %bootstrap-executables system)
|
||||||
|
program)
|
||||||
|
(#f
|
||||||
|
(raise (condition
|
||||||
|
(&message
|
||||||
|
(message
|
||||||
|
(format #f (G_ "could not find bootstrap binary '~a' \
|
||||||
|
for system '~a'")
|
||||||
|
program system))))))
|
||||||
|
((sha256)
|
||||||
|
(origin
|
||||||
|
(method url-fetch/executable)
|
||||||
|
(uri (bootstrap-executable-url program system))
|
||||||
|
(file-name program)
|
||||||
|
(sha256 sha256)))))))
|
||||||
|
|
||||||
|
|
||||||
;;;
|
;;;
|
||||||
;;; Helper procedures.
|
;;; Helper procedures.
|
||||||
|
@ -133,8 +212,8 @@ (define* (package-from-tarball name source program-to-test description
|
||||||
(invoke (string-append "bin/" ,program-to-test)
|
(invoke (string-append "bin/" ,program-to-test)
|
||||||
"--version"))))))))
|
"--version"))))))))
|
||||||
(inputs
|
(inputs
|
||||||
`(("tar" ,(search-bootstrap-binary "tar" (%current-system)))
|
`(("tar" ,(bootstrap-executable "tar" (%current-system)))
|
||||||
("xz" ,(search-bootstrap-binary "xz" (%current-system)))
|
("xz" ,(bootstrap-executable "xz" (%current-system)))
|
||||||
("tarball" ,(bootstrap-origin (source (%current-system))))))
|
("tarball" ,(bootstrap-origin (source (%current-system))))))
|
||||||
(source #f)
|
(source #f)
|
||||||
(synopsis description)
|
(synopsis description)
|
||||||
|
@ -258,11 +337,9 @@ (define* (raw-build store name inputs
|
||||||
#:key outputs system search-paths
|
#:key outputs system search-paths
|
||||||
#:allow-other-keys)
|
#:allow-other-keys)
|
||||||
(define (->store file)
|
(define (->store file)
|
||||||
(add-to-store store file #t "sha256"
|
(run-with-store store
|
||||||
(or (search-bootstrap-binary file
|
(origin->derivation (bootstrap-executable file system)
|
||||||
system)
|
system)))
|
||||||
(error "bootstrap binary not found"
|
|
||||||
file system))))
|
|
||||||
|
|
||||||
(let* ((tar (->store "tar"))
|
(let* ((tar (->store "tar"))
|
||||||
(xz (->store "xz"))
|
(xz (->store "xz"))
|
||||||
|
@ -312,14 +389,16 @@ (define (->store file)
|
||||||
|
|
||||||
# Sanity check.
|
# Sanity check.
|
||||||
$out/bin/guile --version~%"
|
$out/bin/guile --version~%"
|
||||||
mkdir xz tar
|
(derivation->output-path mkdir)
|
||||||
|
(derivation->output-path xz)
|
||||||
|
(derivation->output-path tar)
|
||||||
(format #f "~s" make-guile-wrapper)
|
(format #f "~s" make-guile-wrapper)
|
||||||
bash)
|
(derivation->output-path bash)))))
|
||||||
(list mkdir xz tar bash))))
|
|
||||||
(derivation store name
|
(derivation store name
|
||||||
bash `(,builder)
|
(derivation->output-path bash) `(,builder)
|
||||||
#:system system
|
#:system system
|
||||||
#:inputs `((,bash) (,builder) (,guile))
|
#:inputs `((,bash) (,mkdir) (,tar) (,xz)
|
||||||
|
(,builder) (,guile))
|
||||||
#:env-vars `(("GUILE_TARBALL"
|
#:env-vars `(("GUILE_TARBALL"
|
||||||
. ,(derivation->output-path guile))))))
|
. ,(derivation->output-path guile))))))
|
||||||
|
|
||||||
|
@ -486,8 +565,8 @@ (define %bootstrap-glibc
|
||||||
|
|
||||||
#t))))))
|
#t))))))
|
||||||
(inputs
|
(inputs
|
||||||
`(("tar" ,(search-bootstrap-binary "tar" (%current-system)))
|
`(("tar" ,(bootstrap-executable "tar" (%current-system)))
|
||||||
("xz" ,(search-bootstrap-binary "xz" (%current-system)))
|
("xz" ,(bootstrap-executable "xz" (%current-system)))
|
||||||
("tarball" ,(bootstrap-origin
|
("tarball" ,(bootstrap-origin
|
||||||
(origin
|
(origin
|
||||||
(method url-fetch)
|
(method url-fetch)
|
||||||
|
@ -570,9 +649,9 @@ (define %bootstrap-gcc
|
||||||
(chmod "gcc" #o555)
|
(chmod "gcc" #o555)
|
||||||
#t))))))
|
#t))))))
|
||||||
(inputs
|
(inputs
|
||||||
`(("tar" ,(search-bootstrap-binary "tar" (%current-system)))
|
`(("tar" ,(bootstrap-executable "tar" (%current-system)))
|
||||||
("xz" ,(search-bootstrap-binary "xz" (%current-system)))
|
("xz" ,(bootstrap-executable "xz" (%current-system)))
|
||||||
("bash" ,(search-bootstrap-binary "bash" (%current-system)))
|
("bash" ,(bootstrap-executable "bash" (%current-system)))
|
||||||
("libc" ,%bootstrap-glibc)
|
("libc" ,%bootstrap-glibc)
|
||||||
("tarball" ,(bootstrap-origin
|
("tarball" ,(bootstrap-origin
|
||||||
(origin
|
(origin
|
||||||
|
@ -644,8 +723,8 @@ (define %bootstrap-mescc-tools
|
||||||
(invoke tar "xvf"
|
(invoke tar "xvf"
|
||||||
(string-append builddir "/binaries.tar"))))))))
|
(string-append builddir "/binaries.tar"))))))))
|
||||||
(inputs
|
(inputs
|
||||||
`(("tar" ,(search-bootstrap-binary "tar" (%current-system)))
|
`(("tar" ,(bootstrap-executable "tar" (%current-system)))
|
||||||
("xz" ,(search-bootstrap-binary "xz" (%current-system)))
|
("xz" ,(bootstrap-executable "xz" (%current-system)))
|
||||||
("tarball"
|
("tarball"
|
||||||
,(bootstrap-origin
|
,(bootstrap-origin
|
||||||
(origin
|
(origin
|
||||||
|
@ -693,8 +772,8 @@ (define %bootstrap-mes
|
||||||
(invoke tar "xvf"
|
(invoke tar "xvf"
|
||||||
(string-append builddir "/binaries.tar"))))))))
|
(string-append builddir "/binaries.tar"))))))))
|
||||||
(inputs
|
(inputs
|
||||||
`(("tar" ,(search-bootstrap-binary "tar" (%current-system)))
|
`(("tar" ,(bootstrap-executable "tar" (%current-system)))
|
||||||
("xz" ,(search-bootstrap-binary "xz" (%current-system)))
|
("xz" ,(bootstrap-executable "xz" (%current-system)))
|
||||||
("tarball"
|
("tarball"
|
||||||
,(bootstrap-origin
|
,(bootstrap-origin
|
||||||
(origin
|
(origin
|
||||||
|
|
|
@ -29,7 +29,7 @@ (define-module (guix scripts environment)
|
||||||
#:use-module (guix search-paths)
|
#:use-module (guix search-paths)
|
||||||
#:use-module (guix build utils)
|
#:use-module (guix build utils)
|
||||||
#:use-module (guix monads)
|
#:use-module (guix monads)
|
||||||
#:use-module ((guix gexp) #:select (lower-inputs))
|
#:use-module ((guix gexp) #:select (lower-object))
|
||||||
#:use-module (guix scripts)
|
#:use-module (guix scripts)
|
||||||
#:use-module (guix scripts build)
|
#:use-module (guix scripts build)
|
||||||
#:use-module (gnu build linux-container)
|
#:use-module (gnu build linux-container)
|
||||||
|
@ -40,7 +40,8 @@ (define-module (guix scripts environment)
|
||||||
#:use-module (gnu packages bash)
|
#:use-module (gnu packages bash)
|
||||||
#:use-module (gnu packages commencement)
|
#:use-module (gnu packages commencement)
|
||||||
#:use-module (gnu packages guile)
|
#:use-module (gnu packages guile)
|
||||||
#:use-module ((gnu packages bootstrap) #:select (%bootstrap-guile))
|
#:use-module ((gnu packages bootstrap)
|
||||||
|
#:select (bootstrap-executable %bootstrap-guile))
|
||||||
#:use-module (ice-9 format)
|
#:use-module (ice-9 format)
|
||||||
#:use-module (ice-9 match)
|
#:use-module (ice-9 match)
|
||||||
#:use-module (ice-9 rdelim)
|
#:use-module (ice-9 rdelim)
|
||||||
|
@ -600,8 +601,7 @@ (define (environment-bash container? bootstrap? system)
|
||||||
(package->derivation bash))
|
(package->derivation bash))
|
||||||
;; Use the bootstrap Bash instead.
|
;; Use the bootstrap Bash instead.
|
||||||
((and container? bootstrap?)
|
((and container? bootstrap?)
|
||||||
(interned-file
|
(lower-object (bootstrap-executable "bash" system)))
|
||||||
(search-bootstrap-binary "bash" system)))
|
|
||||||
(else
|
(else
|
||||||
(return #f)))))
|
(return #f)))))
|
||||||
|
|
||||||
|
@ -730,7 +730,7 @@ (define manifest
|
||||||
(container?
|
(container?
|
||||||
(let ((bash-binary
|
(let ((bash-binary
|
||||||
(if bootstrap?
|
(if bootstrap?
|
||||||
bash
|
(derivation->output-path bash)
|
||||||
(string-append (derivation->output-path bash)
|
(string-append (derivation->output-path bash)
|
||||||
"/bin/sh"))))
|
"/bin/sh"))))
|
||||||
(launch-environment/container #:command command
|
(launch-environment/container #:command command
|
||||||
|
|
|
@ -36,6 +36,7 @@ gnu/installer/steps.scm
|
||||||
gnu/installer/timezone.scm
|
gnu/installer/timezone.scm
|
||||||
gnu/installer/user.scm
|
gnu/installer/user.scm
|
||||||
gnu/installer/utils.scm
|
gnu/installer/utils.scm
|
||||||
|
gnu/packages/bootstrap.scm
|
||||||
guix/scripts.scm
|
guix/scripts.scm
|
||||||
guix/scripts/build.scm
|
guix/scripts/build.scm
|
||||||
guix/discovery.scm
|
guix/discovery.scm
|
||||||
|
|
Loading…
Reference in a new issue