mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2024-12-25 05:48:07 -05:00
Merge branch 'wip-binaries'
This commit is contained in:
commit
32e18e9b94
4 changed files with 294 additions and 25 deletions
|
@ -699,6 +699,7 @@ dist_patch_DATA = \
|
||||||
%D%/packages/patches/avidemux-install-to-lib.patch \
|
%D%/packages/patches/avidemux-install-to-lib.patch \
|
||||||
%D%/packages/patches/awesome-reproducible-png.patch \
|
%D%/packages/patches/awesome-reproducible-png.patch \
|
||||||
%D%/packages/patches/azr3.patch \
|
%D%/packages/patches/azr3.patch \
|
||||||
|
%D%/packages/patches/bash-4.4-linux-pgrp-pipe.patch \
|
||||||
%D%/packages/patches/bash-completion-directories.patch \
|
%D%/packages/patches/bash-completion-directories.patch \
|
||||||
%D%/packages/patches/bastet-change-source-of-unordered_set.patch \
|
%D%/packages/patches/bastet-change-source-of-unordered_set.patch \
|
||||||
%D%/packages/patches/bazaar-CVE-2017-14176.patch \
|
%D%/packages/patches/bazaar-CVE-2017-14176.patch \
|
||||||
|
|
|
@ -2,7 +2,8 @@
|
||||||
;;; Copyright © 2012, 2013, 2014, 2015, 2016, 2017, 2018 Ludovic Courtès <ludo@gnu.org>
|
;;; Copyright © 2012, 2013, 2014, 2015, 2016, 2017, 2018 Ludovic Courtès <ludo@gnu.org>
|
||||||
;;; Copyright © 2017 Efraim Flashner <efraim@flashner.co.il>
|
;;; Copyright © 2017 Efraim Flashner <efraim@flashner.co.il>
|
||||||
;;; Copyright © 2018 Tobias Geerinckx-Rice <me@tobias.gr>
|
;;; Copyright © 2018 Tobias Geerinckx-Rice <me@tobias.gr>
|
||||||
;;; Copyright © 2018 Mark H Weaver <mhw@netris.org>
|
;;; Copyright © 2018, 2019 Mark H Weaver <mhw@netris.org>
|
||||||
|
;;; Copyright © 2019 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -37,14 +38,18 @@ (define-module (gnu packages make-bootstrap)
|
||||||
#:use-module (gnu packages libunistring)
|
#:use-module (gnu packages libunistring)
|
||||||
#:use-module (gnu packages linux)
|
#:use-module (gnu packages linux)
|
||||||
#:use-module (gnu packages hurd)
|
#:use-module (gnu packages hurd)
|
||||||
|
#:use-module (gnu packages mes)
|
||||||
#:use-module (gnu packages multiprecision)
|
#:use-module (gnu packages multiprecision)
|
||||||
#:use-module (ice-9 match)
|
#:use-module (ice-9 match)
|
||||||
#:use-module (srfi srfi-1)
|
#:use-module (srfi srfi-1)
|
||||||
#:export (%bootstrap-binaries-tarball
|
#:export (%bootstrap-binaries-tarball
|
||||||
|
%linux-libre-headers-bootstrap-tarball
|
||||||
%binutils-bootstrap-tarball
|
%binutils-bootstrap-tarball
|
||||||
%glibc-bootstrap-tarball
|
%glibc-bootstrap-tarball
|
||||||
%gcc-bootstrap-tarball
|
%gcc-bootstrap-tarball
|
||||||
%guile-bootstrap-tarball
|
%guile-bootstrap-tarball
|
||||||
|
%mescc-tools-bootstrap-tarball
|
||||||
|
%mes-bootstrap-tarball
|
||||||
%bootstrap-tarballs
|
%bootstrap-tarballs
|
||||||
|
|
||||||
%guile-static-stripped))
|
%guile-static-stripped))
|
||||||
|
@ -120,6 +125,15 @@ (define (native-inputs)
|
||||||
(current-source-location)
|
(current-source-location)
|
||||||
#:native-inputs native-inputs))
|
#:native-inputs native-inputs))
|
||||||
|
|
||||||
|
(define static-bash-for-bootstrap
|
||||||
|
(package
|
||||||
|
(inherit static-bash)
|
||||||
|
(source (origin
|
||||||
|
(inherit (package-source static-bash))
|
||||||
|
(patches
|
||||||
|
(cons (search-patch "bash-4.4-linux-pgrp-pipe.patch")
|
||||||
|
(origin-patches (package-source static-bash))))))))
|
||||||
|
|
||||||
(define %static-inputs
|
(define %static-inputs
|
||||||
;; Packages that are to be used as %BOOTSTRAP-INPUTS.
|
;; Packages that are to be used as %BOOTSTRAP-INPUTS.
|
||||||
(let ((coreutils (package (inherit coreutils)
|
(let ((coreutils (package (inherit coreutils)
|
||||||
|
@ -187,7 +201,7 @@ (define %static-inputs
|
||||||
(("-Wl,-export-dynamic") ""))
|
(("-Wl,-export-dynamic") ""))
|
||||||
#t)))))))
|
#t)))))))
|
||||||
(inputs (if (%current-target-system)
|
(inputs (if (%current-target-system)
|
||||||
`(("bash" ,static-bash))
|
`(("bash" ,static-bash-for-bootstrap))
|
||||||
'()))))
|
'()))))
|
||||||
(tar (package (inherit tar)
|
(tar (package (inherit tar)
|
||||||
(arguments
|
(arguments
|
||||||
|
@ -228,7 +242,7 @@ (define %static-inputs
|
||||||
("sed" ,sed)
|
("sed" ,sed)
|
||||||
("grep" ,grep)
|
("grep" ,grep)
|
||||||
("gawk" ,gawk)))
|
("gawk" ,gawk)))
|
||||||
("bash" ,static-bash))))
|
("bash" ,static-bash-for-bootstrap))))
|
||||||
|
|
||||||
(define %static-binaries
|
(define %static-binaries
|
||||||
(package
|
(package
|
||||||
|
@ -300,6 +314,26 @@ (define (copy-directory source destination)
|
||||||
(license gpl3+)
|
(license gpl3+)
|
||||||
(home-page #f)))
|
(home-page #f)))
|
||||||
|
|
||||||
|
(define %linux-libre-headers-stripped
|
||||||
|
;; The subset of Linux-Libre-Headers that we need.
|
||||||
|
(package (inherit linux-libre-headers)
|
||||||
|
(name (string-append (package-name linux-libre-headers) "-stripped"))
|
||||||
|
(build-system trivial-build-system)
|
||||||
|
(outputs '("out"))
|
||||||
|
(arguments
|
||||||
|
`(#:modules ((guix build utils)
|
||||||
|
(guix build make-bootstrap))
|
||||||
|
#:builder
|
||||||
|
(begin
|
||||||
|
(use-modules (guix build utils)
|
||||||
|
(guix build make-bootstrap))
|
||||||
|
|
||||||
|
(let* ((in (assoc-ref %build-inputs "linux-libre-headers"))
|
||||||
|
(out (assoc-ref %outputs "out")))
|
||||||
|
(copy-linux-headers out in)
|
||||||
|
#t))))
|
||||||
|
(inputs `(("linux-libre-headers" ,linux-libre-headers)))))
|
||||||
|
|
||||||
(define %binutils-static
|
(define %binutils-static
|
||||||
;; Statically-linked Binutils.
|
;; Statically-linked Binutils.
|
||||||
(package (inherit binutils)
|
(package (inherit binutils)
|
||||||
|
@ -513,6 +547,154 @@ (define %gcc-stripped
|
||||||
#t))))
|
#t))))
|
||||||
(inputs `(("gcc" ,%gcc-static)))))
|
(inputs `(("gcc" ,%gcc-static)))))
|
||||||
|
|
||||||
|
;; One package: build + remove store references
|
||||||
|
;; (define %mescc-tools-static-stripped
|
||||||
|
;; ;; A statically linked Mescc Tools with store references removed, for
|
||||||
|
;; ;; bootstrap.
|
||||||
|
;; (package
|
||||||
|
;; (inherit mescc-tools)
|
||||||
|
;; (name "mescc-tools-static-stripped")
|
||||||
|
;; (arguments
|
||||||
|
;; `(#:make-flags (list (string-append "PREFIX=" (assoc-ref %outputs "out"))
|
||||||
|
;; "CC=gcc -static")
|
||||||
|
;; #:test-target "test"
|
||||||
|
;; #:phases (modify-phases %standard-phases
|
||||||
|
;; (delete 'configure)
|
||||||
|
;; (add-after 'install 'strip-store-references
|
||||||
|
;; (lambda _
|
||||||
|
;; (let* ((out (assoc-ref %outputs "out"))
|
||||||
|
;; (bin (string-append out "/bin")))
|
||||||
|
;; (for-each (lambda (file)
|
||||||
|
;; (let ((target (string-append bin "/" file)))
|
||||||
|
;; (format #t "strippingg `~a'...~%" target)
|
||||||
|
;; (remove-store-references target)))
|
||||||
|
;; '( "M1" "blood-elf" "hex2"))))))))))
|
||||||
|
|
||||||
|
;; Two packages: first build static, bare minimum content.
|
||||||
|
(define %mescc-tools-static
|
||||||
|
;; A statically linked MesCC Tools.
|
||||||
|
(package
|
||||||
|
(inherit mescc-tools)
|
||||||
|
(name "mescc-tools-static")
|
||||||
|
(arguments
|
||||||
|
`(#:system "i686-linux"
|
||||||
|
,@(substitute-keyword-arguments (package-arguments mescc-tools)
|
||||||
|
((#:make-flags flags)
|
||||||
|
`(cons "CC=gcc -static" ,flags)))))))
|
||||||
|
|
||||||
|
;; ... next remove store references.
|
||||||
|
(define %mescc-tools-static-stripped
|
||||||
|
;; A statically linked Mescc Tools with store references removed, for
|
||||||
|
;; bootstrap.
|
||||||
|
(package
|
||||||
|
(inherit %mescc-tools-static)
|
||||||
|
(name (string-append (package-name %mescc-tools-static) "-stripped"))
|
||||||
|
(build-system trivial-build-system)
|
||||||
|
(arguments
|
||||||
|
`(#:modules ((guix build utils))
|
||||||
|
#:builder
|
||||||
|
(begin
|
||||||
|
(use-modules (guix build utils))
|
||||||
|
(let* ((in (assoc-ref %build-inputs "mescc-tools"))
|
||||||
|
(out (assoc-ref %outputs "out"))
|
||||||
|
(bin (string-append out "/bin")))
|
||||||
|
(mkdir-p bin)
|
||||||
|
(for-each (lambda (file)
|
||||||
|
(let ((target (string-append bin "/" file)))
|
||||||
|
(format #t "copying `~a'...~%" file)
|
||||||
|
(copy-file (string-append in "/bin/" file)
|
||||||
|
target)
|
||||||
|
(remove-store-references target)))
|
||||||
|
'( "M1" "blood-elf" "hex2"))
|
||||||
|
#t))))
|
||||||
|
(inputs `(("mescc-tools" ,%mescc-tools-static)))))
|
||||||
|
|
||||||
|
;; (define-public %mes-minimal-stripped
|
||||||
|
;; ;; A minimal Mes without documentation dependencies, for bootstrap.
|
||||||
|
;; (let ((triplet "i686-unknown-linux-gnu"))
|
||||||
|
;; (package
|
||||||
|
;; (inherit mes)
|
||||||
|
;; (name "mes-minimal-stripped")
|
||||||
|
;; (native-inputs
|
||||||
|
;; `(("guile" ,guile-2.2)))
|
||||||
|
;; (arguments
|
||||||
|
;; `(#:system "i686-linux"
|
||||||
|
;; #:strip-binaries? #f
|
||||||
|
;; #:configure-flags '("--mes")
|
||||||
|
;; #:phases
|
||||||
|
;; (modify-phases %standard-phases
|
||||||
|
;; (delete 'patch-shebangs)
|
||||||
|
;; (add-after 'install 'strip-install
|
||||||
|
;; (lambda _
|
||||||
|
;; (let* ((out (assoc-ref %outputs "out"))
|
||||||
|
;; (share (string-append out "/share")))
|
||||||
|
;; (delete-file-recursively (string-append out "/lib/guile"))
|
||||||
|
;; (delete-file-recursively (string-append share "/guile"))
|
||||||
|
;; (delete-file-recursively (string-append share "/mes/scaffold"))
|
||||||
|
|
||||||
|
;; (for-each delete-file
|
||||||
|
;; (find-files
|
||||||
|
;; (string-append share "/mes/lib") "\\.(h|c)"))
|
||||||
|
|
||||||
|
;; (for-each (lambda (dir)
|
||||||
|
;; (for-each remove-store-references
|
||||||
|
;; (find-files (string-append out "/" dir)
|
||||||
|
;; ".*")))
|
||||||
|
;; '("bin" "share/mes")))))))))))
|
||||||
|
|
||||||
|
;; Two packages: first build static, bare minimum content.
|
||||||
|
(define-public %mes-minimal
|
||||||
|
;; A minimal Mes without documentation.
|
||||||
|
(let ((triplet "i686-unknown-linux-gnu"))
|
||||||
|
(package
|
||||||
|
(inherit mes)
|
||||||
|
(name "mes-minimal")
|
||||||
|
(native-inputs
|
||||||
|
`(("guile" ,guile-2.2)))
|
||||||
|
(arguments
|
||||||
|
`(#:system "i686-linux"
|
||||||
|
#:strip-binaries? #f
|
||||||
|
#:configure-flags '("--mes")
|
||||||
|
#:phases
|
||||||
|
(modify-phases %standard-phases
|
||||||
|
(delete 'patch-shebangs)
|
||||||
|
(add-after 'install 'strip-install
|
||||||
|
(lambda _
|
||||||
|
(let* ((out (assoc-ref %outputs "out"))
|
||||||
|
(share (string-append out "/share")))
|
||||||
|
(delete-file-recursively (string-append out "/lib/guile"))
|
||||||
|
(delete-file-recursively (string-append share "/guile"))
|
||||||
|
(delete-file-recursively (string-append share "/mes/scaffold"))
|
||||||
|
|
||||||
|
(for-each delete-file
|
||||||
|
(find-files
|
||||||
|
(string-append share "/mes/lib")
|
||||||
|
"\\.(h|c)")))))))))))
|
||||||
|
|
||||||
|
;; next remove store references.
|
||||||
|
(define %mes-minimal-stripped
|
||||||
|
;; A minimal Mes with store references removed, for bootstrap.
|
||||||
|
(package
|
||||||
|
(inherit %mes-minimal)
|
||||||
|
(name (string-append (package-name %mes-minimal) "-stripped"))
|
||||||
|
(build-system trivial-build-system)
|
||||||
|
(arguments
|
||||||
|
`(#:modules ((guix build utils))
|
||||||
|
#:builder
|
||||||
|
(begin
|
||||||
|
(use-modules (guix build utils))
|
||||||
|
(let ((in (assoc-ref %build-inputs "mes"))
|
||||||
|
(out (assoc-ref %outputs "out")))
|
||||||
|
|
||||||
|
(copy-recursively in out)
|
||||||
|
(for-each (lambda (dir)
|
||||||
|
(for-each remove-store-references
|
||||||
|
(find-files (string-append out "/" dir)
|
||||||
|
".*")))
|
||||||
|
'("bin" "share/mes"))
|
||||||
|
#t))))
|
||||||
|
(inputs `(("mes" ,%mes-minimal)))))
|
||||||
|
|
||||||
(define %guile-static
|
(define %guile-static
|
||||||
;; A statically-linked Guile that is relocatable--i.e., it can search
|
;; A statically-linked Guile that is relocatable--i.e., it can search
|
||||||
;; .scm and .go files relative to its installation directory, rather
|
;; .scm and .go files relative to its installation directory, rather
|
||||||
|
@ -571,6 +753,10 @@ (define %guile-static
|
||||||
((#:tests? _ #f)
|
((#:tests? _ #f)
|
||||||
;; There are uses of `dynamic-link' in
|
;; There are uses of `dynamic-link' in
|
||||||
;; {foreign,coverage}.test that don't fly here.
|
;; {foreign,coverage}.test that don't fly here.
|
||||||
|
#f)
|
||||||
|
((#:parallel-build? _ #f)
|
||||||
|
;; Work around the fact that the Guile build system is
|
||||||
|
;; not deterministic when parallel-build is enabled.
|
||||||
#f))))))
|
#f))))))
|
||||||
(package-with-relocatable-glibc (static-package guile))))
|
(package-with-relocatable-glibc (static-package guile))))
|
||||||
|
|
||||||
|
@ -660,6 +846,10 @@ (define %bootstrap-binaries-tarball
|
||||||
;; A tarball with the statically-linked bootstrap binaries.
|
;; A tarball with the statically-linked bootstrap binaries.
|
||||||
(tarball-package %static-binaries))
|
(tarball-package %static-binaries))
|
||||||
|
|
||||||
|
(define %linux-libre-headers-bootstrap-tarball
|
||||||
|
;; A tarball with the statically-linked Linux-Libre-Headers programs.
|
||||||
|
(tarball-package %linux-libre-headers-stripped))
|
||||||
|
|
||||||
(define %binutils-bootstrap-tarball
|
(define %binutils-bootstrap-tarball
|
||||||
;; A tarball with the statically-linked Binutils programs.
|
;; A tarball with the statically-linked Binutils programs.
|
||||||
(tarball-package %binutils-static-stripped))
|
(tarball-package %binutils-static-stripped))
|
||||||
|
@ -676,6 +866,14 @@ (define %guile-bootstrap-tarball
|
||||||
;; A tarball with the statically-linked, relocatable Guile.
|
;; A tarball with the statically-linked, relocatable Guile.
|
||||||
(tarball-package %guile-static-stripped))
|
(tarball-package %guile-static-stripped))
|
||||||
|
|
||||||
|
(define %mescc-tools-bootstrap-tarball
|
||||||
|
;; A tarball with statically-linked MesCC binary seed.
|
||||||
|
(tarball-package %mescc-tools-static-stripped))
|
||||||
|
|
||||||
|
(define %mes-bootstrap-tarball
|
||||||
|
;; A tarball with Mes binary seed.
|
||||||
|
(tarball-package %mes-minimal-stripped))
|
||||||
|
|
||||||
(define %bootstrap-tarballs
|
(define %bootstrap-tarballs
|
||||||
;; A single derivation containing all the bootstrap tarballs, for
|
;; A single derivation containing all the bootstrap tarballs, for
|
||||||
;; convenience.
|
;; convenience.
|
||||||
|
@ -704,9 +902,15 @@ (define %bootstrap-tarballs
|
||||||
%build-inputs)
|
%build-inputs)
|
||||||
#t)))
|
#t)))
|
||||||
(inputs `(("guile-tarball" ,%guile-bootstrap-tarball)
|
(inputs `(("guile-tarball" ,%guile-bootstrap-tarball)
|
||||||
("gcc-tarball" ,%gcc-bootstrap-tarball)
|
,@(match (or (%current-target-system) (%current-system))
|
||||||
("binutils-tarball" ,%binutils-bootstrap-tarball)
|
((or "i686-linux" "x86_64-linux")
|
||||||
("glibc-tarball" ,(%glibc-bootstrap-tarball))
|
`(("bootstrap-mescc-tools" ,%mescc-tools-bootstrap-tarball)
|
||||||
|
("bootstrap-mes" ,%mes-bootstrap-tarball)
|
||||||
|
("bootstrap-linux-libre-headers"
|
||||||
|
,%linux-libre-headers-bootstrap-tarball)))
|
||||||
|
(_ `(("gcc-tarball" ,%gcc-bootstrap-tarball)
|
||||||
|
("binutils-tarball" ,%binutils-bootstrap-tarball)
|
||||||
|
("glibc-tarball" ,(%glibc-bootstrap-tarball)))))
|
||||||
("coreutils&co-tarball" ,%bootstrap-binaries-tarball)))
|
("coreutils&co-tarball" ,%bootstrap-binaries-tarball)))
|
||||||
(synopsis "Tarballs containing all the bootstrap binaries")
|
(synopsis "Tarballs containing all the bootstrap binaries")
|
||||||
(description synopsis)
|
(description synopsis)
|
||||||
|
|
30
gnu/packages/patches/bash-4.4-linux-pgrp-pipe.patch
Normal file
30
gnu/packages/patches/bash-4.4-linux-pgrp-pipe.patch
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
Unconditionally enable PGRP_PIPE on Linux (the kernel), regardless of
|
||||||
|
the kernel version in use on the build machine.
|
||||||
|
|
||||||
|
--- configure.ac.orig 1969-12-31 19:00:00.000000000 -0500
|
||||||
|
+++ configure.ac 2019-08-11 22:28:26.038841961 -0400
|
||||||
|
@@ -1092,9 +1092,7 @@
|
||||||
|
solaris2*) LOCAL_CFLAGS=-DSOLARIS ;;
|
||||||
|
lynxos*) LOCAL_CFLAGS=-DRECYCLES_PIDS ;;
|
||||||
|
linux*) LOCAL_LDFLAGS=-rdynamic # allow dynamic loading
|
||||||
|
- case "`uname -r`" in
|
||||||
|
- 2.[[456789]]*|[[34]]*) AC_DEFINE(PGRP_PIPE) ;;
|
||||||
|
- esac ;;
|
||||||
|
+ AC_DEFINE(PGRP_PIPE) ;;
|
||||||
|
*qnx6*) LOCAL_CFLAGS="-Dqnx -Dqnx6" LOCAL_LIBS="-lncurses" ;;
|
||||||
|
*qnx*) LOCAL_CFLAGS="-Dqnx -F -3s" LOCAL_LDFLAGS="-3s" LOCAL_LIBS="-lunix -lncurses" ;;
|
||||||
|
powerux*) LOCAL_LIBS="-lgen" ;;
|
||||||
|
--- configure.orig 1969-12-31 19:00:00.000000000 -0500
|
||||||
|
+++ configure 2019-08-11 22:28:10.166763255 -0400
|
||||||
|
@@ -16064,10 +16064,7 @@
|
||||||
|
solaris2*) LOCAL_CFLAGS=-DSOLARIS ;;
|
||||||
|
lynxos*) LOCAL_CFLAGS=-DRECYCLES_PIDS ;;
|
||||||
|
linux*) LOCAL_LDFLAGS=-rdynamic # allow dynamic loading
|
||||||
|
- case "`uname -r`" in
|
||||||
|
- 2.[456789]*|[34]*) $as_echo "#define PGRP_PIPE 1" >>confdefs.h
|
||||||
|
- ;;
|
||||||
|
- esac ;;
|
||||||
|
+ $as_echo "#define PGRP_PIPE 1" >>confdefs.h ;;
|
||||||
|
*qnx6*) LOCAL_CFLAGS="-Dqnx -Dqnx6" LOCAL_LIBS="-lncurses" ;;
|
||||||
|
*qnx*) LOCAL_CFLAGS="-Dqnx -F -3s" LOCAL_LDFLAGS="-3s" LOCAL_LIBS="-lunix -lncurses" ;;
|
||||||
|
powerux*) LOCAL_LIBS="-lgen" ;;
|
|
@ -1,6 +1,7 @@
|
||||||
;;; GNU Guix --- Functional package management for GNU
|
;;; GNU Guix --- Functional package management for GNU
|
||||||
;;; Copyright © 2015, 2017 Manolis Fragkiskos Ragkousis <manolis837@gmail.com>
|
;;; Copyright © 2015, 2017 Manolis Fragkiskos Ragkousis <manolis837@gmail.com>
|
||||||
;;; Copyright © 2015, 2019 Ludovic Courtès <ludo@gnu.org>
|
;;; Copyright © 2015, 2019 Ludovic Courtès <ludo@gnu.org>
|
||||||
|
;;; Copyright © 2018 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -23,7 +24,8 @@ (define-module (guix build make-bootstrap)
|
||||||
#:use-module (srfi srfi-19)
|
#:use-module (srfi srfi-19)
|
||||||
#:use-module (srfi srfi-26)
|
#:use-module (srfi srfi-26)
|
||||||
#:use-module (guix build utils)
|
#:use-module (guix build utils)
|
||||||
#:export (make-stripped-libc))
|
#:export (copy-linux-headers
|
||||||
|
make-stripped-libc))
|
||||||
|
|
||||||
;; Commentary:
|
;; Commentary:
|
||||||
;;
|
;;
|
||||||
|
@ -31,6 +33,53 @@ (define-module (guix build make-bootstrap)
|
||||||
;;
|
;;
|
||||||
;; Code:
|
;; Code:
|
||||||
|
|
||||||
|
(define (copy-linux-headers output kernel-headers)
|
||||||
|
"Copy to OUTPUT the subset of KERNEL-HEADERS that is needed when producing a
|
||||||
|
bootstrap libc."
|
||||||
|
|
||||||
|
(let* ((incdir (string-append output "/include")))
|
||||||
|
(mkdir-p incdir)
|
||||||
|
|
||||||
|
;; Copy some of the Linux-Libre headers that glibc headers
|
||||||
|
;; refer to.
|
||||||
|
(mkdir (string-append incdir "/linux"))
|
||||||
|
(for-each (lambda (file)
|
||||||
|
(install-file (pk 'src (string-append kernel-headers "/include/linux/" file))
|
||||||
|
(pk 'dest (string-append incdir "/linux"))))
|
||||||
|
'(
|
||||||
|
"a.out.h" ; for 2.2.5
|
||||||
|
"atalk.h" ; for 2.2.5
|
||||||
|
"errno.h"
|
||||||
|
"falloc.h"
|
||||||
|
"if_addr.h" ; for 2.16.0
|
||||||
|
"if_ether.h" ; for 2.2.5
|
||||||
|
"if_link.h" ; for 2.16.0
|
||||||
|
"ioctl.h"
|
||||||
|
"kernel.h"
|
||||||
|
"limits.h"
|
||||||
|
"neighbour.h" ; for 2.16.0
|
||||||
|
"netlink.h" ; for 2.16.0
|
||||||
|
"param.h"
|
||||||
|
"prctl.h" ; for 2.16.0
|
||||||
|
"posix_types.h"
|
||||||
|
"rtnetlink.h" ; for 2.16.0
|
||||||
|
"socket.h"
|
||||||
|
"stddef.h"
|
||||||
|
"swab.h" ; for 2.2.5
|
||||||
|
"sysctl.h"
|
||||||
|
"sysinfo.h" ; for 2.2.5
|
||||||
|
"types.h"
|
||||||
|
"version.h" ; for 2.2.5
|
||||||
|
))
|
||||||
|
|
||||||
|
(copy-recursively (string-append kernel-headers "/include/asm")
|
||||||
|
(string-append incdir "/asm"))
|
||||||
|
(copy-recursively (string-append kernel-headers "/include/asm-generic")
|
||||||
|
(string-append incdir "/asm-generic"))
|
||||||
|
(copy-recursively (string-append kernel-headers "/include/linux/byteorder")
|
||||||
|
(string-append incdir "/linux/byteorder"))
|
||||||
|
#t))
|
||||||
|
|
||||||
(define (make-stripped-libc output libc kernel-headers)
|
(define (make-stripped-libc output libc kernel-headers)
|
||||||
"Copy to OUTPUT the subset of LIBC and KERNEL-HEADERS that is needed
|
"Copy to OUTPUT the subset of LIBC and KERNEL-HEADERS that is needed
|
||||||
when producing a bootstrap libc."
|
when producing a bootstrap libc."
|
||||||
|
@ -43,25 +92,10 @@ (define (copy-mach-headers output kernel-headers)
|
||||||
(string-append incdir "/mach"))
|
(string-append incdir "/mach"))
|
||||||
#t))
|
#t))
|
||||||
|
|
||||||
(define (copy-linux-headers output kernel-headers)
|
(define (copy-libc+linux-headers output kernel-headers)
|
||||||
(let* ((incdir (string-append output "/include")))
|
(let* ((incdir (string-append output "/include")))
|
||||||
(copy-recursively (string-append libc "/include") incdir)
|
(copy-recursively (string-append libc "/include") incdir)
|
||||||
|
(copy-linux-headers output kernel-headers)))
|
||||||
;; Copy some of the Linux-Libre headers that glibc headers
|
|
||||||
;; refer to.
|
|
||||||
(mkdir (string-append incdir "/linux"))
|
|
||||||
(for-each (lambda (file)
|
|
||||||
(install-file (string-append kernel-headers "/include/linux/" file)
|
|
||||||
(string-append incdir "/linux")))
|
|
||||||
'("limits.h" "errno.h" "socket.h" "kernel.h"
|
|
||||||
"sysctl.h" "param.h" "ioctl.h" "types.h"
|
|
||||||
"posix_types.h" "stddef.h" "falloc.h"))
|
|
||||||
|
|
||||||
(copy-recursively (string-append kernel-headers "/include/asm")
|
|
||||||
(string-append incdir "/asm"))
|
|
||||||
(copy-recursively (string-append kernel-headers "/include/asm-generic")
|
|
||||||
(string-append incdir "/asm-generic"))
|
|
||||||
#t))
|
|
||||||
|
|
||||||
(define %libc-object-files-rx "^(crt.*|ld.*|lib(c|m|dl|rt|pthread|nsl|\
|
(define %libc-object-files-rx "^(crt.*|ld.*|lib(c|m|dl|rt|pthread|nsl|\
|
||||||
util).*\\.so(\\..*)?|lib(machuser|hurduser).so.*|(libc(rt|)|libpthread)\
|
util).*\\.so(\\..*)?|lib(machuser|hurduser).so.*|(libc(rt|)|libpthread)\
|
||||||
|
@ -80,6 +114,6 @@ (define %libc-object-files-rx "^(crt.*|ld.*|lib(c|m|dl|rt|pthread|nsl|\
|
||||||
|
|
||||||
(if (directory-exists? (string-append kernel-headers "/include/mach"))
|
(if (directory-exists? (string-append kernel-headers "/include/mach"))
|
||||||
(copy-mach-headers output kernel-headers)
|
(copy-mach-headers output kernel-headers)
|
||||||
(copy-linux-headers output kernel-headers)))
|
(copy-libc+linux-headers output kernel-headers)))
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue