From 0c4d1b3767066c04793168b3c8494dbc0542c1bcc12a45b71e8ea67078011f7d Mon Sep 17 00:00:00 2001 From: Andreas Schwab Date: Thu, 6 Aug 2015 09:55:23 +0000 Subject: [PATCH] Accepting request 320838 from home:Andreas_Schwab:Factory - Update to glibc 2.22 release. * Cache information can be queried via sysconf() function on s390 * A buffer overflow in gethostbyname_r and related functions performing DNS requests has been fixed. * The time zone file parser has been made more robust against crafted time zone files * A powerpc and powerpc64 optimization for TLS, similar to TLS descriptors for LD and GD on x86 and x86-64, has been implemented. * Character encoding and ctype tables were updated to Unicode 7.0.0 * Added vector math library named libmvec * A new fmemopen implementation has been added with the goal of POSIX compliance. * The header is deprecated, and will be removed in a future release. - Patches from upstream removed * htm-tabort.patch * o-tmpfile.patch * memcpy-chk-non-SSE2.patch * pthread-mutexattr-gettype-kind.patch * powerpc-software-sqrt.patch * static-tls-dtv-limit.patch * threaded-trim-threshold.patch * resolv-nameserver-handling.patch * nss-separate-state-getXXent.patch * aarch64-sigstksz.patch * heap-top-corruption.patch * pthread-join-deadlock.patch OBS-URL: https://build.opensuse.org/request/show/320838 OBS-URL: https://build.opensuse.org/package/show/Base:System/glibc?expand=0&rev=410 --- aarch64-sigstksz.patch | 62 -- ...r.gz.sign => crypt_blowfish-1.3.tar.gz.sig | 0 fix-locking-in-_IO_cleanup.patch | 4 +- glibc-2.21.tar.xz | 3 - glibc-2.22.tar.xz | 3 + glibc-2.22.tar.xz.sig | 11 + glibc-testsuite.changes | 31 + glibc-testsuite.spec | 55 +- glibc-utils.changes | 31 + glibc-utils.spec | 55 +- glibc.changes | 31 + glibc.keyring | 149 ++++ glibc.spec | 55 +- heap-top-corruption.patch | 51 -- htm-tabort.patch | 18 - memcpy-chk-non-SSE2.patch | 21 - nss-separate-state-getXXent.patch | 715 ------------------ o-tmpfile.patch | 29 - powerpc-software-sqrt.patch | 117 --- pthread-join-deadlock.patch | 187 ----- pthread-mutexattr-gettype-kind.patch | 111 --- resolv-nameserver-handling.patch | 426 ----------- static-tls-dtv-limit.patch | 641 ---------------- threaded-trim-threshold.patch | 224 ------ 24 files changed, 303 insertions(+), 2727 deletions(-) delete mode 100644 aarch64-sigstksz.patch rename crypt_blowfish-1.3.tar.gz.sign => crypt_blowfish-1.3.tar.gz.sig (100%) delete mode 100644 glibc-2.21.tar.xz create mode 100644 glibc-2.22.tar.xz create mode 100644 glibc-2.22.tar.xz.sig create mode 100644 glibc.keyring delete mode 100644 heap-top-corruption.patch delete mode 100644 htm-tabort.patch delete mode 100644 memcpy-chk-non-SSE2.patch delete mode 100644 nss-separate-state-getXXent.patch delete mode 100644 o-tmpfile.patch delete mode 100644 powerpc-software-sqrt.patch delete mode 100644 pthread-join-deadlock.patch delete mode 100644 pthread-mutexattr-gettype-kind.patch delete mode 100644 resolv-nameserver-handling.patch delete mode 100644 static-tls-dtv-limit.patch delete mode 100644 threaded-trim-threshold.patch diff --git a/aarch64-sigstksz.patch b/aarch64-sigstksz.patch deleted file mode 100644 index a405f0c..0000000 --- a/aarch64-sigstksz.patch +++ /dev/null @@ -1,62 +0,0 @@ - [BZ #16850] - * sysdeps/unix/sysv/linux/aarch64/bits/sigstack.h: New file. - -Index: glibc-2.21/sysdeps/unix/sysv/linux/aarch64/bits/sigstack.h -=================================================================== ---- /dev/null -+++ glibc-2.21/sysdeps/unix/sysv/linux/aarch64/bits/sigstack.h -@@ -0,0 +1,54 @@ -+/* sigstack, sigaltstack definitions. -+ Copyright (C) 2015 Free Software Foundation, Inc. -+ This file is part of the GNU C Library. -+ -+ The GNU C Library is free software; you can redistribute it and/or -+ modify it under the terms of the GNU Lesser General Public -+ License as published by the Free Software Foundation; either -+ version 2.1 of the License, or (at your option) any later version. -+ -+ The GNU C Library 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 -+ Lesser General Public License for more details. -+ -+ You should have received a copy of the GNU Lesser General Public -+ License along with the GNU C Library; if not, see -+ . */ -+ -+#ifndef _SIGNAL_H -+# error "Never include this file directly. Use instead" -+#endif -+ -+ -+/* Structure describing a signal stack (obsolete). */ -+struct sigstack -+ { -+ void *ss_sp; /* Signal stack pointer. */ -+ int ss_onstack; /* Nonzero if executing on this stack. */ -+ }; -+ -+ -+/* Possible values for `ss_flags.'. */ -+enum -+{ -+ SS_ONSTACK = 1, -+#define SS_ONSTACK SS_ONSTACK -+ SS_DISABLE -+#define SS_DISABLE SS_DISABLE -+}; -+ -+/* Minimum stack size for a signal handler. */ -+#define MINSIGSTKSZ 5120 -+ -+/* System default stack size. */ -+#define SIGSTKSZ 16384 -+ -+ -+/* Alternate, preferred interface. */ -+typedef struct sigaltstack -+ { -+ void *ss_sp; -+ int ss_flags; -+ size_t ss_size; -+ } stack_t; diff --git a/crypt_blowfish-1.3.tar.gz.sign b/crypt_blowfish-1.3.tar.gz.sig similarity index 100% rename from crypt_blowfish-1.3.tar.gz.sign rename to crypt_blowfish-1.3.tar.gz.sig diff --git a/fix-locking-in-_IO_cleanup.patch b/fix-locking-in-_IO_cleanup.patch index e47c1c2..4608ecc 100644 --- a/fix-locking-in-_IO_cleanup.patch +++ b/fix-locking-in-_IO_cleanup.patch @@ -5,7 +5,7 @@ Always do locking when accessing streams (_IO_flush_all_all_lockp): Delete. (_IO_flush_all): Replace with body of _IO_flush_all_all_lockp. Always do locking. - (_IO_unbuffer_write): Always do locking. + (_IO_unbuffer_all): Always do locking. (_IO_cleanup): Call _IO_flush_all instead of _IO_flush_all_lockp. * libio/libioP.h (_IO_flush_all_all_lockp): Remove declaration. @@ -155,7 +155,7 @@ index e0ce8cc..9def1d4 100644 #ifdef _IO_MTSAFE_IO @@ -947,6 +902,12 @@ static void - _IO_unbuffer_write (void) + _IO_unbuffer_all (void) { struct _IO_FILE *fp; + diff --git a/glibc-2.21.tar.xz b/glibc-2.21.tar.xz deleted file mode 100644 index e6aa0d9..0000000 --- a/glibc-2.21.tar.xz +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:aeeb362437965a5d3f40b151094ca79def04a115bd363fdd4a9a0c69482923b8 -size 12322092 diff --git a/glibc-2.22.tar.xz b/glibc-2.22.tar.xz new file mode 100644 index 0000000..cda9102 --- /dev/null +++ b/glibc-2.22.tar.xz @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:eb731406903befef1d8f878a46be75ef862b9056ab0cde1626d08a7a05328948 +size 12969072 diff --git a/glibc-2.22.tar.xz.sig b/glibc-2.22.tar.xz.sig new file mode 100644 index 0000000..7c558c4 --- /dev/null +++ b/glibc-2.22.tar.xz.sig @@ -0,0 +1,11 @@ +-----BEGIN PGP SIGNATURE----- +Version: GnuPG v1 + +iQEcBAABAgAGBQJVwbd/AAoJECXvCkNsKkr/51cIAKdzgyrQSN6EKFIIhj/SrxPz +RyxACKUITXw5F5BldwIx3pYqpF3V7eslWdkPcZ7Ztcc/9irgvoW+qARAxivciOn1 +N33GA8hLG+Nj4kYCI9DjdJTB01UsR1iEd02ISRB23rqnUvVOgioPubJKb6GJM9Ob +NyAn/rIR+hVXAb5SDci2lkiA604MWg2VdjPxt+dDc8lBCcBfkGHh1Sz+nVxyXWGR +v45+US9jwefFCgBLJvfUmqlgUYxmB6RxMcxrlNx4mTtobdsQM+rBOy84T12s3HMK +k1IPVd6YD7k4lOYjSpzzc/sj7Ib33/hfbGvwDFpjr85RgoGUgsyqnSxEL1U8Azw= +=C5JY +-----END PGP SIGNATURE----- diff --git a/glibc-testsuite.changes b/glibc-testsuite.changes index 87b8f63..a97824d 100644 --- a/glibc-testsuite.changes +++ b/glibc-testsuite.changes @@ -1,3 +1,34 @@ +------------------------------------------------------------------- +Wed Aug 5 09:35:41 UTC 2015 - schwab@suse.de + +- Update to glibc 2.22 release. + * Cache information can be queried via sysconf() function on s390 + * A buffer overflow in gethostbyname_r and related functions performing DNS + requests has been fixed. + * The time zone file parser has been made more robust against crafted time + zone files + * A powerpc and powerpc64 optimization for TLS, similar to TLS descriptors + for LD and GD on x86 and x86-64, has been implemented. + * Character encoding and ctype tables were updated to Unicode 7.0.0 + * Added vector math library named libmvec + * A new fmemopen implementation has been added with the goal of POSIX + compliance. + * The header is deprecated, and will be removed in a future + release. +- Patches from upstream removed + * htm-tabort.patch + * o-tmpfile.patch + * memcpy-chk-non-SSE2.patch + * pthread-mutexattr-gettype-kind.patch + * powerpc-software-sqrt.patch + * static-tls-dtv-limit.patch + * threaded-trim-threshold.patch + * resolv-nameserver-handling.patch + * nss-separate-state-getXXent.patch + * aarch64-sigstksz.patch + * heap-top-corruption.patch + * pthread-join-deadlock.patch + ------------------------------------------------------------------- Mon Jul 27 09:08:21 UTC 2015 - schwab@suse.de diff --git a/glibc-testsuite.spec b/glibc-testsuite.spec index fc14097..413e3b7 100644 --- a/glibc-testsuite.spec +++ b/glibc-testsuite.spec @@ -100,13 +100,15 @@ BuildRequires: gd-devel # 3.1 is the openSUSE 12.1 kernel %define enablekernel 3.0 -Version: 2.21 +Version: 2.22 Release: 0 -%define git_id 4e42b5b8f89f +%define git_id bbab82c25da9 Url: http://www.gnu.org/software/libc/libc.html BuildRoot: %{_tmppath}/%{name}-%{version}-build #Source: glibc-%{version}-%{git_id}.tar.xz Source: http://ftp.gnu.org/pub/gnu/glibc/glibc-%{version}.tar.xz +Source1: http://ftp.gnu.org/pub/gnu/glibc/glibc-%{version}.tar.xz.sig +Source2: glibc.keyring Source3: noversion.tar.bz2 Source4: manpages.tar.bz2 Source5: nsswitch.conf @@ -119,7 +121,7 @@ Source20: nscd.conf Source21: nscd.service # crypt_blowfish Source50: http://www.openwall.com/crypt/crypt_blowfish-%{crypt_bf_version}.tar.gz -Source51: http://www.openwall.com/crypt/crypt_blowfish-%{crypt_bf_version}.tar.gz.sign +Source51: http://www.openwall.com/crypt/crypt_blowfish-%{crypt_bf_version}.tar.gz.sig %if %{normal_build} # ngpt was used in 8.1 and SLES8 @@ -229,30 +231,6 @@ Patch306: glibc-fix-double-loopback.diff ### # Patches from upstream ### -# PATCH-FIX-UPSTREAM powerpc: Fix TABORT encoding for little endian -Patch1000: htm-tabort.patch -# PATCH-FIX-UPSTREAM Fix value of O_TMPFILE for architectures with non-default O_DIRECTORY (BZ #17912) -Patch1001: o-tmpfile.patch -# PATCH-FIX-UPSTREAM Fix __memcpy_chk on non-SSE2 CPUs (BZ #17949) -Patch1002: memcpy-chk-non-SSE2.patch -# PATCH-FIX-UPSTREAM Filter out PTHREAD_MUTEX_NO_ELISION_NP bit in pthread_mutexattr_gettype (BZ #15790) -Patch1003: pthread-mutexattr-gettype-kind.patch -# PATCH-FIX-UPSTREAM Fix powerpc software sqrt (BZ #17964, BZ #17967) -Patch1004: powerpc-software-sqrt.patch -# PATCH-FIX-UPSTREAM Fix DTV race, assert, DTV_SURPLUS Static TLS limit, and nptl_db garbage (bsc#919678, BZ #17090, BZ #17620, BZ #17621, BZ #17628) -Patch1005: static-tls-dtv-limit.patch -# PATCH-FIX-UPSTREAM Fix regression in threaded application malloc performance (bsc#915955, BZ #17195) -Patch1006: threaded-trim-threshold.patch -# PATCH-FIX-UPSTREAM Simplify handling of nameserver configuration in resolver -Patch1007: resolv-nameserver-handling.patch -# PATCH-FIX-UPSTREAM Separate internal state between getXXent and getXXbyYY NSS calls (bsc#918187, BZ #18007) -Patch1008: nss-separate-state-getXXent.patch -# PATCH-FIX-UPSTREAM aarch64: Increase MINSIGSTKSZ and SIGSTKSZ (BZ #16850) -Patch1009: aarch64-sigstksz.patch -# PATCH-FIX-UPSTREAM malloc: Do not corrupt the top of a threaded heap if top chunk is MINSIZE (BZ #18502) -Patch1010: heap-top-corruption.patch -# PATCH-FIX-UPSTREAM Use IE model for static variables in libc.so, libpthread.so and rtld (BZ #18457) -Patch1011: pthread-join-deadlock.patch ### # Patches awaiting upstream approval @@ -466,19 +444,6 @@ rm nscd/s-stamp %patch304 -p1 %patch306 -p1 -%patch1000 -p1 -%patch1001 -p1 -%patch1002 -p1 -%patch1003 -p1 -%patch1004 -p1 -%patch1005 -p1 -%patch1006 -p1 -%patch1007 -p1 -%patch1008 -p1 -%patch1009 -p1 -%patch1010 -p1 -%patch1011 -p1 - %patch2000 -p1 %patch2002 -p1 %patch2003 -p1 @@ -1144,6 +1109,10 @@ exit 0 /%{_lib}/libdl.so.2* /%{_lib}/libm-%{version}.so /%{_lib}/libm.so.6* +%ifarch x86_64 +/%{_lib}/libmvec-%{version}.so +/%{_lib}/libmvec.so.1 +%endif /%{_lib}/libnsl-%{version}.so /%{_lib}/libnsl.so.1 /%{_lib}/libnss_compat-%{version}.so @@ -1265,6 +1234,9 @@ exit 0 %{_libdir}/libowcrypt.a %{_libdir}/libdl.a %{_libdir}/libm.a +%ifarch x86_64 +%{_libdir}/libmvec.a +%endif %{_libdir}/libnsl.a %{_libdir}/libpthread.a %{_libdir}/libresolv.a @@ -1313,6 +1285,9 @@ exit 0 %{_libdir}/libBrokenLocale_p.a %{_libdir}/libanl_p.a %{_libdir}/libm_p.a +%ifarch x86_64 +%{_libdir}/libmvec_p.a +%endif %{_libdir}/libcrypt_p.a %{_libdir}/libowcrypt_p.a %{_libdir}/libpthread_p.a diff --git a/glibc-utils.changes b/glibc-utils.changes index 87b8f63..a97824d 100644 --- a/glibc-utils.changes +++ b/glibc-utils.changes @@ -1,3 +1,34 @@ +------------------------------------------------------------------- +Wed Aug 5 09:35:41 UTC 2015 - schwab@suse.de + +- Update to glibc 2.22 release. + * Cache information can be queried via sysconf() function on s390 + * A buffer overflow in gethostbyname_r and related functions performing DNS + requests has been fixed. + * The time zone file parser has been made more robust against crafted time + zone files + * A powerpc and powerpc64 optimization for TLS, similar to TLS descriptors + for LD and GD on x86 and x86-64, has been implemented. + * Character encoding and ctype tables were updated to Unicode 7.0.0 + * Added vector math library named libmvec + * A new fmemopen implementation has been added with the goal of POSIX + compliance. + * The header is deprecated, and will be removed in a future + release. +- Patches from upstream removed + * htm-tabort.patch + * o-tmpfile.patch + * memcpy-chk-non-SSE2.patch + * pthread-mutexattr-gettype-kind.patch + * powerpc-software-sqrt.patch + * static-tls-dtv-limit.patch + * threaded-trim-threshold.patch + * resolv-nameserver-handling.patch + * nss-separate-state-getXXent.patch + * aarch64-sigstksz.patch + * heap-top-corruption.patch + * pthread-join-deadlock.patch + ------------------------------------------------------------------- Mon Jul 27 09:08:21 UTC 2015 - schwab@suse.de diff --git a/glibc-utils.spec b/glibc-utils.spec index fcb2297..0e3efb4 100644 --- a/glibc-utils.spec +++ b/glibc-utils.spec @@ -99,13 +99,15 @@ BuildRequires: gd-devel # 3.1 is the openSUSE 12.1 kernel %define enablekernel 3.0 -Version: 2.21 +Version: 2.22 Release: 0 -%define git_id 4e42b5b8f89f +%define git_id bbab82c25da9 Url: http://www.gnu.org/software/libc/libc.html BuildRoot: %{_tmppath}/%{name}-%{version}-build #Source: glibc-%{version}-%{git_id}.tar.xz Source: http://ftp.gnu.org/pub/gnu/glibc/glibc-%{version}.tar.xz +Source1: http://ftp.gnu.org/pub/gnu/glibc/glibc-%{version}.tar.xz.sig +Source2: glibc.keyring Source3: noversion.tar.bz2 Source4: manpages.tar.bz2 Source5: nsswitch.conf @@ -118,7 +120,7 @@ Source20: nscd.conf Source21: nscd.service # crypt_blowfish Source50: http://www.openwall.com/crypt/crypt_blowfish-%{crypt_bf_version}.tar.gz -Source51: http://www.openwall.com/crypt/crypt_blowfish-%{crypt_bf_version}.tar.gz.sign +Source51: http://www.openwall.com/crypt/crypt_blowfish-%{crypt_bf_version}.tar.gz.sig %if %{normal_build} # ngpt was used in 8.1 and SLES8 @@ -228,30 +230,6 @@ Patch306: glibc-fix-double-loopback.diff ### # Patches from upstream ### -# PATCH-FIX-UPSTREAM powerpc: Fix TABORT encoding for little endian -Patch1000: htm-tabort.patch -# PATCH-FIX-UPSTREAM Fix value of O_TMPFILE for architectures with non-default O_DIRECTORY (BZ #17912) -Patch1001: o-tmpfile.patch -# PATCH-FIX-UPSTREAM Fix __memcpy_chk on non-SSE2 CPUs (BZ #17949) -Patch1002: memcpy-chk-non-SSE2.patch -# PATCH-FIX-UPSTREAM Filter out PTHREAD_MUTEX_NO_ELISION_NP bit in pthread_mutexattr_gettype (BZ #15790) -Patch1003: pthread-mutexattr-gettype-kind.patch -# PATCH-FIX-UPSTREAM Fix powerpc software sqrt (BZ #17964, BZ #17967) -Patch1004: powerpc-software-sqrt.patch -# PATCH-FIX-UPSTREAM Fix DTV race, assert, DTV_SURPLUS Static TLS limit, and nptl_db garbage (bsc#919678, BZ #17090, BZ #17620, BZ #17621, BZ #17628) -Patch1005: static-tls-dtv-limit.patch -# PATCH-FIX-UPSTREAM Fix regression in threaded application malloc performance (bsc#915955, BZ #17195) -Patch1006: threaded-trim-threshold.patch -# PATCH-FIX-UPSTREAM Simplify handling of nameserver configuration in resolver -Patch1007: resolv-nameserver-handling.patch -# PATCH-FIX-UPSTREAM Separate internal state between getXXent and getXXbyYY NSS calls (bsc#918187, BZ #18007) -Patch1008: nss-separate-state-getXXent.patch -# PATCH-FIX-UPSTREAM aarch64: Increase MINSIGSTKSZ and SIGSTKSZ (BZ #16850) -Patch1009: aarch64-sigstksz.patch -# PATCH-FIX-UPSTREAM malloc: Do not corrupt the top of a threaded heap if top chunk is MINSIZE (BZ #18502) -Patch1010: heap-top-corruption.patch -# PATCH-FIX-UPSTREAM Use IE model for static variables in libc.so, libpthread.so and rtld (BZ #18457) -Patch1011: pthread-join-deadlock.patch ### # Patches awaiting upstream approval @@ -466,19 +444,6 @@ rm nscd/s-stamp %patch304 -p1 %patch306 -p1 -%patch1000 -p1 -%patch1001 -p1 -%patch1002 -p1 -%patch1003 -p1 -%patch1004 -p1 -%patch1005 -p1 -%patch1006 -p1 -%patch1007 -p1 -%patch1008 -p1 -%patch1009 -p1 -%patch1010 -p1 -%patch1011 -p1 - %patch2000 -p1 %patch2002 -p1 %patch2003 -p1 @@ -1144,6 +1109,10 @@ exit 0 /%{_lib}/libdl.so.2* /%{_lib}/libm-%{version}.so /%{_lib}/libm.so.6* +%ifarch x86_64 +/%{_lib}/libmvec-%{version}.so +/%{_lib}/libmvec.so.1 +%endif /%{_lib}/libnsl-%{version}.so /%{_lib}/libnsl.so.1 /%{_lib}/libnss_compat-%{version}.so @@ -1265,6 +1234,9 @@ exit 0 %{_libdir}/libowcrypt.a %{_libdir}/libdl.a %{_libdir}/libm.a +%ifarch x86_64 +%{_libdir}/libmvec.a +%endif %{_libdir}/libnsl.a %{_libdir}/libpthread.a %{_libdir}/libresolv.a @@ -1313,6 +1285,9 @@ exit 0 %{_libdir}/libBrokenLocale_p.a %{_libdir}/libanl_p.a %{_libdir}/libm_p.a +%ifarch x86_64 +%{_libdir}/libmvec_p.a +%endif %{_libdir}/libcrypt_p.a %{_libdir}/libowcrypt_p.a %{_libdir}/libpthread_p.a diff --git a/glibc.changes b/glibc.changes index 87b8f63..a97824d 100644 --- a/glibc.changes +++ b/glibc.changes @@ -1,3 +1,34 @@ +------------------------------------------------------------------- +Wed Aug 5 09:35:41 UTC 2015 - schwab@suse.de + +- Update to glibc 2.22 release. + * Cache information can be queried via sysconf() function on s390 + * A buffer overflow in gethostbyname_r and related functions performing DNS + requests has been fixed. + * The time zone file parser has been made more robust against crafted time + zone files + * A powerpc and powerpc64 optimization for TLS, similar to TLS descriptors + for LD and GD on x86 and x86-64, has been implemented. + * Character encoding and ctype tables were updated to Unicode 7.0.0 + * Added vector math library named libmvec + * A new fmemopen implementation has been added with the goal of POSIX + compliance. + * The header is deprecated, and will be removed in a future + release. +- Patches from upstream removed + * htm-tabort.patch + * o-tmpfile.patch + * memcpy-chk-non-SSE2.patch + * pthread-mutexattr-gettype-kind.patch + * powerpc-software-sqrt.patch + * static-tls-dtv-limit.patch + * threaded-trim-threshold.patch + * resolv-nameserver-handling.patch + * nss-separate-state-getXXent.patch + * aarch64-sigstksz.patch + * heap-top-corruption.patch + * pthread-join-deadlock.patch + ------------------------------------------------------------------- Mon Jul 27 09:08:21 UTC 2015 - schwab@suse.de diff --git a/glibc.keyring b/glibc.keyring new file mode 100644 index 0000000..4de855c --- /dev/null +++ b/glibc.keyring @@ -0,0 +1,149 @@ +-----BEGIN PGP PUBLIC KEY BLOCK----- +Version: GnuPG v2 + +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 +5YGy0WPvg8z+Jq17TMKt8qd7CArYdg== +=n8pX +-----END PGP PUBLIC KEY BLOCK----- diff --git a/glibc.spec b/glibc.spec index 8486816..65f1c69 100644 --- a/glibc.spec +++ b/glibc.spec @@ -100,13 +100,15 @@ BuildRequires: gd-devel # 3.1 is the openSUSE 12.1 kernel %define enablekernel 3.0 -Version: 2.21 +Version: 2.22 Release: 0 -%define git_id 4e42b5b8f89f +%define git_id bbab82c25da9 Url: http://www.gnu.org/software/libc/libc.html BuildRoot: %{_tmppath}/%{name}-%{version}-build #Source: glibc-%{version}-%{git_id}.tar.xz Source: http://ftp.gnu.org/pub/gnu/glibc/glibc-%{version}.tar.xz +Source1: http://ftp.gnu.org/pub/gnu/glibc/glibc-%{version}.tar.xz.sig +Source2: glibc.keyring Source3: noversion.tar.bz2 Source4: manpages.tar.bz2 Source5: nsswitch.conf @@ -119,7 +121,7 @@ Source20: nscd.conf Source21: nscd.service # crypt_blowfish Source50: http://www.openwall.com/crypt/crypt_blowfish-%{crypt_bf_version}.tar.gz -Source51: http://www.openwall.com/crypt/crypt_blowfish-%{crypt_bf_version}.tar.gz.sign +Source51: http://www.openwall.com/crypt/crypt_blowfish-%{crypt_bf_version}.tar.gz.sig %if %{normal_build} # ngpt was used in 8.1 and SLES8 @@ -229,30 +231,6 @@ Patch306: glibc-fix-double-loopback.diff ### # Patches from upstream ### -# PATCH-FIX-UPSTREAM powerpc: Fix TABORT encoding for little endian -Patch1000: htm-tabort.patch -# PATCH-FIX-UPSTREAM Fix value of O_TMPFILE for architectures with non-default O_DIRECTORY (BZ #17912) -Patch1001: o-tmpfile.patch -# PATCH-FIX-UPSTREAM Fix __memcpy_chk on non-SSE2 CPUs (BZ #17949) -Patch1002: memcpy-chk-non-SSE2.patch -# PATCH-FIX-UPSTREAM Filter out PTHREAD_MUTEX_NO_ELISION_NP bit in pthread_mutexattr_gettype (BZ #15790) -Patch1003: pthread-mutexattr-gettype-kind.patch -# PATCH-FIX-UPSTREAM Fix powerpc software sqrt (BZ #17964, BZ #17967) -Patch1004: powerpc-software-sqrt.patch -# PATCH-FIX-UPSTREAM Fix DTV race, assert, DTV_SURPLUS Static TLS limit, and nptl_db garbage (bsc#919678, BZ #17090, BZ #17620, BZ #17621, BZ #17628) -Patch1005: static-tls-dtv-limit.patch -# PATCH-FIX-UPSTREAM Fix regression in threaded application malloc performance (bsc#915955, BZ #17195) -Patch1006: threaded-trim-threshold.patch -# PATCH-FIX-UPSTREAM Simplify handling of nameserver configuration in resolver -Patch1007: resolv-nameserver-handling.patch -# PATCH-FIX-UPSTREAM Separate internal state between getXXent and getXXbyYY NSS calls (bsc#918187, BZ #18007) -Patch1008: nss-separate-state-getXXent.patch -# PATCH-FIX-UPSTREAM aarch64: Increase MINSIGSTKSZ and SIGSTKSZ (BZ #16850) -Patch1009: aarch64-sigstksz.patch -# PATCH-FIX-UPSTREAM malloc: Do not corrupt the top of a threaded heap if top chunk is MINSIZE (BZ #18502) -Patch1010: heap-top-corruption.patch -# PATCH-FIX-UPSTREAM Use IE model for static variables in libc.so, libpthread.so and rtld (BZ #18457) -Patch1011: pthread-join-deadlock.patch ### # Patches awaiting upstream approval @@ -466,19 +444,6 @@ rm nscd/s-stamp %patch304 -p1 %patch306 -p1 -%patch1000 -p1 -%patch1001 -p1 -%patch1002 -p1 -%patch1003 -p1 -%patch1004 -p1 -%patch1005 -p1 -%patch1006 -p1 -%patch1007 -p1 -%patch1008 -p1 -%patch1009 -p1 -%patch1010 -p1 -%patch1011 -p1 - %patch2000 -p1 %patch2002 -p1 %patch2003 -p1 @@ -1144,6 +1109,10 @@ exit 0 /%{_lib}/libdl.so.2* /%{_lib}/libm-%{version}.so /%{_lib}/libm.so.6* +%ifarch x86_64 +/%{_lib}/libmvec-%{version}.so +/%{_lib}/libmvec.so.1 +%endif /%{_lib}/libnsl-%{version}.so /%{_lib}/libnsl.so.1 /%{_lib}/libnss_compat-%{version}.so @@ -1265,6 +1234,9 @@ exit 0 %{_libdir}/libowcrypt.a %{_libdir}/libdl.a %{_libdir}/libm.a +%ifarch x86_64 +%{_libdir}/libmvec.a +%endif %{_libdir}/libnsl.a %{_libdir}/libpthread.a %{_libdir}/libresolv.a @@ -1313,6 +1285,9 @@ exit 0 %{_libdir}/libBrokenLocale_p.a %{_libdir}/libanl_p.a %{_libdir}/libm_p.a +%ifarch x86_64 +%{_libdir}/libmvec_p.a +%endif %{_libdir}/libcrypt_p.a %{_libdir}/libowcrypt_p.a %{_libdir}/libpthread_p.a diff --git a/heap-top-corruption.patch b/heap-top-corruption.patch deleted file mode 100644 index 9b000a7..0000000 --- a/heap-top-corruption.patch +++ /dev/null @@ -1,51 +0,0 @@ -From: Mel Gorman -Subject: [PATCH] [v3] malloc: Do not corrupt the top of a threaded heap if - top chunk is MINSIZE [BZ #18502] -Date: Mon, 8 Jun 2015 13:36:13 +0100 - -mksquashfs was reported in openSUSE to be causing segmentation faults when -creating installation images. Testing showed that mksquashfs sometimes -failed and could be reproduced within 10 attempts. The core dump looked -like the heap top was corrupted and was pointing to an unmapped area. In -other cases, this has been due to an application corrupting glibc structures -but mksquashfs appears to be fine in this regard. - -The problem is that heap_trim is "growing" the top into unmapped space. -If the top chunk == MINSIZE then top_area is -1 and this check does not -behave as expected due to a signed/unsigned comparison - - if (top_area <= pad) - return 0; - -The next calculation extra = ALIGN_DOWN(top_area - pad, pagesz) calculates -extra as a negative number which also is unnoticed due to a signed/unsigned -comparison. We then call shrink_heap(heap, negative_number) which crashes -later. This patch adds a simple check against MINSIZE to make sure extra -does not become negative. It adds a cast to hint to the reader that this -is a signed vs unsigned issue. - -Without the patch, mksquash fails within 10 attempts. With it applied, it -completed 1000 times without error. The standard test suite "make check" -showed no changes in the summary of test results. - -2015-06-08 Mel Gorman - - [BZ #18502] - * malloc/arena.c: Avoid corruption of the top of heaps for threads ---- - malloc/arena.c | 2 +- - 1 file changed, 1 insertion(+), 1 deletion(-) - -Index: glibc-2.21/malloc/arena.c -=================================================================== ---- glibc-2.21.orig/malloc/arena.c -+++ glibc-2.21/malloc/arena.c -@@ -699,7 +699,7 @@ heap_trim (heap_info *heap, size_t pad) - by preserving the top pad and at least a page. */ - top_size = chunksize (top_chunk); - top_area = top_size - MINSIZE - 1; -- if (top_area <= pad) -+ if (top_area < 0 || (size_t) top_area <= pad) - return 0; - - extra = ALIGN_DOWN(top_area - pad, pagesz); diff --git a/htm-tabort.patch b/htm-tabort.patch deleted file mode 100644 index 209b334..0000000 --- a/htm-tabort.patch +++ /dev/null @@ -1,18 +0,0 @@ -2015-02-12 Adhemerval Zanella - - * sysdeps/unix/sysv/linux/powerpc/htm.h [TABORT]: Fix encoding for - little endian. - -Index: glibc-2.21/sysdeps/unix/sysv/linux/powerpc/htm.h -=================================================================== ---- glibc-2.21.orig/sysdeps/unix/sysv/linux/powerpc/htm.h -+++ glibc-2.21/sysdeps/unix/sysv/linux/powerpc/htm.h -@@ -60,7 +60,7 @@ - #define TBEGIN ".long 0x7c00051d" - #define TEND ".long 0x7c00055d" - #if __BYTE_ORDER == __LITTLE_ENDIAN --# define TABORT ".byte 0x1d,0x07,%1,0x1d" -+# define TABORT ".byte 0x1d,0x07,%1,0x7c" - #else - # define TABORT ".byte 0x7c,%1,0x07,0x1d" - #endif diff --git a/memcpy-chk-non-SSE2.patch b/memcpy-chk-non-SSE2.patch deleted file mode 100644 index 810481e..0000000 --- a/memcpy-chk-non-SSE2.patch +++ /dev/null @@ -1,21 +0,0 @@ -2015-02-10 Evangelos Foutras - - [BZ #17949] - * sysdeps/i386/i686/multiarch/mempcpy_chk.S: Fix position of - jump label. - -Index: glibc-2.21/sysdeps/i386/i686/multiarch/mempcpy_chk.S -=================================================================== ---- glibc-2.21.orig/sysdeps/i386/i686/multiarch/mempcpy_chk.S -+++ glibc-2.21/sysdeps/i386/i686/multiarch/mempcpy_chk.S -@@ -36,8 +36,8 @@ ENTRY(__mempcpy_chk) - cmpl $0, KIND_OFFSET+__cpu_features@GOTOFF(%ebx) - jne 1f - call __init_cpu_features -- leal __mempcpy_chk_ia32@GOTOFF(%ebx), %eax --1: testl $bit_SSE2, CPUID_OFFSET+index_SSE2+__cpu_features@GOTOFF(%ebx) -+1: leal __mempcpy_chk_ia32@GOTOFF(%ebx), %eax -+ testl $bit_SSE2, CPUID_OFFSET+index_SSE2+__cpu_features@GOTOFF(%ebx) - jz 2f - leal __mempcpy_chk_sse2_unaligned@GOTOFF(%ebx), %eax - testl $bit_Fast_Unaligned_Load, FEATURE_OFFSET+index_Fast_Unaligned_Load+__cpu_features@GOTOFF(%ebx) diff --git a/nss-separate-state-getXXent.patch b/nss-separate-state-getXXent.patch deleted file mode 100644 index 10b4dea..0000000 --- a/nss-separate-state-getXXent.patch +++ /dev/null @@ -1,715 +0,0 @@ - [BZ #18007] - * nis/nss_compat/compat-grp.c (internal_endgrent): Add parameter - needent, call nss_endgrent only if non-zero. - (_nss_compat_endgrent): Pass non-zero. - (_nss_compat_getgrnam_r, _nss_compat_getgrgid_r): Pass zero. - * nis/nss_compat/compat-pwd.c (internal_endpwent): Add parameter - needent, call nss_endpwent only if non-zero. - (_nss_compat_endpwent): Pass non-zero. - (_nss_compat_getpwnam_r, _nss_compat_getpwuid_r): Pass zero. - * nis/nss_compat/compat-spwd.c (internal_setspent): Add parameter - needent, call nss_setspent only if non-zero. - (_nss_compat_setspent): Pass non-zero. - (internal_endspent): Add parameter needent, call nss_endspent only - if non-zero. - (_nss_compat_endspent, _nss_compat_getspent_r): Pass non-zero. - (_nss_compat_getspnam_r): Pass zero. - * nss/nss_files/files-XXX.c (position, last_use, keep_stream): - Remove. All uses removed. - (internal_setent): Remove parameter stayopen, add parameter - stream. Use it instead of global variable. - (CONCAT(_nss_files_set,ENTNAME)): Pass global stream. - (internal_endent, internal_getent): Add parameter stream. Use it - instead of global variable. - (CONCAT(_nss_files_end,ENTNAME)) - (CONCAT(_nss_files_get,ENTNAME_r)): Pass global stream. - (_nss_files_get##name##_r): Pass local stream. Remove locking. - * nss/nss_files/files-alias.c (position, last_use): Remove. All - uses removed. - (internal_setent, internal_endent): Add parameter stream. Use it - instead of global variable. - (_nss_files_setaliasent, _nss_files_endaliasent): Pass global - stream. - (get_next_alias): Add parameter stream. - (_nss_files_getaliasent_r): Pass global stream. - (_nss_files_getaliasbyname_r): Pass local stream. Remove locking. - * nss/nss_files/files-hosts.c (_nss_files_gethostbyname3_r) - (_nss_files_gethostbyname4_r): Pass local stream to - internal_setent, internal_getent and internal_endent. Remove - locking. - -Index: glibc-2.21/nis/nss_compat/compat-grp.c -=================================================================== ---- glibc-2.21.orig/nis/nss_compat/compat-grp.c -+++ glibc-2.21/nis/nss_compat/compat-grp.c -@@ -192,9 +192,9 @@ _nss_compat_setgrent (int stayopen) - - - static enum nss_status --internal_endgrent (ent_t *ent) -+internal_endgrent (ent_t *ent, int needent) - { -- if (nss_endgrent) -+ if (needent && nss_endgrent) - nss_endgrent (); - - if (ent->stream != NULL) -@@ -222,7 +222,7 @@ _nss_compat_endgrent (void) - - __libc_lock_lock (lock); - -- result = internal_endgrent (&ext_ent); -+ result = internal_endgrent (&ext_ent, 1); - - __libc_lock_unlock (lock); - -@@ -532,7 +532,7 @@ _nss_compat_getgrnam_r (const char *name - if (result == NSS_STATUS_SUCCESS) - result = internal_getgrnam_r (name, grp, &ent, buffer, buflen, errnop); - -- internal_endgrent (&ent); -+ internal_endgrent (&ent, 0); - - return result; - } -@@ -661,7 +661,7 @@ _nss_compat_getgrgid_r (gid_t gid, struc - if (result == NSS_STATUS_SUCCESS) - result = internal_getgrgid_r (gid, grp, &ent, buffer, buflen, errnop); - -- internal_endgrent (&ent); -+ internal_endgrent (&ent, 0); - - return result; - } -Index: glibc-2.21/nis/nss_compat/compat-pwd.c -=================================================================== ---- glibc-2.21.orig/nis/nss_compat/compat-pwd.c -+++ glibc-2.21/nis/nss_compat/compat-pwd.c -@@ -309,9 +309,9 @@ _nss_compat_setpwent (int stayopen) - - - static enum nss_status --internal_endpwent (ent_t *ent) -+internal_endpwent (ent_t *ent, int needent) - { -- if (nss_endpwent) -+ if (needent && nss_endpwent) - nss_endpwent (); - - if (ent->stream != NULL) -@@ -346,7 +346,7 @@ _nss_compat_endpwent (void) - - __libc_lock_lock (lock); - -- result = internal_endpwent (&ext_ent); -+ result = internal_endpwent (&ext_ent, 1); - - __libc_lock_unlock (lock); - -@@ -871,7 +871,7 @@ _nss_compat_getpwnam_r (const char *name - if (result == NSS_STATUS_SUCCESS) - result = internal_getpwnam_r (name, pwd, &ent, buffer, buflen, errnop); - -- internal_endpwent (&ent); -+ internal_endpwent (&ent, 0); - - return result; - } -@@ -1110,7 +1110,7 @@ _nss_compat_getpwuid_r (uid_t uid, struc - if (result == NSS_STATUS_SUCCESS) - result = internal_getpwuid_r (uid, pwd, &ent, buffer, buflen, errnop); - -- internal_endpwent (&ent); -+ internal_endpwent (&ent, 0); - - return result; - } -Index: glibc-2.21/nis/nss_compat/compat-spwd.c -=================================================================== ---- glibc-2.21.orig/nis/nss_compat/compat-spwd.c -+++ glibc-2.21/nis/nss_compat/compat-spwd.c -@@ -169,7 +169,7 @@ copy_spwd_changes (struct spwd *dest, st - } - - static enum nss_status --internal_setspent (ent_t *ent, int stayopen) -+internal_setspent (ent_t *ent, int stayopen, int needent) - { - enum nss_status status = NSS_STATUS_SUCCESS; - -@@ -239,7 +239,7 @@ internal_setspent (ent_t *ent, int stayo - - give_spwd_free (&ent->pwd); - -- if (status == NSS_STATUS_SUCCESS && nss_setspent) -+ if (needent && status == NSS_STATUS_SUCCESS && nss_setspent) - ent->setent_status = nss_setspent (stayopen); - - return status; -@@ -256,7 +256,7 @@ _nss_compat_setspent (int stayopen) - if (ni == NULL) - init_nss_interface (); - -- result = internal_setspent (&ext_ent, stayopen); -+ result = internal_setspent (&ext_ent, stayopen, 1); - - __libc_lock_unlock (lock); - -@@ -265,9 +265,9 @@ _nss_compat_setspent (int stayopen) - - - static enum nss_status --internal_endspent (ent_t *ent) -+internal_endspent (ent_t *ent, int needent) - { -- if (nss_endspent) -+ if (needent && nss_endspent) - nss_endspent (); - - if (ent->stream != NULL) -@@ -303,7 +303,7 @@ _nss_compat_endspent (void) - - __libc_lock_lock (lock); - -- result = internal_endspent (&ext_ent); -+ result = internal_endspent (&ext_ent, 1); - - __libc_lock_unlock (lock); - -@@ -658,7 +658,7 @@ _nss_compat_getspent_r (struct spwd *pwd - init_nss_interface (); - - if (ext_ent.stream == NULL) -- result = internal_setspent (&ext_ent, 1); -+ result = internal_setspent (&ext_ent, 1, 1); - - if (result == NSS_STATUS_SUCCESS) - result = internal_getspent_r (pwd, &ext_ent, buffer, buflen, errnop); -@@ -830,12 +830,12 @@ _nss_compat_getspnam_r (const char *name - - __libc_lock_unlock (lock); - -- result = internal_setspent (&ent, 0); -+ result = internal_setspent (&ent, 0, 0); - - if (result == NSS_STATUS_SUCCESS) - result = internal_getspnam_r (name, pwd, &ent, buffer, buflen, errnop); - -- internal_endspent (&ent); -+ internal_endspent (&ent, 0); - - return result; - } -Index: glibc-2.21/nss/nss_files/files-XXX.c -=================================================================== ---- glibc-2.21.orig/nss/nss_files/files-XXX.c -+++ glibc-2.21/nss/nss_files/files-XXX.c -@@ -63,21 +63,18 @@ __libc_lock_define_initialized (static, - /* Maintenance of the shared stream open on the database file. */ - - static FILE *stream; --static fpos_t position; --static enum { nouse, getent, getby } last_use; --static int keep_stream; - - /* Open database file if not already opened. */ - static enum nss_status --internal_setent (int stayopen) -+internal_setent (FILE **stream) - { - enum nss_status status = NSS_STATUS_SUCCESS; - -- if (stream == NULL) -+ if (*stream == NULL) - { -- stream = fopen (DATAFILE, "rce"); -+ *stream = fopen (DATAFILE, "rce"); - -- if (stream == NULL) -+ if (*stream == NULL) - status = errno == EAGAIN ? NSS_STATUS_TRYAGAIN : NSS_STATUS_UNAVAIL; - else - { -@@ -90,7 +87,7 @@ internal_setent (int stayopen) - int result; - int flags; - -- result = flags = fcntl (fileno (stream), F_GETFD, 0); -+ result = flags = fcntl (fileno (*stream), F_GETFD, 0); - if (result >= 0) - { - # ifdef O_CLOEXEC -@@ -100,15 +97,15 @@ internal_setent (int stayopen) - # endif - { - flags |= FD_CLOEXEC; -- result = fcntl (fileno (stream), F_SETFD, flags); -+ result = fcntl (fileno (*stream), F_SETFD, flags); - } - } - if (result < 0) - { - /* Something went wrong. Close the stream and return a - failure. */ -- fclose (stream); -- stream = NULL; -+ fclose (*stream); -+ *stream = NULL; - status = NSS_STATUS_UNAVAIL; - } - } -@@ -116,11 +113,7 @@ internal_setent (int stayopen) - } - } - else -- rewind (stream); -- -- /* Remember STAYOPEN flag. */ -- if (stream != NULL) -- keep_stream |= stayopen; -+ rewind (*stream); - - return status; - } -@@ -134,16 +127,7 @@ CONCAT(_nss_files_set,ENTNAME) (int stay - - __libc_lock_lock (lock); - -- status = internal_setent (stayopen); -- -- if (status == NSS_STATUS_SUCCESS && fgetpos (stream, &position) < 0) -- { -- fclose (stream); -- stream = NULL; -- status = NSS_STATUS_UNAVAIL; -- } -- -- last_use = getent; -+ status = internal_setent (&stream); - - __libc_lock_unlock (lock); - -@@ -153,12 +137,12 @@ CONCAT(_nss_files_set,ENTNAME) (int stay - - /* Close the database file. */ - static void --internal_endent (void) -+internal_endent (FILE **stream) - { -- if (stream != NULL) -+ if (*stream != NULL) - { -- fclose (stream); -- stream = NULL; -+ fclose (*stream); -+ *stream = NULL; - } - } - -@@ -169,10 +153,7 @@ CONCAT(_nss_files_end,ENTNAME) (void) - { - __libc_lock_lock (lock); - -- internal_endent (); -- -- /* Reset STAYOPEN flag. */ -- keep_stream = 0; -+ internal_endent (&stream); - - __libc_lock_unlock (lock); - -@@ -227,7 +208,7 @@ get_contents (char *linebuf, size_t len, - - /* Parsing the database file into `struct STRUCTURE' data structures. */ - static enum nss_status --internal_getent (struct STRUCTURE *result, -+internal_getent (FILE *stream, struct STRUCTURE *result, - char *buffer, size_t buflen, int *errnop H_ERRNO_PROTO - EXTRA_ARGS_DECL) - { -@@ -300,45 +281,14 @@ CONCAT(_nss_files_get,ENTNAME_r) (struct - { - int save_errno = errno; - -- status = internal_setent (0); -+ status = internal_setent (&stream); - - __set_errno (save_errno); -- -- if (status == NSS_STATUS_SUCCESS && fgetpos (stream, &position) < 0) -- { -- fclose (stream); -- stream = NULL; -- status = NSS_STATUS_UNAVAIL; -- } - } - - if (status == NSS_STATUS_SUCCESS) -- { -- /* If the last use was not by the getent function we need the -- position the stream. */ -- if (last_use != getent) -- { -- if (fsetpos (stream, &position) < 0) -- status = NSS_STATUS_UNAVAIL; -- else -- last_use = getent; -- } -- -- if (status == NSS_STATUS_SUCCESS) -- { -- status = internal_getent (result, buffer, buflen, errnop -- H_ERRNO_ARG EXTRA_ARGS_VALUE); -- -- /* Remember this position if we were successful. If the -- operation failed we give the user a chance to repeat the -- operation (perhaps the buffer was too small). */ -- if (status == NSS_STATUS_SUCCESS) -- fgetpos (stream, &position); -- else -- /* We must make sure we reposition the stream the next call. */ -- last_use = nouse; -- } -- } -+ status = internal_getent (stream, result, buffer, buflen, errnop -+ H_ERRNO_ARG EXTRA_ARGS_VALUE); - - __libc_lock_unlock (lock); - -@@ -364,27 +314,20 @@ _nss_files_get##name##_r (proto, - size_t buflen, int *errnop H_ERRNO_PROTO) \ - { \ - enum nss_status status; \ -+ FILE *stream = NULL; \ - \ -- __libc_lock_lock (lock); \ -- \ -- /* Reset file pointer to beginning or open file. */ \ -- status = internal_setent (keep_stream); \ -+ /* Open file. */ \ -+ status = internal_setent (&stream); \ - \ - if (status == NSS_STATUS_SUCCESS) \ - { \ -- /* Tell getent function that we have repositioned the file pointer. */ \ -- last_use = getby; \ -- \ -- while ((status = internal_getent (result, buffer, buflen, errnop \ -+ while ((status = internal_getent (stream, result, buffer, buflen, errnop \ - H_ERRNO_ARG EXTRA_ARGS_VALUE)) \ - == NSS_STATUS_SUCCESS) \ - { break_if_match } \ - \ -- if (! keep_stream) \ -- internal_endent (); \ -+ internal_endent (&stream); \ - } \ - \ -- __libc_lock_unlock (lock); \ -- \ - return status; \ - } -Index: glibc-2.21/nss/nss_files/files-alias.c -=================================================================== ---- glibc-2.21.orig/nss/nss_files/files-alias.c -+++ glibc-2.21/nss/nss_files/files-alias.c -@@ -36,20 +36,18 @@ __libc_lock_define_initialized (static, - /* Maintenance of the shared stream open on the database file. */ - - static FILE *stream; --static fpos_t position; --static enum { nouse, getent, getby } last_use; - - - static enum nss_status --internal_setent (void) -+internal_setent (FILE **stream) - { - enum nss_status status = NSS_STATUS_SUCCESS; - -- if (stream == NULL) -+ if (*stream == NULL) - { -- stream = fopen ("/etc/aliases", "rce"); -+ *stream = fopen ("/etc/aliases", "rce"); - -- if (stream == NULL) -+ if (*stream == NULL) - status = errno == EAGAIN ? NSS_STATUS_TRYAGAIN : NSS_STATUS_UNAVAIL; - else - { -@@ -62,7 +60,7 @@ internal_setent (void) - int result; - int flags; - -- result = flags = fcntl (fileno (stream), F_GETFD, 0); -+ result = flags = fcntl (fileno (*stream), F_GETFD, 0); - if (result >= 0) - { - # ifdef O_CLOEXEC -@@ -72,14 +70,14 @@ internal_setent (void) - # endif - { - flags |= FD_CLOEXEC; -- result = fcntl (fileno (stream), F_SETFD, flags); -+ result = fcntl (fileno (*stream), F_SETFD, flags); - } - } - if (result < 0) - { - /* Something went wrong. Close the stream and return a - failure. */ -- fclose (stream); -+ fclose (*stream); - stream = NULL; - status = NSS_STATUS_UNAVAIL; - } -@@ -88,7 +86,7 @@ internal_setent (void) - } - } - else -- rewind (stream); -+ rewind (*stream); - - return status; - } -@@ -102,16 +100,7 @@ _nss_files_setaliasent (void) - - __libc_lock_lock (lock); - -- status = internal_setent (); -- -- if (status == NSS_STATUS_SUCCESS && fgetpos (stream, &position) < 0) -- { -- fclose (stream); -- stream = NULL; -- status = NSS_STATUS_UNAVAIL; -- } -- -- last_use = getent; -+ status = internal_setent (&stream); - - __libc_lock_unlock (lock); - -@@ -121,12 +110,12 @@ _nss_files_setaliasent (void) - - /* Close the database file. */ - static void --internal_endent (void) -+internal_endent (FILE **stream) - { -- if (stream != NULL) -+ if (*stream != NULL) - { -- fclose (stream); -- stream = NULL; -+ fclose (*stream); -+ *stream = NULL; - } - } - -@@ -137,7 +126,7 @@ _nss_files_endaliasent (void) - { - __libc_lock_lock (lock); - -- internal_endent (); -+ internal_endent (&stream); - - __libc_lock_unlock (lock); - -@@ -146,7 +135,7 @@ _nss_files_endaliasent (void) - - /* Parsing the database file into `struct aliasent' data structures. */ - static enum nss_status --get_next_alias (const char *match, struct aliasent *result, -+get_next_alias (FILE *stream, const char *match, struct aliasent *result, - char *buffer, size_t buflen, int *errnop) - { - enum nss_status status = NSS_STATUS_NOTFOUND; -@@ -397,35 +386,16 @@ _nss_files_getaliasent_r (struct aliasen - - /* Be prepared that the set*ent function was not called before. */ - if (stream == NULL) -- status = internal_setent (); -+ status = internal_setent (&stream); - - if (status == NSS_STATUS_SUCCESS) - { -- /* If the last use was not by the getent function we need the -- position the stream. */ -- if (last_use != getent) -- { -- if (fsetpos (stream, &position) < 0) -- status = NSS_STATUS_UNAVAIL; -- else -- last_use = getent; -- } -- -- if (status == NSS_STATUS_SUCCESS) -- { -- result->alias_local = 1; -+ result->alias_local = 1; - -- /* Read lines until we get a definite result. */ -- do -- status = get_next_alias (NULL, result, buffer, buflen, errnop); -- while (status == NSS_STATUS_RETURN); -- -- /* If we successfully read an entry remember this position. */ -- if (status == NSS_STATUS_SUCCESS) -- fgetpos (stream, &position); -- else -- last_use = nouse; -- } -+ /* Read lines until we get a definite result. */ -+ do -+ status = get_next_alias (stream, NULL, result, buffer, buflen, errnop); -+ while (status == NSS_STATUS_RETURN); - } - - __libc_lock_unlock (lock); -@@ -440,6 +410,7 @@ _nss_files_getaliasbyname_r (const char - { - /* Return next entry in host file. */ - enum nss_status status = NSS_STATUS_SUCCESS; -+ FILE *stream = NULL; - - if (name == NULL) - { -@@ -447,11 +418,8 @@ _nss_files_getaliasbyname_r (const char - return NSS_STATUS_UNAVAIL; - } - -- __libc_lock_lock (lock); -- -- /* Open the stream or rest it. */ -- status = internal_setent (); -- last_use = getby; -+ /* Open the stream. */ -+ status = internal_setent (&stream); - - if (status == NSS_STATUS_SUCCESS) - { -@@ -459,13 +427,11 @@ _nss_files_getaliasbyname_r (const char - - /* Read lines until we get a definite result. */ - do -- status = get_next_alias (name, result, buffer, buflen, errnop); -+ status = get_next_alias (stream, name, result, buffer, buflen, errnop); - while (status == NSS_STATUS_RETURN); - } - -- internal_endent (); -- -- __libc_lock_unlock (lock); -+ internal_endent (&stream); - - return status; - } -Index: glibc-2.21/nss/nss_files/files-hosts.c -=================================================================== ---- glibc-2.21.orig/nss/nss_files/files-hosts.c -+++ glibc-2.21/nss/nss_files/files-hosts.c -@@ -115,14 +115,13 @@ _nss_files_gethostbyname3_r (const char - char *buffer, size_t buflen, int *errnop, - int *herrnop, int32_t *ttlp, char **canonp) - { -+ FILE *stream = NULL; - uintptr_t pad = -(uintptr_t) buffer % __alignof__ (struct hostent_data); - buffer += pad; - buflen = buflen > pad ? buflen - pad : 0; - -- __libc_lock_lock (lock); -- -- /* Reset file pointer to beginning or open file. */ -- enum nss_status status = internal_setent (keep_stream); -+ /* Open file. */ -+ enum nss_status status = internal_setent (&stream); - - if (status == NSS_STATUS_SUCCESS) - { -@@ -130,10 +129,7 @@ _nss_files_gethostbyname3_r (const char - addresses to IPv6 addresses really the right thing to do? */ - int flags = ((_res.options & RES_USE_INET6) ? AI_V4MAPPED : 0); - -- /* Tell getent function that we have repositioned the file pointer. */ -- last_use = getby; -- -- while ((status = internal_getent (result, buffer, buflen, errnop, -+ while ((status = internal_getent (stream, result, buffer, buflen, errnop, - herrnop, af, flags)) - == NSS_STATUS_SUCCESS) - { -@@ -160,7 +156,7 @@ _nss_files_gethostbyname3_r (const char - bufferend = (char *) &result->h_aliases[naliases + 1]; - - again: -- while ((status = internal_getent (&tmp_result_buf, tmp_buffer, -+ while ((status = internal_getent (stream, &tmp_result_buf, tmp_buffer, - tmp_buflen, errnop, herrnop, af, - flags)) - == NSS_STATUS_SUCCESS) -@@ -336,15 +332,12 @@ _nss_files_gethostbyname3_r (const char - free (tmp_buffer); - } - -- if (! keep_stream) -- internal_endent (); -+ internal_endent (&stream); - } - - if (canonp && status == NSS_STATUS_SUCCESS) - *canonp = result->h_name; - -- __libc_lock_unlock (lock); -- - return status; - } - -@@ -373,16 +366,13 @@ _nss_files_gethostbyname4_r (const char - char *buffer, size_t buflen, int *errnop, - int *herrnop, int32_t *ttlp) - { -- __libc_lock_lock (lock); -+ FILE *stream = NULL; - -- /* Reset file pointer to beginning or open file. */ -- enum nss_status status = internal_setent (keep_stream); -+ /* Open file. */ -+ enum nss_status status = internal_setent (&stream); - - if (status == NSS_STATUS_SUCCESS) - { -- /* Tell getent function that we have repositioned the file pointer. */ -- last_use = getby; -- - bool any = false; - bool got_canon = false; - while (1) -@@ -394,7 +384,7 @@ _nss_files_gethostbyname4_r (const char - buflen = buflen > pad ? buflen - pad : 0; - - struct hostent result; -- status = internal_getent (&result, buffer, buflen, errnop, -+ status = internal_getent (stream, &result, buffer, buflen, errnop, - herrnop, AF_UNSPEC, 0); - if (status != NSS_STATUS_SUCCESS) - break; -@@ -470,8 +460,7 @@ _nss_files_gethostbyname4_r (const char - status = NSS_STATUS_SUCCESS; - } - -- if (! keep_stream) -- internal_endent (); -+ internal_endent (&stream); - } - else if (status == NSS_STATUS_TRYAGAIN) - { -@@ -484,7 +473,5 @@ _nss_files_gethostbyname4_r (const char - *herrnop = NO_DATA; - } - -- __libc_lock_unlock (lock); -- - return status; - } diff --git a/o-tmpfile.patch b/o-tmpfile.patch deleted file mode 100644 index b8e357e..0000000 --- a/o-tmpfile.patch +++ /dev/null @@ -1,29 +0,0 @@ -From 127ffc81a8565bebd134c0f43afba5ae7997bf97 Mon Sep 17 00:00:00 2001 -From: Andreas Schwab -Date: Sun, 1 Feb 2015 14:04:15 +0100 -Subject: [PATCH] Fix value of O_TMPFILE for architectures with non-default - O_DIRECTORY - - [BZ #17912] - * sysdeps/unix/sysv/linux/bits/fcntl-linux.h (__O_TMPFILE): Define - in terms of __O_DIRECTORY. ---- - sysdeps/unix/sysv/linux/bits/fcntl-linux.h | 2 +- - 1 file changed, 1 insertion(+), 1 deletion(-) - -diff --git a/sysdeps/unix/sysv/linux/bits/fcntl-linux.h b/sysdeps/unix/sysv/linux/bits/fcntl-linux.h -index 3d28c84..d2baeb3 100644 ---- a/sysdeps/unix/sysv/linux/bits/fcntl-linux.h -+++ b/sysdeps/unix/sysv/linux/bits/fcntl-linux.h -@@ -97,7 +97,7 @@ - # define __O_DSYNC 010000 - #endif - #ifndef __O_TMPFILE --# define __O_TMPFILE 020200000 -+# define __O_TMPFILE (020000000 | __O_DIRECTORY) - #endif - - #ifndef F_GETLK --- -2.2.2 - diff --git a/powerpc-software-sqrt.patch b/powerpc-software-sqrt.patch deleted file mode 100644 index d86b73f..0000000 --- a/powerpc-software-sqrt.patch +++ /dev/null @@ -1,117 +0,0 @@ -2015-02-13 Joseph Myers - - [BZ #17967] - * sysdeps/powerpc/fpu/e_sqrtf.c (__slow_ieee754_sqrtf): Use - __builtin_fmaf instead of relying on contraction of a * b + c. - -2015-02-12 Joseph Myers - - [BZ #17964] - * sysdeps/powerpc/fpu/e_sqrt.c (__slow_ieee754_sqrt): Use - __builtin_fma instead of relying on contraction of a * b + c. - -Index: glibc-2.21/sysdeps/powerpc/fpu/e_sqrt.c -=================================================================== ---- glibc-2.21.orig/sysdeps/powerpc/fpu/e_sqrt.c -+++ glibc-2.21/sysdeps/powerpc/fpu/e_sqrt.c -@@ -99,38 +99,41 @@ __slow_ieee754_sqrt (double x) - /* Here we have three Newton-Raphson iterations each of a - division and a square root and the remainder of the - argument reduction, all interleaved. */ -- sd = -(sg * sg - sx); -+ sd = -__builtin_fma (sg, sg, -sx); - fsgi = (xi0 + 0x40000000) >> 1 & 0x7ff00000; - sy2 = sy + sy; -- sg = sy * sd + sg; /* 16-bit approximation to sqrt(sx). */ -+ sg = __builtin_fma (sy, sd, sg); /* 16-bit approximation to -+ sqrt(sx). */ - - /* schedule the INSERT_WORDS (fsg, fsgi, 0) to get separation - between the store and the load. */ - INSERT_WORDS (fsg, fsgi, 0); - iw_u.parts.msw = fsgi; - iw_u.parts.lsw = (0); -- e = -(sy * sg - almost_half); -- sd = -(sg * sg - sx); -+ e = -__builtin_fma (sy, sg, -almost_half); -+ sd = -__builtin_fma (sg, sg, -sx); - if ((xi0 & 0x7ff00000) == 0) - goto denorm; -- sy = sy + e * sy2; -- sg = sg + sy * sd; /* 32-bit approximation to sqrt(sx). */ -+ sy = __builtin_fma (e, sy2, sy); -+ sg = __builtin_fma (sy, sd, sg); /* 32-bit approximation to -+ sqrt(sx). */ - sy2 = sy + sy; - /* complete the INSERT_WORDS (fsg, fsgi, 0) operation. */ - fsg = iw_u.value; -- e = -(sy * sg - almost_half); -- sd = -(sg * sg - sx); -- sy = sy + e * sy2; -+ e = -__builtin_fma (sy, sg, -almost_half); -+ sd = -__builtin_fma (sg, sg, -sx); -+ sy = __builtin_fma (e, sy2, sy); - shx = sx * fsg; -- sg = sg + sy * sd; /* 64-bit approximation to sqrt(sx), -- but perhaps rounded incorrectly. */ -+ sg = __builtin_fma (sy, sd, sg); /* 64-bit approximation to -+ sqrt(sx), but perhaps -+ rounded incorrectly. */ - sy2 = sy + sy; - g = sg * fsg; -- e = -(sy * sg - almost_half); -- d = -(g * sg - shx); -- sy = sy + e * sy2; -+ e = -__builtin_fma (sy, sg, -almost_half); -+ d = -__builtin_fma (g, sg, -shx); -+ sy = __builtin_fma (e, sy2, sy); - fesetenv_register (fe); -- return g + sy * d; -+ return __builtin_fma (sy, d, g); - denorm: - /* For denormalised numbers, we normalise, calculate the - square root, and return an adjusted result. */ -Index: glibc-2.21/sysdeps/powerpc/fpu/e_sqrtf.c -=================================================================== ---- glibc-2.21.orig/sysdeps/powerpc/fpu/e_sqrtf.c -+++ glibc-2.21/sysdeps/powerpc/fpu/e_sqrtf.c -@@ -87,26 +87,28 @@ __slow_ieee754_sqrtf (float x) - /* Here we have three Newton-Raphson iterations each of a - division and a square root and the remainder of the - argument reduction, all interleaved. */ -- sd = -(sg * sg - sx); -+ sd = -__builtin_fmaf (sg, sg, -sx); - fsgi = (xi + 0x40000000) >> 1 & 0x7f800000; - sy2 = sy + sy; -- sg = sy * sd + sg; /* 16-bit approximation to sqrt(sx). */ -- e = -(sy * sg - almost_half); -+ sg = __builtin_fmaf (sy, sd, sg); /* 16-bit approximation to -+ sqrt(sx). */ -+ e = -__builtin_fmaf (sy, sg, -almost_half); - SET_FLOAT_WORD (fsg, fsgi); -- sd = -(sg * sg - sx); -- sy = sy + e * sy2; -+ sd = -__builtin_fmaf (sg, sg, -sx); -+ sy = __builtin_fmaf (e, sy2, sy); - if ((xi & 0x7f800000) == 0) - goto denorm; - shx = sx * fsg; -- sg = sg + sy * sd; /* 32-bit approximation to sqrt(sx), -- but perhaps rounded incorrectly. */ -+ sg = __builtin_fmaf (sy, sd, sg); /* 32-bit approximation to -+ sqrt(sx), but perhaps -+ rounded incorrectly. */ - sy2 = sy + sy; - g = sg * fsg; -- e = -(sy * sg - almost_half); -- d = -(g * sg - shx); -- sy = sy + e * sy2; -+ e = -__builtin_fmaf (sy, sg, -almost_half); -+ d = -__builtin_fmaf (g, sg, -shx); -+ sy = __builtin_fmaf (e, sy2, sy); - fesetenv_register (fe); -- return g + sy * d; -+ return __builtin_fmaf (sy, d, g); - denorm: - /* For denormalised numbers, we normalise, calculate the - square root, and return an adjusted result. */ diff --git a/pthread-join-deadlock.patch b/pthread-join-deadlock.patch deleted file mode 100644 index e3f6299..0000000 --- a/pthread-join-deadlock.patch +++ /dev/null @@ -1,187 +0,0 @@ -2015-07-24 Siddhesh Poyarekar - - [BZ #18457] - * nptl/Makefile (tests): New test case tst-join7. - (modules-names): New test case module tst-join7mod. - * nptl/tst-join7.c: New file. - * nptl/tst-join7mod.c: New file. - * Makeconfig (tls-model): Pass -ftls-model=initial-exec for - all translation units in libc.so, libpthread.so and rtld. - -Index: glibc-2.21/Makeconfig -=================================================================== ---- glibc-2.21.orig/Makeconfig -+++ glibc-2.21/Makeconfig -@@ -832,6 +832,10 @@ in-module = $(subst -,_,$(firstword $(li - $(libof-$(@F)) \ - libc)) - -+# Build ld.so, libc.so and libpthread.so with -ftls-model=initial-exec -+tls-model = $(if $(filter libpthread rtld \ -+ libc,$(in-module)),-ftls-model=initial-exec,) -+ - module-cppflags-real = -include $(common-objpfx)libc-modules.h \ - -DMODULE_NAME=$(in-module) - -@@ -855,7 +859,7 @@ CPPFLAGS = $(config-extra-cppflags) $(CP - override CFLAGS = -std=gnu99 $(gnu89-inline-CFLAGS) $(config-extra-cflags) \ - $(filter-out %frame-pointer,$(+cflags)) $(+gccwarn-c) \ - $(sysdep-CFLAGS) $(CFLAGS-$(suffix $@)) $(CFLAGS-$(. */ -+ -+#include -+ -+/* When one dynamically loads a module, which spawns a thread to perform some -+ activities, it could be possible that TLS storage is accessed for the first -+ time in that thread. This results in an allocation request within the -+ thread, which could result in an attempt to take the rtld load_lock. This -+ is a problem because it would then deadlock with the dlopen (which owns the -+ lock), if the main thread is waiting for the spawned thread to exit. We can -+ at least ensure that this problem does not occur due to accesses within -+ libc.so, by marking TLS variables within libc.so as IE. The problem of an -+ arbitrary variable being accessed and constructed within such a thread still -+ exists but this test case does not verify that. */ -+ -+int -+do_test (void) -+{ -+ void *f = dlopen ("tst-join7mod.so", RTLD_NOW | RTLD_GLOBAL); -+ if (f) -+ dlclose (f); -+ else -+ return 1; -+ -+ return 0; -+} -+ -+#define TEST_FUNCTION do_test () -+#include "../test-skeleton.c" -Index: glibc-2.21/nptl/tst-join7mod.c -=================================================================== ---- /dev/null -+++ glibc-2.21/nptl/tst-join7mod.c -@@ -0,0 +1,62 @@ -+/* Verify that TLS access in separate thread in a dlopened library does not -+ deadlock - the module. -+ Copyright (C) 2015 Free Software Foundation, Inc. -+ This file is part of the GNU C Library. -+ -+ The GNU C Library is free software; you can redistribute it and/or -+ modify it under the terms of the GNU Lesser General Public -+ License as published by the Free Software Foundation; either -+ version 2.1 of the License, or (at your option) any later version. -+ -+ The GNU C Library 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 -+ Lesser General Public License for more details. -+ -+ You should have received a copy of the GNU Lesser General Public -+ License along with the GNU C Library; if not, see -+ . */ -+ -+#include -+#include -+#include -+#include -+ -+static pthread_t th; -+static int running = 1; -+ -+static void * -+test_run (void *p) -+{ -+ while (atomic_load_relaxed (&running)) -+ printf ("Test running\n"); -+ printf ("Test finished\n"); -+ return NULL; -+} -+ -+static void __attribute__ ((constructor)) -+do_init (void) -+{ -+ int ret = pthread_create (&th, NULL, test_run, NULL); -+ -+ if (ret != 0) -+ { -+ printf ("failed to create thread: %s (%d)\n", strerror (ret), ret); -+ exit (1); -+ } -+} -+ -+static void __attribute__ ((destructor)) -+do_end (void) -+{ -+ atomic_store_relaxed (&running, 0); -+ int ret = pthread_join (th, NULL); -+ -+ if (ret != 0) -+ { -+ printf ("pthread_join: %s(%d)\n", strerror (ret), ret); -+ exit (1); -+ } -+ -+ printf ("Thread joined\n"); -+} diff --git a/pthread-mutexattr-gettype-kind.patch b/pthread-mutexattr-gettype-kind.patch deleted file mode 100644 index 0af5da6..0000000 --- a/pthread-mutexattr-gettype-kind.patch +++ /dev/null @@ -1,111 +0,0 @@ -From 867dbf6ba31c0a0f5c0366f9ed71b0afc3727a23 Mon Sep 17 00:00:00 2001 -From: Andreas Schwab -Date: Mon, 11 Aug 2014 11:18:26 +0200 -Subject: [PATCH] Filter out PTHREAD_MUTEX_NO_ELISION_NP bit in - pthread_mutexattr_gettype (BZ #15790) - - [BZ #15790] - * nptl/pthread_mutexattr_gettype.c (pthread_mutexattr_gettype): - Filter out PTHREAD_MUTEX_NO_ELISION_NP from value returned in - kind. - * nptl/Makefile (tests): Add tst-pthread-mutexattr. - * nptl/tst-pthread-mutexattr.c: New file. ---- - nptl/Makefile | 2 +- - nptl/pthread_mutexattr_gettype.c | 3 +- - nptl/tst-pthread-mutexattr.c | 60 ++++++++++++++++++++++++++++++++++++++++ - 3 files changed, 63 insertions(+), 2 deletions(-) - create mode 100644 nptl/tst-pthread-mutexattr.c - -Index: glibc-2.19/nptl/Makefile -=================================================================== ---- glibc-2.19.orig/nptl/Makefile -+++ glibc-2.19/nptl/Makefile -@@ -253,7 +253,7 @@ tests = tst-typesizes \ - tst-exit1 tst-exit2 tst-exit3 \ - tst-stdio1 tst-stdio2 \ - tst-stack1 tst-stack2 tst-stack3 tst-stack4 tst-pthread-getattr \ -- tst-pthread-attr-affinity \ -+ tst-pthread-attr-affinity tst-pthread-mutexattr \ - tst-unload \ - tst-dlsym1 \ - tst-sysconf \ -Index: glibc-2.19/nptl/pthread_mutexattr_gettype.c -=================================================================== ---- glibc-2.19.orig/nptl/pthread_mutexattr_gettype.c -+++ glibc-2.19/nptl/pthread_mutexattr_gettype.c -@@ -28,7 +28,8 @@ pthread_mutexattr_gettype (attr, kind) - - iattr = (const struct pthread_mutexattr *) attr; - -- *kind = iattr->mutexkind & ~PTHREAD_MUTEXATTR_FLAG_BITS; -+ *kind = (iattr->mutexkind & ~PTHREAD_MUTEXATTR_FLAG_BITS -+ & ~PTHREAD_MUTEX_NO_ELISION_NP); - - return 0; - } -Index: glibc-2.19/nptl/tst-pthread-mutexattr.c -=================================================================== ---- /dev/null -+++ glibc-2.19/nptl/tst-pthread-mutexattr.c -@@ -0,0 +1,60 @@ -+/* Make sure that pthread_mutexattr_gettype returns a valid kind. -+ -+ Copyright (C) 2014 Free Software Foundation, Inc. -+ This file is part of the GNU C Library. -+ -+ The GNU C Library is free software; you can redistribute it and/or -+ modify it under the terms of the GNU Lesser General Public -+ License as published by the Free Software Foundation; either -+ version 2.1 of the License, or (at your option) any later version. -+ -+ The GNU C Library 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 -+ Lesser General Public License for more details. -+ -+ You should have received a copy of the GNU Lesser General Public -+ License along with the GNU C Library; if not, see -+ . */ -+ -+#include -+#include -+#include -+ -+static int -+do_test (void) -+{ -+ pthread_mutexattr_t attr; -+ int kind; -+ int error; -+ -+ error = pthread_mutexattr_init (&attr); -+ if (error) -+ { -+ printf ("pthread_mutexattr_init: %s\n", strerror (error)); -+ return 1; -+ } -+ error = pthread_mutexattr_settype (&attr, PTHREAD_MUTEX_DEFAULT); -+ if (error) -+ { -+ printf ("pthread_mutexattr_settype (1): %s\n", strerror (error)); -+ return 1; -+ } -+ error = pthread_mutexattr_gettype (&attr, &kind); -+ if (error) -+ { -+ printf ("pthread_mutexattr_gettype: %s\n", strerror (error)); -+ return 1; -+ } -+ error = pthread_mutexattr_settype (&attr, kind); -+ if (error) -+ { -+ printf ("pthread_mutexattr_settype (2): %s\n", strerror (error)); -+ return 1; -+ } -+ return 0; -+} -+ -+ -+#define TEST_FUNCTION do_test () -+#include "../test-skeleton.c" diff --git a/resolv-nameserver-handling.patch b/resolv-nameserver-handling.patch deleted file mode 100644 index 9bc0e78..0000000 --- a/resolv-nameserver-handling.patch +++ /dev/null @@ -1,426 +0,0 @@ -From 6c07233f12e00b9cf66fb5d4a9b7ddb897590912 Mon Sep 17 00:00:00 2001 -From: Andreas Schwab -Date: Thu, 19 Feb 2015 15:52:08 +0100 -Subject: [PATCH] Simplify handling of nameserver configuration in resolver - - [BZ #13028] - [BZ #17053] - * resolv/res_init.c (__res_vinit): Remove use of ext.nsmap. - * resolv/res_send.c (__libc_res_nsend): Likewise. - (get_nsaddr): New function. - (res_ourserver_p, send_vc, reopen): Use it instead of accessing - statp directly. ---- - resolv/res_init.c | 47 +++++----------- - resolv/res_send.c | 164 +++++++++++++++++++++++------------------------------- - 2 files changed, 84 insertions(+), 127 deletions(-) - -diff --git a/resolv/res_init.c b/resolv/res_init.c -index 553ba12..66561ff 100644 ---- a/resolv/res_init.c -+++ b/resolv/res_init.c -@@ -153,10 +153,8 @@ __res_vinit(res_state statp, int preinit) { - char *cp, **pp; - int n; - char buf[BUFSIZ]; -- int nserv = 0; /* number of IPv4 nameservers read from file */ --#ifdef _LIBC -- int nservall = 0; /* number of (IPv4 + IPV6) nameservers read from file */ --#endif -+ int nserv = 0; /* number of nameservers read from file */ -+ int have_serv6 = 0; - int haveenv = 0; - int havesearch = 0; - #ifdef RESOLVSORT -@@ -184,15 +182,9 @@ __res_vinit(res_state statp, int preinit) { - statp->_flags = 0; - statp->qhook = NULL; - statp->rhook = NULL; -- statp->_u._ext.nsinit = 0; - statp->_u._ext.nscount = 0; --#ifdef _LIBC -- statp->_u._ext.nscount6 = 0; -- for (n = 0; n < MAXNS; n++) { -- statp->_u._ext.nsaddrs[n] = NULL; -- statp->_u._ext.nsmap[n] = MAXNS; -- } --#endif -+ for (n = 0; n < MAXNS; n++) -+ statp->_u._ext.nsaddrs[n] = NULL; - - /* Allow user to override the local domain definition */ - if ((cp = getenv("LOCALDOMAIN")) != NULL) { -@@ -296,11 +288,7 @@ __res_vinit(res_state statp, int preinit) { - continue; - } - /* read nameservers to query */ --#ifdef _LIBC -- if (MATCH(buf, "nameserver") && nservall < MAXNS) { --#else - if (MATCH(buf, "nameserver") && nserv < MAXNS) { --#endif - struct in_addr a; - - cp = buf + sizeof("nameserver") - 1; -@@ -308,13 +296,12 @@ __res_vinit(res_state statp, int preinit) { - cp++; - if ((*cp != '\0') && (*cp != '\n') - && __inet_aton(cp, &a)) { -- statp->nsaddr_list[nservall].sin_addr = a; -- statp->nsaddr_list[nservall].sin_family = AF_INET; -- statp->nsaddr_list[nservall].sin_port = -+ statp->nsaddr_list[nserv].sin_addr = a; -+ statp->nsaddr_list[nserv].sin_family = AF_INET; -+ statp->nsaddr_list[nserv].sin_port = - htons(NAMESERVER_PORT); - nserv++; - #ifdef _LIBC -- nservall++; - } else { - struct in6_addr a6; - char *el; -@@ -356,10 +343,11 @@ __res_vinit(res_state statp, int preinit) { - } - } - -- statp->_u._ext.nsaddrs[nservall] = sa6; -- statp->_u._ext.nssocks[nservall] = -1; -- statp->_u._ext.nsmap[nservall] = MAXNS + 1; -- nservall++; -+ statp->nsaddr_list[nserv].sin_family = 0; -+ statp->_u._ext.nsaddrs[nserv] = sa6; -+ statp->_u._ext.nssocks[nserv] = -1; -+ have_serv6 = 1; -+ nserv++; - } - } - #endif -@@ -414,10 +402,9 @@ __res_vinit(res_state statp, int preinit) { - continue; - } - } -- statp->nscount = nservall; -+ statp->nscount = nserv; - #ifdef _LIBC -- if (nservall - nserv > 0) { -- statp->_u._ext.nscount6 = nservall - nserv; -+ if (have_serv6) { - /* We try IPv6 servers again. */ - statp->ipv6_unavail = false; - } -@@ -606,11 +593,7 @@ __res_iclose(res_state statp, bool free_addr) { - statp->_vcsock = -1; - statp->_flags &= ~(RES_F_VC | RES_F_CONN); - } --#ifdef _LIBC -- for (ns = 0; ns < MAXNS; ns++) --#else - for (ns = 0; ns < statp->_u._ext.nscount; ns++) --#endif - if (statp->_u._ext.nsaddrs[ns]) { - if (statp->_u._ext.nssocks[ns] != -1) { - close_not_cancel_no_status(statp->_u._ext.nssocks[ns]); -@@ -621,8 +604,6 @@ __res_iclose(res_state statp, bool free_addr) { - statp->_u._ext.nsaddrs[ns] = NULL; - } - } -- if (free_addr) -- statp->_u._ext.nsinit = 0; - } - libc_hidden_def (__res_iclose) - -diff --git a/resolv/res_send.c b/resolv/res_send.c -index c35fb66..5e53cc2 100644 ---- a/resolv/res_send.c -+++ b/resolv/res_send.c -@@ -184,6 +184,7 @@ evNowTime(struct timespec *res) { - - /* Forward. */ - -+static struct sockaddr *get_nsaddr (res_state, int); - static int send_vc(res_state, const u_char *, int, - const u_char *, int, - u_char **, int *, int *, int, u_char **, -@@ -221,20 +222,21 @@ res_ourserver_p(const res_state statp, const struct sockaddr_in6 *inp) - in_port_t port = in4p->sin_port; - in_addr_t addr = in4p->sin_addr.s_addr; - -- for (ns = 0; ns < MAXNS; ns++) { -+ for (ns = 0; ns < statp->nscount; ns++) { - const struct sockaddr_in *srv = -- (struct sockaddr_in *)EXT(statp).nsaddrs[ns]; -+ (struct sockaddr_in *) get_nsaddr (statp, ns); - -- if ((srv != NULL) && (srv->sin_family == AF_INET) && -+ if ((srv->sin_family == AF_INET) && - (srv->sin_port == port) && - (srv->sin_addr.s_addr == INADDR_ANY || - srv->sin_addr.s_addr == addr)) - return (1); - } - } else if (inp->sin6_family == AF_INET6) { -- for (ns = 0; ns < MAXNS; ns++) { -- const struct sockaddr_in6 *srv = EXT(statp).nsaddrs[ns]; -- if ((srv != NULL) && (srv->sin6_family == AF_INET6) && -+ for (ns = 0; ns < statp->nscount; ns++) { -+ const struct sockaddr_in6 *srv -+ = (struct sockaddr_in6 *) get_nsaddr (statp, ns); -+ if ((srv->sin6_family == AF_INET6) && - (srv->sin6_port == inp->sin6_port) && - !(memcmp(&srv->sin6_addr, &in6addr_any, - sizeof (struct in6_addr)) && -@@ -384,80 +386,48 @@ __libc_res_nsend(res_state statp, const u_char *buf, int buflen, - * If the ns_addr_list in the resolver context has changed, then - * invalidate our cached copy and the associated timing data. - */ -- if (EXT(statp).nsinit) { -+ if (EXT(statp).nscount != 0) { - int needclose = 0; - - if (EXT(statp).nscount != statp->nscount) - needclose++; - else -- for (ns = 0; ns < MAXNS; ns++) { -- unsigned int map = EXT(statp).nsmap[ns]; -- if (map < MAXNS -+ for (ns = 0; ns < statp->nscount; ns++) { -+ if (statp->nsaddr_list[ns].sin_family != 0 - && !sock_eq((struct sockaddr_in6 *) -- &statp->nsaddr_list[map], -+ &statp->nsaddr_list[ns], - EXT(statp).nsaddrs[ns])) - { - needclose++; - break; - } - } -- if (needclose) -+ if (needclose) { - __res_iclose(statp, false); -+ EXT(statp).nscount = 0; -+ } - } - - /* - * Maybe initialize our private copy of the ns_addr_list. - */ -- if (EXT(statp).nsinit == 0) { -- unsigned char map[MAXNS]; -- -- memset (map, MAXNS, sizeof (map)); -- for (n = 0; n < MAXNS; n++) { -- ns = EXT(statp).nsmap[n]; -- if (ns < statp->nscount) -- map[ns] = n; -- else if (ns < MAXNS) { -- free(EXT(statp).nsaddrs[n]); -- EXT(statp).nsaddrs[n] = NULL; -- EXT(statp).nsmap[n] = MAXNS; -- } -- } -- n = statp->nscount; -- if (statp->nscount > EXT(statp).nscount) -- for (n = EXT(statp).nscount, ns = 0; -- n < statp->nscount; n++) { -- while (ns < MAXNS -- && EXT(statp).nsmap[ns] != MAXNS) -- ns++; -- if (ns == MAXNS) -- break; -- /* NS never exceeds MAXNS, but gcc 4.9 somehow -- does not see this. */ -- DIAG_PUSH_NEEDS_COMMENT; -- DIAG_IGNORE_NEEDS_COMMENT (4.9, -- "-Warray-bounds"); -- EXT(statp).nsmap[ns] = n; -- DIAG_POP_NEEDS_COMMENT; -- map[n] = ns++; -- } -- EXT(statp).nscount = n; -- for (ns = 0; ns < EXT(statp).nscount; ns++) { -- n = map[ns]; -- if (EXT(statp).nsaddrs[n] == NULL) -- EXT(statp).nsaddrs[n] = -+ if (EXT(statp).nscount == 0) { -+ for (ns = 0; ns < statp->nscount; ns++) { -+ EXT(statp).nssocks[ns] = -1; -+ if (statp->nsaddr_list[ns].sin_family == 0) -+ continue; -+ if (EXT(statp).nsaddrs[ns] == NULL) -+ EXT(statp).nsaddrs[ns] = - malloc(sizeof (struct sockaddr_in6)); -- if (EXT(statp).nsaddrs[n] != NULL) { -- memset (mempcpy(EXT(statp).nsaddrs[n], -+ if (EXT(statp).nsaddrs[ns] != NULL) -+ memset (mempcpy(EXT(statp).nsaddrs[ns], - &statp->nsaddr_list[ns], - sizeof (struct sockaddr_in)), - '\0', - sizeof (struct sockaddr_in6) - - sizeof (struct sockaddr_in)); -- EXT(statp).nssocks[n] = -1; -- n++; -- } - } -- EXT(statp).nsinit = 1; -+ EXT(statp).nscount = statp->nscount; - } - - /* -@@ -466,44 +436,37 @@ __libc_res_nsend(res_state statp, const u_char *buf, int buflen, - */ - if (__builtin_expect ((statp->options & RES_ROTATE) != 0, 0) && - (statp->options & RES_BLAST) == 0) { -- struct sockaddr_in6 *ina; -- unsigned int map; -- -- n = 0; -- while (n < MAXNS && EXT(statp).nsmap[n] == MAXNS) -- n++; -- if (n < MAXNS) { -- ina = EXT(statp).nsaddrs[n]; -- map = EXT(statp).nsmap[n]; -- for (;;) { -- ns = n + 1; -- while (ns < MAXNS -- && EXT(statp).nsmap[ns] == MAXNS) -- ns++; -- if (ns == MAXNS) -- break; -- EXT(statp).nsaddrs[n] = EXT(statp).nsaddrs[ns]; -- EXT(statp).nsmap[n] = EXT(statp).nsmap[ns]; -- n = ns; -- } -- EXT(statp).nsaddrs[n] = ina; -- EXT(statp).nsmap[n] = map; -+ struct sockaddr_in ina; -+ struct sockaddr_in6 *inp; -+ int lastns = statp->nscount - 1; -+ int fd; -+ -+ inp = EXT(statp).nsaddrs[0]; -+ ina = statp->nsaddr_list[0]; -+ fd = EXT(statp).nssocks[0]; -+ for (ns = 0; ns < lastns; ns++) { -+ EXT(statp).nsaddrs[ns] = EXT(statp).nsaddrs[ns + 1]; -+ statp->nsaddr_list[ns] = statp->nsaddr_list[ns + 1]; -+ EXT(statp).nssocks[ns] = EXT(statp).nssocks[ns + 1]; - } -+ EXT(statp).nsaddrs[lastns] = inp; -+ statp->nsaddr_list[lastns] = ina; -+ EXT(statp).nssocks[lastns] = fd; - } - - /* - * Send request, RETRY times, or until successful. - */ - for (try = 0; try < statp->retry; try++) { -- for (ns = 0; ns < MAXNS; ns++) -+ for (ns = 0; ns < statp->nscount; ns++) - { - #ifdef DEBUG - char tmpbuf[40]; - #endif -- struct sockaddr_in6 *nsap = EXT(statp).nsaddrs[ns]; -+#if defined USE_HOOKS || defined DEBUG -+ struct sockaddr *nsap = get_nsaddr (statp, ns); -+#endif - -- if (nsap == NULL) -- goto next_ns; - same_ns: - #ifdef USE_HOOKS - if (__glibc_unlikely (statp->qhook != NULL)) { -@@ -542,9 +505,9 @@ __libc_res_nsend(res_state statp, const u_char *buf, int buflen, - - Dprint(statp->options & RES_DEBUG, - (stdout, ";; Querying server (# %d) address = %s\n", -- ns + 1, inet_ntop(nsap->sin6_family, -- (nsap->sin6_family == AF_INET6 -- ? &nsap->sin6_addr -+ ns + 1, inet_ntop(nsap->sa_family, -+ (nsap->sa_family == AF_INET6 -+ ? &((struct sockaddr_in6 *) nsap)->sin6_addr - : &((struct sockaddr_in *) nsap)->sin_addr), - tmpbuf, sizeof (tmpbuf)))); - -@@ -660,6 +623,21 @@ libresolv_hidden_def (res_nsend) - - /* Private */ - -+static struct sockaddr * -+get_nsaddr (res_state statp, int n) -+{ -+ -+ if (statp->nsaddr_list[n].sin_family == 0 && EXT(statp).nsaddrs[n] != NULL) -+ /* EXT(statp).nsaddrs[n] holds an address that is larger than -+ struct sockaddr, and user code did not update -+ statp->nsaddr_list[n]. */ -+ return (struct sockaddr *) EXT(statp).nsaddrs[n]; -+ else -+ /* User code updated statp->nsaddr_list[n], or statp->nsaddr_list[n] -+ has the same content as EXT(statp).nsaddrs[n]. */ -+ return (struct sockaddr *) (void *) &statp->nsaddr_list[n]; -+} -+ - static int - send_vc(res_state statp, - const u_char *buf, int buflen, const u_char *buf2, int buflen2, -@@ -674,7 +652,7 @@ send_vc(res_state statp, - // XXX REMOVE - // int anssiz = *anssizp; - HEADER *anhp = (HEADER *) ans; -- struct sockaddr_in6 *nsap = EXT(statp).nsaddrs[ns]; -+ struct sockaddr *nsap = get_nsaddr (statp, ns); - int truncating, connreset, n; - /* On some architectures compiler might emit a warning indicating - 'resplen' may be used uninitialized. However if buf2 == NULL -@@ -711,8 +689,8 @@ send_vc(res_state statp, - - if (getpeername(statp->_vcsock, - (struct sockaddr *)&peer, &size) < 0 || -- !sock_eq(&peer, nsap)) { -- __res_iclose(statp, false); -+ !sock_eq(&peer, (struct sockaddr_in6 *) nsap)) { -+ __res_iclose(statp, false); - statp->_flags &= ~RES_F_VC; - } - } -@@ -721,20 +699,19 @@ send_vc(res_state statp, - if (statp->_vcsock >= 0) - __res_iclose(statp, false); - -- statp->_vcsock = socket(nsap->sin6_family, SOCK_STREAM, 0); -+ statp->_vcsock = socket(nsap->sa_family, SOCK_STREAM, 0); - if (statp->_vcsock < 0) { - *terrno = errno; - Perror(statp, stderr, "socket(vc)", errno); - return (-1); - } - __set_errno (0); -- if (connect(statp->_vcsock, (struct sockaddr *)nsap, -- nsap->sin6_family == AF_INET -+ if (connect(statp->_vcsock, nsap, -+ nsap->sa_family == AF_INET - ? sizeof (struct sockaddr_in) - : sizeof (struct sockaddr_in6)) < 0) { - *terrno = errno; -- Aerror(statp, stderr, "connect/vc", errno, -- (struct sockaddr *) nsap); -+ Aerror(statp, stderr, "connect/vc", errno, nsap); - __res_iclose(statp, false); - return (0); - } -@@ -945,8 +922,7 @@ static int - reopen (res_state statp, int *terrno, int ns) - { - if (EXT(statp).nssocks[ns] == -1) { -- struct sockaddr *nsap -- = (struct sockaddr *) EXT(statp).nsaddrs[ns]; -+ struct sockaddr *nsap = get_nsaddr (statp, ns); - socklen_t slen; - - /* only try IPv6 if IPv6 NS and if not failed before */ --- -2.3.2 - diff --git a/static-tls-dtv-limit.patch b/static-tls-dtv-limit.patch deleted file mode 100644 index 209153f..0000000 --- a/static-tls-dtv-limit.patch +++ /dev/null @@ -1,641 +0,0 @@ -2015-03-17 Alexandre Oliva - - [BZ #17090] - [BZ #17620] - [BZ #17621] - [BZ #17628] - * NEWS: Update. - * elf/dl-tls.c (_dl_update_slotinfo): Clean up outdated DTV - entries with Static TLS too. Skip entries past the end of the - allocated DTV, from Alan Modra. - (tls_get_addr_tail): Update to glibc_likely/unlikely. Move - Static TLS DTV entry set up from... - (_dl_allocate_tls_init): ... here (fix modid assertion), ... - * elf/dl-reloc.c (_dl_nothread_init_static_tls): ... here... - * nptl/allocatestack.c (init_one_static_tls): ... and here... - * elf/dlopen.c (dl_open_worker): Drop l_tls_modid upper bound - for Static TLS. - * elf/tlsdeschtab.h (map_generation): Return size_t. Check - that the slot we find is associated with the given map before - using its generation count. - * nptl_db/db_info.c: Include ldsodefs.h. - (rtld_global, dtv_slotinfo_list, dtv_slotinfo): New typedefs. - * nptl_db/structs.def (DB_RTLD_VARIABLE): New macro. - (DB_MAIN_VARIABLE, DB_RTLD_GLOBAL_FIELD): Likewise. - (link_map::l_tls_offset): New struct field. - (dtv_t::counter): Likewise. - (rtld_global): New struct. - (_rtld_global): New rtld variable. - (dl_tls_dtv_slotinfo_list): New rtld global field. - (dtv_slotinfo_list): New struct. - (dtv_slotinfo): Likewise. - * nptl_db/td_symbol_list.c: Drop gnu/lib-names.h include. - (td_lookup): Rename to... - (td_mod_lookup): ... this. Use new mod parameter instead of - LIBPTHREAD_SO. - * nptl_db/td_thr_tlsbase.c: Include link.h. - (dtv_slotinfo_list, dtv_slotinfo): New functions. - (td_thr_tlsbase): Check DTV generation. Compute Static TLS - addresses even if the DTV is out of date or missing them. - * nptl_db/fetch-value.c (_td_locate_field): Do not refuse to - index zero-length arrays. - * nptl_db/thread_dbP.h: Include gnu/lib-names.h. - (td_lookup): Make it a macro implemented in terms of... - (td_mod_lookup): ... this declaration. - * nptl_db/db-symbols.awk (DB_RTLD_VARIABLE): Override. - (DB_MAIN_VARIABLE): Likewise. - -Index: glibc-2.21/elf/dl-open.c -=================================================================== ---- glibc-2.21.orig/elf/dl-open.c -+++ glibc-2.21/elf/dl-open.c -@@ -533,17 +533,7 @@ TLS generation counter wrapped! Please - && imap->l_tls_blocksize > 0) - { - /* For static TLS we have to allocate the memory here and -- now. This includes allocating memory in the DTV. But we -- cannot change any DTV other than our own. So, if we -- cannot guarantee that there is room in the DTV we don't -- even try it and fail the load. -- -- XXX We could track the minimum DTV slots allocated in -- all threads. */ -- if (! RTLD_SINGLE_THREAD_P && imap->l_tls_modid > DTV_SURPLUS) -- _dl_signal_error (0, "dlopen", NULL, N_("\ --cannot load any more object with static TLS")); -- -+ now, but we can delay updating the DTV. */ - imap->l_need_tls_init = 0; - #ifdef SHARED - /* Update the slot information data for at least the -Index: glibc-2.21/elf/dl-reloc.c -=================================================================== ---- glibc-2.21.orig/elf/dl-reloc.c -+++ glibc-2.21/elf/dl-reloc.c -@@ -136,12 +136,6 @@ _dl_nothread_init_static_tls (struct lin - # error "Either TLS_TCB_AT_TP or TLS_DTV_AT_TP must be defined" - #endif - -- /* Fill in the DTV slot so that a later LD/GD access will find it. */ -- dtv_t *dtv = THREAD_DTV (); -- assert (map->l_tls_modid <= dtv[-1].counter); -- dtv[map->l_tls_modid].pointer.val = dest; -- dtv[map->l_tls_modid].pointer.is_static = true; -- - /* Initialize the memory. */ - memset (__mempcpy (dest, map->l_tls_initimage, map->l_tls_initimage_size), - '\0', map->l_tls_blocksize - map->l_tls_initimage_size); -Index: glibc-2.21/elf/dl-tls.c -=================================================================== ---- glibc-2.21.orig/elf/dl-tls.c -+++ glibc-2.21/elf/dl-tls.c -@@ -493,17 +493,14 @@ _dl_allocate_tls_init (void *result) - assert (listp->slotinfo[cnt].gen <= GL(dl_tls_generation)); - maxgen = MAX (maxgen, listp->slotinfo[cnt].gen); - -+ dtv[map->l_tls_modid].pointer.val = TLS_DTV_UNALLOCATED; -+ dtv[map->l_tls_modid].pointer.is_static = false; -+ - if (map->l_tls_offset == NO_TLS_OFFSET - || map->l_tls_offset == FORCED_DYNAMIC_TLS_OFFSET) -- { -- /* For dynamically loaded modules we simply store -- the value indicating deferred allocation. */ -- dtv[map->l_tls_modid].pointer.val = TLS_DTV_UNALLOCATED; -- dtv[map->l_tls_modid].pointer.is_static = false; -- continue; -- } -+ continue; - -- assert (map->l_tls_modid == cnt); -+ assert (map->l_tls_modid == total + cnt); - assert (map->l_tls_blocksize >= map->l_tls_initimage_size); - #if TLS_TCB_AT_TP - assert ((size_t) map->l_tls_offset >= map->l_tls_blocksize); -@@ -515,8 +512,6 @@ _dl_allocate_tls_init (void *result) - #endif - - /* Copy the initialization image and clear the BSS part. */ -- dtv[map->l_tls_modid].pointer.val = dest; -- dtv[map->l_tls_modid].pointer.is_static = true; - memset (__mempcpy (dest, map->l_tls_initimage, - map->l_tls_initimage_size), '\0', - map->l_tls_blocksize - map->l_tls_initimage_size); -@@ -679,13 +674,16 @@ _dl_update_slotinfo (unsigned long int r - struct link_map *map = listp->slotinfo[cnt].map; - if (map == NULL) - { -- /* If this modid was used at some point the memory -- might still be allocated. */ -- if (! dtv[total + cnt].pointer.is_static -- && dtv[total + cnt].pointer.val != TLS_DTV_UNALLOCATED) -+ if (dtv[-1].counter >= total + cnt) - { -- free (dtv[total + cnt].pointer.val); -+ /* If this modid was used at some point the memory -+ might still be allocated. */ -+ if (! dtv[total + cnt].pointer.is_static -+ && (dtv[total + cnt].pointer.val -+ != TLS_DTV_UNALLOCATED)) -+ free (dtv[total + cnt].pointer.val); - dtv[total + cnt].pointer.val = TLS_DTV_UNALLOCATED; -+ dtv[total + cnt].pointer.is_static = false; - } - - continue; -@@ -718,10 +716,8 @@ _dl_update_slotinfo (unsigned long int r - memalign and not malloc. */ - free (dtv[modid].pointer.val); - -- /* This module is loaded dynamically- We defer memory -- allocation. */ -- dtv[modid].pointer.is_static = false; - dtv[modid].pointer.val = TLS_DTV_UNALLOCATED; -+ dtv[modid].pointer.is_static = false; - - if (modid == req_modid) - the_map = map; -@@ -759,13 +755,12 @@ tls_get_addr_tail (GET_ADDR_ARGS, dtv_t - the_map = listp->slotinfo[idx].map; - } - -- again: - /* Make sure that, if a dlopen running in parallel forces the - variable into static storage, we'll wait until the address in the - static TLS block is set up, and use that. If we're undecided - yet, make sure we make the decision holding the lock as well. */ -- if (__builtin_expect (the_map->l_tls_offset -- != FORCED_DYNAMIC_TLS_OFFSET, 0)) -+ if (__glibc_unlikely (the_map->l_tls_offset -+ != FORCED_DYNAMIC_TLS_OFFSET)) - { - __rtld_lock_lock_recursive (GL(dl_load_lock)); - if (__glibc_likely (the_map->l_tls_offset == NO_TLS_OFFSET)) -@@ -773,22 +768,28 @@ tls_get_addr_tail (GET_ADDR_ARGS, dtv_t - the_map->l_tls_offset = FORCED_DYNAMIC_TLS_OFFSET; - __rtld_lock_unlock_recursive (GL(dl_load_lock)); - } -- else -+ else if (__glibc_likely (the_map->l_tls_offset -+ != FORCED_DYNAMIC_TLS_OFFSET)) - { -+#if TLS_TCB_AT_TP -+ void *p = (char *) THREAD_SELF - the_map->l_tls_offset; -+#elif TLS_DTV_AT_TP -+ void *p = (char *) THREAD_SELF + the_map->l_tls_offset + TLS_PRE_TCB_SIZE; -+#else -+# error "Either TLS_TCB_AT_TP or TLS_DTV_AT_TP must be defined" -+#endif - __rtld_lock_unlock_recursive (GL(dl_load_lock)); -- if (__builtin_expect (the_map->l_tls_offset -- != FORCED_DYNAMIC_TLS_OFFSET, 1)) -- { -- void *p = dtv[GET_ADDR_MODULE].pointer.val; -- if (__glibc_unlikely (p == TLS_DTV_UNALLOCATED)) -- goto again; - -- return (char *) p + GET_ADDR_OFFSET; -- } -+ dtv[GET_ADDR_MODULE].pointer.is_static = true; -+ dtv[GET_ADDR_MODULE].pointer.val = p; -+ -+ return (char *) p + GET_ADDR_OFFSET; - } -+ else -+ __rtld_lock_unlock_recursive (GL(dl_load_lock)); - } - void *p = dtv[GET_ADDR_MODULE].pointer.val = allocate_and_init (the_map); -- dtv[GET_ADDR_MODULE].pointer.is_static = false; -+ assert (!dtv[GET_ADDR_MODULE].pointer.is_static); - - return (char *) p + GET_ADDR_OFFSET; - } -Index: glibc-2.21/elf/tlsdeschtab.h -=================================================================== ---- glibc-2.21.orig/elf/tlsdeschtab.h -+++ glibc-2.21/elf/tlsdeschtab.h -@@ -42,7 +42,7 @@ eq_tlsdesc (void *p, void *q) - return tdp->tlsinfo.ti_offset == tdq->tlsinfo.ti_offset; - } - --inline static int -+inline static size_t - map_generation (struct link_map *map) - { - size_t idx = map->l_tls_modid; -@@ -58,7 +58,7 @@ map_generation (struct link_map *map) - we can assume that, if the generation count is zero, we - still haven't determined the generation count for this - module. */ -- if (listp->slotinfo[idx].gen) -+ if (listp->slotinfo[idx].map == map && listp->slotinfo[idx].gen) - return listp->slotinfo[idx].gen; - else - break; -Index: glibc-2.21/nptl/allocatestack.c -=================================================================== ---- glibc-2.21.orig/nptl/allocatestack.c -+++ glibc-2.21/nptl/allocatestack.c -@@ -1190,7 +1190,6 @@ __nptl_setxid (struct xid_command *cmdp) - static inline void __attribute__((always_inline)) - init_one_static_tls (struct pthread *curp, struct link_map *map) - { -- dtv_t *dtv = GET_DTV (TLS_TPADJ (curp)); - # if TLS_TCB_AT_TP - void *dest = (char *) curp - map->l_tls_offset; - # elif TLS_DTV_AT_TP -@@ -1199,11 +1198,9 @@ init_one_static_tls (struct pthread *cur - # error "Either TLS_TCB_AT_TP or TLS_DTV_AT_TP must be defined" - # endif - -- /* Fill in the DTV slot so that a later LD/GD access will find it. */ -- dtv[map->l_tls_modid].pointer.val = dest; -- dtv[map->l_tls_modid].pointer.is_static = true; -- -- /* Initialize the memory. */ -+ /* We cannot delay the initialization of the Static TLS area, since -+ it can be accessed with LE or IE, but since the DTV is only used -+ by GD and LD, we can delay its update to avoid a race. */ - memset (__mempcpy (dest, map->l_tls_initimage, map->l_tls_initimage_size), - '\0', map->l_tls_blocksize - map->l_tls_initimage_size); - } -Index: glibc-2.21/nptl_db/db-symbols.awk -=================================================================== ---- glibc-2.21.orig/nptl_db/db-symbols.awk -+++ glibc-2.21/nptl_db/db-symbols.awk -@@ -2,6 +2,8 @@ - # we've just built. It checks for all the symbols used in td_symbol_list. - - BEGIN { -+%define DB_RTLD_VARIABLE(name) /* Nothing. */ -+%define DB_MAIN_VARIABLE(name) /* Nothing. */ - %define DB_LOOKUP_NAME(idx, name) required[STRINGIFY (name)] = 1; - %define DB_LOOKUP_NAME_TH_UNIQUE(idx, name) th_unique[STRINGIFY (name)] = 1; - %include "db-symbols.h" -Index: glibc-2.21/nptl_db/db_info.c -=================================================================== ---- glibc-2.21.orig/nptl_db/db_info.c -+++ glibc-2.21/nptl_db/db_info.c -@@ -21,6 +21,7 @@ - #include - #include "thread_dbP.h" - #include -+#include - - typedef struct pthread pthread; - typedef struct pthread_key_struct pthread_key_struct; -@@ -37,6 +38,9 @@ typedef struct - } dtv; - - typedef struct link_map link_map; -+typedef struct rtld_global rtld_global; -+typedef struct dtv_slotinfo_list dtv_slotinfo_list; -+typedef struct dtv_slotinfo dtv_slotinfo; - - /* Actually static in nptl/init.c, but we only need it for typeof. */ - extern bool __nptl_initial_report_events; -Index: glibc-2.21/nptl_db/fetch-value.c -=================================================================== ---- glibc-2.21.orig/nptl_db/fetch-value.c -+++ glibc-2.21/nptl_db/fetch-value.c -@@ -69,7 +69,8 @@ _td_locate_field (td_thragent_t *ta, - } - } - -- if (idx != 0 && idx - (psaddr_t) 0 > DB_DESC_NELEM (desc)) -+ if (idx != 0 && DB_DESC_NELEM (desc) != 0 -+ && idx - (psaddr_t) 0 > DB_DESC_NELEM (desc)) - /* This is an internal indicator to callers with nonzero IDX - that the IDX value is too big. */ - return TD_NOAPLIC; -Index: glibc-2.21/nptl_db/structs.def -=================================================================== ---- glibc-2.21.orig/nptl_db/structs.def -+++ glibc-2.21/nptl_db/structs.def -@@ -22,6 +22,28 @@ - # define STRUCTS_DEF_DEFAULTS 1 - #endif - -+#ifndef DB_RTLD_VARIABLE -+# define DB_RTLD_VARIABLE(name) DB_VARIABLE (name) -+#endif -+ -+#ifndef DB_MAIN_VARIABLE -+# define DB_MAIN_VARIABLE(name) DB_VARIABLE (name) -+#endif -+ -+#ifndef DB_RTLD_GLOBAL_FIELD -+# if !IS_IN (libpthread) -+# define DB_RTLD_GLOBAL_FIELD(field) \ -+ DB_STRUCT_FIELD (rtld_global, _##field) \ -+ DB_MAIN_VARIABLE (_##field) -+# elif defined SHARED -+# define DB_RTLD_GLOBAL_FIELD(field) \ -+ DB_STRUCT_FIELD (rtld_global, _##field) -+# else -+# define DB_RTLD_GLOBAL_FIELD(field) \ -+ DB_MAIN_VARIABLE (_##field) -+# endif -+#endif /* DB_RTLD_GLOBAL_FIELD */ -+ - DB_STRUCT (pthread) - DB_STRUCT_FIELD (pthread, list) - DB_STRUCT_FIELD (pthread, report_events) -@@ -70,14 +92,31 @@ DB_STRUCT (pthread_key_data_level2) - DB_STRUCT_ARRAY_FIELD (pthread_key_data_level2, data) - - DB_STRUCT_FIELD (link_map, l_tls_modid) -+DB_STRUCT_FIELD (link_map, l_tls_offset) - - DB_STRUCT_ARRAY_FIELD (dtv, dtv) - #define pointer_val pointer.val /* Field of anonymous struct in dtv_t. */ - DB_STRUCT_FIELD (dtv_t, pointer_val) -+DB_STRUCT_FIELD (dtv_t, counter) - #if !IS_IN (libpthread) || TLS_TCB_AT_TP - DB_STRUCT_FIELD (pthread, dtvp) - #endif - -+#if !(IS_IN (libpthread) && !defined SHARED) -+DB_STRUCT (rtld_global) -+DB_RTLD_VARIABLE (_rtld_global) -+#endif -+DB_RTLD_GLOBAL_FIELD (dl_tls_dtv_slotinfo_list) -+ -+DB_STRUCT (dtv_slotinfo_list) -+DB_STRUCT_FIELD (dtv_slotinfo_list, len) -+DB_STRUCT_FIELD (dtv_slotinfo_list, next) -+DB_STRUCT_ARRAY_FIELD (dtv_slotinfo_list, slotinfo) -+ -+DB_STRUCT (dtv_slotinfo) -+DB_STRUCT_FIELD (dtv_slotinfo, gen) -+DB_STRUCT_FIELD (dtv_slotinfo, map) -+ - #ifdef STRUCTS_DEF_DEFAULTS - # undef DB_STRUCT_ARRAY_FIELD - # undef DB_ARRAY_VARIABLE -Index: glibc-2.21/nptl_db/td_symbol_list.c -=================================================================== ---- glibc-2.21.orig/nptl_db/td_symbol_list.c -+++ glibc-2.21/nptl_db/td_symbol_list.c -@@ -18,7 +18,6 @@ - . */ - - #include --#include - #include "thread_dbP.h" - - static const char *symbol_list_arr[] = -@@ -41,12 +40,12 @@ td_symbol_list (void) - - - ps_err_e --td_lookup (struct ps_prochandle *ps, int idx, psaddr_t *sym_addr) -+td_mod_lookup (struct ps_prochandle *ps, const char *mod, -+ int idx, psaddr_t *sym_addr) - { - ps_err_e result; - assert (idx >= 0 && idx < SYM_NUM_MESSAGES); -- result = ps_pglobal_lookup (ps, LIBPTHREAD_SO, symbol_list_arr[idx], -- sym_addr); -+ result = ps_pglobal_lookup (ps, mod, symbol_list_arr[idx], sym_addr); - - #ifdef HAVE_ASM_GLOBAL_DOT_NAME - /* For PowerPC, 64-bit uses dot symbols but 32-bit does not. -Index: glibc-2.21/nptl_db/td_thr_tlsbase.c -=================================================================== ---- glibc-2.21.orig/nptl_db/td_thr_tlsbase.c -+++ glibc-2.21/nptl_db/td_thr_tlsbase.c -@@ -17,14 +17,118 @@ - . */ - - #include "thread_dbP.h" -+#include - -+/* Get the DTV slotinfo list head entry from the dynamic loader state -+ into *LISTHEAD. */ -+static td_err_e -+dtv_slotinfo_list (td_thragent_t *ta, -+ psaddr_t *listhead) -+{ -+ td_err_e err; -+ psaddr_t head; -+ -+ if (ta->ta_addr__rtld_global == 0 -+ && td_mod_lookup (ta->ph, LD_SO, SYM__rtld_global, -+ &ta->ta_addr__rtld_global) != PS_OK) -+ ta->ta_addr__rtld_global = (void*)-1; -+ -+ if (ta->ta_addr__rtld_global != (void*)-1) -+ { -+ err = DB_GET_FIELD (head, ta, ta->ta_addr__rtld_global, -+ rtld_global, _dl_tls_dtv_slotinfo_list, 0); -+ if (err != TD_OK) -+ return err; -+ } -+ else -+ { -+ if (ta->ta_addr__dl_tls_dtv_slotinfo_list == 0 -+ && td_mod_lookup (ta->ph, NULL, SYM__dl_tls_dtv_slotinfo_list, -+ &ta->ta_addr__dl_tls_dtv_slotinfo_list) != PS_OK) -+ return TD_ERR; -+ -+ err = _td_fetch_value (ta, ta->ta_var__dl_tls_dtv_slotinfo_list, -+ SYM_DESC__dl_tls_dtv_slotinfo_list, -+ 0, ta->ta_addr__dl_tls_dtv_slotinfo_list, &head); -+ if (err != TD_OK) -+ return err; -+ } -+ -+ *listhead = head; -+ return TD_OK; -+} -+ -+/* Get the address of the DTV slotinfo entry for MODID into -+ *DTVSLOTINFO. */ -+static td_err_e -+dtv_slotinfo (td_thragent_t *ta, -+ unsigned long int modid, -+ psaddr_t *dtvslotinfo) -+{ -+ td_err_e err; -+ psaddr_t slot, temp; -+ size_t slbase = 0; -+ -+ err = dtv_slotinfo_list (ta, &slot); -+ if (err != TD_OK) -+ return err; -+ -+ while (slot) -+ { -+ /* Get the number of entries in this list entry's array. */ -+ err = DB_GET_FIELD (temp, ta, slot, dtv_slotinfo_list, len, 0); -+ if (err != TD_OK) -+ return err; -+ size_t len = (uintptr_t)temp; -+ -+ /* Did we find the list entry for modid? */ -+ if (modid < slbase + len) -+ break; -+ -+ /* We didn't, so get the next list entry. */ -+ slbase += len; -+ err = DB_GET_FIELD (temp, ta, slot, dtv_slotinfo_list, -+ next, 0); -+ if (err != TD_OK) -+ return err; -+ slot = temp; -+ } -+ -+ /* We reached the end of the list and found nothing. */ -+ if (!slot) -+ return TD_ERR; -+ -+ /* Take the slotinfo for modid from the list entry. */ -+ err = DB_GET_FIELD_ADDRESS (temp, ta, slot, dtv_slotinfo_list, -+ slotinfo, modid - slbase); -+ if (err != TD_OK) -+ return err; -+ slot = temp; -+ -+ *dtvslotinfo = slot; -+ return TD_OK; -+} -+ -+/* Return in *BASE the base address of the TLS block for MODID within -+ TH. -+ -+ It should return success and yield the correct pointer in any -+ circumstance where the TLS block for the module and thread -+ requested has already been initialized. -+ -+ It should fail with TD_TLSDEFER only when the thread could not -+ possibly have observed any values in that TLS block. That way, the -+ debugger can fall back to showing initial values from the PT_TLS -+ segment (and refusing attempts to mutate) for the TD_TLSDEFER case, -+ and never fail to make the values the program will actually see -+ available to the user of the debugger. */ - td_err_e - td_thr_tlsbase (const td_thrhandle_t *th, - unsigned long int modid, - psaddr_t *base) - { - td_err_e err; -- psaddr_t dtv, dtvslot, dtvptr; -+ psaddr_t dtv, dtvslot, dtvptr, temp; - - if (modid < 1) - return TD_NOTLS; -@@ -50,11 +154,75 @@ td_thr_tlsbase (const td_thrhandle_t *th - return TD_TLSDEFER; - } - -+ err = dtv_slotinfo (th->th_ta_p, modid, &temp); -+ if (err != TD_OK) -+ return err; -+ -+ psaddr_t slot; -+ err = DB_GET_STRUCT (slot, th->th_ta_p, temp, dtv_slotinfo); -+ if (err != TD_OK) -+ return err; -+ -+ /* Take the link_map from the slotinfo. */ -+ psaddr_t map; -+ err = DB_GET_FIELD_LOCAL (map, th->th_ta_p, slot, dtv_slotinfo, map, 0); -+ if (err != TD_OK) -+ return err; -+ if (!map) -+ return TD_ERR; -+ -+ /* Ok, the modid is good, now find out what DTV generation it -+ requires. */ -+ err = DB_GET_FIELD_LOCAL (temp, th->th_ta_p, slot, dtv_slotinfo, gen, 0); -+ if (err != TD_OK) -+ return err; -+ size_t modgen = (uintptr_t)temp; -+ - /* Get the DTV pointer from the thread descriptor. */ - err = DB_GET_FIELD (dtv, th->th_ta_p, pd, pthread, dtvp, 0); - if (err != TD_OK) - return err; - -+ psaddr_t dtvgenloc; -+ /* Get the DTV generation count at dtv[0].counter. */ -+ err = DB_GET_FIELD_ADDRESS (dtvgenloc, th->th_ta_p, dtv, dtv, dtv, 0); -+ if (err != TD_OK) -+ return err; -+ err = DB_GET_FIELD (temp, th->th_ta_p, dtvgenloc, dtv_t, counter, 0); -+ if (err != TD_OK) -+ return err; -+ size_t dtvgen = (uintptr_t)temp; -+ -+ /* Is the DTV current enough? */ -+ if (dtvgen < modgen) -+ { -+ try_static_tls: -+ /* If the module uses Static TLS, we're still good. */ -+ err = DB_GET_FIELD (temp, th->th_ta_p, map, link_map, l_tls_offset, 0); -+ if (err != TD_OK) -+ return err; -+ ptrdiff_t tlsoff = (uintptr_t)temp; -+ -+ if (tlsoff != FORCED_DYNAMIC_TLS_OFFSET -+ && tlsoff != NO_TLS_OFFSET) -+ { -+ psaddr_t tp = pd; -+ -+#if TLS_TCB_AT_TP -+ dtvptr = tp - tlsoff; -+#elif TLS_DTV_AT_TP -+ dtvptr = tp + tlsoff + TLS_PRE_TCB_SIZE; -+#else -+# error "Either TLS_TCB_AT_TP or TLS_DTV_AT_TP must be defined" -+#endif -+ -+ *base = dtvptr; -+ return TD_OK; -+ } -+ -+ return TD_TLSDEFER; -+ } -+ - /* Find the corresponding entry in the DTV. */ - err = DB_GET_FIELD_ADDRESS (dtvslot, th->th_ta_p, dtv, dtv, dtv, modid); - if (err != TD_OK) -@@ -68,7 +236,7 @@ td_thr_tlsbase (const td_thrhandle_t *th - /* It could be that the memory for this module is not allocated for - the given thread. */ - if ((uintptr_t) dtvptr & 1) -- return TD_TLSDEFER; -+ goto try_static_tls; - - *base = dtvptr; - return TD_OK; -Index: glibc-2.21/nptl_db/thread_dbP.h -=================================================================== ---- glibc-2.21.orig/nptl_db/thread_dbP.h -+++ glibc-2.21/nptl_db/thread_dbP.h -@@ -29,6 +29,7 @@ - #include "thread_db.h" - #include "../nptl/pthreadP.h" /* This is for *_BITMASK only. */ - #include -+#include - - /* Indeces for the symbol names. */ - enum -@@ -139,11 +140,11 @@ ta_ok (const td_thragent_t *ta) - } - - --/* Internal wrapper around ps_pglobal_lookup. */ --extern ps_err_e td_lookup (struct ps_prochandle *ps, -- int idx, psaddr_t *sym_addr) attribute_hidden; -- -- -+/* Internal wrappers around ps_pglobal_lookup. */ -+extern ps_err_e td_mod_lookup (struct ps_prochandle *ps, const char *modname, -+ int idx, psaddr_t *sym_addr) attribute_hidden; -+#define td_lookup(ps, idx, sym_addr) \ -+ td_mod_lookup ((ps), LIBPTHREAD_SO, (idx), (sym_addr)) - - - /* Store in psaddr_t VAR the address of inferior's symbol NAME. */ diff --git a/threaded-trim-threshold.patch b/threaded-trim-threshold.patch deleted file mode 100644 index 4457442..0000000 --- a/threaded-trim-threshold.patch +++ /dev/null @@ -1,224 +0,0 @@ -From c26efef9798914e208329c0e8c3c73bb1135d9e3 Mon Sep 17 00:00:00 2001 -From: Mel Gorman -Date: Thu, 2 Apr 2015 12:14:14 +0530 -Subject: [PATCH] malloc: Consistently apply trim_threshold to all heaps [BZ - #17195] - -Trimming heaps is a balance between saving memory and the system overhead -required to update page tables and discard allocated pages. The malloc -option M_TRIM_THRESHOLD is a tunable that users are meant to use to decide -where this balance point is but it is only applied to the main arena. - -For scalability reasons, glibc malloc has per-thread heaps but these are -shrunk with madvise() if there is one page free at the top of the heap. -In some circumstances this can lead to high system overhead if a thread -has a control flow like - - while (data_to_process) { - buf = malloc(large_size); - do_stuff(); - free(buf); - } - -For a large size, the free() will call madvise (pagetable teardown, page -free and TLB flush) every time followed immediately by a malloc (fault, -kernel page alloc, zeroing and charge accounting). The kernel overhead -can dominate such a workload. - -This patch allows the user to tune when madvise gets called by applying -the trim threshold to the per-thread heaps and using similar logic to the -main arena when deciding whether to shrink. Alternatively if the dynamic -brk/mmap threshold gets adjusted then the new values will be obeyed by -the per-thread heaps. - -Bug 17195 was a test case motivated by a problem encountered in scientific -applications written in python that performance badly due to high page fault -overhead. The basic operation of such a program was posted by Julian Taylor -https://sourceware.org/ml/libc-alpha/2015-02/msg00373.html - -With this patch applied, the overhead is eliminated. All numbers in this -report are in seconds and were recorded by running Julian's program 30 -times. - -pyarray - glibc madvise - 2.21 v2 -System min 1.81 ( 0.00%) 0.00 (100.00%) -System mean 1.93 ( 0.00%) 0.02 ( 99.20%) -System stddev 0.06 ( 0.00%) 0.01 ( 88.99%) -System max 2.06 ( 0.00%) 0.03 ( 98.54%) -Elapsed min 3.26 ( 0.00%) 2.37 ( 27.30%) -Elapsed mean 3.39 ( 0.00%) 2.41 ( 28.84%) -Elapsed stddev 0.14 ( 0.00%) 0.02 ( 82.73%) -Elapsed max 4.05 ( 0.00%) 2.47 ( 39.01%) - - glibc madvise - 2.21 v2 -User 141.86 142.28 -System 57.94 0.60 -Elapsed 102.02 72.66 - -Note that almost a minutes worth of system time is eliminted and the -program completes 28% faster on average. - -To illustrate the problem without python this is a basic test-case for -the worst case scenario where every free is a madvise followed by a an alloc - -/* gcc bench-free.c -lpthread -o bench-free */ -static int num = 1024; - -void __attribute__((noinline,noclone)) dostuff (void *p) -{ -} - -void *worker (void *data) -{ - int i; - - for (i = num; i--;) - { - void *m = malloc (48*4096); - dostuff (m); - free (m); - } - - return NULL; -} - -int main() -{ - int i; - pthread_t t; - void *ret; - if (pthread_create (&t, NULL, worker, NULL)) - exit (2); - if (pthread_join (t, &ret)) - exit (3); - return 0; -} - -Before the patch, this resulted in 1024 calls to madvise. With the patch applied, -madvise is called twice because the default trim threshold is high enough to avoid -this. - -This a more complex case where there is a mix of frees. It's simply a different worker -function for the test case above - -void *worker (void *data) -{ - int i; - int j = 0; - void *free_index[num]; - - for (i = num; i--;) - { - void *m = malloc ((i % 58) *4096); - dostuff (m); - if (i % 2 == 0) { - free (m); - } else { - free_index[j++] = m; - } - } - for (; j >= 0; j--) - { - free(free_index[j]); - } - - return NULL; -} - -glibc 2.21 calls malloc 90305 times but with the patch applied, it's -called 13438. Increasing the trim threshold will decrease the number of -times it's called with the option of eliminating the overhead. - -ebizzy is meant to generate a workload resembling common web application -server workloads. It is threaded with a large working set that at its core -has an allocation, do_stuff, free loop that also hits this case. The primary -metric of the benchmark is records processed per second. This is running on -my desktop which is a single socket machine with an I7-4770 and 8 cores. -Each thread count was run for 30 seconds. It was only run once as the -performance difference is so high that the variation is insignificant. - - glibc 2.21 patch -threads 1 10230 44114 -threads 2 19153 84925 -threads 4 34295 134569 -threads 8 51007 183387 - -Note that the saving happens to be a concidence as the size allocated -by ebizzy was less than the default threshold. If a different number of -chunks were specified then it may also be necessary to tune the threshold -to compensate - -This is roughly quadrupling the performance of this benchmark. The difference in -system CPU usage illustrates why. - -ebizzy running 1 thread with glibc 2.21 -10230 records/s 306904 -real 30.00 s -user 7.47 s -sys 22.49 s - -22.49 seconds was spent in the kernel for a workload runinng 30 seconds. With the -patch applied - -ebizzy running 1 thread with patch applied -44126 records/s 1323792 -real 30.00 s -user 29.97 s -sys 0.00 s - -system CPU usage was zero with the patch applied. strace shows that glibc -running this workload calls madvise approximately 9000 times a second. With -the patch applied madvise was called twice during the workload (or 0.06 -times per second). - -2015-02-10 Mel Gorman - - [BZ #17195] - * malloc/arena.c (free): Apply trim threshold to per-thread heaps - as well as the main arena. ---- - ---- a/malloc/malloc.c -+++ b/malloc/malloc.c -@@ -241,6 +241,8 @@ - /* For MIN, MAX, powerof2. */ - #include - -+/* For ALIGN_DOWN. */ -+#include - - /* - Debugging: ---- a/malloc/arena.c -+++ b/malloc/arena.c -@@ -658,7 +658,7 @@ heap_trim (heap_info *heap, size_t pad) - unsigned long pagesz = GLRO (dl_pagesize); - mchunkptr top_chunk = top (ar_ptr), p, bck, fwd; - heap_info *prev_heap; -- long new_size, top_size, extra, prev_size, misalign; -+ long new_size, top_size, top_area, extra, prev_size, misalign; - - /* Can this heap go away completely? */ - while (top_chunk == chunk_at_offset (heap, sizeof (*heap))) -@@ -694,9 +694,16 @@ heap_trim (heap_info *heap, size_t pad) - set_head (top_chunk, new_size | PREV_INUSE); - /*check_chunk(ar_ptr, top_chunk);*/ - } -+ -+ /* Uses similar logic for per-thread arenas as the main arena with systrim -+ by preserving the top pad and at least a page. */ - top_size = chunksize (top_chunk); -- extra = (top_size - pad - MINSIZE - 1) & ~(pagesz - 1); -- if (extra < (long) pagesz) -+ top_area = top_size - MINSIZE - 1; -+ if (top_area <= pad) -+ return 0; -+ -+ extra = ALIGN_DOWN(top_area - pad, pagesz); -+ if ((unsigned long) extra < mp_.trim_threshold) - return 0; - - /* Try to shrink. */