[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
15/19: gnu: glibc: Update to 2.35.
From: |
guix-commits |
Subject: |
15/19: gnu: glibc: Update to 2.35. |
Date: |
Thu, 8 Sep 2022 15:45:20 -0400 (EDT) |
mbakke pushed a commit to branch core-updates
in repository guix.
commit 25b30622b4a77cd4b2965b9d62fa310a22413d54
Author: zamfofex <zamfofex@twdb.moe>
AuthorDate: Tue Jul 19 16:13:01 2022 +0000
gnu: glibc: Update to 2.35.
* gnu/packages/base.scm (glibc): Update to 2.35.
[arguments]: Handle empty library files.
* gnu/packages/patches/glibc-hurd-clock_gettime_monotonic.patch: Adjust for
renamed file.
Signed-off-by: Marius Bakke <marius@gnu.org>
---
gnu/packages/base.scm | 34 ++++++++++++++++++++--
.../glibc-hurd-clock_gettime_monotonic.patch | 4 +--
2 files changed, 33 insertions(+), 5 deletions(-)
diff --git a/gnu/packages/base.scm b/gnu/packages/base.scm
index 382aa94b90..291f2e15f0 100644
--- a/gnu/packages/base.scm
+++ b/gnu/packages/base.scm
@@ -20,6 +20,7 @@
;;; Copyright © 2021 Maxime Devos <maximedevos@telenet.be>
;;; Copyright © 2021 Guillaume Le Vaillant <glv@posteo.net>
;;; Copyright © 2021 Maxim Cournoyer <maxim.cournoyer@gmail.com>
+;;; Copyright © 2022 zamfofex <zamfofex@twdb.moe>
;;;
;;; This file is part of GNU Guix.
;;;
@@ -709,13 +710,13 @@ the store.")
;; version 2.28, GNU/Hurd used a different glibc branch.
(package
(name "glibc")
- (version "2.33")
+ (version "2.35")
(source (origin
(method url-fetch)
(uri (string-append "mirror://gnu/glibc/glibc-" version ".tar.xz"))
(sha256
(base32
- "1zvp0qdfbdyqrzydz18d9zg3n5ygy8ps7cmny1bvsp8h1q05c99f"))
+ "0bpm1kfi09dxl4c6aanc5c9951fmf6ckkzay60cx7k37dcpp68si"))
(patches (search-patches "glibc-ldd-powerpc.patch"
"glibc-ldd-x86_64.patch"
"glibc-dl-cache.patch"
@@ -753,6 +754,7 @@ the store.")
#:validate-runpath? #f
#:modules ((ice-9 ftw)
+ (srfi srfi-1)
(srfi srfi-26)
(guix build utils)
(guix build gnu-build-system))
@@ -867,13 +869,34 @@ the store.")
(add-after 'install 'move-static-libs
(lambda* (#:key outputs #:allow-other-keys)
;; Move static libraries to the "static" output.
+ ;; Note: As of GNU libc 2.34, the contents of some ".a"
+ ;; files have been moved into "libc.so", and *both* empty
+ ;; ".so" and ".a" files have been introduced to avoid
+ ;; breaking existing executables and existing builds
+ ;; respectively. The intent of the seemingly redundant
+ ;; empty ".a" files is to avoid newly-compiled executables
+ ;; from having dependencies on the empty shared libraries,
+ ;; and as such, it is useful to have these ".a" files in
+ ;; OUT in addition to STATIC.
+
+ ;; XXX: It might be better to determine whether a static
+ ;; library is empty by some criterion (such as their file
+ ;; size equaling eight bytes) rather than hardcoding them
+ ;; by name.
+ (define empty-static-libraries
+ '("libpthread.a" "libdl.a" "libutil.a" "libanl.a"))
+ (define (empty-static-library? file)
+ (any (lambda (s)
+ (string=? file s)) empty-static-libraries))
+
(define (static-library? file)
;; Return true if FILE is a static library. The
;; "_nonshared.a" files are referred to by libc.so,
;; libpthread.so, etc., which are in fact linker
;; scripts.
(and (string-suffix? ".a" file)
- (not (string-contains file "_nonshared"))))
+ (not (string-contains file "_nonshared"))
+ (not (empty-static-library? file))))
(define (linker-script? file)
;; Guess whether FILE, a ".a" file, is actually a
@@ -884,6 +907,7 @@ the store.")
(let* ((out (assoc-ref outputs "out"))
(lib (string-append out "/lib"))
(files (scandir lib static-library?))
+ (empty (scandir lib empty-static-library?))
(static (assoc-ref outputs "static"))
(slib (string-append static "/lib")))
(mkdir-p slib)
@@ -891,6 +915,10 @@ the store.")
(rename-file (string-append lib "/" base)
(string-append slib "/" base)))
files)
+ (for-each (lambda (base)
+ (copy-file (string-append lib "/" base)
+ (string-append slib "/" base)))
+ empty)
;; Usually libm.a is a linker script so we need to
;; change the file names in there to refer to STATIC
diff --git a/gnu/packages/patches/glibc-hurd-clock_gettime_monotonic.patch
b/gnu/packages/patches/glibc-hurd-clock_gettime_monotonic.patch
index e31f99a1ce..b02215550d 100644
--- a/gnu/packages/patches/glibc-hurd-clock_gettime_monotonic.patch
+++ b/gnu/packages/patches/glibc-hurd-clock_gettime_monotonic.patch
@@ -67,8 +67,8 @@ index fcd79fd554..1dd02aa449 100644
diff --git a/sysdeps/pthread/timer_create.c b/sysdeps/pthread/timer_create.c
index 9d8a9ea8ae..3430582c09 100644
---- a/sysdeps/pthread/timer_create.c
-+++ b/sysdeps/pthread/timer_create.c
+--- a/rt/timer_create.c
++++ b/rt/timer_create.c
@@ -48,7 +48,7 @@ timer_create (clockid_t clock_id, struct sigevent *evp,
timer_t *timerid)
return -1;
}
- 07/19: gnu: xorgproto: Update to 2022.2., (continued)
- 07/19: gnu: xorgproto: Update to 2022.2., guix-commits, 2022/09/08
- 01/19: gnu: xz: Update to 5.2.6 [security fix]., guix-commits, 2022/09/08
- 18/19: gnu: glm: Fix build with GCC 11., guix-commits, 2022/09/08
- 17/19: gnu: Switch to GCC 11., guix-commits, 2022/09/08
- 04/19: gnu: gsasl: Update to 2.2.0., guix-commits, 2022/09/08
- 13/19: gnu: doxygen: Update to 1.9.5., guix-commits, 2022/09/08
- 03/19: gnu: gawk: Update to 5.2.0., guix-commits, 2022/09/08
- 05/19: gnu: ninja: Update to 1.11.1., guix-commits, 2022/09/08
- 06/19: gnu: libxslt: Update to 1.1.37., guix-commits, 2022/09/08
- 11/19: gnu: fontconfig: Update to 2.14.0., guix-commits, 2022/09/08
- 15/19: gnu: glibc: Update to 2.35.,
guix-commits <=
- 19/19: gnu: clang-runtime: Remove obsolete workaround., guix-commits, 2022/09/08
- 16/19: syscalls: Adjust for glibc 2.34 and later., guix-commits, 2022/09/08
- 09/19: gnu: iproute2: Update to 5.19.0., guix-commits, 2022/09/08
- 14/19: gnu: nss, nss-certs: Update to 3.82., guix-commits, 2022/09/08