unofficial mirror of guix-patches@gnu.org 
 help / color / mirror / code / Atom feed
From: Marius Bakke <mbakke@fastmail.com>
To: Leo Famulari <leo@famulari.name>
Cc: 29406@debbugs.gnu.org
Subject: [bug#29406] [PATCH core-updates]: Add selected upstream fixes for glibc 2.26.
Date: Fri, 24 Nov 2017 04:08:20 +0100	[thread overview]
Message-ID: <87d148pe57.fsf@fastmail.com> (raw)
In-Reply-To: <87ine0pjiu.fsf@fastmail.com>


[-- Attachment #1.1: Type: text/plain, Size: 2753 bytes --]

Marius Bakke <mbakke@fastmail.com> writes:

> Leo Famulari <leo@famulari.name> writes:
>
>> On Wed, Nov 22, 2017 at 10:28:49PM +0100, Marius Bakke wrote:
>>> Hello!
>>> 
>>> I discovered that 'icu4c' failed to build for x86_64 on 'core-updates'.
>>> After some investigation, it turns out to be a problem with <math.h> in
>>> C++ mode, due to its usage of C-only builtins (in the 2.26 release).
>>> 
>>> Here are the relevant bug reports I've found so far by digging through
>>> the "release/2.26/master" branch, aka "2.26 stable"[0]:
>>> 
>>> <https://sourceware.org/bugzilla/show_bug.cgi?id=21930>
>>> <https://sourceware.org/bugzilla/show_bug.cgi?id=22235>
>>> <https://sourceware.org/bugzilla/show_bug.cgi?id=22146>
>>> <https://sourceware.org/bugzilla/show_bug.cgi?id=22296>
>>> 
>>> The attached patch includes the fixes from those bugs, as well as a
>>> couple of others that looked important.  However it's still a very small
>>> subset of the 2.26 post-release fixes.
>>> 
>>> I've read through _most_ of the commits and around half of them look
>>> important enough to pick "unconditionally".  The other half I mainly
>>> lack the context or skills to assess.
>>> 
>>> So I wonder if we should simply pick everything from this branch,
>>> instead of only the few that fixes immediately visible problems.
>>> Thoughts?
>>
>> Based on this discussion [0], I think we should take the whole branch.
>> It sounds like commits on the release branches are considered important
>> bug fixes and "stable".
>
> I agree.
>
>> There was talk of a mid-October 2.26.1 release, but that didn't happen,
>> as we know.
>>
>> Are you able to prepare a patch, Marius? If not, I can do it later
>> tonight.
>
> I ran this command from a glibc git checkout:
>
>   $ git format-patch -p --minimal --no-signature -o ~/guix/gnu/packages/patches/ \
>     glibc-2.26..origin/release/2.26/master
>
> Afterwards, in ~/guix/gnu/packages/patches:
>
>   $ rename 's/^(\d{4})-.*\.patch/glibc-2-26-$1.patch/' 00*.patch

There was a major bug in the regexp here: ^

The patch below fixes that, and add CVE identifiers to the patch names.

I realized the glibc graft on master has been classified as low severity
in Debian and not added to the stable releases.  I wish to revert it, or
at the very least remove the graft.  Thoughts?

https://security-tracker.debian.org/tracker/CVE-2017-15670
https://security-tracker.debian.org/tracker/CVE-2017-15671

It also incorrectly mentions that CVE-2017-15671 is fixed, when in fact
that was a different bug entirely.  I have an ugly patch to fix that,
but I'm not sure if it's even worth the hassle.

I will also refrain from doing important work late at night :-(


[-- Attachment #1.2: 0001-gnu-glibc-Add-fixes-from-upstream-2.26-stable-branch.patch --]
[-- Type: text/x-patch, Size: 1266207 bytes --]

From 9fcb7c3b5397acf43e3e1d0fc7a79cea9ad555a3 Mon Sep 17 00:00:00 2001
From: Marius Bakke <mbakke@fastmail.com>
Date: Fri, 24 Nov 2017 01:19:02 +0100
Subject: [PATCH] gnu: glibc: Add fixes from upstream 2.26 stable branch.

See <https://bugs.gnu.org/29406>.

* gnu/packages/patches/glibc-2.26-0001.patch,
gnu/packages/patches/glibc-2.26-0002.patch,
gnu/packages/patches/glibc-2.26-0003.patch,
gnu/packages/patches/glibc-2.26-0004.patch,
gnu/packages/patches/glibc-2.26-0005.patch,
gnu/packages/patches/glibc-2.26-0006.patch,
gnu/packages/patches/glibc-2.26-0007.patch,
gnu/packages/patches/glibc-2.26-0008.patch,
gnu/packages/patches/glibc-2.26-0009.patch,
gnu/packages/patches/glibc-2.26-0010.patch,
gnu/packages/patches/glibc-2.26-0011.patch,
gnu/packages/patches/glibc-2.26-0012.patch,
gnu/packages/patches/glibc-2.26-0013.patch,
gnu/packages/patches/glibc-2.26-0014.patch,
gnu/packages/patches/glibc-2.26-0015.patch,
gnu/packages/patches/glibc-2.26-0016.patch,
gnu/packages/patches/glibc-2.26-0017.patch,
gnu/packages/patches/glibc-2.26-0018.patch,
gnu/packages/patches/glibc-2.26-0019.patch,
gnu/packages/patches/glibc-2.26-0020.patch,
gnu/packages/patches/glibc-2.26-0021.patch,
gnu/packages/patches/glibc-2.26-0022.patch,
gnu/packages/patches/glibc-2.26-0023.patch,
gnu/packages/patches/glibc-2.26-0025.patch,
gnu/packages/patches/glibc-2.26-0026.patch,
gnu/packages/patches/glibc-2.26-0027.patch,
gnu/packages/patches/glibc-2.26-0028.patch,
gnu/packages/patches/glibc-2.26-0029.patch,
gnu/packages/patches/glibc-2.26-0030.patch,
gnu/packages/patches/glibc-2.26-0031.patch,
gnu/packages/patches/glibc-2.26-0032.patch,
gnu/packages/patches/glibc-2.26-0033.patch,
gnu/packages/patches/glibc-2.26-0034.patch,
gnu/packages/patches/glibc-2.26-0035.patch,
gnu/packages/patches/glibc-2.26-0036.patch,
gnu/packages/patches/glibc-2.26-0037.patch,
gnu/packages/patches/glibc-2.26-0038.patch,
gnu/packages/patches/glibc-2.26-0039.patch,
gnu/packages/patches/glibc-2.26-0040.patch,
gnu/packages/patches/glibc-2.26-0041.patch,
gnu/packages/patches/glibc-2.26-0042.patch,
gnu/packages/patches/glibc-2.26-0043.patch,
gnu/packages/patches/glibc-2.26-0044.patch,
gnu/packages/patches/glibc-2.26-0045.patch,
gnu/packages/patches/glibc-2.26-0046.patch,
gnu/packages/patches/glibc-2.26-0047.patch,
gnu/packages/patches/glibc-2.26-0048.patch,
gnu/packages/patches/glibc-2.26-0049.patch,
gnu/packages/patches/glibc-2.26-0050.patch,
gnu/packages/patches/glibc-2.26-0051.patch,
gnu/packages/patches/glibc-2.26-0052.patch,
gnu/packages/patches/glibc-2.26-0053.patch,
gnu/packages/patches/glibc-2.26-0054.patch,
gnu/packages/patches/glibc-2.26-0055.patch,
gnu/packages/patches/glibc-2.26-0056.patch,
gnu/packages/patches/glibc-2.26-0057.patch,
gnu/packages/patches/glibc-2.26-0058.patch,
gnu/packages/patches/glibc-2.26-0059.patch,
gnu/packages/patches/glibc-2.26-0060.patch,
gnu/packages/patches/glibc-2.26-0061.patch,
gnu/packages/patches/glibc-2.26-0062.patch,
gnu/packages/patches/glibc-2.26-0063.patch,
gnu/packages/patches/glibc-2.26-0064.patch,
gnu/packages/patches/glibc-2.26-0065.patch,
gnu/packages/patches/glibc-2.26-0066.patch,
gnu/packages/patches/glibc-2.26-0067.patch,
gnu/packages/patches/glibc-2.26-0068.patch,
gnu/packages/patches/glibc-2.26-0069.patch,
gnu/packages/patches/glibc-2.26-0070.patch,
gnu/packages/patches/glibc-2.26-0071.patch,
gnu/packages/patches/glibc-2.26-0072.patch,
gnu/packages/patches/glibc-2.26-0073.patch,
gnu/packages/patches/glibc-2.26-0074.patch,
gnu/packages/patches/glibc-2.26-0075.patch,
gnu/packages/patches/glibc-2.26-0076.patch,
gnu/packages/patches/glibc-2.26-0077.patch,
gnu/packages/patches/glibc-2.26-0078.patch,
gnu/packages/patches/glibc-2.26-0079.patch,
gnu/packages/patches/glibc-2.26-0080.patch,
gnu/packages/patches/glibc-2.26-0081.patch,
gnu/packages/patches/glibc-2.26-0082.patch,
gnu/packages/patches/glibc-2.26-0083.patch,
gnu/packages/patches/glibc-2.26-0084.patch,
gnu/packages/patches/glibc-2.26-0085.patch,
gnu/packages/patches/glibc-2.26-0086.patch,
gnu/packages/patches/glibc-2.26-0087.patch,
gnu/packages/patches/glibc-2.26-0088.patch,
gnu/packages/patches/glibc-2.26-0089.patch,
gnu/packages/patches/glibc-2.26-0090.patch: New files.
* gnu/local.mk (dist_patch_DATA): Register them.
* gnu/packages/base.scm (glibc/linux)[source]: Use them.
[version]: Update to 2.26.90.
---
 gnu/local.mk                               |   90 +
 gnu/packages/base.scm                      |   96 +-
 gnu/packages/patches/glibc-2-26-0001.patch |   52 +
 gnu/packages/patches/glibc-2-26-0002.patch |   72 +
 gnu/packages/patches/glibc-2-26-0003.patch |   38 +
 gnu/packages/patches/glibc-2-26-0004.patch |   87 +
 gnu/packages/patches/glibc-2-26-0005.patch |  197 +
 gnu/packages/patches/glibc-2-26-0006.patch |   66 +
 gnu/packages/patches/glibc-2-26-0007.patch |   66 +
 gnu/packages/patches/glibc-2-26-0008.patch |   70 +
 gnu/packages/patches/glibc-2-26-0009.patch |   74 +
 gnu/packages/patches/glibc-2-26-0010.patch |   68 +
 gnu/packages/patches/glibc-2-26-0011.patch |   61 +
 gnu/packages/patches/glibc-2-26-0012.patch |  204 ++
 gnu/packages/patches/glibc-2-26-0013.patch |   23 +
 gnu/packages/patches/glibc-2-26-0014.patch |   56 +
 gnu/packages/patches/glibc-2-26-0015.patch |   75 +
 gnu/packages/patches/glibc-2-26-0016.patch |  235 ++
 gnu/packages/patches/glibc-2-26-0017.patch |   53 +
 gnu/packages/patches/glibc-2-26-0018.patch |  225 ++
 gnu/packages/patches/glibc-2-26-0019.patch |   56 +
 gnu/packages/patches/glibc-2-26-0020.patch |   42 +
 gnu/packages/patches/glibc-2-26-0021.patch |   94 +
 gnu/packages/patches/glibc-2-26-0022.patch |  112 +
 gnu/packages/patches/glibc-2-26-0023.patch |  164 +
 gnu/packages/patches/glibc-2-26-0024.patch |   49 +
 gnu/packages/patches/glibc-2-26-0025.patch |   40 +
 gnu/packages/patches/glibc-2-26-0026.patch |   53 +
 gnu/packages/patches/glibc-2-26-0027.patch |  364 ++
 gnu/packages/patches/glibc-2-26-0028.patch |  341 ++
 gnu/packages/patches/glibc-2-26-0029.patch |  308 ++
 gnu/packages/patches/glibc-2-26-0030.patch |   50 +
 gnu/packages/patches/glibc-2-26-0031.patch |   50 +
 gnu/packages/patches/glibc-2-26-0032.patch |   34 +
 gnu/packages/patches/glibc-2-26-0033.patch |  132 +
 gnu/packages/patches/glibc-2-26-0034.patch |   54 +
 gnu/packages/patches/glibc-2-26-0035.patch |   36 +
 gnu/packages/patches/glibc-2-26-0036.patch |   38 +
 gnu/packages/patches/glibc-2-26-0037.patch |  649 ++++
 gnu/packages/patches/glibc-2-26-0038.patch |  214 ++
 gnu/packages/patches/glibc-2-26-0039.patch |   36 +
 gnu/packages/patches/glibc-2-26-0040.patch |   71 +
 gnu/packages/patches/glibc-2-26-0041.patch |   80 +
 gnu/packages/patches/glibc-2-26-0042.patch |  157 +
 gnu/packages/patches/glibc-2-26-0043.patch |   24 +
 gnu/packages/patches/glibc-2-26-0044.patch |   96 +
 gnu/packages/patches/glibc-2-26-0045.patch |  238 ++
 gnu/packages/patches/glibc-2-26-0046.patch |   59 +
 gnu/packages/patches/glibc-2-26-0047.patch |  209 ++
 gnu/packages/patches/glibc-2-26-0048.patch |   18 +
 gnu/packages/patches/glibc-2-26-0049.patch |  837 +++++
 gnu/packages/patches/glibc-2-26-0050.patch |   53 +
 gnu/packages/patches/glibc-2-26-0051.patch | 2933 +++++++++++++++
 gnu/packages/patches/glibc-2-26-0052.patch |  406 +++
 gnu/packages/patches/glibc-2-26-0053.patch |   34 +
 gnu/packages/patches/glibc-2-26-0054.patch |   56 +
 gnu/packages/patches/glibc-2-26-0055.patch |  157 +
 gnu/packages/patches/glibc-2-26-0056.patch | 3930 ++++++++++++++++++++
 gnu/packages/patches/glibc-2-26-0057.patch | 5465 ++++++++++++++++++++++++++++
 gnu/packages/patches/glibc-2-26-0058.patch |   86 +
 gnu/packages/patches/glibc-2-26-0059.patch |  437 +++
 gnu/packages/patches/glibc-2-26-0060.patch |  369 ++
 gnu/packages/patches/glibc-2-26-0061.patch |  679 ++++
 gnu/packages/patches/glibc-2-26-0062.patch |  160 +
 gnu/packages/patches/glibc-2-26-0063.patch |   48 +
 gnu/packages/patches/glibc-2-26-0064.patch | 2141 +++++++++++
 gnu/packages/patches/glibc-2-26-0065.patch |   50 +
 gnu/packages/patches/glibc-2-26-0066.patch |  204 ++
 gnu/packages/patches/glibc-2-26-0067.patch |  251 ++
 gnu/packages/patches/glibc-2-26-0068.patch |  970 +++++
 gnu/packages/patches/glibc-2-26-0069.patch |   81 +
 gnu/packages/patches/glibc-2-26-0070.patch |   26 +
 gnu/packages/patches/glibc-2-26-0071.patch |   60 +
 gnu/packages/patches/glibc-2-26-0072.patch |  135 +
 gnu/packages/patches/glibc-2-26-0073.patch |  247 ++
 gnu/packages/patches/glibc-2-26-0074.patch |  482 +++
 gnu/packages/patches/glibc-2-26-0075.patch |   56 +
 gnu/packages/patches/glibc-2-26-0076.patch |  158 +
 gnu/packages/patches/glibc-2-26-0077.patch |   61 +
 gnu/packages/patches/glibc-2-26-0078.patch |  354 ++
 gnu/packages/patches/glibc-2-26-0079.patch |  535 +++
 gnu/packages/patches/glibc-2-26-0080.patch |   50 +
 gnu/packages/patches/glibc-2-26-0081.patch |   84 +
 gnu/packages/patches/glibc-2-26-0082.patch |   51 +
 gnu/packages/patches/glibc-2-26-0083.patch |  180 +
 gnu/packages/patches/glibc-2-26-0084.patch |   37 +
 gnu/packages/patches/glibc-2-26-0085.patch |  114 +
 gnu/packages/patches/glibc-2-26-0086.patch |   34 +
 gnu/packages/patches/glibc-2-26-0087.patch |  332 ++
 gnu/packages/patches/glibc-2-26-0088.patch |  119 +
 gnu/packages/patches/glibc-2-26-0089.patch |   35 +
 gnu/packages/patches/glibc-2-26-0090.patch |  131 +
 92 files changed, 28402 insertions(+), 2 deletions(-)
 create mode 100644 gnu/packages/patches/glibc-2-26-0001.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0002.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0003.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0004.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0005.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0006.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0007.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0008.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0009.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0010.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0011.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0012.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0013.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0014.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0015.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0016.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0017.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0018.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0019.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0020.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0021.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0022.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0023.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0024.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0025.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0026.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0027.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0028.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0029.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0030.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0031.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0032.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0033.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0034.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0035.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0036.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0037.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0038.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0039.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0040.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0041.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0042.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0043.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0044.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0045.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0046.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0047.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0048.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0049.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0050.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0051.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0052.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0053.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0054.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0055.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0056.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0057.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0058.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0059.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0060.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0061.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0062.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0063.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0064.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0065.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0066.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0067.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0068.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0069.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0070.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0071.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0072.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0073.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0074.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0075.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0076.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0077.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0078.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0079.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0080.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0081.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0082.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0083.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0084.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0085.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0086.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0087.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0088.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0089.patch
 create mode 100644 gnu/packages/patches/glibc-2-26-0090.patch

diff --git a/gnu/local.mk b/gnu/local.mk
index be093eccd..08749ad66 100644
--- a/gnu/local.mk
+++ b/gnu/local.mk
@@ -665,6 +665,96 @@ dist_patch_DATA =						\
   %D%/packages/patches/glib-networking-ssl-cert-file.patch	\
   %D%/packages/patches/glib-respect-datadir.patch		\
   %D%/packages/patches/glib-tests-timer.patch			\
+  %D%/packages/patches/glibc-2.26-0001.patch			\
+  %D%/packages/patches/glibc-2.26-0002.patch			\
+  %D%/packages/patches/glibc-2.26-0003.patch			\
+  %D%/packages/patches/glibc-2.26-0004.patch			\
+  %D%/packages/patches/glibc-2.26-0005.patch			\
+  %D%/packages/patches/glibc-2.26-0006.patch			\
+  %D%/packages/patches/glibc-2.26-0007.patch			\
+  %D%/packages/patches/glibc-2.26-0008.patch			\
+  %D%/packages/patches/glibc-2.26-0009.patch			\
+  %D%/packages/patches/glibc-2.26-0010.patch			\
+  %D%/packages/patches/glibc-2.26-0011.patch			\
+  %D%/packages/patches/glibc-2.26-0012.patch			\
+  %D%/packages/patches/glibc-2.26-0013.patch			\
+  %D%/packages/patches/glibc-2.26-0014.patch			\
+  %D%/packages/patches/glibc-2.26-0015.patch			\
+  %D%/packages/patches/glibc-2.26-0016.patch			\
+  %D%/packages/patches/glibc-2.26-0017.patch			\
+  %D%/packages/patches/glibc-2.26-0018.patch			\
+  %D%/packages/patches/glibc-2.26-0019.patch			\
+  %D%/packages/patches/glibc-2.26-0020.patch			\
+  %D%/packages/patches/glibc-2.26-0021.patch			\
+  %D%/packages/patches/glibc-2.26-0022.patch			\
+  %D%/packages/patches/glibc-2.26-0023.patch			\
+  %D%/packages/patches/glibc-2.26-0024.patch			\
+  %D%/packages/patches/glibc-2.26-0025.patch			\
+  %D%/packages/patches/glibc-2.26-0026.patch			\
+  %D%/packages/patches/glibc-2.26-0027.patch			\
+  %D%/packages/patches/glibc-2.26-0028.patch			\
+  %D%/packages/patches/glibc-2.26-0029.patch			\
+  %D%/packages/patches/glibc-2.26-0030.patch			\
+  %D%/packages/patches/glibc-2.26-0031.patch			\
+  %D%/packages/patches/glibc-2.26-0032.patch			\
+  %D%/packages/patches/glibc-2.26-0033.patch			\
+  %D%/packages/patches/glibc-2.26-0034.patch			\
+  %D%/packages/patches/glibc-2.26-0035.patch			\
+  %D%/packages/patches/glibc-2.26-0036.patch			\
+  %D%/packages/patches/glibc-2.26-0037.patch			\
+  %D%/packages/patches/glibc-2.26-0038.patch			\
+  %D%/packages/patches/glibc-2.26-0039.patch			\
+  %D%/packages/patches/glibc-2.26-0040.patch			\
+  %D%/packages/patches/glibc-2.26-0041.patch			\
+  %D%/packages/patches/glibc-2.26-0042.patch			\
+  %D%/packages/patches/glibc-2.26-0043.patch			\
+  %D%/packages/patches/glibc-2.26-0044.patch			\
+  %D%/packages/patches/glibc-2.26-0045.patch			\
+  %D%/packages/patches/glibc-2.26-0046.patch			\
+  %D%/packages/patches/glibc-2.26-0047.patch			\
+  %D%/packages/patches/glibc-2.26-0048.patch			\
+  %D%/packages/patches/glibc-2.26-0049.patch			\
+  %D%/packages/patches/glibc-2.26-0050.patch			\
+  %D%/packages/patches/glibc-2.26-0051.patch			\
+  %D%/packages/patches/glibc-2.26-0052.patch			\
+  %D%/packages/patches/glibc-2.26-0053.patch			\
+  %D%/packages/patches/glibc-2.26-0054.patch			\
+  %D%/packages/patches/glibc-2.26-0055.patch			\
+  %D%/packages/patches/glibc-2.26-0056.patch			\
+  %D%/packages/patches/glibc-2.26-0057.patch			\
+  %D%/packages/patches/glibc-2.26-0058.patch			\
+  %D%/packages/patches/glibc-2.26-0059.patch			\
+  %D%/packages/patches/glibc-2.26-0060.patch			\
+  %D%/packages/patches/glibc-2.26-0061.patch			\
+  %D%/packages/patches/glibc-2.26-0062.patch			\
+  %D%/packages/patches/glibc-2.26-0063.patch			\
+  %D%/packages/patches/glibc-2.26-0064.patch			\
+  %D%/packages/patches/glibc-2.26-0065.patch			\
+  %D%/packages/patches/glibc-2.26-0066.patch			\
+  %D%/packages/patches/glibc-2.26-0067.patch			\
+  %D%/packages/patches/glibc-2.26-0068.patch			\
+  %D%/packages/patches/glibc-2.26-0069.patch			\
+  %D%/packages/patches/glibc-2.26-0070.patch			\
+  %D%/packages/patches/glibc-2.26-0071.patch			\
+  %D%/packages/patches/glibc-2.26-0072.patch			\
+  %D%/packages/patches/glibc-2.26-0073.patch			\
+  %D%/packages/patches/glibc-2.26-0074.patch			\
+  %D%/packages/patches/glibc-2.26-0075.patch			\
+  %D%/packages/patches/glibc-2.26-0076.patch			\
+  %D%/packages/patches/glibc-2.26-0077.patch			\
+  %D%/packages/patches/glibc-2.26-0078.patch			\
+  %D%/packages/patches/glibc-2.26-0079.patch			\
+  %D%/packages/patches/glibc-2.26-0080.patch			\
+  %D%/packages/patches/glibc-2.26-0081.patch			\
+  %D%/packages/patches/glibc-2.26-0082.patch			\
+  %D%/packages/patches/glibc-2.26-0083.patch			\
+  %D%/packages/patches/glibc-2.26-0084.patch			\
+  %D%/packages/patches/glibc-2.26-0085.patch			\
+  %D%/packages/patches/glibc-2.26-0086.patch			\
+  %D%/packages/patches/glibc-2.26-0087.patch			\
+  %D%/packages/patches/glibc-2.26-0088.patch			\
+  %D%/packages/patches/glibc-2.26-0089.patch			\
+  %D%/packages/patches/glibc-2.26-0090.patch			\
   %D%/packages/patches/glibc-CVE-2015-5180.patch		\
   %D%/packages/patches/glibc-CVE-2015-7547.patch		\
   %D%/packages/patches/glibc-CVE-2016-3075.patch		\
diff --git a/gnu/packages/base.scm b/gnu/packages/base.scm
index a6663c5cf..1eab8abcd 100644
--- a/gnu/packages/base.scm
+++ b/gnu/packages/base.scm
@@ -515,7 +515,7 @@ store.")
 (define-public glibc/linux
   (package
    (name "glibc")
-   (version "2.26")
+   (version "2.26.90")
    (source (origin
             (method url-fetch)
             (uri (string-append "mirror://gnu/glibc/glibc-"
@@ -533,7 +533,99 @@ store.")
             (modules '((guix build utils)))
             (patches (search-patches "glibc-ldd-x86_64.patch"
                                      "glibc-versioned-locpath.patch"
-                                     "glibc-CVE-2017-15670-15671.patch"
+                                     "glibc-2.26-0001.patch"
+                                     "glibc-2.26-0002.patch"
+                                     "glibc-2.26-0003.patch"
+                                     "glibc-2.26-0004.patch"
+                                     "glibc-2.26-0005.patch"
+                                     "glibc-2.26-0006.patch"
+                                     "glibc-2.26-0007.patch"
+                                     "glibc-2.26-0008.patch"
+                                     "glibc-2.26-0009.patch"
+                                     "glibc-2.26-0010.patch"
+                                     "glibc-2.26-0011.patch"
+                                     "glibc-2.26-0012.patch"
+                                     "glibc-2.26-0013.patch"
+                                     "glibc-2.26-0014.patch"
+                                     "glibc-2.26-0015.patch"
+                                     "glibc-2.26-0016.patch"
+                                     "glibc-2.26-0017.patch"
+                                     "glibc-2.26-0018.patch"
+                                     "glibc-2.26-0019.patch"
+                                     "glibc-2.26-0020.patch"
+                                     "glibc-2.26-0021.patch"
+                                     "glibc-2.26-0022.patch"
+                                     "glibc-2.26-0023.patch"
+                                     "glibc-2.26-0024.patch"
+                                     "glibc-2.26-0025.patch"
+                                     "glibc-2.26-0026.patch"
+                                     "glibc-2.26-0027.patch"
+                                     "glibc-2.26-0028.patch"
+                                     "glibc-2.26-0029.patch"
+                                     "glibc-2.26-0030.patch"
+                                     "glibc-2.26-0031.patch"
+                                     "glibc-2.26-0032.patch"
+                                     "glibc-2.26-0033.patch"
+                                     "glibc-2.26-0034.patch"
+                                     "glibc-2.26-0035.patch"
+                                     "glibc-2.26-0036.patch"
+                                     "glibc-2.26-0037.patch"
+                                     "glibc-2.26-0038.patch"
+                                     "glibc-2.26-0039.patch"
+                                     "glibc-2.26-0040.patch"
+                                     "glibc-2.26-0041.patch"
+                                     "glibc-2.26-0042.patch"
+                                     "glibc-2.26-0043.patch"
+                                     "glibc-2.26-0044.patch"
+                                     "glibc-2.26-0045.patch"
+                                     "glibc-2.26-0046.patch"
+                                     "glibc-2.26-0047.patch"
+                                     "glibc-2.26-0048.patch"
+                                     "glibc-2.26-0049.patch"
+                                     "glibc-2.26-0050.patch"
+                                     "glibc-2.26-0051.patch"
+                                     "glibc-2.26-0052.patch"
+                                     "glibc-2.26-0053.patch"
+                                     "glibc-2.26-0054.patch"
+                                     "glibc-2.26-0055.patch"
+                                     "glibc-2.26-0056.patch"
+                                     "glibc-2.26-0057.patch"
+                                     "glibc-2.26-0058.patch"
+                                     "glibc-2.26-0059.patch"
+                                     "glibc-2.26-0060.patch"
+                                     "glibc-2.26-0061.patch"
+                                     "glibc-2.26-0062.patch"
+                                     "glibc-2.26-0063.patch"
+                                     "glibc-2.26-0064.patch"
+                                     ;; XXX: This patch is the same as
+                                     ;; "glibc-CVE-2017-15670-15671.patch", but
+                                     ;; contains updates to NEWS and ChangeLog.
+                                     "glibc-2.26-0065.patch"
+                                     "glibc-2.26-0066.patch"
+                                     "glibc-2.26-0067.patch"
+                                     "glibc-2.26-0068.patch"
+                                     "glibc-2.26-0069.patch"
+                                     "glibc-2.26-0070.patch"
+                                     "glibc-2.26-0071.patch"
+                                     "glibc-2.26-0072.patch"
+                                     "glibc-2.26-0073.patch"
+                                     "glibc-2.26-0074.patch"
+                                     "glibc-2.26-0075.patch"
+                                     "glibc-2.26-0076.patch"
+                                     "glibc-2.26-0077.patch"
+                                     "glibc-2.26-0078.patch"
+                                     "glibc-2.26-0079.patch"
+                                     "glibc-2.26-0080.patch"
+                                     "glibc-2.26-0081.patch"
+                                     "glibc-2.26-0082.patch"
+                                     "glibc-2.26-0083.patch"
+                                     "glibc-2.26-0084.patch"
+                                     "glibc-2.26-0085.patch"
+                                     "glibc-2.26-0086.patch"
+                                     "glibc-2.26-0087.patch"
+                                     "glibc-2.26-0088.patch"
+                                     "glibc-2.26-0089.patch"
+                                     "glibc-2.26-0090.patch"
                                      "glibc-o-largefile.patch"))))
    (build-system gnu-build-system)
 
diff --git a/gnu/packages/patches/glibc-2-26-0001.patch b/gnu/packages/patches/glibc-2-26-0001.patch
new file mode 100644
index 000000000..49d9d5222
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0001.patch
@@ -0,0 +1,52 @@
+From dc258ce62ae0bbb456c6a855dbb6b384ecf7e988 Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Thu, 3 Aug 2017 13:59:17 +0200
+Subject: [PATCH 01/90] getaddrinfo: Release resolver context on error in
+ gethosts [BZ #21885]
+
+(cherry picked from commit 964263bb8d650f1681665c55704fb01a8e725621)
+
+diff --git a/ChangeLog b/ChangeLog
+index 8dbfc7eaff..28ce9c8479 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-08-03  Florian Weimer  <fweimer@redhat.com>
++
++	[BZ #21885]
++	* sysdeps/posix/getaddrinfo.c (gethosts): Release resolver context
++	on memory allocation failure.
++
+ 2017-08-02  Siddhesh Poyarekar  <siddhesh@sourceware.org>
+ 
+ 	* version.h (RELEASE): Set to "stable"
+diff --git a/NEWS b/NEWS
+index 8295f20c0a..9a64579658 100644
+--- a/NEWS
++++ b/NEWS
+@@ -5,6 +5,12 @@ See the end for copying conditions.
+ Please send GNU C library bug reports via <http://sourceware.org/bugzilla/>
+ using `glibc' in the "product" field.
+ \f
++Version 2.26.1
++
++The following bugs are resolved with this release:
++
++  [21885] getaddrinfo: Release resolver context on error in gethosts
++\f
+ Version 2.26
+ 
+ Major new features:
+diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
+index efa7118498..699411cc92 100644
+--- a/sysdeps/posix/getaddrinfo.c
++++ b/sysdeps/posix/getaddrinfo.c
+@@ -255,6 +255,8 @@ convert_hostent_to_gaih_addrtuple (const struct addrinfo *req,
+       break;								      \
+     if (!scratch_buffer_grow (tmpbuf))					      \
+       {									      \
++	__resolv_context_enable_inet6 (res_ctx, res_enable_inet6);	      \
++	__resolv_context_put (res_ctx);					      \
+ 	result = -EAI_MEMORY;						      \
+ 	goto free_and_return;						      \
+       }									      \
diff --git a/gnu/packages/patches/glibc-2-26-0002.patch b/gnu/packages/patches/glibc-2-26-0002.patch
new file mode 100644
index 000000000..237285b61
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0002.patch
@@ -0,0 +1,72 @@
+From 665ce88d68fd13c5c4cbaf2808434c618745137c Mon Sep 17 00:00:00 2001
+From: Aurelien Jarno <aurelien@aurel32.net>
+Date: Thu, 3 Aug 2017 22:33:19 +0000
+Subject: [PATCH 02/90] i686/multiarch: Regenerate ulps
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+This comes from running “make regen-ulps” on an AMD Opteron 2378 CPU.
+
+Changelog:
+	* sysdeps/i386/i686/fpu/multiarch/libm-test-ulps: Regenerated.
+(cherry picked from commit 144bdab050bdd78c327d98a79b15c5b164e1d56f)
+
+diff --git a/ChangeLog b/ChangeLog
+index 28ce9c8479..3478699b10 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,7 @@
++2017-08-03  Aurelien Jarno  <aurelien@aurel32.net>
++
++	* sysdeps/i386/i686/fpu/multiarch/libm-test-ulps: Regenerated.
++
+ 2017-08-03  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	[BZ #21885]
+diff --git a/sysdeps/i386/i686/fpu/multiarch/libm-test-ulps b/sysdeps/i386/i686/fpu/multiarch/libm-test-ulps
+index 81dd1a09ea..053f5ec972 100644
+--- a/sysdeps/i386/i686/fpu/multiarch/libm-test-ulps
++++ b/sysdeps/i386/i686/fpu/multiarch/libm-test-ulps
+@@ -58,7 +58,7 @@ double: 1
+ float128: 2
+ idouble: 1
+ ifloat128: 2
+-ildouble: 4
++ildouble: 5
+ ldouble: 3
+ 
+ Function: "asin":
+@@ -1154,8 +1154,8 @@ float128: 4
+ idouble: 3
+ ifloat: 3
+ ifloat128: 4
+-ildouble: 7
+-ldouble: 7
++ildouble: 8
++ldouble: 8
+ 
+ Function: Imaginary part of "clog10_upward":
+ double: 1
+@@ -2013,8 +2013,8 @@ double: 3
+ float: 4
+ idouble: 3
+ ifloat: 4
+-ildouble: 5
+-ldouble: 5
++ildouble: 6
++ldouble: 6
+ 
+ Function: "hypot":
+ double: 1
+@@ -2205,8 +2205,8 @@ float128: 8
+ idouble: 3
+ ifloat: 4
+ ifloat128: 8
+-ildouble: 5
+-ldouble: 5
++ildouble: 6
++ldouble: 6
+ 
+ Function: "log":
+ double: 1
diff --git a/gnu/packages/patches/glibc-2-26-0003.patch b/gnu/packages/patches/glibc-2-26-0003.patch
new file mode 100644
index 000000000..3a9e9d706
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0003.patch
@@ -0,0 +1,38 @@
+From a4e5aa1a443cfad09bc98f9bb527995371a53a88 Mon Sep 17 00:00:00 2001
+From: Aurelien Jarno <aurelien@aurel32.net>
+Date: Thu, 3 Aug 2017 22:35:48 +0000
+Subject: [PATCH 03/90] Fix the return type of the getentropy stub
+
+The return type of the getentropy stub is wrongly defined as ssize_t,
+while both the <sys/random.h> header and the Linux implementation
+define it as int. This patch fixes that.
+
+Changelog:
+	* stdlib/getentropy.c (getentropy): Change return type to int.
+(cherry picked from commit 2b34e2716f1e84b2c3457ffc868c3dc775b55845)
+
+diff --git a/ChangeLog b/ChangeLog
+index 3478699b10..4357ad1eb8 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,7 @@
++2017-08-03  Aurelien Jarno  <aurelien@aurel32.net>
++
++	* stdlib/getentropy.c (getentropy): Change return type to int.
++
+ 2017-08-03  Aurelien Jarno  <aurelien@aurel32.net>
+ 
+ 	* sysdeps/i386/i686/fpu/multiarch/libm-test-ulps: Regenerated.
+diff --git a/stdlib/getentropy.c b/stdlib/getentropy.c
+index a71d4cd8f5..a88bbf8de3 100644
+--- a/stdlib/getentropy.c
++++ b/stdlib/getentropy.c
+@@ -21,7 +21,7 @@
+ 
+ /* Write LENGTH bytes of randomness starting at BUFFER.  Return 0 on
+    success and -1 on failure.  */
+-ssize_t
++int
+ getentropy (void *buffer, size_t length)
+ {
+   __set_errno (ENOSYS);
diff --git a/gnu/packages/patches/glibc-2-26-0004.patch b/gnu/packages/patches/glibc-2-26-0004.patch
new file mode 100644
index 000000000..f4b60c030
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0004.patch
@@ -0,0 +1,87 @@
+From 799859f6635d68487ea2472bd79d96a7639a1ab1 Mon Sep 17 00:00:00 2001
+From: "H.J. Lu" <hjl.tools@gmail.com>
+Date: Sun, 6 Aug 2017 10:44:30 -0700
+Subject: [PATCH 04/90] x86-64: Use _dl_runtime_resolve_opt only with AVX512F
+ [BZ #21871]
+
+On AVX machines with XGETBV (ECX == 1) like Skylake processors,
+
+(gdb) disass _dl_runtime_resolve_avx_opt
+Dump of assembler code for function _dl_runtime_resolve_avx_opt:
+   0x0000000000015890 <+0>:	push   %rax
+   0x0000000000015891 <+1>:	push   %rcx
+   0x0000000000015892 <+2>:	push   %rdx
+   0x0000000000015893 <+3>:	mov    $0x1,%ecx
+   0x0000000000015898 <+8>:	xgetbv
+   0x000000000001589b <+11>:	mov    %eax,%r11d
+   0x000000000001589e <+14>:	pop    %rdx
+   0x000000000001589f <+15>:	pop    %rcx
+   0x00000000000158a0 <+16>:	pop    %rax
+   0x00000000000158a1 <+17>:	and    $0x4,%r11d
+   0x00000000000158a5 <+21>:	bnd je 0x16200 <_dl_runtime_resolve_sse_vex>
+End of assembler dump.
+
+is slower than:
+
+(gdb) disass _dl_runtime_resolve_avx_slow
+Dump of assembler code for function _dl_runtime_resolve_avx_slow:
+   0x0000000000015850 <+0>:	vorpd  %ymm0,%ymm1,%ymm8
+   0x0000000000015854 <+4>:	vorpd  %ymm2,%ymm3,%ymm9
+   0x0000000000015858 <+8>:	vorpd  %ymm4,%ymm5,%ymm10
+   0x000000000001585c <+12>:	vorpd  %ymm6,%ymm7,%ymm11
+   0x0000000000015860 <+16>:	vorpd  %ymm8,%ymm9,%ymm9
+   0x0000000000015865 <+21>:	vorpd  %ymm10,%ymm11,%ymm10
+   0x000000000001586a <+26>:	vpcmpeqd %xmm8,%xmm8,%xmm8
+   0x000000000001586f <+31>:	vorpd  %ymm9,%ymm10,%ymm10
+   0x0000000000015874 <+36>:	vptest %ymm10,%ymm8
+   0x0000000000015879 <+41>:	bnd jae 0x158b0 <_dl_runtime_resolve_avx>
+   0x000000000001587c <+44>:	vzeroupper
+   0x000000000001587f <+47>:	bnd jmpq 0x16200 <_dl_runtime_resolve_sse_vex>
+End of assembler dump.
+(gdb)
+
+since xgetbv takes much more cycles than single cycle operations like
+vpord/vvpcmpeq/ptest.  _dl_runtime_resolve_opt should be used only with
+AVX512 where AVX512 instructions lead to lower CPU frequency on Skylake
+server.
+
+	[BZ #21871]
+	* sysdeps/x86/cpu-features.c (init_cpu_features): Set
+	bit_arch_Use_dl_runtime_resolve_opt only with AVX512F.
+
+(cherry picked from commit d2cf37c0a2a375cf2fde69f1afbcc49e45368fc4)
+
+diff --git a/ChangeLog b/ChangeLog
+index 4357ad1eb8..764c827161 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-08-06  H.J. Lu  <hongjiu.lu@intel.com>
++
++	[BZ #21871]
++	* sysdeps/x86/cpu-features.c (init_cpu_features): Set
++	bit_arch_Use_dl_runtime_resolve_opt only with AVX512F.
++
+ 2017-08-03  Aurelien Jarno  <aurelien@aurel32.net>
+ 
+ 	* stdlib/getentropy.c (getentropy): Change return type to int.
+diff --git a/sysdeps/x86/cpu-features.c b/sysdeps/x86/cpu-features.c
+index 1d087ea732..6f900840d4 100644
+--- a/sysdeps/x86/cpu-features.c
++++ b/sysdeps/x86/cpu-features.c
+@@ -244,10 +244,13 @@ init_cpu_features (struct cpu_features *cpu_features)
+ 	  |= bit_arch_Prefer_No_AVX512;
+ 
+       /* To avoid SSE transition penalty, use _dl_runtime_resolve_slow.
+-         If XGETBV suports ECX == 1, use _dl_runtime_resolve_opt.  */
++         If XGETBV suports ECX == 1, use _dl_runtime_resolve_opt.
++	 Use _dl_runtime_resolve_opt only with AVX512F since it is
++	 slower than _dl_runtime_resolve_slow with AVX.  */
+       cpu_features->feature[index_arch_Use_dl_runtime_resolve_slow]
+ 	|= bit_arch_Use_dl_runtime_resolve_slow;
+-      if (cpu_features->max_cpuid >= 0xd)
++      if (CPU_FEATURES_ARCH_P (cpu_features, AVX512F_Usable)
++	  && cpu_features->max_cpuid >= 0xd)
+ 	{
+ 	  unsigned int eax;
+ 
diff --git a/gnu/packages/patches/glibc-2-26-0005.patch b/gnu/packages/patches/glibc-2-26-0005.patch
new file mode 100644
index 000000000..b606698e7
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0005.patch
@@ -0,0 +1,197 @@
+From 82efa1ffd43bed1494d20a4b86f6b15ac6bb5545 Mon Sep 17 00:00:00 2001
+From: Adhemerval Zanella <adhemerval.zanella@linaro.org>
+Date: Mon, 17 Jul 2017 10:59:59 -0300
+Subject: [PATCH 05/90] posix: Set p{read,write}v2 to return ENOTSUP (BZ#21780)
+
+Different than other architectures hppa-linux-gnu define different values
+for ENOTSUP and EOPNOTSUPP, where the later is a Linux specific one.
+This leads to tst-preadwritev{64}v2 tests failures:
+
+$ ./testrun.sh misc/tst-preadvwritev2
+error: tst-preadvwritev2-common.c:35: preadv2 failure did not set errno to ENOTSUP (223)
+error: 1 test failures
+
+The straightforward fix is to return the POSIX defined ENOTSUP on all
+p{read,write}v{64}v2 implementations instead of Linux specific one.
+
+Checked on x86_64-linux-gnu and the tst-preadwritev{64}v2 on
+hppa-linux-gnu (although due the installed kernel on my testing system
+the pwritev{64}v2 with an invalid flag still fails due a known kernel
+issue [1]).
+
+	[BZ #21780]
+	* sysdeps/posix/preadv2.c (preadv2): Use ENOTSUP instead of
+	EOPNOTSUPP.
+	* sysdeps/posix/preadv64v2.c (preadv64v2): Likewise.
+	* sysdeps/posix/pwritev2.c (pwritev2): Likewise.
+	* sysdeps/posix/pwritev64v2.c (pwritev64v2): Likewise.
+	* sysdeps/unix/sysv/linux/preadv2.c (preadv2): Likewise.
+	* sysdeps/unix/sysv/linux/preadv64v2.c (preadv64v2): Likewise.
+	* sysdeps/unix/sysv/linux/pwritev2.c (pwritev2): Likewise.
+	* sysdeps/unix/sysv/linux/pwritev64v2.c (pwritev64v2): Likewise.
+
+[1] https://sourceware.org/ml/libc-alpha/2017-06/msg00726.html
+
+Cherry-pick of 852d63120783fae5bf85a067320dc4ba1ed59f11
+
+diff --git a/ChangeLog b/ChangeLog
+index 764c827161..459062cc20 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,16 @@
++2017-08-09  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
++
++	[BZ #21780]
++	* sysdeps/posix/preadv2.c (preadv2): Use ENOTSUP instead of
++	EOPNOTSUPP.
++	* sysdeps/posix/preadv64v2.c (preadv64v2): Likewise.
++	* sysdeps/posix/pwritev2.c (pwritev2): Likewise.
++	* sysdeps/posix/pwritev64v2.c (pwritev64v2): Likewise.
++	* sysdeps/unix/sysv/linux/preadv2.c (preadv2): Likewise.
++	* sysdeps/unix/sysv/linux/preadv64v2.c (preadv64v2): Likewise.
++	* sysdeps/unix/sysv/linux/pwritev2.c (pwritev2): Likewise.
++	* sysdeps/unix/sysv/linux/pwritev64v2.c (pwritev64v2): Likewise.
++
+ 2017-08-06  H.J. Lu  <hongjiu.lu@intel.com>
+ 
+ 	[BZ #21871]
+diff --git a/sysdeps/posix/preadv2.c b/sysdeps/posix/preadv2.c
+index 2a7cf11e27..d27f7028ed 100644
+--- a/sysdeps/posix/preadv2.c
++++ b/sysdeps/posix/preadv2.c
+@@ -28,7 +28,7 @@ preadv2 (int fd, const struct iovec *vector, int count, OFF_T offset,
+ {
+   if (flags != 0)
+     {
+-      __set_errno (EOPNOTSUPP);
++      __set_errno (ENOTSUP);
+       return -1;
+     }
+ 
+diff --git a/sysdeps/posix/preadv64v2.c b/sysdeps/posix/preadv64v2.c
+index e084f3f9e1..ce7cb40bf2 100644
+--- a/sysdeps/posix/preadv64v2.c
++++ b/sysdeps/posix/preadv64v2.c
+@@ -25,7 +25,7 @@ preadv64v2 (int fd, const struct iovec *vector, int count, OFF_T offset,
+ {
+   if (flags != 0)
+     {
+-      __set_errno (EOPNOTSUPP);
++      __set_errno (ENOTSUP);
+       return -1;
+     }
+ 
+diff --git a/sysdeps/posix/pwritev2.c b/sysdeps/posix/pwritev2.c
+index 5b7650c4fc..7ec8cbc407 100644
+--- a/sysdeps/posix/pwritev2.c
++++ b/sysdeps/posix/pwritev2.c
+@@ -28,7 +28,7 @@ pwritev2 (int fd, const struct iovec *vector, int count, OFF_T offset,
+ {
+   if (flags != 0)
+     {
+-      __set_errno (EOPNOTSUPP);
++      __set_errno (ENOTSUP);
+       return -1;
+     }
+ 
+diff --git a/sysdeps/posix/pwritev64v2.c b/sysdeps/posix/pwritev64v2.c
+index 0f2f9ef863..be98aeed9d 100644
+--- a/sysdeps/posix/pwritev64v2.c
++++ b/sysdeps/posix/pwritev64v2.c
+@@ -26,7 +26,7 @@ pwritev64v2 (int fd, const struct iovec *vector, int count, OFF_T offset,
+ {
+   if (flags != 0)
+     {
+-      __set_errno (EOPNOTSUPP);
++      __set_errno (ENOTSUP);
+       return -1;
+     }
+ 
+diff --git a/sysdeps/unix/sysv/linux/preadv2.c b/sysdeps/unix/sysv/linux/preadv2.c
+index 11fe85eaa8..137e2dd791 100644
+--- a/sysdeps/unix/sysv/linux/preadv2.c
++++ b/sysdeps/unix/sysv/linux/preadv2.c
+@@ -32,7 +32,7 @@ preadv2 (int fd, const struct iovec *vector, int count, off_t offset,
+ # ifdef __NR_preadv2
+   ssize_t result = SYSCALL_CANCEL (preadv2, fd, vector, count,
+ 				   LO_HI_LONG (offset), flags);
+-  if (result >= 0 || errno != ENOSYS)
++  if (result >= 0)
+     return result;
+ # endif
+   /* Trying to emulate the preadv2 syscall flags is troublesome:
+@@ -46,7 +46,7 @@ preadv2 (int fd, const struct iovec *vector, int count, off_t offset,
+ 
+   if (flags != 0)
+     {
+-      __set_errno (EOPNOTSUPP);
++      __set_errno (ENOTSUP);
+       return -1;
+     }
+   return preadv (fd, vector, count, offset);
+diff --git a/sysdeps/unix/sysv/linux/preadv64v2.c b/sysdeps/unix/sysv/linux/preadv64v2.c
+index 9d7f8c9893..8f413253f4 100644
+--- a/sysdeps/unix/sysv/linux/preadv64v2.c
++++ b/sysdeps/unix/sysv/linux/preadv64v2.c
+@@ -30,7 +30,7 @@ preadv64v2 (int fd, const struct iovec *vector, int count, off64_t offset,
+ #ifdef __NR_preadv64v2
+   ssize_t result = SYSCALL_CANCEL (preadv64v2, fd, vector, count,
+ 				   LO_HI_LONG (offset), flags);
+-  if (result >= 0 || errno != ENOSYS)
++  if (result >= 0)
+     return result;
+ #endif
+   /* Trying to emulate the preadv2 syscall flags is troublesome:
+@@ -44,7 +44,7 @@ preadv64v2 (int fd, const struct iovec *vector, int count, off64_t offset,
+ 
+   if (flags != 0)
+     {
+-      __set_errno (EOPNOTSUPP);
++      __set_errno (ENOTSUP);
+       return -1;
+     }
+   return preadv64 (fd, vector, count, offset);
+diff --git a/sysdeps/unix/sysv/linux/pwritev2.c b/sysdeps/unix/sysv/linux/pwritev2.c
+index 72f0471f96..8e5032fe2f 100644
+--- a/sysdeps/unix/sysv/linux/pwritev2.c
++++ b/sysdeps/unix/sysv/linux/pwritev2.c
+@@ -28,7 +28,7 @@ pwritev2 (int fd, const struct iovec *vector, int count, off_t offset,
+ # ifdef __NR_pwritev2
+   ssize_t result = SYSCALL_CANCEL (pwritev2, fd, vector, count,
+ 				   LO_HI_LONG (offset), flags);
+-  if (result >= 0 || errno != ENOSYS)
++  if (result >= 0)
+     return result;
+ # endif
+   /* Trying to emulate the pwritev2 syscall flags is troublesome:
+@@ -42,7 +42,7 @@ pwritev2 (int fd, const struct iovec *vector, int count, off_t offset,
+ 
+   if (flags != 0)
+     {
+-      __set_errno (EOPNOTSUPP);
++      __set_errno (ENOTSUP);
+       return -1;
+     }
+   return pwritev (fd, vector, count, offset);
+diff --git a/sysdeps/unix/sysv/linux/pwritev64v2.c b/sysdeps/unix/sysv/linux/pwritev64v2.c
+index def9a0bc57..d2800c6657 100644
+--- a/sysdeps/unix/sysv/linux/pwritev64v2.c
++++ b/sysdeps/unix/sysv/linux/pwritev64v2.c
+@@ -30,7 +30,7 @@ pwritev64v2 (int fd, const struct iovec *vector, int count, off64_t offset,
+ #ifdef __NR_pwritev64v2
+   ssize_t result = SYSCALL_CANCEL (pwritev64v2, fd, vector, count,
+ 				   LO_HI_LONG (offset), flags);
+-  if (result >= 0 || errno != ENOSYS)
++  if (result >= 0)
+     return result;
+ #endif
+   /* Trying to emulate the pwritev2 syscall flags is troublesome:
+@@ -44,7 +44,7 @@ pwritev64v2 (int fd, const struct iovec *vector, int count, off64_t offset,
+ 
+   if (flags != 0)
+     {
+-      __set_errno (EOPNOTSUPP);
++      __set_errno (ENOTSUP);
+       return -1;
+     }
+   return pwritev64 (fd, vector, count, offset);
diff --git a/gnu/packages/patches/glibc-2-26-0006.patch b/gnu/packages/patches/glibc-2-26-0006.patch
new file mode 100644
index 000000000..c1502c56c
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0006.patch
@@ -0,0 +1,66 @@
+From 302434688d925134065498b4a5574f6ee6bfb9fd Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Thu, 10 Aug 2017 09:10:36 +0200
+Subject: [PATCH 06/90] nss: Call __resolv_context_put before early return in
+ get*_r [BZ #21932]
+
+This corrects an oversight introduced in commit
+352f4ff9a268b81ef5d4b2413f582565806e4790 (resolv: Introduce struct
+resolv_context).
+
+(cherry picked from commit 3016149819268b14660f791b971910ccc2cc13e5)
+
+diff --git a/ChangeLog b/ChangeLog
+index 459062cc20..3127648626 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-08-09  Florian Weimer  <fweimer@redhat.com>
++
++	[BZ #21932]
++	* nss/getXXbyYY_r.c (REENTRANT_NAME): Call __resolv_context_put
++	before early return.
++
+ 2017-08-09  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
+ 
+ 	[BZ #21780]
+diff --git a/NEWS b/NEWS
+index 9a64579658..ec6cf34122 100644
+--- a/NEWS
++++ b/NEWS
+@@ -10,6 +10,7 @@ Version 2.26.1
+ The following bugs are resolved with this release:
+ 
+   [21885] getaddrinfo: Release resolver context on error in gethosts
++  [21932] Unpaired __resolv_context_get in generic get*_r implementation
+ \f
+ Version 2.26
+ 
+diff --git a/nss/getXXbyYY_r.c b/nss/getXXbyYY_r.c
+index 6c547ea1ca..bce80e05dd 100644
+--- a/nss/getXXbyYY_r.c
++++ b/nss/getXXbyYY_r.c
+@@ -234,6 +234,9 @@ INTERNAL (REENTRANT_NAME) (ADD_PARAMS, LOOKUP_TYPE *resbuf, char *buffer,
+ 				      H_ERRNO_VAR_P))
+     {
+     case -1:
++# ifdef NEED__RES
++      __resolv_context_put (res_ctx);
++# endif
+       return errno;
+     case 1:
+ #ifdef NEED_H_ERRNO
+@@ -253,7 +256,12 @@ INTERNAL (REENTRANT_NAME) (ADD_PARAMS, LOOKUP_TYPE *resbuf, char *buffer,
+       nscd_status = NSCD_NAME (ADD_VARIABLES, resbuf, buffer, buflen, result
+ 			       H_ERRNO_VAR);
+       if (nscd_status >= 0)
+-	return nscd_status;
++	{
++# ifdef NEED__RES
++	  __resolv_context_put (res_ctx);
++# endif
++	  return nscd_status;
++	}
+     }
+ #endif
+ 
diff --git a/gnu/packages/patches/glibc-2-26-0007.patch b/gnu/packages/patches/glibc-2-26-0007.patch
new file mode 100644
index 000000000..82f284800
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0007.patch
@@ -0,0 +1,66 @@
+From c55ad6452e2d63ebf6fcaabb00bfd27aae02ffb6 Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Thu, 10 Aug 2017 15:58:28 +0200
+Subject: [PATCH 07/90] malloc: Avoid optimizer warning with GCC 7 and -O3
+
+(cherry picked from commit eac43cbb8d808a40004aa0a4a286f5c5155beccb)
+
+diff --git a/ChangeLog b/ChangeLog
+index 3127648626..5ea9b8baa7 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-08-10  Florian Weimer  <fweimer@redhat.com>
++
++	* malloc/malloc.c (get_max_fast): Reimplement as an inline
++	function which calls __builtin_unreachable.
++
+ 2017-08-09  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	[BZ #21932]
+diff --git a/malloc/malloc.c b/malloc/malloc.c
+index 54e406bcb6..e3ff778113 100644
+--- a/malloc/malloc.c
++++ b/malloc/malloc.c
+@@ -1658,6 +1658,9 @@ typedef struct malloc_chunk *mfastbinptr;
+ #define arena_is_corrupt(A)	(((A)->flags & ARENA_CORRUPTION_BIT))
+ #define set_arena_corrupt(A)	((A)->flags |= ARENA_CORRUPTION_BIT)
+ 
++/* Maximum size of memory handled in fastbins.  */
++static INTERNAL_SIZE_T global_max_fast;
++
+ /*
+    Set value of max_fast.
+    Use impossibly small value if 0.
+@@ -1668,8 +1671,20 @@ typedef struct malloc_chunk *mfastbinptr;
+ #define set_max_fast(s) \
+   global_max_fast = (((s) == 0)						      \
+                      ? SMALLBIN_WIDTH : ((s + SIZE_SZ) & ~MALLOC_ALIGN_MASK))
+-#define get_max_fast() global_max_fast
+ 
++static inline INTERNAL_SIZE_T
++get_max_fast (void)
++{
++  /* Tell the GCC optimizers that global_max_fast is never larger
++     than MAX_FAST_SIZE.  This avoids out-of-bounds array accesses in
++     _int_malloc after constant propagation of the size parameter.
++     (The code never executes because malloc preserves the
++     global_max_fast invariant, but the optimizers may not recognize
++     this.)  */
++  if (global_max_fast > MAX_FAST_SIZE)
++    __builtin_unreachable ();
++  return global_max_fast;
++}
+ 
+ /*
+    ----------- Internal state representation and initialization -----------
+@@ -1797,9 +1812,6 @@ static struct malloc_par mp_ =
+ #endif
+ };
+ 
+-/* Maximum size of memory handled in fastbins.  */
+-static INTERNAL_SIZE_T global_max_fast;
+-
+ /*
+    Initialize a malloc_state struct.
+ 
diff --git a/gnu/packages/patches/glibc-2-26-0008.patch b/gnu/packages/patches/glibc-2-26-0008.patch
new file mode 100644
index 000000000..5ee3e5524
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0008.patch
@@ -0,0 +1,70 @@
+From 2aa1a7a8f8b9b7879bc6eb1c34d1580f992c406d Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Fri, 11 Aug 2017 15:48:14 +0200
+Subject: [PATCH 08/90] assert: Suppress pedantic warning caused by statement
+ expression [BZ #21242]
+
+(cherry picked from commit 8b2c63e4e2ad1fd161f80004ed30624f2a37b57b)
+
+diff --git a/ChangeLog b/ChangeLog
+index 5ea9b8baa7..0057c0902a 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,10 @@
++2017-08-11  Florian Weimer  <fweimer@redhat.com>
++
++	[BZ #21242]
++	* assert/assert.h [__GNUC__ && !__STRICT_ANSI__] (assert):
++	Suppress pedantic warning resulting from statement expression.
++	(__ASSERT_FUNCTION): Add missing __extension__.
++
+ 2017-08-10  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	* malloc/malloc.c (get_max_fast): Reimplement as an inline
+diff --git a/NEWS b/NEWS
+index ec6cf34122..d57c4052cf 100644
+--- a/NEWS
++++ b/NEWS
+@@ -9,6 +9,7 @@ Version 2.26.1
+ 
+ The following bugs are resolved with this release:
+ 
++  [21242] assert: Suppress pedantic warning caused by statement expression
+   [21885] getaddrinfo: Release resolver context on error in gethosts
+   [21932] Unpaired __resolv_context_get in generic get*_r implementation
+ \f
+diff --git a/assert/assert.h b/assert/assert.h
+index 22f019537c..6801cfeb10 100644
+--- a/assert/assert.h
++++ b/assert/assert.h
+@@ -91,13 +91,19 @@ __END_DECLS
+      ? __ASSERT_VOID_CAST (0)						\
+      : __assert_fail (#expr, __FILE__, __LINE__, __ASSERT_FUNCTION))
+ # else
++/* The first occurrence of EXPR is not evaluated due to the sizeof,
++   but will trigger any pedantic warnings masked by the __extension__
++   for the second occurrence.  The explicit comparison against zero is
++   required to support function pointers and bit fields in this
++   context, and to suppress the evaluation of variable length
++   arrays.  */
+ #  define assert(expr)							\
+-    ({									\
++  ((void) sizeof ((expr) == 0), __extension__ ({			\
+       if (expr)								\
+         ; /* empty */							\
+       else								\
+         __assert_fail (#expr, __FILE__, __LINE__, __ASSERT_FUNCTION);	\
+-    })
++    }))
+ # endif
+ 
+ # ifdef	__USE_GNU
+@@ -113,7 +119,7 @@ __END_DECLS
+    C9x has a similar variable called __func__, but prefer the GCC one since
+    it demangles C++ function names.  */
+ # if defined __cplusplus ? __GNUC_PREREQ (2, 6) : __GNUC_PREREQ (2, 4)
+-#   define __ASSERT_FUNCTION	__PRETTY_FUNCTION__
++#   define __ASSERT_FUNCTION	__extension__ __PRETTY_FUNCTION__
+ # else
+ #  if defined __STDC_VERSION__ && __STDC_VERSION__ >= 199901L
+ #   define __ASSERT_FUNCTION	__func__
diff --git a/gnu/packages/patches/glibc-2-26-0009.patch b/gnu/packages/patches/glibc-2-26-0009.patch
new file mode 100644
index 000000000..4a82fc1cb
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0009.patch
@@ -0,0 +1,74 @@
+From 645b7635ba8fd58062245419e8bb668ab90cd3ec Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gftg@linux.vnet.ibm.com>
+Date: Mon, 7 Aug 2017 09:14:14 -0300
+Subject: [PATCH 09/90] powerpc: Restrict xssqrtqp operands to Vector Registers
+ (bug 21941)
+
+POWER ISA 3.0 introduces the xssqrtqp instructions, which expects
+operands to be in Vector Registers (Altivec/VMX), even though this
+instruction belongs to the Vector-Scalar Instruction Set.
+
+In GCC's Extended Assembly for POWER, the 'wq' register constraint is
+provided for use with IEEE 754 128-bit floating-point values.  However,
+this constraint does not limit the register allocation to Vector
+Registers (Altivec/VMX) and could assign a Vector-Scalar Register (VSX)
+to the operands of the instruction.
+
+This patch changes the register constraint used in sqrtf128 from 'wq' to
+'v', in order to request a Vector Register (Altivec/VMX) for use with
+the xssqrtqp instruction.
+
+Tested for powerpc64le and --with-cpu=power9.
+
+	[BZ #21941]
+	* sysdeps/powerpc/fpu/math_private.h (__ieee754_sqrtf128): Since
+	xssqrtqp requires operands to be in Vector Registers
+	(Altivec/VMX), replace the register constraint 'wq' with 'v'.
+	* sysdeps/powerpc/powerpc64le/power9/fpu/e_sqrtf128.c
+	(__ieee754_sqrtf128): Likewise.
+
+(cherry picked from commit 4d98ace9de3183309cb394cd0110eda5ad2d2531)
+
+diff --git a/ChangeLog b/ChangeLog
+index 0057c0902a..6886cd9361 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,12 @@
++2017-08-10  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
++
++	[BZ #21941]
++	* sysdeps/powerpc/fpu/math_private.h (__ieee754_sqrtf128): Since
++	xssqrtqp requires operands to be in Vector Registers
++	(Altivec/VMX), replace the register constraint 'wq' with 'v'.
++	* sysdeps/powerpc/powerpc64le/power9/fpu/e_sqrtf128.c
++	(__ieee754_sqrtf128): Likewise.
++
+ 2017-08-11  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	[BZ #21242]
+diff --git a/sysdeps/powerpc/fpu/math_private.h b/sysdeps/powerpc/fpu/math_private.h
+index d8fd4923ac..396fd0562e 100644
+--- a/sysdeps/powerpc/fpu/math_private.h
++++ b/sysdeps/powerpc/fpu/math_private.h
+@@ -30,7 +30,7 @@ extern __always_inline _Float128
+ __ieee754_sqrtf128 (_Float128 __x)
+ {
+   _Float128 __z;
+-  asm ("xssqrtqp %0,%1" : "=wq" (__z) : "wq" (__x));
++  asm ("xssqrtqp %0,%1" : "=v" (__z) : "v" (__x));
+   return __z;
+ }
+ #endif
+diff --git a/sysdeps/powerpc/powerpc64le/power9/fpu/e_sqrtf128.c b/sysdeps/powerpc/powerpc64le/power9/fpu/e_sqrtf128.c
+index 769d3f8922..59fd8269f5 100644
+--- a/sysdeps/powerpc/powerpc64le/power9/fpu/e_sqrtf128.c
++++ b/sysdeps/powerpc/powerpc64le/power9/fpu/e_sqrtf128.c
+@@ -30,7 +30,7 @@ __float128
+ __ieee754_sqrtf128 (__float128 a)
+ {
+   __float128 z;
+-  asm ("xssqrtqp %0,%1" : "=wq" (z) : "wq" (a));
++  asm ("xssqrtqp %0,%1" : "=v" (z) : "v" (a));
+   return z;
+ }
+ strong_alias (__ieee754_sqrtf128, __sqrtf128_finite)
diff --git a/gnu/packages/patches/glibc-2-26-0010.patch b/gnu/packages/patches/glibc-2-26-0010.patch
new file mode 100644
index 000000000..096984947
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0010.patch
@@ -0,0 +1,68 @@
+From c2921b17a37e887b8a5ca9d84b875b9ba702b79c Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gftg@linux.vnet.ibm.com>
+Date: Mon, 21 Aug 2017 14:23:27 +0200
+Subject: [PATCH 10/90] Do not use __builtin_types_compatible_p in C++ mode
+ (bug 21930)
+
+The logic to define isinf for float128 depends on the availability of
+__builtin_types_compatible_p, which is only available in C mode,
+however, the conditionals do not check for C or C++ mode.  This lead to
+an error in libstdc++ configure, as reported by bug 21930.
+
+This patch adds a conditional for C mode in the definition of isinf for
+float128.  No definition is provided in C++ mode, since libstdc++
+headers undefine isinf.
+
+Tested for powerpc64le (glibc test suite and libstdc++-v3 configure).
+
+	[BZ #21930]
+	* math/math.h (isinf): Check if in C or C++ mode before using
+	__builtin_types_compatible_p, since this is a C mode feature.
+
+(cherry picked from commit 47a67213a9f51c5f8816d240500b10db605d8b77)
+
+diff --git a/ChangeLog b/ChangeLog
+index 6886cd9361..415fa3cc79 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-08-18  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
++
++	[BZ #21930]
++	* math/math.h (isinf): Check if in C or C++ mode before using
++	__builtin_types_compatible_p, since this is a C mode feature.
++
+ 2017-08-10  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
+ 
+ 	[BZ #21941]
+diff --git a/NEWS b/NEWS
+index d57c4052cf..75b82c899e 100644
+--- a/NEWS
++++ b/NEWS
+@@ -11,6 +11,7 @@ The following bugs are resolved with this release:
+ 
+   [21242] assert: Suppress pedantic warning caused by statement expression
+   [21885] getaddrinfo: Release resolver context on error in gethosts
++  [21930] Do not use __builtin_types_compatible_p in C++ mode
+   [21932] Unpaired __resolv_context_get in generic get*_r implementation
+ \f
+ Version 2.26
+diff --git a/math/math.h b/math/math.h
+index e21708045a..dea8dbe1ae 100644
+--- a/math/math.h
++++ b/math/math.h
+@@ -442,8 +442,12 @@ enum
+ 
+ /* Return nonzero value if X is positive or negative infinity.  */
+ # if __HAVE_DISTINCT_FLOAT128 && !__GNUC_PREREQ (7,0) \
+-     && !defined __SUPPORT_SNAN__
+-   /* __builtin_isinf_sign is broken for float128 only before GCC 7.0.  */
++     && !defined __SUPPORT_SNAN__ && !defined __cplusplus
++   /* Since __builtin_isinf_sign is broken for float128 before GCC 7.0,
++      use the helper function, __isinff128, with older compilers.  This is
++      only provided for C mode, because in C++ mode, GCC has no support
++      for __builtin_types_compatible_p (and when in C++ mode, this macro is
++      not used anyway, because libstdc++ headers undefine it).  */
+ #  define isinf(x) \
+     (__builtin_types_compatible_p (__typeof (x), _Float128) \
+      ? __isinff128 (x) : __builtin_isinf_sign (x))
diff --git a/gnu/packages/patches/glibc-2-26-0011.patch b/gnu/packages/patches/glibc-2-26-0011.patch
new file mode 100644
index 000000000..39d1c40e6
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0011.patch
@@ -0,0 +1,61 @@
+From 5e989c36934d0f0cf13b7a53ef2fa440bce39210 Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gftg@linux.vnet.ibm.com>
+Date: Mon, 14 Aug 2017 17:51:51 -0300
+Subject: [PATCH 11/90] Do not use generic selection in C++ mode
+
+The logic to protect the use of generic selection (_Generic) does not
+check for C or C++ mode, however, generic selection is a C-only
+feature.
+
+Tested for powerpc64le.
+
+	* misc/sys/cdefs.h (__HAVE_GENERIC_SELECTION): Define to 0, if
+	in C++ mode.
+
+(cherry picked from commit 6913ad65e00bb32417ad39c41d292b976171e27e)
+
+diff --git a/ChangeLog b/ChangeLog
+index 415fa3cc79..23c00aed09 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-08-18  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
++
++	* misc/sys/cdefs.h (__HAVE_GENERIC_SELECTION): Define to 0, if
++	in C++ mode.
++
+ 2017-08-18  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
+ 
+ 	[BZ #21930]
+diff --git a/misc/sys/cdefs.h b/misc/sys/cdefs.h
+index 06523bfe9c..0c808216a4 100644
+--- a/misc/sys/cdefs.h
++++ b/misc/sys/cdefs.h
+@@ -464,17 +464,18 @@
+ # define __glibc_macro_warning(msg)
+ #endif
+ 
+-/* Support for generic selection (ISO C11) is available in GCC since
+-   version 4.9.  Previous versions do not provide generic selection,
+-   even though they might set __STDC_VERSION__ to 201112L, when in
+-   -std=c11 mode.  Thus, we must check for !defined __GNUC__ when
+-   testing __STDC_VERSION__ for generic selection support.
++/* Generic selection (ISO C11) is a C-only feature, available in GCC
++   since version 4.9.  Previous versions do not provide generic
++   selection, even though they might set __STDC_VERSION__ to 201112L,
++   when in -std=c11 mode.  Thus, we must check for !defined __GNUC__
++   when testing __STDC_VERSION__ for generic selection support.
+    On the other hand, Clang also defines __GNUC__, so a clang-specific
+    check is required to enable the use of generic selection.  */
+-#if __GNUC_PREREQ (4, 9) \
+-    || __glibc_clang_has_extension (c_generic_selections) \
+-    || (!defined __GNUC__ && defined __STDC_VERSION__ \
+-	&& __STDC_VERSION__ >= 201112L)
++#if !defined __cplusplus \
++    && (__GNUC_PREREQ (4, 9) \
++	|| __glibc_clang_has_extension (c_generic_selections) \
++	|| (!defined __GNUC__ && defined __STDC_VERSION__ \
++	    && __STDC_VERSION__ >= 201112L))
+ # define __HAVE_GENERIC_SELECTION 1
+ #else
+ # define __HAVE_GENERIC_SELECTION 0
diff --git a/gnu/packages/patches/glibc-2-26-0012.patch b/gnu/packages/patches/glibc-2-26-0012.patch
new file mode 100644
index 000000000..7d5fc6c0d
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0012.patch
@@ -0,0 +1,204 @@
+From fb9a781e9d62c5d7a1f4196915cdfb7c6db59a0c Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Mon, 21 Aug 2017 16:13:49 +0200
+Subject: [PATCH 12/90] assert: Support types without operator== (int) [BZ
+ #21972]
+
+(cherry picked from commit b5889d25e9bf944a89fdd7bcabf3b6c6f6bb6f7c)
+
+diff --git a/ChangeLog b/ChangeLog
+index 23c00aed09..8bc3ad9a46 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,14 @@
++2017-08-21  Florian Weimer  <fweimer@redhat.com>
++
++	[BZ #21972]
++	* assert/assert.h (assert): Use static_cast (bool) for C++.
++	Use the ternary operator in the warning branch for GNU C.
++	* assert/Makefile (tests): Add tst-assert-c++, tst-assert-g++.
++	(CFLAGS-tst-assert-c++.o): Compile in C++11 mode.
++	(CFLAGS-tst-assert-g++.o): Compile in GnU C++11 mode.
++	(LDLIBS-tst-assert-c++, LDLIBS-tst-assert-g++): Link with libstdc++.
++	* assert/tst-assert-c++.cc, assert/tst-assert-g++.cc: New files.
++
+ 2017-08-18  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
+ 
+ 	* misc/sys/cdefs.h (__HAVE_GENERIC_SELECTION): Define to 0, if
+diff --git a/NEWS b/NEWS
+index 75b82c899e..1996e5fbef 100644
+--- a/NEWS
++++ b/NEWS
+@@ -13,6 +13,7 @@ The following bugs are resolved with this release:
+   [21885] getaddrinfo: Release resolver context on error in gethosts
+   [21930] Do not use __builtin_types_compatible_p in C++ mode
+   [21932] Unpaired __resolv_context_get in generic get*_r implementation
++  [21972] assert macro requires operator== (int) for its argument type
+ \f
+ Version 2.26
+ 
+diff --git a/assert/Makefile b/assert/Makefile
+index 1c3be9b01f..9ec1be81a9 100644
+--- a/assert/Makefile
++++ b/assert/Makefile
+@@ -25,6 +25,15 @@ include ../Makeconfig
+ headers	:= assert.h
+ 
+ routines := assert assert-perr __assert
+-tests := test-assert test-assert-perr
++tests := test-assert test-assert-perr tst-assert-c++ tst-assert-g++
+ 
+ include ../Rules
++
++ifeq ($(have-cxx-thread_local),yes)
++CFLAGS-tst-assert-c++.o = -std=c++11
++LDLIBS-tst-assert-c++ = -lstdc++
++CFLAGS-tst-assert-g++.o = -std=gnu++11
++LDLIBS-tst-assert-g++ = -lstdc++
++else
++tests-unsupported += tst-assert-c++ tst-assert-g++
++endif
+diff --git a/assert/assert.h b/assert/assert.h
+index 6801cfeb10..640c95c063 100644
+--- a/assert/assert.h
++++ b/assert/assert.h
+@@ -85,7 +85,12 @@ __END_DECLS
+ /* When possible, define assert so that it does not add extra
+    parentheses around EXPR.  Otherwise, those added parentheses would
+    suppress warnings we'd expect to be detected by gcc's -Wparentheses.  */
+-# if !defined __GNUC__ || defined __STRICT_ANSI__
++# if defined __cplusplus
++#  define assert(expr)							\
++     (static_cast <bool> (expr)						\
++      ? void (0)							\
++      : __assert_fail (#expr, __FILE__, __LINE__, __ASSERT_FUNCTION))
++# elif !defined __GNUC__ || defined __STRICT_ANSI__
+ #  define assert(expr)							\
+     ((expr)								\
+      ? __ASSERT_VOID_CAST (0)						\
+@@ -93,12 +98,11 @@ __END_DECLS
+ # else
+ /* The first occurrence of EXPR is not evaluated due to the sizeof,
+    but will trigger any pedantic warnings masked by the __extension__
+-   for the second occurrence.  The explicit comparison against zero is
+-   required to support function pointers and bit fields in this
+-   context, and to suppress the evaluation of variable length
+-   arrays.  */
++   for the second occurrence.  The ternary operator is required to
++   support function pointers and bit fields in this context, and to
++   suppress the evaluation of variable length arrays.  */
+ #  define assert(expr)							\
+-  ((void) sizeof ((expr) == 0), __extension__ ({			\
++  ((void) sizeof ((expr) ? 1 : 0), __extension__ ({			\
+       if (expr)								\
+         ; /* empty */							\
+       else								\
+diff --git a/assert/tst-assert-c++.cc b/assert/tst-assert-c++.cc
+new file mode 100644
+index 0000000000..12a5e690cb
+--- /dev/null
++++ b/assert/tst-assert-c++.cc
+@@ -0,0 +1,78 @@
++/* Tests for interactions between C++ and assert.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#include <assert.h>
++
++/* The C++ standard requires that if the assert argument is a constant
++   subexpression, then the assert itself is one, too.  */
++constexpr int
++check_constexpr ()
++{
++  return (assert (true), 1);
++}
++
++/* Objects of this class can be contextually converted to bool, but
++   cannot be compared to int.  */
++struct no_int
++{
++  no_int () = default;
++  no_int (const no_int &) = delete;
++
++  explicit operator bool () const
++  {
++    return true;
++  }
++
++  bool operator! () const; /* No definition.  */
++  template <class T> bool operator== (T) const; /* No definition.  */
++  template <class T> bool operator!= (T) const; /* No definition.  */
++};
++
++/* This class tests that operator== is not used by assert.  */
++struct bool_and_int
++{
++  bool_and_int () = default;
++  bool_and_int (const no_int &) = delete;
++
++  explicit operator bool () const
++  {
++    return true;
++  }
++
++  bool operator! () const; /* No definition.  */
++  template <class T> bool operator== (T) const; /* No definition.  */
++  template <class T> bool operator!= (T) const; /* No definition.  */
++};
++
++static int
++do_test ()
++{
++  {
++    no_int value;
++    assert (value);
++  }
++
++  {
++    bool_and_int value;
++    assert (value);
++  }
++
++  return 0;
++}
++
++#include <support/test-driver.c>
+diff --git a/assert/tst-assert-g++.cc b/assert/tst-assert-g++.cc
+new file mode 100644
+index 0000000000..8c06402825
+--- /dev/null
++++ b/assert/tst-assert-g++.cc
+@@ -0,0 +1,19 @@
++/* Tests for interactions between C++ and assert.  GNU C++11 version.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#include <tst-assert-c++.cc>
diff --git a/gnu/packages/patches/glibc-2-26-0013.patch b/gnu/packages/patches/glibc-2-26-0013.patch
new file mode 100644
index 000000000..62de6e29d
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0013.patch
@@ -0,0 +1,23 @@
+From 3aeab55ee17ca527e4597bc8397c0434c3f8b34e Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gftg@linux.vnet.ibm.com>
+Date: Mon, 21 Aug 2017 15:45:57 -0300
+Subject: [PATCH 13/90] Add missing bug fixes to NEWS
+
+
+diff --git a/NEWS b/NEWS
+index 1996e5fbef..0534c5296e 100644
+--- a/NEWS
++++ b/NEWS
+@@ -10,9 +10,12 @@ Version 2.26.1
+ The following bugs are resolved with this release:
+ 
+   [21242] assert: Suppress pedantic warning caused by statement expression
++  [21780] posix: Set p{read,write}v2 to return ENOTSUP
++  [21871] x86-64: Use _dl_runtime_resolve_opt only with AVX512F
+   [21885] getaddrinfo: Release resolver context on error in gethosts
+   [21930] Do not use __builtin_types_compatible_p in C++ mode
+   [21932] Unpaired __resolv_context_get in generic get*_r implementation
++  [21941] powerpc: Restrict xssqrtqp operands to Vector Registers
+   [21972] assert macro requires operator== (int) for its argument type
+ \f
+ Version 2.26
diff --git a/gnu/packages/patches/glibc-2-26-0014.patch b/gnu/packages/patches/glibc-2-26-0014.patch
new file mode 100644
index 000000000..fa9d76e29
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0014.patch
@@ -0,0 +1,56 @@
+From 77db8772bd3f6f2bbad697dcf46861ce310f5b95 Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Thu, 10 Aug 2017 16:06:52 +0200
+Subject: [PATCH 14/90] __inet6_scopeid_pton: Remove attribute_hidden,
+ internal_function
+
+The hidden attribute was overridden by libc_hidden_proto on GNU/Linux.
+It is incorrect because the function is used from nscd.
+
+internal_function is not supposed to be used across DSO boundaries,
+so this commit removes it (again, due to the use in nscd).
+
+(cherry picked from commit f87cc2bfba9b844da48a63441c6099342b1551c7)
+
+diff --git a/ChangeLog b/ChangeLog
+index 8bc3ad9a46..ad05da8ade 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,10 @@
++2017-08-10  Florian Weimer  <fweimer@redhat.com>
++
++	* inet/net-internal.h (__inet6_scopeid_pton): Remove
++	attribute_hidden, internal_function.
++	* inet/inet6_scopeid_pton.c (__inet6_scopeid_pton): Remove
++	internal_function.
++
+ 2017-08-21  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	[BZ #21972]
+diff --git a/inet/inet6_scopeid_pton.c b/inet/inet6_scopeid_pton.c
+index e09b1cb34d..cc8803fa10 100644
+--- a/inet/inet6_scopeid_pton.c
++++ b/inet/inet6_scopeid_pton.c
+@@ -28,7 +28,7 @@
+ 
+ /* Parse SOURCE as a scope ID for ADDRESS.  Return 0 on success and -1
+    on error.  */
+-internal_function int
++int
+ __inet6_scopeid_pton (const struct in6_addr *address, const char *scope,
+                       uint32_t *result)
+ {
+diff --git a/inet/net-internal.h b/inet/net-internal.h
+index 2b2632c7ba..b2135893e8 100644
+--- a/inet/net-internal.h
++++ b/inet/net-internal.h
+@@ -25,8 +25,7 @@
+ #include <sys/time.h>
+ 
+ int __inet6_scopeid_pton (const struct in6_addr *address,
+-                          const char *scope, uint32_t *result)
+-  internal_function attribute_hidden;
++                          const char *scope, uint32_t *result);
+ libc_hidden_proto (__inet6_scopeid_pton)
+ 
+ 
diff --git a/gnu/packages/patches/glibc-2-26-0015.patch b/gnu/packages/patches/glibc-2-26-0015.patch
new file mode 100644
index 000000000..4beef780b
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0015.patch
@@ -0,0 +1,75 @@
+From 6043d77a47de297b62084c1c261cdada082bf09c Mon Sep 17 00:00:00 2001
+From: Andreas Schwab <schwab@suse.de>
+Date: Mon, 28 Aug 2017 19:49:18 +0200
+Subject: [PATCH 15/90] ldd: never run file directly
+
+(cherry picked from commit eedca9772e99c72ab4c3c34e43cc764250aa3e3c)
+
+diff --git a/ChangeLog b/ChangeLog
+index ad05da8ade..fa27c6f66f 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-08-16  Andreas Schwab  <schwab@suse.de>
++
++	[BZ #16750]
++	CVE-2009-5064
++	* elf/ldd.bash.in: Never run file directly.
++
+ 2017-08-10  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	* inet/net-internal.h (__inet6_scopeid_pton): Remove
+diff --git a/NEWS b/NEWS
+index 0534c5296e..756e849643 100644
+--- a/NEWS
++++ b/NEWS
+@@ -7,8 +7,17 @@ using `glibc' in the "product" field.
+ \f
+ Version 2.26.1
+ 
++Security related changes:
++
++  CVE-2009-5064: The ldd script would sometimes run the program under
++  examination directly, without preventing code execution through the
++  dynamic linker.  (The glibc project disputes that this is a security
++  vulnerability; only trusted binaries must be examined using the ldd
++  script.)
++
+ The following bugs are resolved with this release:
+ 
++  [16750] ldd: Never run file directly.
+   [21242] assert: Suppress pedantic warning caused by statement expression
+   [21780] posix: Set p{read,write}v2 to return ENOTSUP
+   [21871] x86-64: Use _dl_runtime_resolve_opt only with AVX512F
+diff --git a/elf/ldd.bash.in b/elf/ldd.bash.in
+index 7dd1fccf24..686785e235 100644
+--- a/elf/ldd.bash.in
++++ b/elf/ldd.bash.in
+@@ -164,18 +164,6 @@ warning: you do not have execution permission for" "\`$file'" >&2
+       fi
+     done
+     case $ret in
+-    0)
+-      # If the program exits with exit code 5, it means the process has been
+-      # invoked with __libc_enable_secure.  Fall back to running it through
+-      # the dynamic linker.
+-      try_trace "$file"
+-      rc=$?
+-      if [ $rc = 5 ]; then
+-	try_trace "$RTLD" "$file"
+-	rc=$?
+-      fi
+-      [ $rc = 0 ] || result=1
+-      ;;
+     1)
+       # This can be a non-ELF binary or no binary at all.
+       nonelf "$file" || {
+@@ -183,7 +171,7 @@ warning: you do not have execution permission for" "\`$file'" >&2
+ 	result=1
+       }
+       ;;
+-    2)
++    0|2)
+       try_trace "$RTLD" "$file" || result=1
+       ;;
+     *)
diff --git a/gnu/packages/patches/glibc-2-26-0016.patch b/gnu/packages/patches/glibc-2-26-0016.patch
new file mode 100644
index 000000000..88456071f
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0016.patch
@@ -0,0 +1,235 @@
+From ef8566d72af5e03c1b82cf02efb794268a347f8c Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gftg@linux.vnet.ibm.com>
+Date: Mon, 14 Aug 2017 13:46:15 -0300
+Subject: [PATCH 16/90] Provide a C++ version of issignaling that does not use
+ __MATH_TG
+
+The macro __MATH_TG contains the logic to select between long double and
+_Float128, when these types are ABI-distinct.  This logic relies on
+__builtin_types_compatible_p, which is not available in C++ mode.
+
+On the other hand, C++ function overloading provides the means to
+distinguish between the floating-point types.  The overloading
+resolution will match the correct parameter regardless of type
+qualifiers, i.e.: const and volatile.
+
+Tested for powerpc64le, s390x, and x86_64.
+
+	* math/math.h [defined __cplusplus] (issignaling): Provide a C++
+	definition for issignaling that does not rely on __MATH_TG,
+	since __MATH_TG uses __builtin_types_compatible_p, which is only
+	available in C mode.
+	(CFLAGS-test-math-issignaling.cc): New variable.
+	* math/Makefile [CXX] (tests): Add test-math-issignaling.
+	* math/test-math-issignaling.cc: New test for C++ implementation
+	of type-generic issignaling.
+	* sysdeps/powerpc/powerpc64le/Makefile [subdir == math]
+	(CXXFLAGS-test-math-issignaling.cc): Add -mfloat128 to the build
+	options of test-math-issignaling on powerpc64le.
+
+(cherry picked from commit a16e8bc08edca84d507715c66d6cddbbc7ed3b62)
+
+diff --git a/ChangeLog b/ChangeLog
+index fa27c6f66f..527026ba5d 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,17 @@
++2017-08-22  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
++
++	* math/math.h [defined __cplusplus] (issignaling): Provide a C++
++	definition for issignaling that does not rely on __MATH_TG,
++	since __MATH_TG uses __builtin_types_compatible_p, which is only
++	available in C mode.
++	(CFLAGS-test-math-issignaling.cc): New variable.
++	* math/Makefile [CXX] (tests): Add test-math-issignaling.
++	* math/test-math-issignaling.cc: New test for C++ implementation
++	of type-generic issignaling.
++	* sysdeps/powerpc/powerpc64le/Makefile [subdir == math]
++	(CXXFLAGS-test-math-issignaling.cc): Add -mfloat128 to the build
++	options of test-math-issignaling on powerpc64le.
++
+ 2017-08-16  Andreas Schwab  <schwab@suse.de>
+ 
+ 	[BZ #16750]
+diff --git a/math/Makefile b/math/Makefile
+index e09b0c0545..0130fcf38b 100644
+--- a/math/Makefile
++++ b/math/Makefile
+@@ -203,7 +203,7 @@ tests-static = test-fpucw-static test-fpucw-ieee-static \
+ 	       test-signgam-ullong-static test-signgam-ullong-init-static
+ 
+ ifneq (,$(CXX))
+-tests += test-math-isinff test-math-iszero
++tests += test-math-isinff test-math-iszero test-math-issignaling
+ endif
+ 
+ ifneq (no,$(PERL))
+@@ -350,6 +350,7 @@ CFLAGS-test-signgam-ullong-init-static.c = -std=c99
+ 
+ CFLAGS-test-math-isinff.cc = -std=gnu++11
+ CFLAGS-test-math-iszero.cc = -std=gnu++11
++CFLAGS-test-math-issignaling.cc = -std=gnu++11
+ 
+ CFLAGS-test-iszero-excess-precision.c = -fexcess-precision=standard
+ CFLAGS-test-iseqsig-excess-precision.c = -fexcess-precision=standard
+diff --git a/math/math.h b/math/math.h
+index dea8dbe1ae..add86af724 100644
+--- a/math/math.h
++++ b/math/math.h
+@@ -474,7 +474,24 @@ enum
+ # include <bits/iscanonical.h>
+ 
+ /* Return nonzero value if X is a signaling NaN.  */
+-# define issignaling(x) __MATH_TG ((x), __issignaling, (x))
++# ifndef __cplusplus
++#  define issignaling(x) __MATH_TG ((x), __issignaling, (x))
++# else
++   /* In C++ mode, __MATH_TG cannot be used, because it relies on
++      __builtin_types_compatible_p, which is a C-only builtin.  On the
++      other hand, overloading provides the means to distinguish between
++      the floating-point types.  The overloading resolution will match
++      the correct parameter (regardless of type qualifiers (i.e.: const
++      and volatile).  */
++extern "C++" {
++inline int issignaling (float __val) { return __issignalingf (__val); }
++inline int issignaling (double __val) { return __issignaling (__val); }
++inline int issignaling (long double __val) { return __issignalingl (__val); }
++#  if __HAVE_DISTINCT_FLOAT128
++inline int issignaling (_Float128 __val) { return __issignalingf128 (__val); }
++#  endif
++} /* extern C++ */
++# endif
+ 
+ /* Return nonzero value if X is subnormal.  */
+ # define issubnormal(x) (fpclassify (x) == FP_SUBNORMAL)
+diff --git a/math/test-math-issignaling.cc b/math/test-math-issignaling.cc
+new file mode 100644
+index 0000000000..22ae9e1bca
+--- /dev/null
++++ b/math/test-math-issignaling.cc
+@@ -0,0 +1,113 @@
++/* Test for the C++ implementation of issignaling.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#define _GNU_SOURCE 1
++#include <math.h>
++#include <stdio.h>
++
++#include <limits>
++
++/* There is no signaling_NaN for _Float128 in std::numeric_limits.
++   Include ieee754_float128.h and use the bitfields in the union
++   ieee854_float128.ieee_nan to build a signaling NaN.  */
++#if __HAVE_DISTINCT_FLOAT128
++# include <ieee754_float128.h>
++#endif
++
++static bool errors;
++
++static void
++check (int actual, int expected, const char *actual_expr, int line)
++{
++  if (actual != expected)
++    {
++      errors = true;
++      printf ("%s:%d: error: %s\n", __FILE__, line, actual_expr);
++      printf ("%s:%d:   expected: %d\n", __FILE__, line, expected);
++      printf ("%s:%d:   actual: %d\n", __FILE__, line, actual);
++    }
++}
++
++#define CHECK(actual, expected) \
++  check ((actual), (expected), #actual, __LINE__)
++
++template <class T>
++static void
++check_type ()
++{
++  typedef std::numeric_limits<T> limits;
++  CHECK (issignaling (T{0}), 0);
++  if (limits::has_infinity)
++    {
++      CHECK (issignaling (limits::infinity ()), 0);
++      CHECK (issignaling (-limits::infinity ()), 0);
++    }
++  if (limits::has_quiet_NaN)
++    CHECK (issignaling (limits::quiet_NaN ()), 0);
++  if (limits::has_signaling_NaN)
++    CHECK (issignaling (limits::signaling_NaN ()), 1);
++}
++
++#if __HAVE_DISTINCT_FLOAT128
++static void
++check_float128 ()
++{
++  ieee854_float128 q;
++
++  q.d = 0;
++  CHECK (issignaling (q.d), 0);
++
++  /* Infinity.  */
++  q.ieee.negative = 0;
++  q.ieee.exponent = 0x7FFF;
++  q.ieee.mantissa0 = 0x0000;
++  q.ieee.mantissa1 = 0x00000000;
++  q.ieee.mantissa2 = 0x00000000;
++  q.ieee.mantissa3 = 0x00000000;
++  CHECK (issignaling (q.d), 0);
++
++  /* Quiet NaN.  */
++  q.ieee_nan.quiet_nan = 1;
++  q.ieee_nan.mantissa0 = 0x0000;
++  CHECK (issignaling (q.d), 0);
++
++  /* Still a quiet NaN.  */
++  q.ieee_nan.quiet_nan = 1;
++  q.ieee_nan.mantissa0 = 0x4000;
++  CHECK (issignaling (q.d), 0);
++
++  /* Signaling NaN.  */
++  q.ieee_nan.quiet_nan = 0;
++  q.ieee_nan.mantissa0 = 0x4000;
++  CHECK (issignaling (q.d), 1);
++}
++#endif
++
++static int
++do_test (void)
++{
++  check_type<float> ();
++  check_type<double> ();
++  check_type<long double> ();
++#if __HAVE_DISTINCT_FLOAT128
++  check_float128 ();
++#endif
++  return errors;
++}
++
++#include <support/test-driver.c>
+diff --git a/sysdeps/powerpc/powerpc64le/Makefile b/sysdeps/powerpc/powerpc64le/Makefile
+index 77617b670a..19adbfa1c1 100644
+--- a/sysdeps/powerpc/powerpc64le/Makefile
++++ b/sysdeps/powerpc/powerpc64le/Makefile
+@@ -16,6 +16,7 @@ $(foreach suf,$(all-object-suffixes),%f128_r$(suf)): CFLAGS += -mfloat128
+ $(foreach suf,$(all-object-suffixes),$(objpfx)test-float128%$(suf)): CFLAGS += -mfloat128
+ $(foreach suf,$(all-object-suffixes),$(objpfx)test-ifloat128%$(suf)): CFLAGS += -mfloat128
+ CFLAGS-libm-test-support-float128.c += -mfloat128
++CFLAGS-test-math-issignaling.cc += -mfloat128
+ $(objpfx)test-float128% $(objpfx)test-ifloat128%: \
+   gnulib-tests += $(f128-loader-link)
+ endif
diff --git a/gnu/packages/patches/glibc-2-26-0017.patch b/gnu/packages/patches/glibc-2-26-0017.patch
new file mode 100644
index 000000000..7dc840e1f
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0017.patch
@@ -0,0 +1,53 @@
+From 35dded99a89db873b06270ca7f21245a0faf712a Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gftg@linux.vnet.ibm.com>
+Date: Wed, 23 Aug 2017 10:16:54 -0300
+Subject: [PATCH 17/90] Fix the C++ version of issignaling when
+ __NO_LONG_DOUBLE_MATH is defined
+
+When __NO_LONG_DOUBLE_MATH is defined, __issignalingl is not available,
+thus issignaling with long double argument should call __issignaling,
+instead.
+
+Tested for powerpc64le.
+
+	* math/math.h [defined __cplusplus] (issignaling): In the long
+	double case, call __issignalingl only if __NO_LONG_DOUBLE_MATH
+	is not defined.  Call __issignaling, otherwise.
+
+(cherry picked from commit 3d7b66f66cb223e899a7ebc0f4c20f13e711c9e0)
+
+diff --git a/ChangeLog b/ChangeLog
+index 527026ba5d..04b56b555c 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-08-24  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
++
++	* math/math.h [defined __cplusplus] (issignaling): In the long
++	double case, call __issignalingl only if __NO_LONG_DOUBLE_MATH
++	is not defined.  Call __issignaling, otherwise.
++
+ 2017-08-22  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
+ 
+ 	* math/math.h [defined __cplusplus] (issignaling): Provide a C++
+diff --git a/math/math.h b/math/math.h
+index add86af724..60dfa31592 100644
+--- a/math/math.h
++++ b/math/math.h
+@@ -486,7 +486,15 @@ enum
+ extern "C++" {
+ inline int issignaling (float __val) { return __issignalingf (__val); }
+ inline int issignaling (double __val) { return __issignaling (__val); }
+-inline int issignaling (long double __val) { return __issignalingl (__val); }
++inline int
++issignaling (long double __val)
++{
++#  ifdef __NO_LONG_DOUBLE_MATH
++  return __issignaling (__val);
++#  else
++  return __issignalingl (__val);
++#  endif
++}
+ #  if __HAVE_DISTINCT_FLOAT128
+ inline int issignaling (_Float128 __val) { return __issignalingf128 (__val); }
+ #  endif
diff --git a/gnu/packages/patches/glibc-2-26-0018.patch b/gnu/packages/patches/glibc-2-26-0018.patch
new file mode 100644
index 000000000..7e4ccbcfc
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0018.patch
@@ -0,0 +1,225 @@
+From 58270c0049404ef2f878fdd45df55f17f0b8c1f7 Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gftg@linux.vnet.ibm.com>
+Date: Tue, 22 Aug 2017 16:34:42 -0300
+Subject: [PATCH 18/90] Provide a C++ version of iszero that does not use
+ __MATH_TG (bug 21930)
+
+When signaling nans are enabled (with -fsignaling-nans), the C++ version
+of iszero uses the fpclassify macro, which is defined with __MATH_TG.
+However, when support for float128 is available, __MATH_TG uses the
+builtin __builtin_types_compatible_p, which is only available in C mode.
+
+This patch refactors the C++ version of iszero so that it uses function
+overloading to select between the floating-point types, instead of
+relying on fpclassify and __MATH_TG.
+
+Tested for powerpc64le, s390x, x86_64, and with build-many-glibcs.py.
+
+	[BZ #21930]
+	* math/math.h [defined __cplusplus && defined __SUPPORT_SNAN__]
+	(iszero): New C++ implementation that does not use
+	fpclassify/__MATH_TG/__builtin_types_compatible_p, when
+	signaling nans are enabled, since __builtin_types_compatible_p
+	is a C-only feature.
+	* math/test-math-iszero.cc: When __HAVE_DISTINCT_FLOAT128 is
+	defined, include ieee754_float128.h for access to the union and
+	member ieee854_float128.ieee.
+	[__HAVE_DISTINCT_FLOAT128] (do_test): Call check_float128.
+	[__HAVE_DISTINCT_FLOAT128] (check_float128): New function.
+	* sysdeps/powerpc/powerpc64le/Makefile [subdir == math]
+	(CXXFLAGS-test-math-iszero.cc): Add -mfloat128 to the build
+	options of test-math-zero on powerpc64le.
+
+(cherry picked from commit 42496114ec0eb7d6d039d05d4262e109951c600c)
+
+diff --git a/ChangeLog b/ChangeLog
+index 04b56b555c..23ded7f03d 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,20 @@
++2017-08-28  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
++
++	[BZ #21930]
++	* math/math.h [defined __cplusplus && defined __SUPPORT_SNAN__]
++	(iszero): New C++ implementation that does not use
++	fpclassify/__MATH_TG/__builtin_types_compatible_p, when
++	signaling nans are enabled, since __builtin_types_compatible_p
++	is a C-only feature.
++	* math/test-math-iszero.cc: When __HAVE_DISTINCT_FLOAT128 is
++	defined, include ieee754_float128.h for access to the union and
++	member ieee854_float128.ieee.
++	[__HAVE_DISTINCT_FLOAT128] (do_test): Call check_float128.
++	[__HAVE_DISTINCT_FLOAT128] (check_float128): New function.
++	* sysdeps/powerpc/powerpc64le/Makefile [subdir == math]
++	(CXXFLAGS-test-math-iszero.cc): Add -mfloat128 to the build
++	options of test-math-zero on powerpc64le.
++
+ 2017-08-24  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
+ 
+ 	* math/math.h [defined __cplusplus] (issignaling): In the long
+diff --git a/math/math.h b/math/math.h
+index 60dfa31592..7c0fc6dbb3 100644
+--- a/math/math.h
++++ b/math/math.h
+@@ -513,15 +513,40 @@ inline int issignaling (_Float128 __val) { return __issignalingf128 (__val); }
+ #  endif
+ # else	/* __cplusplus */
+ extern "C++" {
++#  ifdef __SUPPORT_SNAN__
++inline int
++iszero (float __val)
++{
++  return __fpclassifyf (__val) == FP_ZERO;
++}
++inline int
++iszero (double __val)
++{
++  return __fpclassify (__val) == FP_ZERO;
++}
++inline int
++iszero (long double __val)
++{
++#   ifdef __NO_LONG_DOUBLE_MATH
++  return __fpclassify (__val) == FP_ZERO;
++#   else
++  return __fpclassifyl (__val) == FP_ZERO;
++#   endif
++}
++#   if __HAVE_DISTINCT_FLOAT128
++inline int
++iszero (_Float128 __val)
++{
++  return __fpclassifyf128 (__val) == FP_ZERO;
++}
++#   endif
++#  else
+ template <class __T> inline bool
+ iszero (__T __val)
+ {
+-#  ifdef __SUPPORT_SNAN__
+-  return fpclassify (__val) == FP_ZERO;
+-#  else
+   return __val == 0;
+-#  endif
+ }
++#  endif
+ } /* extern C++ */
+ # endif	/* __cplusplus */
+ #endif /* Use IEC_60559_BFP_EXT.  */
+diff --git a/math/test-math-iszero.cc b/math/test-math-iszero.cc
+index 027e972654..5c07261626 100644
+--- a/math/test-math-iszero.cc
++++ b/math/test-math-iszero.cc
+@@ -22,6 +22,13 @@
+ 
+ #include <limits>
+ 
++/* Support for _Float128 in std::numeric_limits is limited.
++   Include ieee754_float128.h and use the bitfields in the union
++   ieee854_float128.ieee_nan to build corner-case inputs.  */
++#if __HAVE_DISTINCT_FLOAT128
++# include <ieee754_float128.h>
++#endif
++
+ static bool errors;
+ 
+ static void
+@@ -72,12 +79,84 @@ check_type ()
+          std::numeric_limits<T>::has_denorm == std::denorm_absent);
+ }
+ 
++#if __HAVE_DISTINCT_FLOAT128
++static void
++check_float128 ()
++{
++  ieee854_float128 q;
++
++  q.d = 0.0Q;
++  CHECK (iszero (q.d), 1);
++  q.d = -0.0Q;
++  CHECK (iszero (q.d), 1);
++  q.d = 1.0Q;
++  CHECK (iszero (q.d), 0);
++  q.d = -1.0Q;
++  CHECK (iszero (q.d), 0);
++
++  /* Normal min.  */
++  q.ieee.negative = 0;
++  q.ieee.exponent = 0x0001;
++  q.ieee.mantissa0 = 0x0000;
++  q.ieee.mantissa1 = 0x00000000;
++  q.ieee.mantissa2 = 0x00000000;
++  q.ieee.mantissa3 = 0x00000000;
++  CHECK (iszero (q.d), 0);
++  q.ieee.negative = 1;
++  CHECK (iszero (q.d), 0);
++
++  /* Normal max.  */
++  q.ieee.negative = 0;
++  q.ieee.exponent = 0x7FFE;
++  q.ieee.mantissa0 = 0xFFFF;
++  q.ieee.mantissa1 = 0xFFFFFFFF;
++  q.ieee.mantissa2 = 0xFFFFFFFF;
++  q.ieee.mantissa3 = 0xFFFFFFFF;
++  CHECK (iszero (q.d), 0);
++  q.ieee.negative = 1;
++  CHECK (iszero (q.d), 0);
++
++  /* Infinity.  */
++  q.ieee.negative = 0;
++  q.ieee.exponent = 0x7FFF;
++  q.ieee.mantissa0 = 0x0000;
++  q.ieee.mantissa1 = 0x00000000;
++  q.ieee.mantissa2 = 0x00000000;
++  q.ieee.mantissa3 = 0x00000000;
++  CHECK (iszero (q.d), 0);
++
++  /* Quiet NaN.  */
++  q.ieee_nan.quiet_nan = 1;
++  q.ieee_nan.mantissa0 = 0x0000;
++  CHECK (iszero (q.d), 0);
++
++  /* Signaling NaN.  */
++  q.ieee_nan.quiet_nan = 0;
++  q.ieee_nan.mantissa0 = 0x4000;
++  CHECK (iszero (q.d), 0);
++
++  /* Denormal min.  */
++  q.ieee.negative = 0;
++  q.ieee.exponent = 0x0000;
++  q.ieee.mantissa0 = 0x0000;
++  q.ieee.mantissa1 = 0x00000000;
++  q.ieee.mantissa2 = 0x00000000;
++  q.ieee.mantissa3 = 0x00000001;
++  CHECK (iszero (q.d), 0);
++  q.ieee.negative = 1;
++  CHECK (iszero (q.d), 0);
++}
++#endif
++
+ static int
+ do_test (void)
+ {
+   check_type<float> ();
+   check_type<double> ();
+   check_type<long double> ();
++#if __HAVE_DISTINCT_FLOAT128
++  check_float128 ();
++#endif
+   return errors;
+ }
+ 
+diff --git a/sysdeps/powerpc/powerpc64le/Makefile b/sysdeps/powerpc/powerpc64le/Makefile
+index 19adbfa1c1..dea2290736 100644
+--- a/sysdeps/powerpc/powerpc64le/Makefile
++++ b/sysdeps/powerpc/powerpc64le/Makefile
+@@ -17,7 +17,8 @@ $(foreach suf,$(all-object-suffixes),$(objpfx)test-float128%$(suf)): CFLAGS += -
+ $(foreach suf,$(all-object-suffixes),$(objpfx)test-ifloat128%$(suf)): CFLAGS += -mfloat128
+ CFLAGS-libm-test-support-float128.c += -mfloat128
+ CFLAGS-test-math-issignaling.cc += -mfloat128
+-$(objpfx)test-float128% $(objpfx)test-ifloat128%: \
++CFLAGS-test-math-iszero.cc += -mfloat128
++$(objpfx)test-float128% $(objpfx)test-ifloat128% $(objpfx)test-math-iszero: \
+   gnulib-tests += $(f128-loader-link)
+ endif
+ 
diff --git a/gnu/packages/patches/glibc-2-26-0019.patch b/gnu/packages/patches/glibc-2-26-0019.patch
new file mode 100644
index 000000000..646eb8ea0
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0019.patch
@@ -0,0 +1,56 @@
+From 947e2e0a9410c18eb44144456c7fe8e7c0e2a999 Mon Sep 17 00:00:00 2001
+From: Joseph Myers <joseph@codesourcery.com>
+Date: Tue, 22 Aug 2017 00:30:51 +0000
+Subject: [PATCH 19/90] Fix position of tests-unsupported definition in
+ assert/Makefile.
+
+tests-unsupported has to be defined before the inclusion of Rules in a
+subdirectory Makefile; otherwise it is ineffective.  This patch fixes
+the ordering in assert/Makefile, where a recent test addition put
+tests-unsupported too late (resulting in build failures when the C++
+compiler was missing or broken, and thereby showing up the unrelated
+bug 21987).
+
+Incidentally, I don't see why these tests depend on
+$(have-cxx-thread_local) rather than just a working C++ compiler.
+
+Tested in such a configuration (broken compiler/libstdc++) with
+build-many-glibcs.py.
+
+	* assert/Makefile [$(have-cxx-thread_local)]: Move conditional
+	variable definitions above inclusion of ../Rules.
+
+(cherry picked from commit 75dfe623df945db7dd3c12a206d743c45c16b5ed)
+
+diff --git a/ChangeLog b/ChangeLog
+index 23ded7f03d..87fa54c57b 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-08-22  Joseph Myers  <joseph@codesourcery.com>
++
++	* assert/Makefile [$(have-cxx-thread_local)]: Move conditional
++	variable definitions above inclusion of ../Rules.
++
+ 2017-08-28  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
+ 
+ 	[BZ #21930]
+diff --git a/assert/Makefile b/assert/Makefile
+index 9ec1be81a9..222ab516f0 100644
+--- a/assert/Makefile
++++ b/assert/Makefile
+@@ -27,8 +27,6 @@ headers	:= assert.h
+ routines := assert assert-perr __assert
+ tests := test-assert test-assert-perr tst-assert-c++ tst-assert-g++
+ 
+-include ../Rules
+-
+ ifeq ($(have-cxx-thread_local),yes)
+ CFLAGS-tst-assert-c++.o = -std=c++11
+ LDLIBS-tst-assert-c++ = -lstdc++
+@@ -37,3 +35,5 @@ LDLIBS-tst-assert-g++ = -lstdc++
+ else
+ tests-unsupported += tst-assert-c++ tst-assert-g++
+ endif
++
++include ../Rules
diff --git a/gnu/packages/patches/glibc-2-26-0020.patch b/gnu/packages/patches/glibc-2-26-0020.patch
new file mode 100644
index 000000000..3d7401192
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0020.patch
@@ -0,0 +1,42 @@
+From 4fdd75e4463801b9d8f329769df1a26145560656 Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Tue, 8 Aug 2017 18:48:05 +0200
+Subject: [PATCH 20/90] getaddrinfo: Remove unreachable return statement from
+ gaih_inet
+
+(cherry picked from commit 0df595b23a829c9169ec418a19eef9006b4ae801)
+
+diff --git a/ChangeLog b/ChangeLog
+index 87fa54c57b..591c753fcc 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-08-08  Florian Weimer  <fweimer@redhat.com>
++
++	* sysdeps/posix/getaddrinfo.c (gaih_inet): Remove unreachable
++	return statement.
++
+ 2017-08-22  Joseph Myers  <joseph@codesourcery.com>
+ 
+ 	* assert/Makefile [$(have-cxx-thread_local)]: Move conditional
+diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
+index 699411cc92..09f85fc472 100644
+--- a/sysdeps/posix/getaddrinfo.c
++++ b/sysdeps/posix/getaddrinfo.c
+@@ -420,13 +420,9 @@ gaih_inet (const char *name, const struct gaih_service *service,
+ 		    alloca_account (sizeof (struct gaih_servtuple),
+ 				    alloca_used);
+ 
+-		  if ((rc = gaih_inet_serv (service->name,
+-					    tp, req, newp, tmpbuf)))
+-		    {
+-		      if (rc)
+-			continue;
+-		      return rc;
+-		    }
++		  if (gaih_inet_serv (service->name,
++				      tp, req, newp, tmpbuf) != 0)
++		    continue;
+ 
+ 		  *pst = newp;
+ 		  pst = &(newp->next);
diff --git a/gnu/packages/patches/glibc-2-26-0021.patch b/gnu/packages/patches/glibc-2-26-0021.patch
new file mode 100644
index 000000000..b4edbe1dd
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0021.patch
@@ -0,0 +1,94 @@
+From 5253749232749adb535d9b2bf7d43173b191ebef Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Mon, 4 Sep 2017 11:44:10 +0200
+Subject: [PATCH 21/90] Synchronize support/ infrastructure with master
+
+This commit updates the support/ subdirectory to
+commit 65329bd233db9d1b8b94e90734a564705b619260
+on the master branch.
+
+diff --git a/support/namespace.h b/support/namespace.h
+index 859c2fda3f..9eddb1a0e9 100644
+--- a/support/namespace.h
++++ b/support/namespace.h
+@@ -66,7 +66,9 @@ struct support_chroot_configuration
+ {
+   /* File contents.  The files are not created if the field is
+      NULL.  */
+-  const char *resolv_conf;
++  const char *resolv_conf;      /* /etc/resolv.conf.  */
++  const char *hosts;            /* /etc/hosts.  */
++  const char *host_conf;        /* /etc/host.conf.  */
+ };
+ 
+ /* The result of the creation of a chroot.  */
+@@ -78,8 +80,11 @@ struct support_chroot
+   /* Path to the chroot directory.  */
+   char *path_chroot;
+ 
+-  /* Path to the /etc/resolv.conf file.  */
+-  char *path_resolv_conf;
++  /* Paths to files in the chroot.  These are absolute and outside of
++     the chroot.  */
++  char *path_resolv_conf;       /* /etc/resolv.conf.  */
++  char *path_hosts;             /* /etc/hosts.  */
++  char *path_host_conf;         /* /etc/host.conf.  */
+ };
+ 
+ /* Create a chroot environment.  The returned data should be freed
+diff --git a/support/support_chroot.c b/support/support_chroot.c
+index c0807b313a..f3ef551b05 100644
+--- a/support/support_chroot.c
++++ b/support/support_chroot.c
+@@ -24,6 +24,23 @@
+ #include <support/test-driver.h>
+ #include <support/xunistd.h>
+ 
++/* If CONTENTS is not NULL, write it to the file at DIRECTORY/RELPATH,
++   and store the name in *ABSPATH.  If CONTENTS is NULL, store NULL in
++   *ABSPATH.  */
++static void
++write_file (const char *directory, const char *relpath, const char *contents,
++            char **abspath)
++{
++  if (contents != NULL)
++    {
++      *abspath = xasprintf ("%s/%s", directory, relpath);
++      add_temp_file (*abspath);
++      support_write_file_string (*abspath, contents);
++    }
++  else
++    *abspath = NULL;
++}
++
+ struct support_chroot *
+ support_chroot_create (struct support_chroot_configuration conf)
+ {
+@@ -39,15 +56,10 @@ support_chroot_create (struct support_chroot_configuration conf)
+   xmkdir (path_etc, 0777);
+   add_temp_file (path_etc);
+ 
+-  if (conf.resolv_conf != NULL)
+-    {
+-      /* Create an empty resolv.conf file.  */
+-      chroot->path_resolv_conf = xasprintf ("%s/resolv.conf", path_etc);
+-      add_temp_file (chroot->path_resolv_conf);
+-      support_write_file_string (chroot->path_resolv_conf, conf.resolv_conf);
+-    }
+-  else
+-    chroot->path_resolv_conf = NULL;
++  write_file (path_etc, "resolv.conf", conf.resolv_conf,
++              &chroot->path_resolv_conf);
++  write_file (path_etc, "hosts", conf.hosts, &chroot->path_hosts);
++  write_file (path_etc, "host.conf", conf.host_conf, &chroot->path_host_conf);
+ 
+   free (path_etc);
+ 
+@@ -67,5 +79,7 @@ support_chroot_free (struct support_chroot *chroot)
+ {
+   free (chroot->path_chroot);
+   free (chroot->path_resolv_conf);
++  free (chroot->path_hosts);
++  free (chroot->path_host_conf);
+   free (chroot);
+ }
diff --git a/gnu/packages/patches/glibc-2-26-0022.patch b/gnu/packages/patches/glibc-2-26-0022.patch
new file mode 100644
index 000000000..da3788198
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0022.patch
@@ -0,0 +1,112 @@
+From bdd8422cfb1fe04cb20617495156fb232b00d23c Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Fri, 1 Sep 2017 08:56:46 +0200
+Subject: [PATCH 22/90] getaddrinfo: Use &errno has the errno pointer
+
+Similar code in nss/getXXbyYY_r.c is already using &errno as the
+argument.
+
+(cherry picked from commit 924b121c5978689001ae28cf1c8497371dad4f71)
+
+diff --git a/ChangeLog b/ChangeLog
+index 591c753fcc..04304bb929 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-09-01  Florian Weimer  <fweimer@redhat.com>
++
++	* sysdeps/posix/getaddrinfo.c (gethosts): Use errno directly.
++	(getcanonname): Likewise.
++	(gaih_inet): Likewise.
++
+ 2017-08-08  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	* sysdeps/posix/getaddrinfo.c (gaih_inet): Remove unreachable
+diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
+index 09f85fc472..1a16820b7e 100644
+--- a/sysdeps/posix/getaddrinfo.c
++++ b/sysdeps/posix/getaddrinfo.c
+@@ -247,11 +247,10 @@ convert_hostent_to_gaih_addrtuple (const struct addrinfo *req,
+   char *localcanon = NULL;						      \
+   no_data = 0;								      \
+   while (1) {								      \
+-    rc = 0;								      \
+     status = DL_CALL_FCT (fct, (name, _family, &th,			      \
+ 				tmpbuf->data, tmpbuf->length,		      \
+-				&rc, &herrno, NULL, &localcanon));	      \
+-    if (rc != ERANGE || herrno != NETDB_INTERNAL)			      \
++				&errno, &herrno, NULL, &localcanon));	      \
++    if (errno != ERANGE || herrno != NETDB_INTERNAL)			      \
+       break;								      \
+     if (!scratch_buffer_grow (tmpbuf))					      \
+       {									      \
+@@ -261,11 +260,11 @@ convert_hostent_to_gaih_addrtuple (const struct addrinfo *req,
+ 	goto free_and_return;						      \
+       }									      \
+   }									      \
+-  if (status == NSS_STATUS_SUCCESS && rc == 0)				      \
++  if (status == NSS_STATUS_SUCCESS && errno == 0)			      \
+     h = &th;								      \
+   else									      \
+     h = NULL;								      \
+-  if (rc != 0)								      \
++  if (errno != 0)							      \
+     {									      \
+       if (herrno == NETDB_INTERNAL)					      \
+ 	{								      \
+@@ -335,9 +334,8 @@ getcanonname (service_user *nip, struct gaih_addrtuple *at, const char *name)
+     {
+       char buf[256];
+       int herrno;
+-      int rc;
+       if (DL_CALL_FCT (cfct, (at->name ?: name, buf, sizeof (buf),
+-			      &s, &rc, &herrno)) != NSS_STATUS_SUCCESS)
++			      &s, &errno, &herrno)) != NSS_STATUS_SUCCESS)
+ 	/* If the canonical name cannot be determined, use the passed
+ 	   string.  */
+ 	s = (char *) name;
+@@ -353,7 +351,6 @@ gaih_inet (const char *name, const struct gaih_service *service,
+   const struct gaih_typeproto *tp = gaih_inet_typeproto;
+   struct gaih_servtuple *st = (struct gaih_servtuple *) &nullserv;
+   struct gaih_addrtuple *at = NULL;
+-  int rc;
+   bool got_ipv6 = false;
+   const char *canon = NULL;
+   const char *orig_name = name;
+@@ -395,7 +392,8 @@ gaih_inet (const char *name, const struct gaih_service *service,
+ 	      st = (struct gaih_servtuple *)
+ 		alloca_account (sizeof (struct gaih_servtuple), alloca_used);
+ 
+-	      if ((rc = gaih_inet_serv (service->name, tp, req, st, tmpbuf)))
++	      int rc = gaih_inet_serv (service->name, tp, req, st, tmpbuf);
++	      if (__glibc_unlikely (rc != 0))
+ 		return rc;
+ 	    }
+ 	  else
+@@ -495,7 +493,7 @@ gaih_inet (const char *name, const struct gaih_service *service,
+ 	    idn_flags |= IDNA_USE_STD3_ASCII_RULES;
+ 
+ 	  char *p = NULL;
+-	  rc = __idna_to_ascii_lz (name, &p, idn_flags);
++	  int rc = __idna_to_ascii_lz (name, &p, idn_flags);
+ 	  if (rc != IDNA_SUCCESS)
+ 	    {
+ 	      /* No need to jump to free_and_return here.  */
+@@ -793,15 +791,14 @@ gaih_inet (const char *name, const struct gaih_service *service,
+ 
+ 		  while (1)
+ 		    {
+-		      rc = 0;
+ 		      status = DL_CALL_FCT (fct4, (name, pat,
+ 						   tmpbuf->data, tmpbuf->length,
+-						   &rc, &herrno,
++						   &errno, &herrno,
+ 						   NULL));
+ 		      if (status == NSS_STATUS_SUCCESS)
+ 			break;
+ 		      if (status != NSS_STATUS_TRYAGAIN
+-			  || rc != ERANGE || herrno != NETDB_INTERNAL)
++			  || errno != ERANGE || herrno != NETDB_INTERNAL)
+ 			{
+ 			  if (herrno == TRY_AGAIN)
+ 			    no_data = EAI_AGAIN;
diff --git a/gnu/packages/patches/glibc-2-26-0023.patch b/gnu/packages/patches/glibc-2-26-0023.patch
new file mode 100644
index 000000000..2a400b8b3
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0023.patch
@@ -0,0 +1,164 @@
+From 701f7873da013fb19d9120317322cd78333e63c2 Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Fri, 1 Sep 2017 08:57:07 +0200
+Subject: [PATCH 23/90] getaddrinfo: Use &h_errno has the h_errno pointer
+
+This simplifies the code because it is not necessary to propagate the
+temporary h_errno value to the thread-local variable.  It also increases
+compatibility with NSS modules which update only one of the two places.
+
+(cherry picked from commit 53250a21b81474ef4e78090a4a9a63d8471e1091)
+
+diff --git a/ChangeLog b/ChangeLog
+index 04304bb929..d53c8fe083 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-09-01  Florian Weimer  <fweimer@redhat.com>
++
++	* sysdeps/posix/getaddrinfo.c (gethosts): Use h_errno directly.
++	(getcanonname): Likewise.
++	(gaih_inet): Likewise.
++
+ 2017-09-01  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	* sysdeps/posix/getaddrinfo.c (gethosts): Use errno directly.
+diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
+index 1a16820b7e..076e1fa62b 100644
+--- a/sysdeps/posix/getaddrinfo.c
++++ b/sysdeps/posix/getaddrinfo.c
+@@ -241,7 +241,6 @@ convert_hostent_to_gaih_addrtuple (const struct addrinfo *req,
+ 
+ #define gethosts(_family, _type) \
+  {									      \
+-  int herrno;								      \
+   struct hostent th;							      \
+   struct hostent *h;							      \
+   char *localcanon = NULL;						      \
+@@ -249,8 +248,8 @@ convert_hostent_to_gaih_addrtuple (const struct addrinfo *req,
+   while (1) {								      \
+     status = DL_CALL_FCT (fct, (name, _family, &th,			      \
+ 				tmpbuf->data, tmpbuf->length,		      \
+-				&errno, &herrno, NULL, &localcanon));	      \
+-    if (errno != ERANGE || herrno != NETDB_INTERNAL)			      \
++				&errno, &h_errno, NULL, &localcanon));	      \
++    if (errno != ERANGE || h_errno != NETDB_INTERNAL)			      \
+       break;								      \
+     if (!scratch_buffer_grow (tmpbuf))					      \
+       {									      \
+@@ -266,18 +265,17 @@ convert_hostent_to_gaih_addrtuple (const struct addrinfo *req,
+     h = NULL;								      \
+   if (errno != 0)							      \
+     {									      \
+-      if (herrno == NETDB_INTERNAL)					      \
++      if (h_errno == NETDB_INTERNAL)					      \
+ 	{								      \
+-	  __set_h_errno (herrno);					      \
+ 	  __resolv_context_enable_inet6 (res_ctx, res_enable_inet6);	      \
+ 	  __resolv_context_put (res_ctx);				      \
+ 	  result = -EAI_SYSTEM;						      \
+ 	  goto free_and_return;						      \
+ 	}								      \
+-      if (herrno == TRY_AGAIN)						      \
++      if (h_errno == TRY_AGAIN)						      \
+ 	no_data = EAI_AGAIN;						      \
+       else								      \
+-	no_data = herrno == NO_DATA;					      \
++	no_data = h_errno == NO_DATA;					      \
+     }									      \
+   else if (h != NULL)							      \
+     {									      \
+@@ -333,9 +331,8 @@ getcanonname (service_user *nip, struct gaih_addrtuple *at, const char *name)
+   if (cfct != NULL)
+     {
+       char buf[256];
+-      int herrno;
+       if (DL_CALL_FCT (cfct, (at->name ?: name, buf, sizeof (buf),
+-			      &s, &errno, &herrno)) != NSS_STATUS_SUCCESS)
++			      &s, &errno, &h_errno)) != NSS_STATUS_SUCCESS)
+ 	/* If the canonical name cannot be determined, use the passed
+ 	   string.  */
+ 	s = (char *) name;
+@@ -594,14 +591,13 @@ gaih_inet (const char *name, const struct gaih_service *service,
+ 	      int rc;
+ 	      struct hostent th;
+ 	      struct hostent *h;
+-	      int herrno;
+ 
+ 	      while (1)
+ 		{
+ 		  rc = __gethostbyname2_r (name, AF_INET, &th,
+ 					   tmpbuf->data, tmpbuf->length,
+-					   &h, &herrno);
+-		  if (rc != ERANGE || herrno != NETDB_INTERNAL)
++					   &h, &h_errno);
++		  if (rc != ERANGE || h_errno != NETDB_INTERNAL)
+ 		    break;
+ 		  if (!scratch_buffer_grow (tmpbuf))
+ 		    {
+@@ -626,12 +622,9 @@ gaih_inet (const char *name, const struct gaih_service *service,
+ 		}
+ 	      else
+ 		{
+-		  if (herrno == NETDB_INTERNAL)
+-		    {
+-		      __set_h_errno (herrno);
+-		      result = -EAI_SYSTEM;
+-		    }
+-		  else if (herrno == TRY_AGAIN)
++		  if (h_errno == NETDB_INTERNAL)
++		    result = -EAI_SYSTEM;
++		  else if (h_errno == TRY_AGAIN)
+ 		    result = -EAI_AGAIN;
+ 		  else
+ 		    /* We made requests but they turned out no data.
+@@ -654,8 +647,7 @@ gaih_inet (const char *name, const struct gaih_service *service,
+ 	    {
+ 	      /* Try to use nscd.  */
+ 	      struct nscd_ai_result *air = NULL;
+-	      int herrno;
+-	      int err = __nscd_getai (name, &air, &herrno);
++	      int err = __nscd_getai (name, &air, &h_errno);
+ 	      if (air != NULL)
+ 		{
+ 		  /* Transform into gaih_addrtuple list.  */
+@@ -746,9 +738,9 @@ gaih_inet (const char *name, const struct gaih_service *service,
+ 		goto free_and_return;
+ 	      else if (__nss_not_use_nscd_hosts == 0)
+ 		{
+-		  if (herrno == NETDB_INTERNAL && errno == ENOMEM)
++		  if (h_errno == NETDB_INTERNAL && errno == ENOMEM)
+ 		    result = -EAI_MEMORY;
+-		  else if (herrno == TRY_AGAIN)
++		  else if (h_errno == TRY_AGAIN)
+ 		    result = -EAI_AGAIN;
+ 		  else
+ 		    result = -EAI_SYSTEM;
+@@ -787,23 +779,21 @@ gaih_inet (const char *name, const struct gaih_service *service,
+ 
+ 	      if (fct4 != NULL)
+ 		{
+-		  int herrno;
+-
+ 		  while (1)
+ 		    {
+ 		      status = DL_CALL_FCT (fct4, (name, pat,
+ 						   tmpbuf->data, tmpbuf->length,
+-						   &errno, &herrno,
++						   &errno, &h_errno,
+ 						   NULL));
+ 		      if (status == NSS_STATUS_SUCCESS)
+ 			break;
+ 		      if (status != NSS_STATUS_TRYAGAIN
+-			  || errno != ERANGE || herrno != NETDB_INTERNAL)
++			  || errno != ERANGE || h_errno != NETDB_INTERNAL)
+ 			{
+-			  if (herrno == TRY_AGAIN)
++			  if (h_errno == TRY_AGAIN)
+ 			    no_data = EAI_AGAIN;
+ 			  else
+-			    no_data = herrno == NO_DATA;
++			    no_data = h_errno == NO_DATA;
+ 			  break;
+ 			}
+ 
diff --git a/gnu/packages/patches/glibc-2-26-0024.patch b/gnu/packages/patches/glibc-2-26-0024.patch
new file mode 100644
index 000000000..e79333d5e
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0024.patch
@@ -0,0 +1,49 @@
+From 8f46c6052408a23a77ecf46aa378120c1a4afe37 Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Fri, 1 Sep 2017 08:57:28 +0200
+Subject: [PATCH 24/90] getaddrinfo: Properly set errno for NSS function lookup
+ failure
+
+(cherry picked from commit ad816a5e00ce891a2cea8187638fa0e00f83aaf6)
+
+diff --git a/ChangeLog b/ChangeLog
+index d53c8fe083..2f959d4c36 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-09-01  Florian Weimer  <fweimer@redhat.com>
++
++	* sysdeps/posix/getaddrinfo.c (gaih_inet): Make reporting of NSS
++	function lookup failures more reliable.
++
+ 2017-09-01  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	* sysdeps/posix/getaddrinfo.c (gethosts): Use h_errno directly.
+diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
+index 076e1fa62b..eaf8bafcf4 100644
+--- a/sysdeps/posix/getaddrinfo.c
++++ b/sysdeps/posix/getaddrinfo.c
+@@ -923,13 +923,17 @@ gaih_inet (const char *name, const struct gaih_service *service,
+ 		    }
+ 		  else
+ 		    {
++		      /* Could not locate any of the lookup functions.
++			 The NSS lookup code does not consistently set
++			 errno, so we need to supply our own error
++			 code here.  The root cause could either be a
++			 resource allocation failure, or a missing
++			 service function in the DSO (so it should not
++			 be listed in /etc/nsswitch.conf).  Assume the
++			 former, and return EBUSY.  */
+ 		      status = NSS_STATUS_UNAVAIL;
+-		      /* Could not load any of the lookup functions.  Indicate
+-		         an internal error if the failure was due to a system
+-			 error other than the file not being found.  We use the
+-			 errno from the last failed callback.  */
+-		      if (errno != 0 && errno != ENOENT)
+-			__set_h_errno (NETDB_INTERNAL);
++		     __set_h_errno (NETDB_INTERNAL);
++		     __set_errno (EBUSY);
+ 		    }
+ 		}
+ 
diff --git a/gnu/packages/patches/glibc-2-26-0025.patch b/gnu/packages/patches/glibc-2-26-0025.patch
new file mode 100644
index 000000000..a9cae8637
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0025.patch
@@ -0,0 +1,40 @@
+From 7ab87bccb657b02cac5a3360b11c67aff901de2e Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Fri, 1 Sep 2017 08:57:52 +0200
+Subject: [PATCH 25/90] getaddrinfo: In gaih_inet, use h_errno for certain
+ status values only
+
+h_errno is not set for NSS_STATUS_SUCCESS, so its value might not be
+accurate at this point.
+
+(cherry picked from commit a2881ef01450295782b065f2f850f340d5c12c14)
+
+diff --git a/ChangeLog b/ChangeLog
+index 2f959d4c36..c58cd5ccd0 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-09-01  Florian Weimer  <fweimer@redhat.com>
++
++	* sysdeps/posix/getaddrinfo.c (gaih_inet): Only use h_errno if
++	status indicates it is set.
++
+ 2017-09-01  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	* sysdeps/posix/getaddrinfo.c (gaih_inet): Make reporting of NSS
+diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
+index eaf8bafcf4..9d9e7e2bf2 100644
+--- a/sysdeps/posix/getaddrinfo.c
++++ b/sysdeps/posix/getaddrinfo.c
+@@ -949,7 +949,10 @@ gaih_inet (const char *name, const struct gaih_service *service,
+ 	  __resolv_context_enable_inet6 (res_ctx, res_enable_inet6);
+ 	  __resolv_context_put (res_ctx);
+ 
+-	  if (h_errno == NETDB_INTERNAL)
++	  /* If we have a failure which sets errno, report it using
++	     EAI_SYSTEM.  */
++	  if ((status == NSS_STATUS_TRYAGAIN || status == NSS_STATUS_UNAVAIL)
++	      && h_errno == NETDB_INTERNAL)
+ 	    {
+ 	      result = -EAI_SYSTEM;
+ 	      goto free_and_return;
diff --git a/gnu/packages/patches/glibc-2-26-0026.patch b/gnu/packages/patches/glibc-2-26-0026.patch
new file mode 100644
index 000000000..212ab0a98
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0026.patch
@@ -0,0 +1,53 @@
+From 7966331555df43bb7e2a55ce5a17a330e57f487f Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Mon, 4 Sep 2017 11:25:34 +0200
+Subject: [PATCH 26/90] getaddrinfo: Return EAI_NODATA if gethostbyname2_r
+ reports NO_DATA [BZ #21922]
+
+(cherry picked from commit 5f8340f583fe3d4f5734bd2371c5a45ecff2db0d)
+
+diff --git a/ChangeLog b/ChangeLog
+index c58cd5ccd0..f46bbb7c0d 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-09-01  Florian Weimer  <fweimer@redhat.com>
++
++	[BZ #21922]
++	* sysdeps/posix/getaddrinfo.c (gaih_inet): Report EAI_NODATA error
++	coming from gethostbyname2_r.
++
+ 2017-09-01  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	* sysdeps/posix/getaddrinfo.c (gaih_inet): Only use h_errno if
+diff --git a/NEWS b/NEWS
+index 756e849643..97eb21e868 100644
+--- a/NEWS
++++ b/NEWS
+@@ -22,6 +22,7 @@ The following bugs are resolved with this release:
+   [21780] posix: Set p{read,write}v2 to return ENOTSUP
+   [21871] x86-64: Use _dl_runtime_resolve_opt only with AVX512F
+   [21885] getaddrinfo: Release resolver context on error in gethosts
++  [21922] getaddrinfo with AF_INET(6) returns EAI_NONAME, not EAI_NODATA
+   [21930] Do not use __builtin_types_compatible_p in C++ mode
+   [21932] Unpaired __resolv_context_get in generic get*_r implementation
+   [21941] powerpc: Restrict xssqrtqp operands to Vector Registers
+diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
+index 9d9e7e2bf2..0cf87c224d 100644
+--- a/sysdeps/posix/getaddrinfo.c
++++ b/sysdeps/posix/getaddrinfo.c
+@@ -619,6 +619,14 @@ gaih_inet (const char *name, const struct gaih_service *service,
+ 			}
+ 		      *pat = addrmem;
+ 		    }
++		  else
++		    {
++		      if (h_errno == NO_DATA)
++			result = -EAI_NODATA;
++		      else
++			result = -EAI_NONAME;
++		      goto free_and_return;
++		    }
+ 		}
+ 	      else
+ 		{
diff --git a/gnu/packages/patches/glibc-2-26-0027.patch b/gnu/packages/patches/glibc-2-26-0027.patch
new file mode 100644
index 000000000..e86493fa4
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0027.patch
@@ -0,0 +1,364 @@
+From a71a3374cd8cf53776c33994f69ec184c26f2129 Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Mon, 4 Sep 2017 11:27:24 +0200
+Subject: [PATCH 27/90] getaddrinfo: Fix error handling in gethosts [BZ #21915]
+ [BZ #21922]
+
+The old code uses errno as the primary indicator for success or
+failure.  This is wrong because errno is only set for specific
+combinations of the status return value and the h_errno variable.
+
+(cherry picked from commit f4a6be2582b8dfe8adfa68da3dd8decf566b3983)
+
+diff --git a/ChangeLog b/ChangeLog
+index f46bbb7c0d..3e32d14dbf 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,17 @@
++2017-09-01  Florian Weimer  <fweimer@redhat.com>
++
++	[BZ #21915]
++	[BZ #21922]
++	* sysdeps/posix/getaddrinfo.c (gethosts): Look at NSS function
++	result to determine success or failure, not the errno value.
++	* nss/Makefile (tests): Add tst-nss-files-hosts-erange.
++	(tst-nss-files-hosts-erange): Link with -ldl.
++	* nss/tst-nss-files-hosts-erange.c: New file.
++	* nss/tst-resolv-basic.c (response): Handle nodata.example.
++	(do_test): Add NO_DATA tests.
++	* resolv/tst-resolv-basic.c (test_nodata_nxdomain): New function.
++	(do_test): Call it.
++
+ 2017-09-01  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	[BZ #21922]
+diff --git a/NEWS b/NEWS
+index 97eb21e868..8fbf4241d1 100644
+--- a/NEWS
++++ b/NEWS
+@@ -22,6 +22,7 @@ The following bugs are resolved with this release:
+   [21780] posix: Set p{read,write}v2 to return ENOTSUP
+   [21871] x86-64: Use _dl_runtime_resolve_opt only with AVX512F
+   [21885] getaddrinfo: Release resolver context on error in gethosts
++  [21915] getaddrinfo: incorrect result handling for NSS service modules
+   [21922] getaddrinfo with AF_INET(6) returns EAI_NONAME, not EAI_NODATA
+   [21930] Do not use __builtin_types_compatible_p in C++ mode
+   [21932] Unpaired __resolv_context_get in generic get*_r implementation
+diff --git a/nss/Makefile b/nss/Makefile
+index d9f6d41181..91b1c21567 100644
+--- a/nss/Makefile
++++ b/nss/Makefile
+@@ -58,6 +58,11 @@ tests			= test-netdb test-digits-dots tst-nss-getpwent bug17079 \
+ 			  tst-nss-test5
+ xtests			= bug-erange
+ 
++# Tests which need libdl
++ifeq (yes,$(build-shared))
++tests += tst-nss-files-hosts-erange
++endif
++
+ # If we have a thread library then we can test cancellation against
+ # some routines like getpwuid_r.
+ ifeq (yes,$(have-thread-library))
+@@ -154,3 +159,5 @@ $(patsubst %,$(objpfx)%.out,$(tests)) : \
+ ifeq (yes,$(have-thread-library))
+ $(objpfx)tst-cancel-getpwuid_r: $(shared-thread-library)
+ endif
++
++$(objpfx)tst-nss-files-hosts-erange: $(libdl)
+diff --git a/nss/tst-nss-files-hosts-erange.c b/nss/tst-nss-files-hosts-erange.c
+new file mode 100644
+index 0000000000..beb7aa9fa0
+--- /dev/null
++++ b/nss/tst-nss-files-hosts-erange.c
+@@ -0,0 +1,109 @@
++/* Parse /etc/hosts in multi mode with a trailing long line (bug 21915).
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++
++#include <dlfcn.h>
++#include <errno.h>
++#include <gnu/lib-names.h>
++#include <netdb.h>
++#include <nss.h>
++#include <support/check.h>
++#include <support/check_nss.h>
++#include <support/namespace.h>
++#include <support/test-driver.h>
++#include <support/xunistd.h>
++
++struct support_chroot *chroot_env;
++
++#define X10 "XXXXXXXXXX"
++#define X100 X10 X10 X10 X10 X10 X10 X10 X10 X10 X10
++#define X1000 X100 X100 X100 X100 X100 X100 X100 X100 X100 X100
++
++static void
++prepare (int argc, char **argv)
++{
++  chroot_env = support_chroot_create
++    ((struct support_chroot_configuration)
++     {
++       .resolv_conf = "",
++       .hosts =
++         "127.0.0.1   localhost localhost.localdomain\n"
++         "::1         localhost localhost.localdomain\n"
++         "192.0.2.1   example.com\n"
++         "#" X1000 X100 "\n",
++       .host_conf = "multi on\n",
++     });
++}
++
++static int
++do_test (void)
++{
++  support_become_root ();
++  if (!support_can_chroot ())
++    return EXIT_UNSUPPORTED;
++
++  __nss_configure_lookup ("hosts", "files");
++  if (dlopen (LIBNSS_FILES_SO, RTLD_LAZY) == NULL)
++    FAIL_EXIT1 ("could not load " LIBNSS_DNS_SO ": %s", dlerror ());
++
++  xchroot (chroot_env->path_chroot);
++
++  errno = ERANGE;
++  h_errno = NETDB_INTERNAL;
++  check_hostent ("gethostbyname example.com",
++                 gethostbyname ("example.com"),
++                 "name: example.com\n"
++                 "address: 192.0.2.1\n");
++  errno = ERANGE;
++  h_errno = NETDB_INTERNAL;
++  check_hostent ("gethostbyname2 AF_INET example.com",
++                 gethostbyname2 ("example.com", AF_INET),
++                 "name: example.com\n"
++                 "address: 192.0.2.1\n");
++  {
++    struct addrinfo hints =
++      {
++        .ai_family = AF_UNSPEC,
++        .ai_socktype = SOCK_STREAM,
++        .ai_protocol = IPPROTO_TCP,
++      };
++    errno = ERANGE;
++    h_errno = NETDB_INTERNAL;
++    struct addrinfo *ai;
++    int ret = getaddrinfo ("example.com", "80", &hints, &ai);
++    check_addrinfo ("example.com AF_UNSPEC", ai, ret,
++                    "address: STREAM/TCP 192.0.2.1 80\n");
++    if (ret == 0)
++      freeaddrinfo (ai);
++
++    hints.ai_family = AF_INET;
++    errno = ERANGE;
++    h_errno = NETDB_INTERNAL;
++    ret = getaddrinfo ("example.com", "80", &hints, &ai);
++    check_addrinfo ("example.com AF_INET", ai, ret,
++                    "address: STREAM/TCP 192.0.2.1 80\n");
++    if (ret == 0)
++      freeaddrinfo (ai);
++  }
++
++  support_chroot_free (chroot_env);
++  return 0;
++}
++
++#define PREPARE prepare
++#include <support/test-driver.c>
+diff --git a/resolv/tst-resolv-basic.c b/resolv/tst-resolv-basic.c
+index 64eedbbd81..66a0e8a165 100644
+--- a/resolv/tst-resolv-basic.c
++++ b/resolv/tst-resolv-basic.c
+@@ -50,7 +50,7 @@ response (const struct resolv_response_context *ctx,
+     qname_compare = qname + 2;
+   else
+     qname_compare = qname;
+-  enum {www, alias, nxdomain, long_name} requested_qname;
++  enum {www, alias, nxdomain, long_name, nodata} requested_qname;
+   if (strcmp (qname_compare, "www.example") == 0)
+     requested_qname = www;
+   else if (strcmp (qname_compare, "alias.example") == 0)
+@@ -59,6 +59,8 @@ response (const struct resolv_response_context *ctx,
+     requested_qname = nxdomain;
+   else if (strcmp (qname_compare, LONG_NAME) == 0)
+     requested_qname = long_name;
++  else if (strcmp (qname_compare, "nodata.example") == 0)
++    requested_qname = nodata;
+   else
+     {
+       support_record_failure ();
+@@ -87,6 +89,8 @@ response (const struct resolv_response_context *ctx,
+       resolv_response_close_record (b);
+       resolv_response_open_record (b, "www.example", qclass, qtype, 0);
+       break;
++    case nodata:
++      return;
+     case nxdomain:
+       FAIL_EXIT1 ("unreachable");
+     }
+@@ -267,6 +271,55 @@ test_bug_21295 (void)
+     }
+ }
+ 
++/* Run tests which do not expect any data.  */
++static void
++test_nodata_nxdomain (void)
++{
++  /* Iterate through different address families.  */
++  int families[] = { AF_UNSPEC, AF_INET, AF_INET6, -1 };
++  for (int i = 0; families[i] >= 0; ++i)
++    /* If do_tcp, prepend "t." to the name to trigger TCP
++       fallback.  */
++    for (int do_tcp = 0; do_tcp < 2; ++do_tcp)
++      /* If do_nxdomain, trigger an NXDOMAIN error (DNS failure),
++         otherwise use a NODATA response (empty but successful
++         answer).  */
++      for (int do_nxdomain = 0; do_nxdomain < 2; ++do_nxdomain)
++        {
++          int family = families[i];
++          char *name = xasprintf ("%s%s.example",
++                                  do_tcp ? "t." : "",
++                                  do_nxdomain ? "nxdomain" : "nodata");
++
++          if (family != AF_UNSPEC)
++            {
++              if (do_nxdomain)
++                check_h (name, family, "error: HOST_NOT_FOUND\n");
++              else
++                check_h (name, family, "error: NO_ADDRESS\n");
++            }
++
++          const char *expected;
++          if (do_nxdomain)
++            expected = "error: Name or service not known\n";
++          else
++            expected = "error: No address associated with hostname\n";
++
++          check_ai (name, "80", family, expected);
++
++          struct addrinfo hints =
++            {
++              .ai_family = family,
++              .ai_flags = AI_V4MAPPED | AI_ALL,
++            };
++          check_ai_hints (name, "80", hints, expected);
++          hints.ai_flags |= AI_CANONNAME;
++          check_ai_hints (name, "80", hints, expected);
++
++          free (name);
++        }
++}
++
+ static int
+ do_test (void)
+ {
+@@ -439,29 +492,8 @@ do_test (void)
+             "address: DGRAM/UDP 2001:db8::4 80\n"
+             "address: RAW/IP 2001:db8::4 80\n");
+ 
+-  check_h ("nxdomain.example", AF_INET,
+-           "error: HOST_NOT_FOUND\n");
+-  check_h ("nxdomain.example", AF_INET6,
+-           "error: HOST_NOT_FOUND\n");
+-  check_ai ("nxdomain.example", "80", AF_UNSPEC,
+-            "error: Name or service not known\n");
+-  check_ai ("nxdomain.example", "80", AF_INET,
+-            "error: Name or service not known\n");
+-  check_ai ("nxdomain.example", "80", AF_INET6,
+-            "error: Name or service not known\n");
+-
+-  check_h ("t.nxdomain.example", AF_INET,
+-           "error: HOST_NOT_FOUND\n");
+-  check_h ("t.nxdomain.example", AF_INET6,
+-           "error: HOST_NOT_FOUND\n");
+-  check_ai ("t.nxdomain.example", "80", AF_UNSPEC,
+-            "error: Name or service not known\n");
+-  check_ai ("t.nxdomain.example", "80", AF_INET,
+-            "error: Name or service not known\n");
+-  check_ai ("t.nxdomain.example", "80", AF_INET6,
+-            "error: Name or service not known\n");
+-
+   test_bug_21295 ();
++  test_nodata_nxdomain ();
+ 
+   resolv_test_end (aux);
+ 
+diff --git a/sysdeps/posix/getaddrinfo.c b/sysdeps/posix/getaddrinfo.c
+index 0cf87c224d..2c4b6d6793 100644
+--- a/sysdeps/posix/getaddrinfo.c
++++ b/sysdeps/posix/getaddrinfo.c
+@@ -242,28 +242,26 @@ convert_hostent_to_gaih_addrtuple (const struct addrinfo *req,
+ #define gethosts(_family, _type) \
+  {									      \
+   struct hostent th;							      \
+-  struct hostent *h;							      \
+   char *localcanon = NULL;						      \
+   no_data = 0;								      \
+-  while (1) {								      \
+-    status = DL_CALL_FCT (fct, (name, _family, &th,			      \
+-				tmpbuf->data, tmpbuf->length,		      \
+-				&errno, &h_errno, NULL, &localcanon));	      \
+-    if (errno != ERANGE || h_errno != NETDB_INTERNAL)			      \
+-      break;								      \
+-    if (!scratch_buffer_grow (tmpbuf))					      \
+-      {									      \
+-	__resolv_context_enable_inet6 (res_ctx, res_enable_inet6);	      \
+-	__resolv_context_put (res_ctx);					      \
+-	result = -EAI_MEMORY;						      \
+-	goto free_and_return;						      \
+-      }									      \
+-  }									      \
+-  if (status == NSS_STATUS_SUCCESS && errno == 0)			      \
+-    h = &th;								      \
+-  else									      \
+-    h = NULL;								      \
+-  if (errno != 0)							      \
++  while (1)								      \
++    {									      \
++      status = DL_CALL_FCT (fct, (name, _family, &th,			      \
++				  tmpbuf->data, tmpbuf->length,		      \
++				  &errno, &h_errno, NULL, &localcanon));      \
++      if (status != NSS_STATUS_TRYAGAIN || h_errno != NETDB_INTERNAL	      \
++	  || errno != ERANGE)						      \
++	break;								      \
++      if (!scratch_buffer_grow (tmpbuf))				      \
++	{								      \
++	  __resolv_context_enable_inet6 (res_ctx, res_enable_inet6);	      \
++	  __resolv_context_put (res_ctx);				      \
++	  result = -EAI_MEMORY;						      \
++	  goto free_and_return;						      \
++	}								      \
++    }									      \
++  if (status == NSS_STATUS_NOTFOUND					      \
++      || status == NSS_STATUS_TRYAGAIN || status == NSS_STATUS_UNAVAIL)	      \
+     {									      \
+       if (h_errno == NETDB_INTERNAL)					      \
+ 	{								      \
+@@ -277,9 +275,9 @@ convert_hostent_to_gaih_addrtuple (const struct addrinfo *req,
+       else								      \
+ 	no_data = h_errno == NO_DATA;					      \
+     }									      \
+-  else if (h != NULL)							      \
++  else if (status == NSS_STATUS_SUCCESS)				      \
+     {									      \
+-      if (!convert_hostent_to_gaih_addrtuple (req, _family,h, &addrmem))      \
++      if (!convert_hostent_to_gaih_addrtuple (req, _family, &th, &addrmem))   \
+ 	{								      \
+ 	  __resolv_context_enable_inet6 (res_ctx, res_enable_inet6);	      \
+ 	  __resolv_context_put (res_ctx);				      \
diff --git a/gnu/packages/patches/glibc-2-26-0028.patch b/gnu/packages/patches/glibc-2-26-0028.patch
new file mode 100644
index 000000000..dc38598c9
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0028.patch
@@ -0,0 +1,341 @@
+From 85cfe508568530eed2d9cfd34110c21721d1f99e Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Wed, 6 Sep 2017 13:43:01 +0200
+Subject: [PATCH 28/90] tst-res_use_inet6: Enhance test to cover IPv4-to-IPv6
+ address mapping
+
+This requires more control over the response data, so it is now
+determined by flags embedded in the query name.
+
+(cherry picked from commit 5e9c4d17feb9910f489ad2915d0b6e00597a0f11)
+
+diff --git a/ChangeLog b/ChangeLog
+index 3e32d14dbf..dd71f6c427 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,15 @@
++2017-09-06  Florian Weimer  <fweimer@redhat.com>
++
++	Enhance tst-res_use_inet6 to test IPv4-to-IPv6 address mapping.
++	* resolv/tst-res_use_inet6.c (response): Process flags embedded in
++	the QNAME.
++	(test_gai): Adjust query names.  Add additional tests.
++	(test_get2_any, test_get2_no_inet6, test_get2_inet6): Split from
++	test_get2.  Adjust query names.  Add additional tests.
++	(test_no_inet6): New function, extracted from threadfunc.
++	(threadfunc): Call test_get2_any, test_get2_inet6, test_no_inet6.
++	Add additional tests.
++
+ 2017-09-01  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	[BZ #21915]
+diff --git a/resolv/tst-res_use_inet6.c b/resolv/tst-res_use_inet6.c
+index 6f3db08892..1522d5c5f5 100644
+--- a/resolv/tst-res_use_inet6.c
++++ b/resolv/tst-res_use_inet6.c
+@@ -19,18 +19,44 @@
+ #include <netdb.h>
+ #include <resolv.h>
+ #include <string.h>
++#include <support/check.h>
+ #include <support/check_nss.h>
+ #include <support/resolv_test.h>
+ #include <support/xthread.h>
+ 
++/* Produce a response based on QNAME: Certain characters in the first
++   label of QNAME trigger the inclusion of resource records:
++
++   'a'   A record (IPv4 address)
++   'q'   AAAA record (quad A record, IPv6 address)
++   'm'   record type must match QTYPE (no additional records)
++
++   QTYPE is ignored for record type selection if 'm' is not
++   specified.  */
+ static void
+ response (const struct resolv_response_context *ctx,
+           struct resolv_response_builder *b,
+           const char *qname, uint16_t qclass, uint16_t qtype)
+ {
+-  bool include_both =  strcmp (qname, "both.example") == 0;
+-  bool include_a = qtype == T_A || include_both;
+-  bool include_aaaa = qtype == T_AAAA || include_both;
++  bool include_a = false;
++  bool include_aaaa = false;
++  bool include_match = false;
++  for (const char *p = qname; *p != '.' && *p != '\0'; ++p)
++    {
++      if (*p == 'a')
++        include_a = true;
++      else if (*p == 'q')
++        include_aaaa = true;
++      else if (*p == 'm')
++        include_match = true;
++    }
++  if (include_match)
++    {
++      if (qtype == T_A)
++        include_aaaa = false;
++      else if (qtype == T_AAAA)
++        include_a = false;
++    }
+ 
+   resolv_response_init (b, (struct resolv_response_flags) {});
+   resolv_response_add_question (b, qname, qclass, qtype);
+@@ -64,16 +90,21 @@ test_gai (void)
+         .ai_protocol = IPPROTO_TCP,
+       };
+     struct addrinfo *ai;
+-    int ret = getaddrinfo ("www1.example", "80", &hints, &ai);
+-    check_addrinfo ("getaddrinfo AF_UNSPEC www1.example", ai, ret,
++    int ret = getaddrinfo ("qam.example", "80", &hints, &ai);
++    check_addrinfo ("getaddrinfo AF_UNSPEC qam.example", ai, ret,
+                     "address: STREAM/TCP 192.0.2.17 80\n"
+                     "address: STREAM/TCP 2001:db8::1 80\n");
+     if (ret == 0)
+       freeaddrinfo (ai);
+-    ret = getaddrinfo ("both.example", "80", &hints, &ai);
++    ret = getaddrinfo ("am.example", "80", &hints, &ai);
++    check_addrinfo ("getaddrinfo AF_UNSPEC am.example", ai, ret,
++                    "address: STREAM/TCP 192.0.2.17 80\n");
++    if (ret == 0)
++      freeaddrinfo (ai);
++    ret = getaddrinfo ("qa.example", "80", &hints, &ai);
+     /* Combined A/AAAA responses currently result in address
+        duplication.  */
+-    check_addrinfo ("getaddrinfo AF_UNSPEC both.example", ai, ret,
++    check_addrinfo ("getaddrinfo AF_UNSPEC qa.example", ai, ret,
+                     "address: STREAM/TCP 192.0.2.17 80\n"
+                     "address: STREAM/TCP 192.0.2.17 80\n"
+                     "address: STREAM/TCP 2001:db8::1 80\n"
+@@ -89,13 +120,18 @@ test_gai (void)
+         .ai_protocol = IPPROTO_TCP,
+       };
+     struct addrinfo *ai;
+-    int ret = getaddrinfo ("www1.example", "80", &hints, &ai);
+-    check_addrinfo ("getaddrinfo AF_INET www1.example", ai, ret,
++    int ret = getaddrinfo ("qam.example", "80", &hints, &ai);
++    check_addrinfo ("getaddrinfo AF_INET qam.example", ai, ret,
++                    "address: STREAM/TCP 192.0.2.17 80\n");
++    if (ret == 0)
++      freeaddrinfo (ai);
++    ret = getaddrinfo ("am.example", "80", &hints, &ai);
++    check_addrinfo ("getaddrinfo AF_INET am.example", ai, ret,
+                     "address: STREAM/TCP 192.0.2.17 80\n");
+     if (ret == 0)
+       freeaddrinfo (ai);
+-    ret = getaddrinfo ("both.example", "80", &hints, &ai);
+-    check_addrinfo ("getaddrinfo AF_INET both.example", ai, ret,
++    ret = getaddrinfo ("qa.example", "80", &hints, &ai);
++    check_addrinfo ("getaddrinfo AF_INET qa.example", ai, ret,
+                     "address: STREAM/TCP 192.0.2.17 80\n");
+     if (ret == 0)
+       freeaddrinfo (ai);
+@@ -108,40 +144,131 @@ test_gai (void)
+         .ai_protocol = IPPROTO_TCP,
+       };
+     struct addrinfo *ai;
+-    int ret = getaddrinfo ("www1.example", "80", &hints, &ai);
++    int ret = getaddrinfo ("qa.example", "80", &hints, &ai);
+     check_addrinfo ("getaddrinfo (AF_INET6)", ai, ret,
+                     "address: STREAM/TCP 2001:db8::1 80\n");
+     if (ret == 0)
+       freeaddrinfo (ai);
+-    ret = getaddrinfo ("both.example", "80", &hints, &ai);
+-    check_addrinfo ("getaddrinfo AF_INET6 both.example", ai, ret,
++    ret = getaddrinfo ("am.example", "80", &hints, &ai);
++    check_addrinfo ("getaddrinfo AF_INET6 am.example", ai, ret,
++                    "error: No address associated with hostname\n");
++    if (ret == 0)
++      freeaddrinfo (ai);
++    ret = getaddrinfo ("qam.example", "80", &hints, &ai);
++    check_addrinfo ("getaddrinfo AF_INET6 qam.example", ai, ret,
+                     "address: STREAM/TCP 2001:db8::1 80\n");
+     if (ret == 0)
+       freeaddrinfo (ai);
+   }
+ }
+ 
+-/* Test that gethostbyname2 is not influenced by RES_USE_INET6.  */
++/* Test that gethostbyname2 is mostly not influenced by
++   RES_USE_INET6.  */
+ static void
+-test_get2 (void)
++test_get2_any (void)
+ {
+-  check_hostent ("gethostbyname2 AF_INET www1.example",
+-                 gethostbyname2 ("www1.example", AF_INET),
+-                 "name: www1.example\n"
++  check_hostent ("gethostbyname2 AF_INET am.example",
++                 gethostbyname2 ("am.example", AF_INET),
++                 "name: am.example\n"
+                  "address: 192.0.2.17\n");
+-  check_hostent ("gethostbyname2 AF_INET both.example",
+-                 gethostbyname2 ("both.example", AF_INET),
+-                 "name: both.example\n"
++  check_hostent ("gethostbyname2 AF_INET a.example",
++                 gethostbyname2 ("a.example", AF_INET),
++                 "name: a.example\n"
++                 "address: 192.0.2.17\n");
++  check_hostent ("gethostbyname2 AF_INET qm.example",
++                 gethostbyname2 ("qm.example", AF_INET),
++                 "error: NO_ADDRESS\n");
++  check_hostent ("gethostbyname2 AF_INET q.example",
++                 gethostbyname2 ("q.example", AF_INET),
++                 "error: NO_RECOVERY\n");
++  check_hostent ("gethostbyname2 AF_INET qam.example",
++                 gethostbyname2 ("qam.example", AF_INET),
++                 "name: qam.example\n"
++                 "address: 192.0.2.17\n");
++  check_hostent ("gethostbyname2 AF_INET qa.example",
++                 gethostbyname2 ("qa.example", AF_INET),
++                 "name: qa.example\n"
+                  "address: 192.0.2.17\n");
+ 
+-  check_hostent ("gethostbyname2 AF_INET6 www1.example",
+-                 gethostbyname2 ("www1.example", AF_INET6),
+-                 "name: www1.example\n"
++  check_hostent ("gethostbyname2 AF_INET6 qm.example",
++                 gethostbyname2 ("qm.example", AF_INET6),
++                 "name: qm.example\n"
++                 "address: 2001:db8::1\n");
++  check_hostent ("gethostbyname2 AF_INET6 q.example",
++                 gethostbyname2 ("q.example", AF_INET6),
++                 "name: q.example\n"
+                  "address: 2001:db8::1\n");
+-  check_hostent ("gethostbyname2 AF_INET6 both.example",
+-                 gethostbyname2 ("both.example", AF_INET6),
+-                 "name: both.example\n"
++  check_hostent ("gethostbyname2 AF_INET6 qam.example",
++                 gethostbyname2 ("qam.example", AF_INET6),
++                 "name: qam.example\n"
+                  "address: 2001:db8::1\n");
++  check_hostent ("gethostbyname2 AF_INET6 qa.example",
++                 gethostbyname2 ("qa.example", AF_INET6),
++                 "name: qa.example\n"
++                 "address: 2001:db8::1\n");
++  /* Additional AF_INET6 tests depend on RES_USE_INET6; see below.  */
++}
++
++/* gethostbyname2 tests with RES_USE_INET6 disabled.  */
++static void
++test_get2_no_inet6 (void)
++{
++  test_get2_any ();
++
++  check_hostent ("gethostbyname2 AF_INET6 am.example",
++                 gethostbyname2 ("am.example", AF_INET6),
++                 "error: NO_ADDRESS\n");
++  check_hostent ("gethostbyname2 AF_INET6 a.example",
++                 gethostbyname2 ("a.example", AF_INET6),
++                 "error: NO_RECOVERY\n");
++}
++
++/* gethostbyname2 tests with RES_USE_INET6 enabled.  */
++static void
++test_get2_inet6 (void)
++{
++  test_get2_any ();
++
++  check_hostent ("gethostbyname2 AF_INET6 am.example",
++                 gethostbyname2 ("am.example", AF_INET6),
++                 "name: am.example\n"
++                 "address: ::ffff:192.0.2.17\n");
++  check_hostent ("gethostbyname2 AF_INET6 a.example",
++                 gethostbyname2 ("a.example", AF_INET6),
++                 "error: NO_RECOVERY\n");
++}
++
++/* Collection of tests which assume no RES_USE_INET6 flag.  */
++static void
++test_no_inet6 (void)
++{
++  check_hostent ("gethostbyname (\"a.example\")",
++                 gethostbyname ("a.example"),
++                 "name: a.example\n"
++                 "address: 192.0.2.17\n");
++  check_hostent ("gethostbyname (\"qa.example\")",
++                 gethostbyname ("qa.example"),
++                 "name: qa.example\n"
++                 "address: 192.0.2.17\n");
++  check_hostent ("gethostbyname (\"am.example\")",
++                 gethostbyname ("am.example"),
++                 "name: am.example\n"
++                 "address: 192.0.2.17\n");
++  check_hostent ("gethostbyname (\"qam.example\")",
++                 gethostbyname ("qam.example"),
++                 "name: qam.example\n"
++                 "address: 192.0.2.17\n");
++  check_hostent ("gethostbyname (\"q.example\")",
++                 gethostbyname ("q.example"),
++                 "error: NO_RECOVERY\n");
++  check_hostent ("gethostbyname (\"qm.example\")",
++                 gethostbyname ("qm.example"),
++                 "error: NO_ADDRESS\n");
++  test_get2_no_inet6 ();
++  test_get2_no_inet6 ();
++  test_gai ();
++  test_get2_no_inet6 ();
++  test_get2_no_inet6 ();
+ }
+ 
+ static void *
+@@ -153,28 +280,42 @@ threadfunc (void *ignored)
+        .response_callback = response
+      });
+ 
+-  check_hostent ("gethostbyname (\"www1.example\")",
+-                 gethostbyname ("www1.example"),
+-                 "name: www1.example\n"
+-                 "address: 192.0.2.17\n");
+-  check_hostent ("gethostbyname (\"both.example\")",
+-                 gethostbyname ("both.example"),
+-                 "name: both.example\n"
+-                 "address: 192.0.2.17\n");
+-  test_get2 ();
+-  test_gai ();
++  TEST_VERIFY ((_res.options & RES_USE_INET6) == 0);
++  test_no_inet6 ();
+ 
+   _res.options |= RES_USE_INET6;
+-  check_hostent ("gethostbyname (\"www1.example\")",
+-                 gethostbyname ("www1.example"),
+-                 "name: www1.example\n"
++  check_hostent ("gethostbyname (\"a.inet6.example\")",
++                 gethostbyname ("a.inet6.example"),
++                 "error: NO_RECOVERY\n");
++  check_hostent ("gethostbyname (\"am.inet6.example\")",
++                 gethostbyname ("am.inet6.example"),
++                 "name: am.inet6.example\n"
++                 "address: ::ffff:192.0.2.17\n");
++  check_hostent ("gethostbyname (\"qa.inet6.example\")",
++                 gethostbyname ("qa.inet6.example"),
++                 "name: qa.inet6.example\n"
++                 "address: 2001:db8::1\n");
++  check_hostent ("gethostbyname (\"qam.inet6.example\")",
++                 gethostbyname ("qam.inet6.example"),
++                 "name: qam.inet6.example\n"
+                  "address: 2001:db8::1\n");
+-  check_hostent ("gethostbyname (\"both.example\")",
+-                 gethostbyname ("both.example"),
+-                 "name: both.example\n"
++  check_hostent ("gethostbyname (\"q.inet6.example\")",
++                 gethostbyname ("q.inet6.example"),
++                 "name: q.inet6.example\n"
+                  "address: 2001:db8::1\n");
+-  test_get2 ();
++  check_hostent ("gethostbyname (\"qm.inet6.example\")",
++                 gethostbyname ("qm.inet6.example"),
++                 "name: qm.inet6.example\n"
++                 "address: 2001:db8::1\n");
++  test_get2_inet6 ();
++  test_get2_inet6 ();
+   test_gai ();
++  test_get2_inet6 ();
++  test_get2_inet6 ();
++
++  TEST_VERIFY (_res.options & RES_USE_INET6);
++  _res.options &= ~RES_USE_INET6;
++  test_no_inet6 ();
+ 
+   resolv_test_end (obj);
+ 
diff --git a/gnu/packages/patches/glibc-2-26-0029.patch b/gnu/packages/patches/glibc-2-26-0029.patch
new file mode 100644
index 000000000..92162e19f
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0029.patch
@@ -0,0 +1,308 @@
+From 3005466abe8fb80ad4ff51865f1e28dd81c43347 Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Wed, 6 Sep 2017 15:11:44 +0200
+Subject: [PATCH 29/90] nss_dns: Remove dead PTR IPv4-to-IPv6 mapping code
+
+(cherry picked from commit c77eb96925b719001237ca7c9e3cef40d795d66b)
+
+diff --git a/ChangeLog b/ChangeLog
+index dd71f6c427..fa215c2729 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,15 @@
++2017-09-06  Florian Weimer  <fweimer@redhat.com>
++
++	Remove dead PTR IPv4-to-IPv6 mapping code from nss_dns.
++	* resolv/nss_dns/dns-host.c (getanswer_r): Remove dead code.
++	* resolv/tst-res_use_inet6.c (response_ptr_v4, response_ptr_v6):
++	New functions.
++	(response): Call them.  Add 'p', '6' flag processing.
++	(test_reverse): New function.
++	(test_get2_any): Call it.
++	(test_no_inet6): Add 'p' test.
++	(test_inet6): Likewise.
++
+ 2017-09-06  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	Enhance tst-res_use_inet6 to test IPv4-to-IPv6 address mapping.
+diff --git a/resolv/nss_dns/dns-host.c b/resolv/nss_dns/dns-host.c
+index 7cd54ab504..1e85e4f08f 100644
+--- a/resolv/nss_dns/dns-host.c
++++ b/resolv/nss_dns/dns-host.c
+@@ -889,19 +889,6 @@ getanswer_r (struct resolv_context *ctx,
+ 	  /* bind would put multiple PTR records as aliases, but we don't do
+ 	     that.  */
+ 	  result->h_name = bp;
+-	  if (have_to_map)
+-	    {
+-	      n = strlen (bp) + 1;	/* for the \0 */
+-	      if (__glibc_unlikely (n >= MAXHOSTNAMELEN))
+-		{
+-		  ++had_error;
+-		  break;
+-		}
+-	      bp += n;
+-	      linebuflen -= n;
+-	      if (map_v4v6_hostent (result, &bp, &linebuflen))
+-		goto too_small;
+-	    }
+ 	  *h_errnop = NETDB_SUCCESS;
+ 	  return NSS_STATUS_SUCCESS;
+ 	case T_A:
+diff --git a/resolv/tst-res_use_inet6.c b/resolv/tst-res_use_inet6.c
+index 1522d5c5f5..d819f921d6 100644
+--- a/resolv/tst-res_use_inet6.c
++++ b/resolv/tst-res_use_inet6.c
+@@ -16,31 +16,101 @@
+    License along with the GNU C Library; if not, see
+    <http://www.gnu.org/licenses/>.  */
+ 
++#include <ctype.h>
+ #include <netdb.h>
+ #include <resolv.h>
++#include <stdio.h>
++#include <stdlib.h>
+ #include <string.h>
+ #include <support/check.h>
+ #include <support/check_nss.h>
+ #include <support/resolv_test.h>
++#include <support/support.h>
+ #include <support/xthread.h>
+ 
++/* Handle IPv4 reverse lookup responses.  Product a PTR record
++   A-B-C-D.v4.example.  */
++static void
++response_ptr_v4 (const struct resolv_response_context *ctx,
++                 struct resolv_response_builder *b,
++                 const char *qname, uint16_t qclass, uint16_t qtype)
++{
++  int bytes[4];
++  int offset = -1;
++  TEST_VERIFY (sscanf (qname, "%d.%d.%d.%d.in-addr.arpa%n",
++                       bytes + 0, bytes + 1, bytes + 2, bytes + 3,
++                       &offset) == 4);
++  TEST_VERIFY (offset == strlen (qname));
++  resolv_response_init (b, (struct resolv_response_flags) {});
++  resolv_response_add_question (b, qname, qclass, qtype);
++  resolv_response_section (b, ns_s_an);
++  resolv_response_open_record (b, qname, qclass, T_PTR, 0);
++  char *name = xasprintf ("%d-%d-%d-%d.v4.example",
++                          bytes[3], bytes[2], bytes[1], bytes[0]);
++  resolv_response_add_name (b, name);
++  free (name);
++  resolv_response_close_record (b);
++}
++
++/* Handle IPv6 reverse lookup responses.  Produce a PTR record
++   <32 hex digits>.v6.example. */
++static void
++response_ptr_v6 (const struct resolv_response_context *ctx,
++                 struct resolv_response_builder *b,
++                 const char *qname, uint16_t qclass, uint16_t qtype)
++{
++
++  TEST_VERIFY_EXIT (strlen (qname) > 64);
++
++  char bytes[33];
++  for (int i = 0; i < 64; ++i)
++    if ((i % 2) == 0)
++      {
++        TEST_VERIFY (isxdigit ((unsigned char) qname[i]));
++        bytes[31 - i / 2] = qname[i];
++      }
++    else
++      TEST_VERIFY_EXIT (qname[i] == '.');
++  bytes[32] = '\0';
++
++    resolv_response_init (b, (struct resolv_response_flags) {});
++  resolv_response_add_question (b, qname, qclass, qtype);
++  resolv_response_section (b, ns_s_an);
++  resolv_response_open_record (b, qname, qclass, T_PTR, 0);
++  char *name = xasprintf ("%s.v6.example", bytes);
++  resolv_response_add_name (b, name);
++  free (name);
++  resolv_response_close_record (b);
++}
++
+ /* Produce a response based on QNAME: Certain characters in the first
+    label of QNAME trigger the inclusion of resource records:
+ 
+    'a'   A record (IPv4 address)
+    'q'   AAAA record (quad A record, IPv6 address)
++   'p'   PTR record
+    'm'   record type must match QTYPE (no additional records)
++   '6'   stop flag processing if QTYPE == AAAA
++
++   For 'a' and 'q', QTYPE is ignored for record type selection if 'm'
++   is not specified.
+ 
+-   QTYPE is ignored for record type selection if 'm' is not
+-   specified.  */
++   in-addr.arpa and ip6.arpa queries are handled separately in
++   response_ptr_v4 and response_ptr_v6.  */
+ static void
+ response (const struct resolv_response_context *ctx,
+           struct resolv_response_builder *b,
+           const char *qname, uint16_t qclass, uint16_t qtype)
+ {
++  if (strstr (qname, ".in-addr.arpa") != NULL)
++    return response_ptr_v4 (ctx, b, qname, qclass, qtype);
++  else if (strstr (qname, ".ip6.arpa") != NULL)
++    return response_ptr_v6 (ctx, b, qname, qclass, qtype);
++
+   bool include_a = false;
+   bool include_aaaa = false;
+   bool include_match = false;
++  bool include_ptr = false;
+   for (const char *p = qname; *p != '.' && *p != '\0'; ++p)
+     {
+       if (*p == 'a')
+@@ -49,6 +119,10 @@ response (const struct resolv_response_context *ctx,
+         include_aaaa = true;
+       else if (*p == 'm')
+         include_match = true;
++      else if (*p == 'p')
++        include_ptr = true;
++      else if (*p == '6' && qtype == T_AAAA)
++        break;
+     }
+   if (include_match)
+     {
+@@ -70,11 +144,17 @@ response (const struct resolv_response_context *ctx,
+     }
+   if (include_aaaa)
+     {
+-        char ipv6[16]
+-          = {0x20, 0x01, 0xd, 0xb8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1};
+-        resolv_response_open_record (b, qname, qclass, T_AAAA, 0);
+-        resolv_response_add_data (b, &ipv6, sizeof (ipv6));
+-        resolv_response_close_record (b);
++      char ipv6[16]
++        = {0x20, 0x01, 0xd, 0xb8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1};
++      resolv_response_open_record (b, qname, qclass, T_AAAA, 0);
++      resolv_response_add_data (b, &ipv6, sizeof (ipv6));
++      resolv_response_close_record (b);
++    }
++  if (include_ptr)
++    {
++      resolv_response_open_record (b, qname, qclass, T_PTR, 0);
++      resolv_response_add_name (b, "ptr-target.example");
++      resolv_response_close_record (b);
+     }
+ }
+ 
+@@ -162,6 +242,65 @@ test_gai (void)
+   }
+ }
+ 
++/* Test gethostbyaddr and getnameinfo.  The results are independent of
++   RES_USE_INET6.  */
++static void
++test_reverse (void)
++{
++  {
++    char ipv4[4] = { 192, 0, 2, 17 };
++    check_hostent ("gethostbyaddr AF_INET",
++                   gethostbyaddr (ipv4, sizeof (ipv4), AF_INET),
++                   "name: 192-0-2-17.v4.example\n"
++                   "address: 192.0.2.17\n");
++  }
++  {
++    char ipv6[16]
++      = {0x20, 0x01, 0xd, 0xb8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1};
++    check_hostent ("gethostbyaddr AF_INET",
++                   gethostbyaddr (ipv6, sizeof (ipv6), AF_INET6),
++                   "name: 20010db8000000000000000000000001.v6.example\n"
++                   "address: 2001:db8::1\n");
++  }
++
++  {
++    struct sockaddr_in addr =
++      {
++        .sin_family = AF_INET,
++        .sin_addr = { .s_addr = htonl (0xc0000211) },
++        .sin_port = htons (80)
++      };
++    char host[NI_MAXHOST];
++    char service[NI_MAXSERV];
++    int ret = getnameinfo ((struct sockaddr *) &addr, sizeof (addr),
++                           host, sizeof (host), service, sizeof (service),
++                           NI_NUMERICSERV);
++    TEST_VERIFY (ret == 0);
++    TEST_VERIFY (strcmp (host, "192-0-2-17.v4.example") == 0);
++    TEST_VERIFY (strcmp (service, "80") == 0);
++  }
++  {
++    char ipv6[16]
++      = {0x20, 0x01, 0xd, 0xb8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1};
++    struct sockaddr_in6 addr =
++      {
++        .sin6_family = AF_INET6,
++        .sin6_port = htons (80),
++      };
++    TEST_VERIFY (sizeof (ipv6) == sizeof (addr.sin6_addr));
++    memcpy (&addr.sin6_addr, ipv6, sizeof (addr.sin6_addr));
++    char host[NI_MAXHOST];
++    char service[NI_MAXSERV];
++    int ret = getnameinfo ((struct sockaddr *) &addr, sizeof (addr),
++                           host, sizeof (host), service, sizeof (service),
++                           NI_NUMERICSERV);
++    TEST_VERIFY (ret == 0);
++    TEST_VERIFY
++      (strcmp (host, "20010db8000000000000000000000001.v6.example") == 0);
++    TEST_VERIFY (strcmp (service, "80") == 0);
++  }
++}
++
+ /* Test that gethostbyname2 is mostly not influenced by
+    RES_USE_INET6.  */
+ static void
+@@ -207,6 +346,8 @@ test_get2_any (void)
+                  "name: qa.example\n"
+                  "address: 2001:db8::1\n");
+   /* Additional AF_INET6 tests depend on RES_USE_INET6; see below.  */
++
++  test_reverse ();
+ }
+ 
+ /* gethostbyname2 tests with RES_USE_INET6 disabled.  */
+@@ -254,6 +395,10 @@ test_no_inet6 (void)
+                  gethostbyname ("am.example"),
+                  "name: am.example\n"
+                  "address: 192.0.2.17\n");
++  check_hostent ("gethostbyname (\"amp.example\")",
++                 gethostbyname ("amp.example"),
++                 "name: amp.example\n"
++                 "address: 192.0.2.17\n");
+   check_hostent ("gethostbyname (\"qam.example\")",
+                  gethostbyname ("qam.example"),
+                  "name: qam.example\n"
+@@ -307,6 +452,28 @@ threadfunc (void *ignored)
+                  gethostbyname ("qm.inet6.example"),
+                  "name: qm.inet6.example\n"
+                  "address: 2001:db8::1\n");
++  check_hostent ("gethostbyname (\"amp.inet6.example\")",
++                 gethostbyname ("amp.inet6.example"),
++                 "error: NO_RECOVERY\n");
++  check_hostent ("gethostbyname (\"qmp.inet6.example\")",
++                 gethostbyname ("qmp.inet6.example"),
++                 "name: qmp.inet6.example\n"
++                 "address: 2001:db8::1\n");
++  check_hostent ("gethostbyname (\"ap.inet6.example\")",
++                 gethostbyname ("ap.inet6.example"),
++                 "error: NO_RECOVERY\n");
++  check_hostent ("gethostbyname (\"6ap.inet6.example\")",
++                 gethostbyname ("6ap.inet6.example"),
++                 "name: 6ap.inet6.example\n"
++                 "address: ::ffff:192.0.2.17\n");
++  check_hostent ("gethostbyname (\"am6p.inet6.example\")",
++                 gethostbyname ("am6p.inet6.example"),
++                 "name: am6p.inet6.example\n"
++                 "address: ::ffff:192.0.2.17\n");
++  check_hostent ("gethostbyname (\"qp.inet6.example\")",
++                 gethostbyname ("qp.inet6.example"),
++                 "name: qp.inet6.example\n"
++                 "address: 2001:db8::1\n");
+   test_get2_inet6 ();
+   test_get2_inet6 ();
+   test_gai ();
diff --git a/gnu/packages/patches/glibc-2-26-0030.patch b/gnu/packages/patches/glibc-2-26-0030.patch
new file mode 100644
index 000000000..6a2e3a85b
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0030.patch
@@ -0,0 +1,50 @@
+From 905a6129147e7ee80e8918e23efe212433b8cce7 Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Wed, 6 Sep 2017 15:46:54 +0200
+Subject: [PATCH 30/90] resolv: Fix memory leak with OOM during resolv.conf
+ parsing [BZ #22095]
+
+(cherry picked from commit 5670c4ab256114e869b1df4b05653aa5f909182c)
+
+diff --git a/ChangeLog b/ChangeLog
+index fa215c2729..ef2041b9e5 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-09-06  Florian Weimer  <fweimer@redhat.com>
++
++	[BZ #22095]
++	* resolv/res_init.c (res_vinit_1): Avoid memory leak in case of
++	dynarray allocation failure.
++
+ 2017-09-06  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	Remove dead PTR IPv4-to-IPv6 mapping code from nss_dns.
+diff --git a/NEWS b/NEWS
+index 8fbf4241d1..62959274b3 100644
+--- a/NEWS
++++ b/NEWS
+@@ -28,6 +28,7 @@ The following bugs are resolved with this release:
+   [21932] Unpaired __resolv_context_get in generic get*_r implementation
+   [21941] powerpc: Restrict xssqrtqp operands to Vector Registers
+   [21972] assert macro requires operator== (int) for its argument type
++  [22095] resolv: Fix memory leak with OOM during resolv.conf parsing
+ \f
+ Version 2.26
+ 
+diff --git a/resolv/res_init.c b/resolv/res_init.c
+index fa46ce7813..4e1f9fe8de 100644
+--- a/resolv/res_init.c
++++ b/resolv/res_init.c
+@@ -446,6 +446,11 @@ res_vinit_1 (FILE *fp, struct resolv_conf_parser *parser)
+                     (&parser->nameserver_list);
+                   if (p != NULL)
+                     *p = sa;
++                  else
++                    {
++                      free (sa);
++                      return false;
++                    }
+                 }
+               continue;
+             }
diff --git a/gnu/packages/patches/glibc-2-26-0031.patch b/gnu/packages/patches/glibc-2-26-0031.patch
new file mode 100644
index 000000000..121954b94
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0031.patch
@@ -0,0 +1,50 @@
+From 27233446a62ca35ce0b54566279a99a6774d4210 Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Wed, 6 Sep 2017 15:47:27 +0200
+Subject: [PATCH 31/90] resolv: __resolv_conf_attach must not free passed conf
+ object [BZ #22096]
+
+(cherry picked from commit a83047308196e3e54716a39dd85c0a08b198d6bd)
+
+diff --git a/ChangeLog b/ChangeLog
+index ef2041b9e5..e98a4bbf3c 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-09-06  Florian Weimer  <fweimer@redhat.com>
++
++	[BZ #22096]
++	* resolv/resolv_conf.c (__resolv_conf_attach): Do not free conf in
++	case of failure to obtain the global conf object.
++
+ 2017-09-06  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	[BZ #22095]
+diff --git a/NEWS b/NEWS
+index 62959274b3..9bcb176171 100644
+--- a/NEWS
++++ b/NEWS
+@@ -29,6 +29,7 @@ The following bugs are resolved with this release:
+   [21941] powerpc: Restrict xssqrtqp operands to Vector Registers
+   [21972] assert macro requires operator== (int) for its argument type
+   [22095] resolv: Fix memory leak with OOM during resolv.conf parsing
++  [22096] resolv: __resolv_conf_attach must not free passed conf object
+ \f
+ Version 2.26
+ 
+diff --git a/resolv/resolv_conf.c b/resolv/resolv_conf.c
+index f391d30c27..e0f296d02e 100644
+--- a/resolv/resolv_conf.c
++++ b/resolv/resolv_conf.c
+@@ -600,10 +600,7 @@ __resolv_conf_attach (struct __res_state *resp, struct resolv_conf *conf)
+ 
+   struct resolv_conf_global *global_copy = get_locked_global ();
+   if (global_copy == NULL)
+-    {
+-      free (conf);
+-      return false;
+-    }
++    return false;
+ 
+   /* Try to find an unused index in the array.  */
+   size_t index;
diff --git a/gnu/packages/patches/glibc-2-26-0032.patch b/gnu/packages/patches/glibc-2-26-0032.patch
new file mode 100644
index 000000000..e637b8c87
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0032.patch
@@ -0,0 +1,34 @@
+From d265b6129184dd94da600187b67cef9125bc58c7 Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Wed, 6 Sep 2017 11:25:14 +0200
+Subject: [PATCH 32/90] __libc_dynarray_emplace_enlarge: Add missing else
+
+Before, arrays of small elements received a starting allocation size of
+8, not 16.
+
+diff --git a/ChangeLog b/ChangeLog
+index e98a4bbf3c..f82fd1f97d 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-09-06  Florian Weimer  <fweimer@redhat.com>
++
++	* malloc/dynarray_emplace_enlarge.c
++	(__libc_dynarray_emplace_enlarge): Add missing else.
++
+ 2017-09-06  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	[BZ #22096]
+diff --git a/malloc/dynarray_emplace_enlarge.c b/malloc/dynarray_emplace_enlarge.c
+index dfc70017ce..09cd09268b 100644
+--- a/malloc/dynarray_emplace_enlarge.c
++++ b/malloc/dynarray_emplace_enlarge.c
+@@ -32,7 +32,7 @@ __libc_dynarray_emplace_enlarge (struct dynarray_header *list,
+          size.  */
+       if (element_size < 4)
+         new_allocated = 16;
+-      if (element_size < 8)
++      else if (element_size < 8)
+         new_allocated = 8;
+       else
+         new_allocated = 4;
diff --git a/gnu/packages/patches/glibc-2-26-0033.patch b/gnu/packages/patches/glibc-2-26-0033.patch
new file mode 100644
index 000000000..d3bb68d2c
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0033.patch
@@ -0,0 +1,132 @@
+From 8a1adb593969e099604537804f594efe01e04f6f Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Wed, 30 Aug 2017 20:10:56 +0200
+Subject: [PATCH 33/90] dynarray: Set errno on overflow-induced allocation
+ failure
+
+This allows the caller to return directly on such an error, with an
+appropriate errno value.
+
+(cherry picked from commit 5898f4548efdcd7c0fd437a74eeb80facc51a117)
+
+diff --git a/ChangeLog b/ChangeLog
+index f82fd1f97d..87cc2f4865 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,11 @@
++2017-08-30  Florian Weimer  <fweimer@redhat.com>
++
++	* malloc/dynarray_emplace_enlarge.c
++	(__libc_dynarray_emplace_enlarge): Set errno on overflow.
++	* malloc/dynarray_resize.c (__libc_dynarray_resize): Likewise.
++	* malloc/tst-dynarray.c (test_long_overflow): New function.
++	(do_test): Call it.
++
+ 2017-09-06  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	* malloc/dynarray_emplace_enlarge.c
+diff --git a/malloc/dynarray_emplace_enlarge.c b/malloc/dynarray_emplace_enlarge.c
+index 09cd09268b..a15245f4cb 100644
+--- a/malloc/dynarray_emplace_enlarge.c
++++ b/malloc/dynarray_emplace_enlarge.c
+@@ -17,6 +17,7 @@
+    <http://www.gnu.org/licenses/>.  */
+ 
+ #include <dynarray.h>
++#include <errno.h>
+ #include <malloc-internal.h>
+ #include <stdlib.h>
+ #include <string.h>
+@@ -43,8 +44,11 @@ __libc_dynarray_emplace_enlarge (struct dynarray_header *list,
+     {
+       new_allocated = list->allocated + list->allocated / 2 + 1;
+       if (new_allocated <= list->allocated)
+-        /* Overflow.  */
+-        return false;
++        {
++          /* Overflow.  */
++          __set_errno (ENOMEM);
++          return false;
++        }
+     }
+ 
+   size_t new_size;
+diff --git a/malloc/dynarray_resize.c b/malloc/dynarray_resize.c
+index e6dc9fbc68..63c981bf61 100644
+--- a/malloc/dynarray_resize.c
++++ b/malloc/dynarray_resize.c
+@@ -17,6 +17,7 @@
+    <http://www.gnu.org/licenses/>.  */
+ 
+ #include <dynarray.h>
++#include <errno.h>
+ #include <malloc-internal.h>
+ #include <stdlib.h>
+ #include <string.h>
+@@ -38,7 +39,11 @@ __libc_dynarray_resize (struct dynarray_header *list, size_t size,
+ 
+   size_t new_size_bytes;
+   if (check_mul_overflow_size_t (size, element_size, &new_size_bytes))
+-    return false;
++    {
++      /* Overflow.  */
++      __set_errno (ENOMEM);
++      return false;
++    }
+   void *new_array;
+   if (list->array == scratch)
+     {
+diff --git a/malloc/tst-dynarray.c b/malloc/tst-dynarray.c
+index 2206d75e31..d11f7bb8a3 100644
+--- a/malloc/tst-dynarray.c
++++ b/malloc/tst-dynarray.c
+@@ -18,6 +18,9 @@
+ 
+ #include "tst-dynarray-shared.h"
+ 
++#include <errno.h>
++#include <stdint.h>
++
+ #define DYNARRAY_STRUCT dynarray_long
+ #define DYNARRAY_ELEMENT long
+ #define DYNARRAY_PREFIX dynarray_long_
+@@ -463,6 +466,31 @@ test_long_init (void)
+   }
+ }
+ 
++/* Test overflow in resize.  */
++static void
++test_long_overflow (void)
++{
++  {
++    struct dynarray_long dyn;
++    dynarray_long_init (&dyn);
++    errno = EINVAL;
++    TEST_VERIFY (!dynarray_long_resize
++                 (&dyn, (SIZE_MAX / sizeof (long)) + 1));
++    TEST_VERIFY (errno == ENOMEM);
++    TEST_VERIFY (dynarray_long_has_failed (&dyn));
++  }
++
++  {
++    struct dynarray_long_noscratch dyn;
++    dynarray_long_noscratch_init (&dyn);
++    errno = EINVAL;
++    TEST_VERIFY (!dynarray_long_noscratch_resize
++                 (&dyn, (SIZE_MAX / sizeof (long)) + 1));
++    TEST_VERIFY (errno == ENOMEM);
++    TEST_VERIFY (dynarray_long_noscratch_has_failed (&dyn));
++  }
++}
++
+ /* Test NUL-terminated string construction with the add function and
+    the simple finalize function.  */
+ static void
+@@ -538,6 +566,7 @@ do_test (void)
+   test_int ();
+   test_str ();
+   test_long_init ();
++  test_long_overflow ();
+   test_zstr ();
+   return 0;
+ }
diff --git a/gnu/packages/patches/glibc-2-26-0034.patch b/gnu/packages/patches/glibc-2-26-0034.patch
new file mode 100644
index 000000000..39daff049
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0034.patch
@@ -0,0 +1,54 @@
+From dca8b177f6bb521638f4d8a845b4cb10348137c9 Mon Sep 17 00:00:00 2001
+From: "H.J. Lu" <hjl.tools@gmail.com>
+Date: Thu, 31 Aug 2017 06:28:31 -0700
+Subject: [PATCH 34/90] Place $(elf-objpfx)sofini.os last [BZ #22051]
+
+Since sofini.os terminates .eh_frame section, it should be placed last.
+
+	[BZ #22051]
+	* Makerules (build-module-helper-objlist): Filter out
+	$(elf-objpfx)sofini.os.
+	(build-shlib-objlist): Append $(elf-objpfx)sofini.os if it is
+	needed.
+
+(cherry picked from commit ecd0747df388f3925d4839740b0abcf43d0a9fb2)
+
+diff --git a/ChangeLog b/ChangeLog
+index 87cc2f4865..f9e423dbb3 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,11 @@
++2017-08-31  H.J. Lu  <hongjiu.lu@intel.com>
++
++	[BZ #22051]
++	* Makerules (build-module-helper-objlist): Filter out
++	$(elf-objpfx)sofini.os.
++	(build-shlib-objlist): Append $(elf-objpfx)sofini.os if it is
++	needed.
++
+ 2017-08-30  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	* malloc/dynarray_emplace_enlarge.c
+diff --git a/Makerules b/Makerules
+index 9bb707c168..828a445f24 100644
+--- a/Makerules
++++ b/Makerules
+@@ -686,14 +686,17 @@ $(build-module-helper) -o $@ $(shlib-lds-flags) \
+ $(call after-link,$@)
+ endef
+ 
++# sofini.os must be placed last since it terminates .eh_frame section.
+ build-module-helper-objlist = \
+ 	$(patsubst %_pic.a,$(whole-archive) %_pic.a $(no-whole-archive),\
+ 		   $(filter-out %.lds $(map-file) $(+preinit) $(+postinit) \
++				$(elf-objpfx)sofini.os \
+ 				$(link-libc-deps),$^))
+ 
+ build-module-objlist = $(build-module-helper-objlist) $(LDLIBS-$(@F:%.so=%).so)
+ build-shlib-objlist = $(build-module-helper-objlist) \
+-		      $(LDLIBS-$(@F:lib%.so=%).so)
++		      $(LDLIBS-$(@F:lib%.so=%).so) \
++		      $(filter $(elf-objpfx)sofini.os,$^)
+ 
+ # Don't try to use -lc when making libc.so itself.
+ # Also omits crti.o and crtn.o, which we do not want
diff --git a/gnu/packages/patches/glibc-2-26-0035.patch b/gnu/packages/patches/glibc-2-26-0035.patch
new file mode 100644
index 000000000..e2c071594
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0035.patch
@@ -0,0 +1,36 @@
+From 86553be84d071aee8464b2c2fa03858d12118852 Mon Sep 17 00:00:00 2001
+From: "H.J. Lu" <hjl.tools@gmail.com>
+Date: Thu, 7 Sep 2017 13:56:58 -0700
+Subject: [PATCH 35/90] Use "static const char domain[] ="
+
+	* resolv/tst-resolv-qtypes.c (domain): Changed to
+	"const char domain[] =".
+
+(cherry picked from commit 78bfa877b36e8f33c99cbe9a16eb73f5a2adc0c8)
+
+diff --git a/ChangeLog b/ChangeLog
+index f9e423dbb3..96c461c441 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-09-07  H.J. Lu  <hongjiu.lu@intel.com>
++
++	* resolv/tst-resolv-qtypes.c (domain): Changed to
++	"const char domain[] =".
++
+ 2017-08-31  H.J. Lu  <hongjiu.lu@intel.com>
+ 
+ 	[BZ #22051]
+diff --git a/resolv/tst-resolv-qtypes.c b/resolv/tst-resolv-qtypes.c
+index 06ea3dbd14..da3325f80c 100644
+--- a/resolv/tst-resolv-qtypes.c
++++ b/resolv/tst-resolv-qtypes.c
+@@ -50,7 +50,7 @@ response (const struct resolv_response_context *ctx,
+   resolv_response_close_record (b);
+ }
+ 
+-static const char * const domain = "www.example.com";
++static const char domain[] = "www.example.com";
+ 
+ static int
+ wrap_res_query (int type, unsigned char *answer, int answer_length)
diff --git a/gnu/packages/patches/glibc-2-26-0036.patch b/gnu/packages/patches/glibc-2-26-0036.patch
new file mode 100644
index 000000000..e75e5b521
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0036.patch
@@ -0,0 +1,38 @@
+From 5f5532caf820f47f714d09766082f1e070c12cfb Mon Sep 17 00:00:00 2001
+From: Markus Trippelsdorf <markus@trippelsdorf.de>
+Date: Fri, 8 Sep 2017 19:57:12 +0000
+Subject: [PATCH 36/90] Update x86_64 ulps for AMD Ryzen.
+
+	* sysdeps/x86_64/fpu/libm-test-ulps: Update for AMD Ryzen.
+
+(cherry picked from commit 4c03a696800e3bb4b433626a65c4fef465dcc98b)
+
+diff --git a/ChangeLog b/ChangeLog
+index 96c461c441..c180f8dbca 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,7 @@
++2017-09-08  Markus Trippelsdorf  <markus@trippelsdorf.de>
++
++	* sysdeps/x86_64/fpu/libm-test-ulps: Update for AMD Ryzen.
++
+ 2017-09-07  H.J. Lu  <hongjiu.lu@intel.com>
+ 
+ 	* resolv/tst-resolv-qtypes.c (domain): Changed to
+diff --git a/sysdeps/x86_64/fpu/libm-test-ulps b/sysdeps/x86_64/fpu/libm-test-ulps
+index c347642044..1e28aaa9f1 100644
+--- a/sysdeps/x86_64/fpu/libm-test-ulps
++++ b/sysdeps/x86_64/fpu/libm-test-ulps
+@@ -1733,10 +1733,10 @@ ldouble: 3
+ 
+ Function: Imaginary part of "ctan_upward":
+ double: 2
+-float: 1
++float: 2
+ float128: 5
+ idouble: 2
+-ifloat: 1
++ifloat: 2
+ ifloat128: 5
+ ildouble: 3
+ ldouble: 3
diff --git a/gnu/packages/patches/glibc-2-26-0037.patch b/gnu/packages/patches/glibc-2-26-0037.patch
new file mode 100644
index 000000000..d92a33526
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0037.patch
@@ -0,0 +1,649 @@
+From 56ce01906ecb0a3e04411f8ceb60b27f4877f070 Mon Sep 17 00:00:00 2001
+From: "H.J. Lu" <hjl.tools@gmail.com>
+Date: Wed, 23 Aug 2017 08:22:52 -0700
+Subject: [PATCH 37/90] string/stratcliff.c: Replace int with size_t [BZ
+ #21982]
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+Fix GCC 7 errors when string/stratcliff.c is compiled with -O3:
+
+stratcliff.c: In function ‘do_test’:
+cc1: error: assuming signed overflow does not occur when assuming that (X - c) <= X is always true [-Werror=strict-overflow]
+
+	[BZ #21982]
+	* string/stratcliff.c (do_test): Declare size, nchars, inner,
+	middle and outer with size_t instead of int.  Repleace %d and
+	%Zd with %zu in printf.  Update "MAX (0, nchars - 128)" and
+	"MAX (outer, nchars - 64)" to support unsigned outer and
+	nchars.  Also exit loop when outer == 0.
+
+(cherry picked from commit 376b40a27a6783ea7f73ae577be320df66aeb36d)
+
+diff --git a/ChangeLog b/ChangeLog
+index c180f8dbca..84721f6265 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,12 @@
++2017-09-11  H.J. Lu  <hongjiu.lu@intel.com>
++
++	[BZ #21982]
++	* string/stratcliff.c (do_test): Declare size, nchars, inner,
++	middle and outer with size_t instead of int.  Repleace %d and
++	%Zd with %zu in printf.  Update "MAX (0, nchars - 128)" and
++	"MAX (outer, nchars - 64)" to support unsigned outer and
++	nchars.  Also exit loop when outer == 0.
++
+ 2017-09-08  Markus Trippelsdorf  <markus@trippelsdorf.de>
+ 
+ 	* sysdeps/x86_64/fpu/libm-test-ulps: Update for AMD Ryzen.
+diff --git a/string/stratcliff.c b/string/stratcliff.c
+index e28b0c5058..4320336c9a 100644
+--- a/string/stratcliff.c
++++ b/string/stratcliff.c
+@@ -58,8 +58,8 @@
+ int
+ do_test (void)
+ {
+-  int size = sysconf (_SC_PAGESIZE);
+-  int nchars = size / sizeof (CHAR);
++  size_t size = sysconf (_SC_PAGESIZE);
++  size_t nchars = size / sizeof (CHAR);
+   CHAR *adr;
+   CHAR *dest;
+   int result = 0;
+@@ -80,7 +80,17 @@ do_test (void)
+     }
+   else
+     {
+-      int inner, middle, outer;
++      size_t inner, middle, outer, nchars64, max128;
++
++      if (nchars > 64)
++	nchars64 = nchars - 64;
++      else
++	nchars64 = 0;
++
++      if (nchars > 128)
++	max128 = nchars - 128;
++      else
++	max128 = 0;
+ 
+       mprotect (adr, size, PROT_NONE);
+       mprotect (adr + 2 * nchars, size, PROT_NONE);
+@@ -93,59 +103,65 @@ do_test (void)
+       MEMSET (adr, L('T'), nchars);
+ 
+       /* strlen/wcslen test */
+-      for (outer = nchars - 1; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars - 1; outer >= max128; --outer)
+ 	{
+-	  for (inner = MAX (outer, nchars - 64); inner < nchars; ++inner)
++	  for (inner = MAX (outer, nchars64); inner < nchars; ++inner)
+ 	    {
+ 	      adr[inner] = L('\0');
+ 
+ 	      if (STRLEN (&adr[outer]) != (size_t) (inner - outer))
+ 		{
+-		  printf ("%s flunked for outer = %d, inner = %d\n",
++		  printf ("%s flunked for outer = %zu, inner = %zu\n",
+ 			  STRINGIFY (STRLEN), outer, inner);
+ 		  result = 1;
+ 		}
+ 
+ 	      adr[inner] = L('T');
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+ 
+       /* strnlen/wcsnlen test */
+-      for (outer = nchars; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars; outer >= max128; --outer)
+ 	{
+-	  for (inner = MAX (outer, nchars - 64); inner < nchars; ++inner)
++	  for (inner = MAX (outer, nchars64); inner < nchars; ++inner)
+ 	    {
+ 	      adr[inner] = L('\0');
+ 
+ 	      if (STRNLEN (&adr[outer], inner - outer + 1)
+ 		  != (size_t) (inner - outer))
+ 		{
+-		  printf ("%s flunked for outer = %d, inner = %d\n",
++		  printf ("%s flunked for outer = %zu, inner = %zu\n",
+ 			  STRINGIFY (STRNLEN), outer, inner);
+ 		  result = 1;
+ 		}
+ 
+ 	      adr[inner] = L('T');
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+-      for (outer = nchars; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars; outer >= max128; --outer)
+ 	{
+-	  for (inner = MAX (outer, nchars - 64); inner <= nchars; ++inner)
++	  for (inner = MAX (outer, nchars64); inner <= nchars; ++inner)
+ 	    {
+ 	      if (STRNLEN (&adr[outer], inner - outer)
+ 		  != (size_t) (inner - outer))
+ 		{
+-		  printf ("%s flunked bounded for outer = %d, inner = %d\n",
++		  printf ("%s flunked bounded for outer = %zu, inner = %zu\n",
+ 			  STRINGIFY (STRNLEN), outer, inner);
+ 		  result = 1;
+ 		}
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+ 
+       /* strchr/wcschr test */
+-      for (outer = nchars - 1; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars - 1; outer >= max128; --outer)
+ 	{
+-	  for (middle = MAX (outer, nchars - 64); middle < nchars; ++middle)
++	  for (middle = MAX (outer, nchars64); middle < nchars; ++middle)
+ 	    {
+ 	      for (inner = middle; inner < nchars; ++inner)
+ 		{
+@@ -158,8 +174,8 @@ do_test (void)
+ 		      || (inner != middle
+ 			  && (cp - &adr[outer]) != middle - outer))
+ 		    {
+-		      printf ("%s flunked for outer = %d, middle = %d, "
+-			      "inner = %d\n",
++		      printf ("%s flunked for outer = %zu, middle = %zu, "
++			      "inner = %zu\n",
+ 			      STRINGIFY (STRCHR), outer, middle, inner);
+ 		      result = 1;
+ 		    }
+@@ -168,6 +184,8 @@ do_test (void)
+ 		  adr[middle] = L('T');
+ 		}
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+ 
+       /* Special test.  */
+@@ -180,9 +198,9 @@ do_test (void)
+ 	}
+ 
+       /* strrchr/wcsrchr test */
+-      for (outer = nchars - 1; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars - 1; outer >= max128; --outer)
+ 	{
+-	  for (middle = MAX (outer, nchars - 64); middle < nchars; ++middle)
++	  for (middle = MAX (outer, nchars64); middle < nchars; ++middle)
+ 	    {
+ 	      for (inner = middle; inner < nchars; ++inner)
+ 		{
+@@ -195,8 +213,8 @@ do_test (void)
+ 		      || (inner != middle
+ 			  && (cp - &adr[outer]) != middle - outer))
+ 		    {
+-		      printf ("%s flunked for outer = %d, middle = %d, "
+-			      "inner = %d\n",
++		      printf ("%s flunked for outer = %zu, middle = %zu, "
++			      "inner = %zu\n",
+ 			      STRINGIFY (STRRCHR), outer, middle, inner);
+ 		      result = 1;
+ 		    }
+@@ -205,12 +223,14 @@ do_test (void)
+ 		  adr[middle] = L('T');
+ 		}
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+ 
+       /* memchr test */
+-      for (outer = nchars - 1; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars - 1; outer >= max128; --outer)
+ 	{
+-	  for (middle = MAX (outer, nchars - 64); middle < nchars; ++middle)
++	  for (middle = MAX (outer, nchars64); middle < nchars; ++middle)
+ 	    {
+ 	      adr[middle] = L('V');
+ 
+@@ -218,32 +238,36 @@ do_test (void)
+ 
+ 	      if (cp - &adr[outer] != middle - outer)
+ 		{
+-		  printf ("%s flunked for outer = %d, middle = %d\n",
++		  printf ("%s flunked for outer = %zu, middle = %zu\n",
+ 			  STRINGIFY (MEMCHR), outer, middle);
+ 		  result = 1;
+ 		}
+ 
+ 	      adr[middle] = L('T');
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+-      for (outer = nchars; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars; outer >= max128; --outer)
+ 	{
+ 	  CHAR *cp = MEMCHR (&adr[outer], L('V'), nchars - outer);
+ 
+ 	  if (cp != NULL)
+ 	    {
+-	      printf ("%s flunked for outer = %d\n",
++	      printf ("%s flunked for outer = %zu\n",
+ 		      STRINGIFY (MEMCHR), outer);
+ 	      result = 1;
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+ 
+       /* These functions only exist for single-byte characters.  */
+ #ifndef WCSTEST
+       /* rawmemchr test */
+-      for (outer = nchars - 1; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars - 1; outer >= max128; --outer)
+ 	{
+-	  for (middle = MAX (outer, nchars - 64); middle < nchars; ++middle)
++	  for (middle = MAX (outer, nchars64); middle < nchars; ++middle)
+ 	    {
+ 	      adr[middle] = L('V');
+ 
+@@ -251,19 +275,21 @@ do_test (void)
+ 
+ 	      if (cp - &adr[outer] != middle - outer)
+ 		{
+-		  printf ("%s flunked for outer = %d, middle = %d\n",
++		  printf ("%s flunked for outer = %zu, middle = %zu\n",
+ 			  STRINGIFY (rawmemchr), outer, middle);
+ 		  result = 1;
+ 		}
+ 
+ 	      adr[middle] = L('T');
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+ 
+       /* memrchr test */
+-      for (outer = nchars - 1; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars - 1; outer >= max128; --outer)
+ 	{
+-	  for (middle = MAX (outer, nchars - 64); middle < nchars; ++middle)
++	  for (middle = MAX (outer, nchars64); middle < nchars; ++middle)
+ 	    {
+ 	      adr[middle] = L('V');
+ 
+@@ -271,44 +297,50 @@ do_test (void)
+ 
+ 	      if (cp - &adr[outer] != middle - outer)
+ 		{
+-		  printf ("%s flunked for outer = %d, middle = %d\n",
++		  printf ("%s flunked for outer = %zu, middle = %zu\n",
+ 			  STRINGIFY (memrchr), outer, middle);
+ 		  result = 1;
+ 		}
+ 
+ 	      adr[middle] = L('T');
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+-      for (outer = nchars; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars; outer >= max128; --outer)
+ 	{
+ 	  CHAR *cp = memrchr (&adr[outer], L('V'), nchars - outer);
+ 
+ 	  if (cp != NULL)
+ 	    {
+-	      printf ("%s flunked for outer = %d\n",
++	      printf ("%s flunked for outer = %zu\n",
+ 		      STRINGIFY (memrchr), outer);
+ 	      result = 1;
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+ #endif
+ 
+       /* strcpy/wcscpy test */
+-      for (outer = nchars - 1; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars - 1; outer >= max128; --outer)
+ 	{
+-	  for (inner = MAX (outer, nchars - 64); inner < nchars; ++inner)
++	  for (inner = MAX (outer, nchars64); inner < nchars; ++inner)
+ 	    {
+ 	      adr[inner] = L('\0');
+ 
+ 	      if (STRCPY (dest, &adr[outer]) != dest
+ 		  || STRLEN (dest) != (size_t) (inner - outer))
+ 		{
+-		  printf ("%s flunked for outer = %d, inner = %d\n",
++		  printf ("%s flunked for outer = %zu, inner = %zu\n",
+ 			  STRINGIFY (STRCPY), outer, inner);
+ 		  result = 1;
+ 		}
+ 
+ 	      adr[inner] = L('T');
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+ 
+       /* strcmp/wcscmp tests */
+@@ -322,14 +354,14 @@ do_test (void)
+ 
+ 	    if (STRCMP (adr + middle, dest + nchars - outer) <= 0)
+ 	      {
+-		printf ("%s 1 flunked for outer = %d, middle = %d\n",
++		printf ("%s 1 flunked for outer = %zu, middle = %zu\n",
+ 			STRINGIFY (STRCMP), outer, middle);
+ 		result = 1;
+ 	      }
+ 
+ 	    if (STRCMP (dest + nchars - outer, adr + middle) >= 0)
+ 	      {
+-		printf ("%s 2 flunked for outer = %d, middle = %d\n",
++		printf ("%s 2 flunked for outer = %zu, middle = %zu\n",
+ 			STRINGIFY (STRCMP), outer, middle);
+ 		result = 1;
+ 	      }
+@@ -348,16 +380,16 @@ do_test (void)
+ 	      {
+ 		if (STRNCMP (adr + middle, dest + nchars - outer, inner) != 0)
+ 		  {
+-		    printf ("%s 1 flunked for outer = %d, middle = %d, "
+-			    "inner = %d\n",
++		    printf ("%s 1 flunked for outer = %zu, middle = %zu, "
++			    "inner = %zu\n",
+ 			    STRINGIFY (STRNCMP), outer, middle, inner);
+ 		    result = 1;
+ 		  }
+ 
+ 		if (STRNCMP (dest + nchars - outer, adr + middle, inner) != 0)
+ 		  {
+-		    printf ("%s 2 flunked for outer = %d, middle = %d, "
+-			    "inner = %d\n",
++		    printf ("%s 2 flunked for outer = %zu, middle = %zu, "
++			    "inner = %zu\n",
+ 			    STRINGIFY (STRNCMP), outer, middle, inner);
+ 		    result = 1;
+ 		  }
+@@ -365,14 +397,14 @@ do_test (void)
+ 
+ 	    if (STRNCMP (adr + middle, dest + nchars - outer, outer) >= 0)
+ 	      {
+-		printf ("%s 1 flunked for outer = %d, middle = %d, full\n",
++		printf ("%s 1 flunked for outer = %zu, middle = %zu, full\n",
+ 			STRINGIFY (STRNCMP), outer, middle);
+ 		result = 1;
+ 	      }
+ 
+ 	    if (STRNCMP (dest + nchars - outer, adr + middle, outer) <= 0)
+ 	      {
+-		printf ("%s 2 flunked for outer = %d, middle = %d, full\n",
++		printf ("%s 2 flunked for outer = %zu, middle = %zu, full\n",
+ 			STRINGIFY (STRNCMP), outer, middle);
+ 		result = 1;
+ 	      }
+@@ -380,7 +412,7 @@ do_test (void)
+ 
+       /* strncpy/wcsncpy tests */
+       adr[nchars - 1] = L('T');
+-      for (outer = nchars; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars; outer >= max128; --outer)
+ 	{
+ 	  size_t len;
+ 
+@@ -389,17 +421,19 @@ do_test (void)
+ 	      if (STRNCPY (dest, &adr[outer], len) != dest
+ 		  || MEMCMP (dest, &adr[outer], len) != 0)
+ 		{
+-		  printf ("outer %s flunked for outer = %d, len = %Zd\n",
++		  printf ("outer %s flunked for outer = %zu, len = %zu\n",
+ 			  STRINGIFY (STRNCPY), outer, len);
+ 		  result = 1;
+ 		}
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+       adr[nchars - 1] = L('\0');
+ 
+-      for (outer = nchars - 1; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars - 1; outer >= max128; --outer)
+ 	{
+-	  for (inner = MAX (outer, nchars - 64); inner < nchars; ++inner)
++	  for (inner = MAX (outer, nchars64); inner < nchars; ++inner)
+ 	    {
+ 	      size_t len;
+ 
+@@ -413,8 +447,8 @@ do_test (void)
+ 		      || (inner - outer < len
+ 			  && STRLEN (dest) != (inner - outer)))
+ 		    {
+-		      printf ("%s flunked for outer = %d, inner = %d, "
+-			      "len = %Zd\n",
++		      printf ("%s flunked for outer = %zu, inner = %zu, "
++			      "len = %zu\n",
+ 			      STRINGIFY (STRNCPY), outer, inner, len);
+ 		      result = 1;
+ 		    }
+@@ -424,8 +458,8 @@ do_test (void)
+ 		      || (inner - outer < len
+ 			  && STRLEN (dest + 1) != (inner - outer)))
+ 		    {
+-		      printf ("%s+1 flunked for outer = %d, inner = %d, "
+-			      "len = %Zd\n",
++		      printf ("%s+1 flunked for outer = %zu, inner = %zu, "
++			      "len = %zu\n",
+ 			      STRINGIFY (STRNCPY), outer, inner, len);
+ 		      result = 1;
+ 		    }
+@@ -433,29 +467,33 @@ do_test (void)
+ 
+ 	      adr[inner] = L('T');
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+ 
+       /* stpcpy/wcpcpy test */
+-      for (outer = nchars - 1; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars - 1; outer >= max128; --outer)
+ 	{
+-	  for (inner = MAX (outer, nchars - 64); inner < nchars; ++inner)
++	  for (inner = MAX (outer, nchars64); inner < nchars; ++inner)
+ 	    {
+ 	      adr[inner] = L('\0');
+ 
+ 	      if ((STPCPY (dest, &adr[outer]) - dest) != inner - outer)
+ 		{
+-		  printf ("%s flunked for outer = %d, inner = %d\n",
++		  printf ("%s flunked for outer = %zu, inner = %zu\n",
+ 			  STRINGIFY (STPCPY), outer, inner);
+ 		  result = 1;
+ 		}
+ 
+ 	      adr[inner] = L('T');
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+ 
+       /* stpncpy/wcpncpy test */
+       adr[nchars - 1] = L('T');
+-      for (outer = nchars; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars; outer >= max128; --outer)
+ 	{
+ 	  size_t len;
+ 
+@@ -464,17 +502,19 @@ do_test (void)
+ 	      if (STPNCPY (dest, &adr[outer], len) != dest + len
+ 		  || MEMCMP (dest, &adr[outer], len) != 0)
+ 		{
+-		  printf ("outer %s flunked for outer = %d, len = %Zd\n",
++		  printf ("outer %s flunked for outer = %zu, len = %zu\n",
+ 			  STRINGIFY (STPNCPY), outer, len);
+ 		  result = 1;
+ 		}
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+       adr[nchars - 1] = L('\0');
+ 
+-      for (outer = nchars - 1; outer >= MAX (0, nchars - 128); --outer)
++      for (outer = nchars - 1; outer >= max128; --outer)
+ 	{
+-	  for (middle = MAX (outer, nchars - 64); middle < nchars; ++middle)
++	  for (middle = MAX (outer, nchars64); middle < nchars; ++middle)
+ 	    {
+ 	      adr[middle] = L('\0');
+ 
+@@ -483,8 +523,8 @@ do_test (void)
+ 		  if ((STPNCPY (dest, &adr[outer], inner) - dest)
+ 		      != MIN (inner, middle - outer))
+ 		    {
+-		      printf ("%s flunked for outer = %d, middle = %d, "
+-			      "inner = %d\n",
++		      printf ("%s flunked for outer = %zu, middle = %zu, "
++			      "inner = %zu\n",
+ 			      STRINGIFY (STPNCPY), outer, middle, inner);
+ 		      result = 1;
+ 		    }
+@@ -492,66 +532,84 @@ do_test (void)
+ 
+ 	      adr[middle] = L('T');
+ 	    }
++	  if (outer == 0)
++	    break;
+ 	}
+ 
+       /* memcpy/wmemcpy test */
+-      for (outer = nchars; outer >= MAX (0, nchars - 128); --outer)
+-	for (inner = 0; inner < nchars - outer; ++inner)
+-	  if (MEMCPY (dest, &adr[outer], inner) !=  dest)
+-	    {
+-	      printf ("%s flunked for outer = %d, inner = %d\n",
+-		      STRINGIFY (MEMCPY), outer, inner);
+-	      result = 1;
+-	    }
++      for (outer = nchars; outer >= max128; --outer)
++	{
++	  for (inner = 0; inner < nchars - outer; ++inner)
++	    if (MEMCPY (dest, &adr[outer], inner) !=  dest)
++	      {
++		printf ("%s flunked for outer = %zu, inner = %zu\n",
++			STRINGIFY (MEMCPY), outer, inner);
++		result = 1;
++	      }
++	  if (outer == 0)
++	    break;
++	}
+ 
+       /* mempcpy/wmempcpy test */
+-      for (outer = nchars; outer >= MAX (0, nchars - 128); --outer)
+-	for (inner = 0; inner < nchars - outer; ++inner)
+-	  if (MEMPCPY (dest, &adr[outer], inner) !=  dest + inner)
+-	    {
+-	      printf ("%s flunked for outer = %d, inner = %d\n",
+-		      STRINGIFY (MEMPCPY), outer, inner);
+-	      result = 1;
+-	    }
++      for (outer = nchars; outer >= max128; --outer)
++	{
++	  for (inner = 0; inner < nchars - outer; ++inner)
++	    if (MEMPCPY (dest, &adr[outer], inner) !=  dest + inner)
++	      {
++		printf ("%s flunked for outer = %zu, inner = %zu\n",
++			STRINGIFY (MEMPCPY), outer, inner);
++		result = 1;
++	      }
++	  if (outer == 0)
++	    break;
++	}
+ 
+       /* This function only exists for single-byte characters.  */
+ #ifndef WCSTEST
+       /* memccpy test */
+       memset (adr, '\0', nchars);
+-      for (outer = nchars; outer >= MAX (0, nchars - 128); --outer)
+-	for (inner = 0; inner < nchars - outer; ++inner)
+-	  if (memccpy (dest, &adr[outer], L('\1'), inner) != NULL)
+-	    {
+-	      printf ("memccpy flunked full copy for outer = %d, inner = %d\n",
+-		      outer, inner);
+-	      result = 1;
+-	    }
+-      for (outer = nchars - 1; outer >= MAX (0, nchars - 128); --outer)
+-	for (middle = 0; middle < nchars - outer; ++middle)
+-	  {
+-	    memset (dest, L('\2'), middle + 1);
+-	    for (inner = 0; inner < middle; ++inner)
++      for (outer = nchars; outer >= max128; --outer)
++	{
++	  for (inner = 0; inner < nchars - outer; ++inner)
++	    if (memccpy (dest, &adr[outer], L('\1'), inner) != NULL)
+ 	      {
+-		adr[outer + inner] = L('\1');
+-
+-		if (memccpy (dest, &adr[outer], '\1', middle + 128)
+-		    !=  dest + inner + 1)
+-		  {
+-		    printf ("\
+-memccpy flunked partial copy for outer = %d, middle = %d, inner = %d\n",
+-			    outer, middle, inner);
+-		    result = 1;
+-		  }
+-		else if (dest[inner + 1] != L('\2'))
+-		  {
+-		    printf ("\
+-memccpy copied too much for outer = %d, middle = %d, inner = %d\n",
+-			    outer, middle, inner);
+-		    result = 1;
+-		  }
+-		adr[outer + inner] = L('\0');
++		printf ("memccpy flunked full copy for outer = %zu, inner = %zu\n",
++			outer, inner);
++		result = 1;
+ 	      }
+-	  }
++	  if (outer == 0)
++	    break;
++	}
++      for (outer = nchars - 1; outer >= max128; --outer)
++	{
++	  for (middle = 0; middle < nchars - outer; ++middle)
++	    {
++	      memset (dest, L('\2'), middle + 1);
++	      for (inner = 0; inner < middle; ++inner)
++		{
++		  adr[outer + inner] = L('\1');
++
++		  if (memccpy (dest, &adr[outer], '\1', middle + 128)
++		      !=  dest + inner + 1)
++		    {
++		      printf ("\
++			      memccpy flunked partial copy for outer = %zu, middle = %zu, inner = %zu\n",
++			      outer, middle, inner);
++		      result = 1;
++		    }
++		  else if (dest[inner + 1] != L('\2'))
++		    {
++		      printf ("\
++			      memccpy copied too much for outer = %zu, middle = %zu, inner = %zu\n",
++			      outer, middle, inner);
++		      result = 1;
++		    }
++		  adr[outer + inner] = L('\0');
++		}
++	    }
++	  if (outer == 0)
++	    break;
++	}
+ #endif
+     }
+ 
diff --git a/gnu/packages/patches/glibc-2-26-0038.patch b/gnu/packages/patches/glibc-2-26-0038.patch
new file mode 100644
index 000000000..11c2b3e2a
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0038.patch
@@ -0,0 +1,214 @@
+From 2422c6032fd5e95b1c29df5b8671455ead51314e Mon Sep 17 00:00:00 2001
+From: Alan Modra <amodra@gmail.com>
+Date: Thu, 3 Aug 2017 15:39:21 +0930
+Subject: [PATCH 38/90] tst-tlsopt-powerpc as a shared lib
+
+This makes the __tls_get_addr_opt test run as a shared library, and so
+actually test that DTPMOD64/DTPREL64 pairs are processed by ld.so to
+support the __tls_get_adfr_opt call stub fast return.  After a
+2017-01-24 patch (binutils f0158f4416) ld.bfd no longer emitted
+unnecessary dynamic relocations against local thread variables,
+instead setting up the __tls_index GOT entries for the call stub fast
+return.  This meant tst-tlsopt-powerpc passed but did not check ld.so
+relocation support.  After a 2017-07-16 patch (binutils 676ee2b5fa)
+ld.bfd no longer set up the __tls_index GOT entries for the call stub
+fast return, and tst-tlsopt-powerpc failed.
+
+Compiling mod-tlsopt-powerpc.c with -DSHARED exposed a bug in
+powerpc64/tls-macros.h, which defines a __TLS_GET_ADDR macro that
+clashes with one defined in dl-tls.h.  The tls-macros.h version is
+only used in that file, so delete it and expand.
+
+	* sysdeps/powerpc/mod-tlsopt-powerpc.c: Extract from
+	tst-tlsopt-powerpc.c with function name change and no test harness.
+	* sysdeps/powerpc/tst-tlsopt-powerpc.c: Remove body of test.
+	Call tls_get_addr_opt_test.
+	* sysdeps/powerpc/Makefile (LDFLAGS-tst-tlsopt-powerpc): Don't define.
+	(modules-names): Add mod-tlsopt-powerpc.
+	(mod-tlsopt-powerpc.so-no-z-defs): Define.
+	(tst-tlsopt-powerpc): Depend on .so.
+	* sysdeps/powerpc/powerpc64/tls-macros.h (__TLS_GET_ADDR): Don't
+	define.  Expand use in TLS_GD and TLS_LD.
+
+(cherry picked from commit e98c925fa4f6486447eb20676755dbf9eb36a110)
+
+diff --git a/ChangeLog b/ChangeLog
+index 84721f6265..b53d8830a2 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,16 @@
++2017-08-03  Alan Modra  <amodra@gmail.com>
++
++	* sysdeps/powerpc/mod-tlsopt-powerpc.c: Extract from
++	tst-tlsopt-powerpc.c with function name change and no test harness.
++	* sysdeps/powerpc/tst-tlsopt-powerpc.c: Remove body of test.
++	Call tls_get_addr_opt_test.
++	* sysdeps/powerpc/Makefile (LDFLAGS-tst-tlsopt-powerpc): Don't define.
++	(modules-names): Add mod-tlsopt-powerpc.
++	(mod-tlsopt-powerpc.so-no-z-defs): Define.
++	(tst-tlsopt-powerpc): Depend on .so.
++	* sysdeps/powerpc/powerpc64/tls-macros.h (__TLS_GET_ADDR): Don't
++	define.  Expand use in TLS_GD and TLS_LD.
++
+ 2017-09-11  H.J. Lu  <hongjiu.lu@intel.com>
+ 
+ 	[BZ #21982]
+diff --git a/sysdeps/powerpc/Makefile b/sysdeps/powerpc/Makefile
+index 0d9206bec4..6aa683b03f 100644
+--- a/sysdeps/powerpc/Makefile
++++ b/sysdeps/powerpc/Makefile
+@@ -8,9 +8,11 @@ sysdep-dl-routines += dl-machine hwcapinfo
+ sysdep_routines += dl-machine hwcapinfo
+ # extra shared linker files to link only into dl-allobjs.so
+ sysdep-rtld-routines += dl-machine hwcapinfo
+-# Don't optimize GD tls sequence to LE.
+-LDFLAGS-tst-tlsopt-powerpc += -Wl,--no-tls-optimize
++
++modules-names += mod-tlsopt-powerpc
++mod-tlsopt-powerpc.so-no-z-defs = yes
+ tests += tst-tlsopt-powerpc
++$(objpfx)tst-tlsopt-powerpc: $(objpfx)mod-tlsopt-powerpc.so
+ 
+ ifneq (no,$(multi-arch))
+ tests-static += tst-tlsifunc-static
+diff --git a/sysdeps/powerpc/mod-tlsopt-powerpc.c b/sysdeps/powerpc/mod-tlsopt-powerpc.c
+new file mode 100644
+index 0000000000..ee0db12a73
+--- /dev/null
++++ b/sysdeps/powerpc/mod-tlsopt-powerpc.c
+@@ -0,0 +1,49 @@
++/* shared library to test for __tls_get_addr optimization.  */
++#include <stdio.h>
++
++#include "../../elf/tls-macros.h"
++#include "dl-tls.h"
++
++/* common 'int' variable in TLS.  */
++COMMON_INT_DEF(foo);
++
++
++int
++tls_get_addr_opt_test (void)
++{
++  int result = 0;
++
++  /* Get variable using general dynamic model.  */
++  int *ap = TLS_GD (foo);
++  if (*ap != 0)
++    {
++      printf ("foo = %d\n", *ap);
++      result = 1;
++    }
++
++  tls_index *tls_arg;
++#ifdef __powerpc64__
++  register unsigned long thread_pointer __asm__ ("r13");
++  asm ("addi %0,2,foo@got@tlsgd" : "=r" (tls_arg));
++#else
++  register unsigned long thread_pointer __asm__ ("r2");
++  asm ("bcl 20,31,1f\n1:\t"
++       "mflr %0\n\t"
++       "addis %0,%0,_GLOBAL_OFFSET_TABLE_-1b@ha\n\t"
++       "addi %0,%0,_GLOBAL_OFFSET_TABLE_-1b@l\n\t"
++       "addi %0,%0,foo@got@tlsgd" : "=b" (tls_arg));
++#endif
++
++  if (tls_arg->ti_module != 0)
++    {
++      printf ("tls_index not optimized, binutils too old?\n");
++      result = 1;
++    }
++  else if (tls_arg->ti_offset + thread_pointer != (unsigned long) ap)
++    {
++      printf ("tls_index->ti_offset wrong value\n");
++      result = 1;
++    }
++
++  return result;
++}
+diff --git a/sysdeps/powerpc/powerpc64/tls-macros.h b/sysdeps/powerpc/powerpc64/tls-macros.h
+index 42a95ec5c1..79a0b2579c 100644
+--- a/sysdeps/powerpc/powerpc64/tls-macros.h
++++ b/sysdeps/powerpc/powerpc64/tls-macros.h
+@@ -18,13 +18,11 @@
+      __result;								      \
+   })
+ 
+-#define __TLS_GET_ADDR "__tls_get_addr"
+-
+ /* PowerPC64 Local Dynamic TLS access.  */
+ #define TLS_LD(x)							      \
+   ({ int * __result;							      \
+      asm ("addi  3,2," #x "@got@tlsld\n\t"				      \
+-	  "bl    " __TLS_GET_ADDR "\n\t"				      \
++	  "bl    __tls_get_addr\n\t"					      \
+ 	  "nop   \n\t"							      \
+ 	  "addis %0,3," #x "@dtprel@ha\n\t"				      \
+ 	  "addi  %0,%0," #x "@dtprel@l"					      \
+@@ -36,7 +34,7 @@
+ #define TLS_GD(x)							      \
+   ({ register int *__result __asm__ ("r3");				      \
+      asm ("addi  3,2," #x "@got@tlsgd\n\t"				      \
+-	  "bl    " __TLS_GET_ADDR "\n\t"				      \
++	  "bl    __tls_get_addr\n\t"					      \
+ 	  "nop   "							      \
+ 	  : "=r" (__result) :						      \
+ 	  : __TLS_CALL_CLOBBERS);					      \
+diff --git a/sysdeps/powerpc/tst-tlsopt-powerpc.c b/sysdeps/powerpc/tst-tlsopt-powerpc.c
+index 8ae928a3f4..cc682b2ed0 100644
+--- a/sysdeps/powerpc/tst-tlsopt-powerpc.c
++++ b/sysdeps/powerpc/tst-tlsopt-powerpc.c
+@@ -1,51 +1,11 @@
+ /* glibc test for __tls_get_addr optimization.  */
+-#include <stdio.h>
+-
+-#include "../../elf/tls-macros.h"
+-#include "dl-tls.h"
+-
+-/* common 'int' variable in TLS.  */
+-COMMON_INT_DEF(foo);
+-
+ 
+ static int
+ do_test (void)
+ {
+-  int result = 0;
+-
+-  /* Get variable using general dynamic model.  */
+-  int *ap = TLS_GD (foo);
+-  if (*ap != 0)
+-    {
+-      printf ("foo = %d\n", *ap);
+-      result = 1;
+-    }
+-
+-  tls_index *tls_arg;
+-#ifdef __powerpc64__
+-  register unsigned long thread_pointer __asm__ ("r13");
+-  asm ("addi %0,2,foo@got@tlsgd" : "=r" (tls_arg));
+-#else
+-  register unsigned long thread_pointer __asm__ ("r2");
+-  asm ("bcl 20,31,1f\n1:\t"
+-       "mflr %0\n\t"
+-       "addis %0,%0,_GLOBAL_OFFSET_TABLE_-1b@ha\n\t"
+-       "addi %0,%0,_GLOBAL_OFFSET_TABLE_-1b@l\n\t"
+-       "addi %0,%0,foo@got@tlsgd" : "=b" (tls_arg));
+-#endif
+-
+-  if (tls_arg->ti_module != 0)
+-    {
+-      printf ("tls_index not optimized, binutils too old?\n");
+-      result = 1;
+-    }
+-  else if (tls_arg->ti_offset + thread_pointer != (unsigned long) ap)
+-    {
+-      printf ("tls_index->ti_offset wrong value\n");
+-      result = 1;
+-    }
++  extern int tls_get_addr_opt_test (void);
+ 
+-  return result;
++  return tls_get_addr_opt_test ();
+ }
+ 
+ #include <support/test-driver.c>
diff --git a/gnu/packages/patches/glibc-2-26-0039.patch b/gnu/packages/patches/glibc-2-26-0039.patch
new file mode 100644
index 000000000..581596ffb
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0039.patch
@@ -0,0 +1,36 @@
+From ac6113cb0146494af7ecacbbdc6957ce501a40ec Mon Sep 17 00:00:00 2001
+From: Martin Sebor <msebor@redhat.com>
+Date: Tue, 22 Aug 2017 09:35:23 -0600
+Subject: [PATCH 39/90] Declare ifunc resolver to return a pointer to the same
+ type as the target function to help GCC detect incompatibilities between the
+ two when it's enhanced to do so.
+
+(cherry picked from commit ee4e992ebe5f9712faedeefe8958b67d61eaa0f2)
+
+diff --git a/ChangeLog b/ChangeLog
+index b53d8830a2..ec9b9f5edb 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-08-22  Martin Sebor  <msebor@redhat.com>
++
++	* include/libc-symbols.h (__ifunc_resolver): Declare resolver
++	to return a pointer to the same type as the target function.
++
+ 2017-08-03  Alan Modra  <amodra@gmail.com>
+ 
+ 	* sysdeps/powerpc/mod-tlsopt-powerpc.c: Extract from
+diff --git a/include/libc-symbols.h b/include/libc-symbols.h
+index 3310e3a678..c50f9adec2 100644
+--- a/include/libc-symbols.h
++++ b/include/libc-symbols.h
+@@ -782,7 +782,8 @@ for linking")
+ 
+ /* Helper / base  macros for indirect function symbols.  */
+ #define __ifunc_resolver(type_name, name, expr, arg, init, classifier)	\
+-  classifier inhibit_stack_protector void *name##_ifunc (arg)					\
++  classifier inhibit_stack_protector					\
++  __typeof (type_name) *name##_ifunc (arg)				\
+   {									\
+     init ();								\
+     __typeof (type_name) *res = expr;					\
diff --git a/gnu/packages/patches/glibc-2-26-0040.patch b/gnu/packages/patches/glibc-2-26-0040.patch
new file mode 100644
index 000000000..13c61ba1c
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0040.patch
@@ -0,0 +1,71 @@
+From 37d4262a7a35886cf8ac856457bbad8c0498c8d6 Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gftg@linux.vnet.ibm.com>
+Date: Tue, 22 Aug 2017 14:01:07 -0300
+Subject: [PATCH 40/90] Fix remaining return type of ifunc resolver declaration
+
+Since Martin Sebor's commit
+
+commit ee4e992ebe5f9712faedeefe8958b67d61eaa0f2
+Author: Martin Sebor <msebor@redhat.com>
+Date:   Tue Aug 22 09:35:23 2017 -0600
+
+    Declare ifunc resolver to return a pointer to the same type as the target
+    function to help GCC detect incompatibilities between the two when it's
+    enhanced to do so.
+
+builds for powerpc64le fail in the declaration of some ifunc resolvers,
+because the ifunc is declared with unmatching return types.  One of the
+declarations comes from the __ifunc_resolver macro, which was patched by
+the aforementioned commit:
+
+    /* Helper / base  macros for indirect function symbols.  */
+    #define __ifunc_resolver(type_name, name, expr, arg, init, classifier) \
+      classifier inhibit_stack_protector                                   \
+      __typeof (type_name) *name##_ifunc (arg)                             \
+
+whereas the other comes from the unpatched __ifunc macro when
+HAVE_GCC_IFUNC is not defined:
+
+    # define __ifunc(type_name, name, expr, arg, init)                     \
+      extern __typeof (type_name) name;                                    \
+      void *name##_ifunc (arg) __asm__ (#name);                            \
+
+This patch changes the return type of the ifunc resolver in the __ifunc
+macro, so that it matches the return type of the target function,
+similarly to what the aforementioned commit does.
+
+Tested for powerpc64le and s390x with unpatched GCC.
+
+	* include/libc-symbols.h: [!defined HAVE_GCC_IFUNC] (__ifunc):
+	Change the return type of the ifunc resolver to match the return
+	type of the target function.
+
+(cherry picked from commit b513da7e80febbbfb8e58282075018652b6f7273)
+
+diff --git a/ChangeLog b/ChangeLog
+index ec9b9f5edb..6b09c61d5a 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-08-22  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
++
++	* include/libc-symbols.h: [!defined HAVE_GCC_IFUNC] (__ifunc):
++	Change the return type of the ifunc resolver to match the return
++	type of the target function.
++
+ 2017-08-22  Martin Sebor  <msebor@redhat.com>
+ 
+ 	* include/libc-symbols.h (__ifunc_resolver): Declare resolver
+diff --git a/include/libc-symbols.h b/include/libc-symbols.h
+index c50f9adec2..5bf57703a9 100644
+--- a/include/libc-symbols.h
++++ b/include/libc-symbols.h
+@@ -810,7 +810,7 @@ for linking")
+ 
+ # define __ifunc(type_name, name, expr, arg, init)			\
+   extern __typeof (type_name) name;					\
+-  void *name##_ifunc (arg) __asm__ (#name);				\
++  __typeof (type_name) *name##_ifunc (arg) __asm__ (#name);		\
+   __ifunc_resolver (type_name, name, expr, arg, init,)			\
+  __asm__ (".type " #name ", %gnu_indirect_function");
+ 
diff --git a/gnu/packages/patches/glibc-2-26-0041.patch b/gnu/packages/patches/glibc-2-26-0041.patch
new file mode 100644
index 000000000..baba5971f
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0041.patch
@@ -0,0 +1,80 @@
+From d37c951fde57e8acb320a9a7d437ba50a1fc3c8a Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gabriel@inconstante.eti.br>
+Date: Wed, 20 Sep 2017 15:10:26 -0300
+Subject: [PATCH 41/90] Let fpclassify use the builtin when optimizing for size
+ in C++ mode (bug 22146)
+
+When optimization for size is on (-Os), fpclassify does not use the
+type-generic __builtin_fpclassify builtin, instead it uses __MATH_TG.
+However, when library support for float128 is available, __MATH_TG uses
+__builtin_types_compatible_p, which is not available in C++ mode.
+
+On the other hand, libstdc++ undefines (in cmath) many macros from
+math.h, including fpclassify, so that it can provide its own functions.
+However, during its configure tests, libstdc++ just tests for the
+availability of the macros (it does not undefine them, nor does it
+provide its own functions).
+
+Finally, when libstdc++ is configured with optimization for size
+enabled, its configure tests include math.h and get the definition of
+fpclassify that uses __MATH_TG (and __builtin_types_compatible_p).
+Since libstdc++ does not undefine the macros during its configure tests,
+they fail.
+
+This patch lets fpclassify use the builtin in C++ mode, even when
+optimization for size is on.  This allows the configure test in
+libstdc++ to work.
+
+Tested for powerpc64le and x86_64.
+
+	[BZ #22146]
+	math/math.h: Let fpclassify use the builtin in C++ mode, even
+	when optimazing for size.
+
+(cherry picked from commit c5c4a626098ec884b8527356abdf2a4bb7b6bf27)
+
+diff --git a/ChangeLog b/ChangeLog
+index 6b09c61d5a..382674d5a3 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-09-22  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
++
++	[BZ #22146]
++	math/math.h: Let fpclassify use the builtin in C++ mode, even
++	when optimazing for size.
++
+ 2017-08-22  Gabriel F. T. Gomes  <gftg@linux.vnet.ibm.com>
+ 
+ 	* include/libc-symbols.h: [!defined HAVE_GCC_IFUNC] (__ifunc):
+diff --git a/NEWS b/NEWS
+index 9bcb176171..48e2064380 100644
+--- a/NEWS
++++ b/NEWS
+@@ -30,6 +30,7 @@ The following bugs are resolved with this release:
+   [21972] assert macro requires operator== (int) for its argument type
+   [22095] resolv: Fix memory leak with OOM during resolv.conf parsing
+   [22096] resolv: __resolv_conf_attach must not free passed conf object
++  [22146] Let fpclassify use the builtin when optimizing for size in C++ mode
+ \f
+ Version 2.26
+ 
+diff --git a/math/math.h b/math/math.h
+index 7c0fc6dbb3..f9348ec3ea 100644
+--- a/math/math.h
++++ b/math/math.h
+@@ -402,7 +402,13 @@ enum
+ 
+ /* Return number of classification appropriate for X.  */
+ # if __GNUC_PREREQ (4,4) && !defined __SUPPORT_SNAN__			      \
+-     && !defined __OPTIMIZE_SIZE__
++     && (!defined __OPTIMIZE_SIZE__ || defined __cplusplus)
++     /* The check for __cplusplus allows the use of the builtin, even
++	when optimization for size is on.  This is provided for
++	libstdc++, only to let its configure test work when it is built
++	with -Os.  No further use of this definition of fpclassify is
++	expected in C++ mode, since libstdc++ provides its own version
++	of fpclassify in cmath (which undefines fpclassify).  */
+ #  define fpclassify(x) __builtin_fpclassify (FP_NAN, FP_INFINITE,	      \
+      FP_NORMAL, FP_SUBNORMAL, FP_ZERO, x)
+ # else
diff --git a/gnu/packages/patches/glibc-2-26-0042.patch b/gnu/packages/patches/glibc-2-26-0042.patch
new file mode 100644
index 000000000..3c2d6f94c
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0042.patch
@@ -0,0 +1,157 @@
+From 548cc83c38a91852b1e44045ead3d20ccd5db4cf Mon Sep 17 00:00:00 2001
+From: Joseph Myers <joseph@codesourcery.com>
+Date: Thu, 28 Sep 2017 01:59:02 +0000
+Subject: [PATCH 42/90] Fix nearbyint arithmetic moved before feholdexcept (bug
+ 22225).
+
+In <https://sourceware.org/ml/libc-alpha/2013-05/msg00722.html> I
+remarked on the possibility of arithmetic in various nearbyint
+implementations being scheduled before feholdexcept calls, resulting
+in spurious "inexact" exceptions.
+
+I'm now actually observing this occurring in glibc built for ARM with
+GCC 7 (in fact, both copies of the same addition/subtraction sequence
+being combined and moved out before the conditionals and
+feholdexcept/fesetenv pairs), resulting in test failures.
+
+This patch makes the nearbyint implementations with this particular
+feholdexcept / arithmetic / fesetenv pattern consistently use
+math_opt_barrier on the function argument when first used in
+arithmetic, and also consistently use math_force_eval before fesetenv
+(the latter was generally already done, but the dbl-64/wordsize-64
+implementation used math_opt_barrier instead, and as
+math_opt_barrier's intended effect is through its output value being
+used, such a use that doesn't use the return value is suspect).
+
+Tested for x86_64 (--disable-multi-arch so more of these
+implementations get used), and for ARM in a configuration where I saw
+the problem scheduling.
+
+	[BZ #22225]
+	* sysdeps/ieee754/dbl-64/s_nearbyint.c (__nearbyint): Use
+	math_opt_barrier on argument when doing arithmetic on it.
+	* sysdeps/ieee754/dbl-64/wordsize-64/s_nearbyint.c (__nearbyint):
+	Likewise.  Use math_force_eval not math_opt_barrier after
+	arithmetic.
+	* sysdeps/ieee754/flt-32/s_nearbyintf.c (__nearbyintf): Use
+	math_opt_barrier on argument when doing arithmetic on it.
+	* sysdeps/ieee754/ldbl-128/s_nearbyintl.c (__nearbyintl):
+	Likewise.
+
+(cherry picked from commit f124cb381116b5809de198327690ad0bd8d1478e)
+
+diff --git a/ChangeLog b/ChangeLog
+index 382674d5a3..992722acdb 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,16 @@
++2017-09-28  Joseph Myers  <joseph@codesourcery.com>
++
++	[BZ #22225]
++	* sysdeps/ieee754/dbl-64/s_nearbyint.c (__nearbyint): Use
++	math_opt_barrier on argument when doing arithmetic on it.
++	* sysdeps/ieee754/dbl-64/wordsize-64/s_nearbyint.c (__nearbyint):
++	Likewise.  Use math_force_eval not math_opt_barrier after
++	arithmetic.
++	* sysdeps/ieee754/flt-32/s_nearbyintf.c (__nearbyintf): Use
++	math_opt_barrier on argument when doing arithmetic on it.
++	* sysdeps/ieee754/ldbl-128/s_nearbyintl.c (__nearbyintl):
++	Likewise.
++
+ 2017-09-22  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
+ 
+ 	[BZ #22146]
+diff --git a/sysdeps/ieee754/dbl-64/s_nearbyint.c b/sysdeps/ieee754/dbl-64/s_nearbyint.c
+index dec0c5d6ee..6e3f8316b1 100644
+--- a/sysdeps/ieee754/dbl-64/s_nearbyint.c
++++ b/sysdeps/ieee754/dbl-64/s_nearbyint.c
+@@ -48,7 +48,7 @@ __nearbyint (double x)
+       if (j0 < 0)
+ 	{
+ 	  libc_feholdexcept (&env);
+-	  w = TWO52[sx] + x;
++	  w = TWO52[sx] + math_opt_barrier (x);
+ 	  t = w - TWO52[sx];
+ 	  math_force_eval (t);
+ 	  libc_fesetenv (&env);
+@@ -65,7 +65,7 @@ __nearbyint (double x)
+ 	return x;                       /* x is integral */
+     }
+   libc_feholdexcept (&env);
+-  w = TWO52[sx] + x;
++  w = TWO52[sx] + math_opt_barrier (x);
+   t = w - TWO52[sx];
+   math_force_eval (t);
+   libc_fesetenv (&env);
+diff --git a/sysdeps/ieee754/dbl-64/wordsize-64/s_nearbyint.c b/sysdeps/ieee754/dbl-64/wordsize-64/s_nearbyint.c
+index 8293819981..7d135b54e4 100644
+--- a/sysdeps/ieee754/dbl-64/wordsize-64/s_nearbyint.c
++++ b/sysdeps/ieee754/dbl-64/wordsize-64/s_nearbyint.c
+@@ -42,9 +42,9 @@ __nearbyint(double x)
+ 	if(__builtin_expect(j0<52, 1)) {
+ 	    if(j0<0) {
+ 		libc_feholdexcept (&env);
+-		double w = TWO52[sx]+x;
++		double w = TWO52[sx] + math_opt_barrier (x);
+ 		double t =  w-TWO52[sx];
+-		math_opt_barrier(t);
++		math_force_eval (t);
+ 		libc_fesetenv (&env);
+ 		return __copysign (t, x);
+ 	    }
+@@ -53,9 +53,9 @@ __nearbyint(double x)
+ 	    else return x;		/* x is integral */
+ 	}
+ 	libc_feholdexcept (&env);
+-	double w = TWO52[sx]+x;
++	double w = TWO52[sx] + math_opt_barrier (x);
+ 	double t = w-TWO52[sx];
+-	math_opt_barrier (t);
++	math_force_eval (t);
+ 	libc_fesetenv (&env);
+ 	return t;
+ }
+diff --git a/sysdeps/ieee754/flt-32/s_nearbyintf.c b/sysdeps/ieee754/flt-32/s_nearbyintf.c
+index 5aebefafcf..b06df6b3c8 100644
+--- a/sysdeps/ieee754/flt-32/s_nearbyintf.c
++++ b/sysdeps/ieee754/flt-32/s_nearbyintf.c
+@@ -37,7 +37,7 @@ __nearbyintf(float x)
+ 	if(j0<23) {
+ 	    if(j0<0) {
+ 		libc_feholdexceptf (&env);
+-		w = TWO23[sx]+x;
++		w = TWO23[sx] + math_opt_barrier (x);
+ 		t =  w-TWO23[sx];
+ 		math_force_eval (t);
+ 		libc_fesetenvf (&env);
+@@ -50,7 +50,7 @@ __nearbyintf(float x)
+ 	    else return x;		/* x is integral */
+ 	}
+ 	libc_feholdexceptf (&env);
+-	w = TWO23[sx]+x;
++	w = TWO23[sx] + math_opt_barrier (x);
+ 	t = w-TWO23[sx];
+ 	math_force_eval (t);
+ 	libc_fesetenvf (&env);
+diff --git a/sysdeps/ieee754/ldbl-128/s_nearbyintl.c b/sysdeps/ieee754/ldbl-128/s_nearbyintl.c
+index 1565a8183f..98a33d24a7 100644
+--- a/sysdeps/ieee754/ldbl-128/s_nearbyintl.c
++++ b/sysdeps/ieee754/ldbl-128/s_nearbyintl.c
+@@ -45,7 +45,7 @@ _Float128 __nearbyintl(_Float128 x)
+ 	if(j0<112) {
+ 	    if(j0<0) {
+ 		feholdexcept (&env);
+-	        w = TWO112[sx]+x;
++	        w = TWO112[sx] + math_opt_barrier (x);
+ 	        t = w-TWO112[sx];
+ 		math_force_eval (t);
+ 	        fesetenv (&env);
+@@ -58,7 +58,7 @@ _Float128 __nearbyintl(_Float128 x)
+ 	    else return x;		/* x is integral */
+ 	}
+ 	feholdexcept (&env);
+-	w = TWO112[sx]+x;
++	w = TWO112[sx] + math_opt_barrier (x);
+ 	t = w-TWO112[sx];
+ 	math_force_eval (t);
+ 	fesetenv (&env);
diff --git a/gnu/packages/patches/glibc-2-26-0043.patch b/gnu/packages/patches/glibc-2-26-0043.patch
new file mode 100644
index 000000000..e399f3a9a
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0043.patch
@@ -0,0 +1,24 @@
+From fdf58ebc60ce0eb459fd616241b52872b3571ac1 Mon Sep 17 00:00:00 2001
+From: Joseph Myers <joseph@codesourcery.com>
+Date: Sat, 30 Sep 2017 00:48:07 +0000
+Subject: [PATCH 43/90] Add missing bug fixes to list in NEWS file.
+
+
+diff --git a/NEWS b/NEWS
+index 48e2064380..8e468c0369 100644
+--- a/NEWS
++++ b/NEWS
+@@ -28,9 +28,13 @@ The following bugs are resolved with this release:
+   [21932] Unpaired __resolv_context_get in generic get*_r implementation
+   [21941] powerpc: Restrict xssqrtqp operands to Vector Registers
+   [21972] assert macro requires operator== (int) for its argument type
++  [21982] string: stratcliff.c: error: assuming signed overflow does not
++    occur with -O3
++  [22051] libc: zero terminator in the middle of glibc's .eh_frame
+   [22095] resolv: Fix memory leak with OOM during resolv.conf parsing
+   [22096] resolv: __resolv_conf_attach must not free passed conf object
+   [22146] Let fpclassify use the builtin when optimizing for size in C++ mode
++  [22225] math: nearbyint arithmetic moved before feholdexcept
+ \f
+ Version 2.26
+ 
diff --git a/gnu/packages/patches/glibc-2-26-0044.patch b/gnu/packages/patches/glibc-2-26-0044.patch
new file mode 100644
index 000000000..4f961b1b4
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0044.patch
@@ -0,0 +1,96 @@
+From 3f68c5c9b61600f0f85c75bac15b1520d5059359 Mon Sep 17 00:00:00 2001
+From: Joseph Myers <joseph@codesourcery.com>
+Date: Tue, 22 Aug 2017 00:59:43 +0000
+Subject: [PATCH 44/90] Fix sparc32 bits/long-double.h (bug 21987).
+
+My refactoring of long double information
+
+commit 0acb8a2a855395c25b1feef2470f4d7ca4bed589
+Author: Joseph Myers <joseph@codesourcery.com>
+Date:   Wed Dec 14 18:27:56 2016 +0000
+
+    Refactor long double information into bits/long-double.h.
+
+resulted in sparc32 configurations installing the ldbl-opt version of
+bits/long-double.h instead of the intended
+sysdeps/unix/sysv/linux/sparc version.
+
+For sparc32 by itself, this is not a problem, since the ldbl-opt
+version is correct for sparc32.  However, both sparc32 and sparc64 are
+supposed to install sets of headers that work for both of them, so
+that a single sysroot, whichever order the libraries are built and
+installed in, works for both.  The effect of having the wrong version
+installed is that you end up with a miscompiled sparc64 libstdc++
+which fails glibc's configure tests for the C++ compiler.
+
+This patch moves the header from sysdeps/unix/sysv/linux/sparc to
+separate copies of the same file for sparc32 and sparc64, to ensure it
+comes before ldbl-opt in the sysdeps directory ordering.
+
+Tested with build-many-glibcs.py for sparc64-linux-gnu and
+sparcv9-linux-gnu.
+
+	[BZ #21987]
+	* sysdeps/unix/sysv/linux/sparc/bits/long-double.h: Remove file
+	and copy to ...
+	* sysdeps/unix/sysv/linux/sparc/sparc32/bits/long-double.h:
+	... here.
+	* sysdeps/unix/sysv/linux/sparc/sparc64/bits/long-double.h:
+	... and here.
+
+(cherry picked from commit 80f91666fed71fa3dd5eb5618739147cc731bc89)
+
+diff --git a/ChangeLog b/ChangeLog
+index 992722acdb..cc763ac065 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,13 @@
++2017-08-22  Joseph Myers  <joseph@codesourcery.com>
++
++	[BZ #21987]
++	* sysdeps/unix/sysv/linux/sparc/bits/long-double.h: Remove file
++	and copy to ...
++	* sysdeps/unix/sysv/linux/sparc/sparc32/bits/long-double.h:
++	... here.
++	* sysdeps/unix/sysv/linux/sparc/sparc64/bits/long-double.h:
++	... and here.
++
+ 2017-09-28  Joseph Myers  <joseph@codesourcery.com>
+ 
+ 	[BZ #22225]
+diff --git a/sysdeps/unix/sysv/linux/sparc/bits/long-double.h b/sysdeps/unix/sysv/linux/sparc/sparc32/bits/long-double.h
+similarity index 100%
+rename from sysdeps/unix/sysv/linux/sparc/bits/long-double.h
+rename to sysdeps/unix/sysv/linux/sparc/sparc32/bits/long-double.h
+diff --git a/sysdeps/unix/sysv/linux/sparc/sparc64/bits/long-double.h b/sysdeps/unix/sysv/linux/sparc/sparc64/bits/long-double.h
+new file mode 100644
+index 0000000000..094e05124b
+--- /dev/null
++++ b/sysdeps/unix/sysv/linux/sparc/sparc64/bits/long-double.h
+@@ -0,0 +1,26 @@
++/* Properties of long double type.  SPARC version.
++   Copyright (C) 2016-2017 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  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
++   <http://www.gnu.org/licenses/>.  */
++
++#include <bits/wordsize.h>
++
++#if !defined __NO_LONG_DOUBLE_MATH && __WORDSIZE == 32
++# define __LONG_DOUBLE_MATH_OPTIONAL   1
++# ifndef __LONG_DOUBLE_128__
++#  define __NO_LONG_DOUBLE_MATH        1
++# endif
++#endif
diff --git a/gnu/packages/patches/glibc-2-26-0045.patch b/gnu/packages/patches/glibc-2-26-0045.patch
new file mode 100644
index 000000000..e2e03f656
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0045.patch
@@ -0,0 +1,238 @@
+From 3b10c5d2abb0392d5ecfd865e2eb911ac109e36f Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gabriel@inconstante.eti.br>
+Date: Mon, 2 Oct 2017 14:46:35 -0300
+Subject: [PATCH 45/90] Add C++ versions of iscanonical for ldbl-96 and
+ ldbl-128ibm (bug 22235)
+
+All representations of floating-point numbers in types with IEC 60559
+binary exchange format are canonical.  On the other hand, types with IEC
+60559 extended formats, such as those implemented under ldbl-96 and
+ldbl-128ibm, contain representations that are not canonical.
+
+TS 18661-1 introduced the type-generic macro iscanonical, which returns
+whether a floating-point value is canonical or not.  In Glibc, this
+type-generic macro is implemented using the macro __MATH_TG, which, when
+support for float128 is enabled, relies on __builtin_types_compatible_p
+to select between floating-point types.  However, this use of
+iscanonical breaks C++ applications, because the builtin is only
+available in C mode.
+
+This patch provides a C++ implementation of iscanonical that relies on
+function overloading, rather than builtins, to select between
+floating-point types.
+
+Unlike the C++ implementations for iszero and issignaling, this
+implementation ignores __NO_LONG_DOUBLE_MATH.  The double type always
+matches IEC 60559 double format, which is always canonical.  Thus, when
+double and long double are the same (__NO_LONG_DOUBLE_MATH), iscanonical
+always returns 1 and is not implemented with __MATH_TG.
+
+Tested for powerpc64, powerpc64le and x86_64.
+
+	[BZ #22235]
+	* math/math.h: Trivial fix for unbalanced parentheses in comment.
+	* math/Makefile [CXX] (tests): Add test-math-iscanonical.cc.
+	(CFLAGS-test-math-iscanonical.cc): New variable.
+	* math/test-math-iscanonical.cc: New file.
+	* sysdeps/ieee754/ldbl-96/bits/iscanonical.h (iscanonical):
+	Provide a C++ implementation based on function overloading,
+	rather than using __MATH_TG, which uses C-only builtins.
+	* sysdeps/ieee754/ldbl-128ibm/bits/iscanonical.h (iscanonical):
+	Likewise.
+	* sysdeps/powerpc/powerpc64le/Makefile
+	(CFLAGS-test-math-iscanonical.cc): New variable.
+
+(cherry picked from commit aa0235dfdebffe9b338deba51f3ba563ee9b433d)
+
+diff --git a/ChangeLog b/ChangeLog
+index cc763ac065..fea4fd0cd6 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,18 @@
++2017-10-03  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
++
++	[BZ #22235]
++	* math/math.h: Trivial fix for unbalanced parentheses in comment.
++	* math/Makefile [CXX] (tests): Add test-math-iscanonical.cc.
++	(CFLAGS-test-math-iscanonical.cc): New variable.
++	* math/test-math-iscanonical.cc: New file.
++	* sysdeps/ieee754/ldbl-96/bits/iscanonical.h (iscanonical):
++	Provide a C++ implementation based on function overloading,
++	rather than using __MATH_TG, which uses C-only builtins.
++	* sysdeps/ieee754/ldbl-128ibm/bits/iscanonical.h (iscanonical):
++	Likewise.
++	* sysdeps/powerpc/powerpc64le/Makefile
++	(CFLAGS-test-math-iscanonical.cc): New variable.
++
+ 2017-08-22  Joseph Myers  <joseph@codesourcery.com>
+ 
+ 	[BZ #21987]
+diff --git a/NEWS b/NEWS
+index 8e468c0369..5b05edeb4f 100644
+--- a/NEWS
++++ b/NEWS
+@@ -35,6 +35,7 @@ The following bugs are resolved with this release:
+   [22096] resolv: __resolv_conf_attach must not free passed conf object
+   [22146] Let fpclassify use the builtin when optimizing for size in C++ mode
+   [22225] math: nearbyint arithmetic moved before feholdexcept
++  [22235] Add C++ versions of iscanonical for ldbl-96 and ldbl-128ibm
+ \f
+ Version 2.26
+ 
+diff --git a/math/Makefile b/math/Makefile
+index 0130fcf38b..2c17c68eda 100644
+--- a/math/Makefile
++++ b/math/Makefile
+@@ -203,7 +203,8 @@ tests-static = test-fpucw-static test-fpucw-ieee-static \
+ 	       test-signgam-ullong-static test-signgam-ullong-init-static
+ 
+ ifneq (,$(CXX))
+-tests += test-math-isinff test-math-iszero test-math-issignaling
++tests += test-math-isinff test-math-iszero test-math-issignaling \
++	 test-math-iscanonical
+ endif
+ 
+ ifneq (no,$(PERL))
+@@ -351,6 +352,7 @@ CFLAGS-test-signgam-ullong-init-static.c = -std=c99
+ CFLAGS-test-math-isinff.cc = -std=gnu++11
+ CFLAGS-test-math-iszero.cc = -std=gnu++11
+ CFLAGS-test-math-issignaling.cc = -std=gnu++11
++CFLAGS-test-math-iscanonical.cc = -std=gnu++11
+ 
+ CFLAGS-test-iszero-excess-precision.c = -fexcess-precision=standard
+ CFLAGS-test-iseqsig-excess-precision.c = -fexcess-precision=standard
+diff --git a/math/math.h b/math/math.h
+index f9348ec3ea..2b216c6da1 100644
+--- a/math/math.h
++++ b/math/math.h
+@@ -488,7 +488,7 @@ enum
+       other hand, overloading provides the means to distinguish between
+       the floating-point types.  The overloading resolution will match
+       the correct parameter (regardless of type qualifiers (i.e.: const
+-      and volatile).  */
++      and volatile)).  */
+ extern "C++" {
+ inline int issignaling (float __val) { return __issignalingf (__val); }
+ inline int issignaling (double __val) { return __issignaling (__val); }
+diff --git a/math/test-math-iscanonical.cc b/math/test-math-iscanonical.cc
+new file mode 100644
+index 0000000000..aba68acb4f
+--- /dev/null
++++ b/math/test-math-iscanonical.cc
+@@ -0,0 +1,48 @@
++/* Test for the C++ implementation of iscanonical.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#define _GNU_SOURCE 1
++#include <math.h>
++#include <stdio.h>
++
++static bool errors;
++
++template <class T>
++static void
++check_type ()
++{
++  T val = 0;
++
++  /* Check if iscanonical is available in C++ mode (bug 22235).  */
++  if (iscanonical (val) == 0)
++    errors++;
++}
++
++static int
++do_test (void)
++{
++  check_type<float> ();
++  check_type<double> ();
++  check_type<long double> ();
++#if __HAVE_DISTINCT_FLOAT128
++  check_type<_Float128> ();
++#endif
++  return errors;
++}
++
++#include <support/test-driver.c>
+diff --git a/sysdeps/ieee754/ldbl-128ibm/bits/iscanonical.h b/sysdeps/ieee754/ldbl-128ibm/bits/iscanonical.h
+index 7ddb368d26..f756857c03 100644
+--- a/sysdeps/ieee754/ldbl-128ibm/bits/iscanonical.h
++++ b/sysdeps/ieee754/ldbl-128ibm/bits/iscanonical.h
+@@ -37,5 +37,22 @@ extern int __iscanonicall (long double __x)
+    conversion, before being discarded; in IBM long double, there are
+    encodings that are not consistently handled as corresponding to any
+    particular value of the type, and we return 0 for those.  */
+-# define iscanonical(x) __MATH_TG ((x), __iscanonical, (x))
+-#endif
++# ifndef __cplusplus
++#  define iscanonical(x) __MATH_TG ((x), __iscanonical, (x))
++# else
++/* In C++ mode, __MATH_TG cannot be used, because it relies on
++   __builtin_types_compatible_p, which is a C-only builtin.  On the
++   other hand, overloading provides the means to distinguish between
++   the floating-point types.  The overloading resolution will match
++   the correct parameter (regardless of type qualifiers (i.e.: const
++   and volatile)).  */
++extern "C++" {
++inline int iscanonical (float __val) { return __iscanonicalf (__val); }
++inline int iscanonical (double __val) { return __iscanonical (__val); }
++inline int iscanonical (long double __val) { return __iscanonicall (__val); }
++#  if __HAVE_DISTINCT_FLOAT128
++inline int iscanonical (_Float128 __val) { return __iscanonicalf128 (__val); }
++#  endif
++}
++# endif /* __cplusplus */
++#endif /* __NO_LONG_DOUBLE_MATH */
+diff --git a/sysdeps/ieee754/ldbl-96/bits/iscanonical.h b/sysdeps/ieee754/ldbl-96/bits/iscanonical.h
+index 4a4f4ad024..cfa36a0c2a 100644
+--- a/sysdeps/ieee754/ldbl-96/bits/iscanonical.h
++++ b/sysdeps/ieee754/ldbl-96/bits/iscanonical.h
+@@ -34,4 +34,21 @@ extern int __iscanonicall (long double __x)
+    conversion, before being discarded; in extended precision, there
+    are encodings that are not consistently handled as corresponding to
+    any particular value of the type, and we return 0 for those.  */
+-#define iscanonical(x) __MATH_TG ((x), __iscanonical, (x))
++#ifndef __cplusplus
++# define iscanonical(x) __MATH_TG ((x), __iscanonical, (x))
++#else
++/* In C++ mode, __MATH_TG cannot be used, because it relies on
++   __builtin_types_compatible_p, which is a C-only builtin.  On the
++   other hand, overloading provides the means to distinguish between
++   the floating-point types.  The overloading resolution will match
++   the correct parameter (regardless of type qualifiers (i.e.: const
++   and volatile)).  */
++extern "C++" {
++inline int iscanonical (float __val) { return __iscanonicalf (__val); }
++inline int iscanonical (double __val) { return __iscanonical (__val); }
++inline int iscanonical (long double __val) { return __iscanonicall (__val); }
++# if __HAVE_DISTINCT_FLOAT128
++inline int iscanonical (_Float128 __val) { return __iscanonicalf128 (__val); }
++# endif
++}
++#endif /* __cplusplus */
+diff --git a/sysdeps/powerpc/powerpc64le/Makefile b/sysdeps/powerpc/powerpc64le/Makefile
+index dea2290736..cf2dbfb673 100644
+--- a/sysdeps/powerpc/powerpc64le/Makefile
++++ b/sysdeps/powerpc/powerpc64le/Makefile
+@@ -16,6 +16,7 @@ $(foreach suf,$(all-object-suffixes),%f128_r$(suf)): CFLAGS += -mfloat128
+ $(foreach suf,$(all-object-suffixes),$(objpfx)test-float128%$(suf)): CFLAGS += -mfloat128
+ $(foreach suf,$(all-object-suffixes),$(objpfx)test-ifloat128%$(suf)): CFLAGS += -mfloat128
+ CFLAGS-libm-test-support-float128.c += -mfloat128
++CFLAGS-test-math-iscanonical.cc += -mfloat128
+ CFLAGS-test-math-issignaling.cc += -mfloat128
+ CFLAGS-test-math-iszero.cc += -mfloat128
+ $(objpfx)test-float128% $(objpfx)test-ifloat128% $(objpfx)test-math-iszero: \
diff --git a/gnu/packages/patches/glibc-2-26-0046.patch b/gnu/packages/patches/glibc-2-26-0046.patch
new file mode 100644
index 000000000..ff6d1aaf2
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0046.patch
@@ -0,0 +1,59 @@
+From dd3a7239fddff81ac31373d69978d7aa1902c65f Mon Sep 17 00:00:00 2001
+From: "H.J. Lu" <hjl.tools@gmail.com>
+Date: Tue, 3 Oct 2017 17:41:32 -0700
+Subject: [PATCH 46/90] test-math-iscanonical.cc: Replace bool with int
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+Fix GCC 7 compilation error:
+
+test-math-iscanonical.cc: In function ‘void check_type()’:
+test-math-iscanonical.cc:33:11: error: use of an operand of type ‘bool’ in ‘operator++’ is deprecated [-Werror=deprecated]
+     errors++;
+           ^~
+
+Since not all non-zero error counts are errors, return errors != 0
+instead.
+
+	* math/test-math-iscanonical.cc (error): Replace bool with int.
+	(do_test): Return errors != 0.
+
+(cherry picked from commit cdd4155d6c527c00a89606385859984e35bd2910 and
+ commit 758f1bfa2a1bccb52f1b3e97444a367d35aceaee)
+
+diff --git a/ChangeLog b/ChangeLog
+index fea4fd0cd6..d7a185e99d 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-10-04  H.J. Lu  <hongjiu.lu@intel.com>
++
++	* math/test-math-iscanonical.cc (error): Replace bool with int.
++	(do_test): Return errors != 0.
++
+ 2017-10-03  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
+ 
+ 	[BZ #22235]
+diff --git a/math/test-math-iscanonical.cc b/math/test-math-iscanonical.cc
+index aba68acb4f..4cfb1c5055 100644
+--- a/math/test-math-iscanonical.cc
++++ b/math/test-math-iscanonical.cc
+@@ -20,7 +20,7 @@
+ #include <math.h>
+ #include <stdio.h>
+ 
+-static bool errors;
++static int errors;
+ 
+ template <class T>
+ static void
+@@ -42,7 +42,7 @@ do_test (void)
+ #if __HAVE_DISTINCT_FLOAT128
+   check_type<_Float128> ();
+ #endif
+-  return errors;
++  return errors != 0;
+ }
+ 
+ #include <support/test-driver.c>
diff --git a/gnu/packages/patches/glibc-2-26-0047.patch b/gnu/packages/patches/glibc-2-26-0047.patch
new file mode 100644
index 000000000..d6a58ebd7
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0047.patch
@@ -0,0 +1,209 @@
+From 6e1ea21501eac981204c3cc8212d45998f74983c Mon Sep 17 00:00:00 2001
+From: Carlos O'Donell <carlos@systemhalted.org>
+Date: Thu, 28 Sep 2017 11:05:18 -0600
+Subject: [PATCH 47/90] malloc: Fix tcache leak after thread destruction [BZ
+ #22111]
+
+The malloc tcache added in 2.26 will leak all of the elements remaining
+in the cache and the cache structure itself when a thread exits. The
+defect is that we do not set tcache_shutting_down early enough, and the
+thread simply recreates the tcache and places the elements back onto a
+new tcache which is subsequently lost as the thread exits (unfreed
+memory). The fix is relatively simple, move the setting of
+tcache_shutting_down earlier in tcache_thread_freeres. We add a test
+case which uses mallinfo and some heuristics to look for unaccounted for
+memory usage between the start and end of a thread start/join loop. It
+is very reliable at detecting that there is a leak given the number of
+iterations.  Without the fix the test will consume 122MiB of leaked
+memory.
+
+(cherry picked from commit 1e26d35193efbb29239c710a4c46a64708643320)
+
+diff --git a/ChangeLog b/ChangeLog
+index d7a185e99d..bfcdc1ebbf 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,12 @@
++2017-10-06  Carlos O'Donell  <carlos@redhat.com>
++
++	[BZ #22111]
++	* malloc/malloc.c (tcache_shutting_down): Use bool type.
++	(tcache_thread_freeres): Set tcache_shutting_down before
++	freeing the tcache.
++	* malloc/Makefile (tests): Add tst-malloc-tcache-leak.
++	* malloc/tst-malloc-tcache-leak.c: New file.
++
+ 2017-10-04  H.J. Lu  <hongjiu.lu@intel.com>
+ 
+ 	* math/test-math-iscanonical.cc (error): Replace bool with int.
+diff --git a/malloc/Makefile b/malloc/Makefile
+index 3fa395b949..9e23db9343 100644
+--- a/malloc/Makefile
++++ b/malloc/Makefile
+@@ -34,6 +34,7 @@ tests := mallocbug tst-malloc tst-valloc tst-calloc tst-obstack \
+ 	 tst-interpose-nothread \
+ 	 tst-interpose-thread \
+ 	 tst-alloc_buffer \
++	 tst-malloc-tcache-leak \
+ 
+ tests-static := \
+ 	 tst-interpose-static-nothread \
+@@ -242,3 +243,5 @@ tst-dynarray-fail-ENV = MALLOC_TRACE=$(objpfx)tst-dynarray-fail.mtrace
+ $(objpfx)tst-dynarray-fail-mem.out: $(objpfx)tst-dynarray-fail.out
+ 	$(common-objpfx)malloc/mtrace $(objpfx)tst-dynarray-fail.mtrace > $@; \
+ 	$(evaluate-test)
++
++$(objpfx)tst-malloc-tcache-leak: $(shared-thread-library)
+diff --git a/malloc/malloc.c b/malloc/malloc.c
+index e3ff778113..01ec1571b9 100644
+--- a/malloc/malloc.c
++++ b/malloc/malloc.c
+@@ -2952,7 +2952,7 @@ typedef struct tcache_perthread_struct
+   tcache_entry *entries[TCACHE_MAX_BINS];
+ } tcache_perthread_struct;
+ 
+-static __thread char tcache_shutting_down = 0;
++static __thread bool tcache_shutting_down = false;
+ static __thread tcache_perthread_struct *tcache = NULL;
+ 
+ /* Caller must ensure that we know tc_idx is valid and there's room
+@@ -2989,8 +2989,12 @@ tcache_thread_freeres (void)
+   if (!tcache)
+     return;
+ 
++  /* Disable the tcache and prevent it from being reinitialized.  */
+   tcache = NULL;
++  tcache_shutting_down = true;
+ 
++  /* Free all of the entries and the tcache itself back to the arena
++     heap for coalescing.  */
+   for (i = 0; i < TCACHE_MAX_BINS; ++i)
+     {
+       while (tcache_tmp->entries[i])
+@@ -3002,8 +3006,6 @@ tcache_thread_freeres (void)
+     }
+ 
+   __libc_free (tcache_tmp);
+-
+-  tcache_shutting_down = 1;
+ }
+ text_set_element (__libc_thread_subfreeres, tcache_thread_freeres);
+ 
+diff --git a/malloc/tst-malloc-tcache-leak.c b/malloc/tst-malloc-tcache-leak.c
+new file mode 100644
+index 0000000000..22c679b65b
+--- /dev/null
++++ b/malloc/tst-malloc-tcache-leak.c
+@@ -0,0 +1,112 @@
++/* Bug 22111: Test that threads do not leak their per thread cache.
++   Copyright (C) 2015-2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++/* The point of this test is to start and exit a large number of
++   threads, while at the same time looking to see if the used
++   memory grows with each round of threads run.  If the memory
++   grows above some linear bound we declare the test failed and
++   that the malloc implementation is leaking memory with each
++   thread.  This is a good indicator that the thread local cache
++   is leaking chunks.  */
++
++#include <stdio.h>
++#include <stdlib.h>
++#include <malloc.h>
++#include <pthread.h>
++#include <assert.h>
++
++#include <support/check.h>
++#include <support/support.h>
++#include <support/xthread.h>
++
++void *
++worker (void *data)
++{
++  void *ret;
++  /* Allocate an arbitrary amount of memory that is known to fit into
++     the thread local cache (tcache).  If we have at least 64 bins
++     (default e.g. TCACHE_MAX_BINS) we should be able to allocate 32
++     bytes and force malloc to fill the tcache.  We are assuming tcahce
++     init happens at the first small alloc, but it might in the future
++     be deferred to some other point.  Therefore to future proof this
++     test we include a full alloc/free/alloc cycle for the thread.  We
++     need a compiler barrier to avoid the removal of the useless
++     alloc/free.  We send some memory back to main to have the memory
++     freed after the thread dies, as just another check that the chunks
++     that were previously in the tcache are still OK to free after
++     thread death.  */
++  ret = xmalloc (32);
++  __asm__ volatile ("" ::: "memory");
++  free (ret);
++  return (void *) xmalloc (32);
++}
++
++static int
++do_test (void)
++{
++  pthread_t *thread;
++  struct mallinfo info_before, info_after;
++  void *retval;
++
++  /* This is an arbitrary choice. We choose a total of THREADS
++     threads created and joined.  This gives us enough iterations to
++     show a leak.  */
++  int threads = 100000;
++
++  /* Avoid there being 0 malloc'd data at this point by allocating the
++     pthread_t required to run the test.  */
++  thread = (pthread_t *) xcalloc (1, sizeof (pthread_t));
++
++  info_before = mallinfo ();
++
++  assert (info_before.uordblks != 0);
++
++  printf ("INFO: %d (bytes) are in use before starting threads.\n",
++          info_before.uordblks);
++
++  for (int loop = 0; loop < threads; loop++)
++    {
++      *thread = xpthread_create (NULL, worker, NULL);
++      retval = xpthread_join (*thread);
++      free (retval);
++    }
++
++  info_after = mallinfo ();
++  printf ("INFO: %d (bytes) are in use after all threads joined.\n",
++          info_after.uordblks);
++
++  /* We need to compare the memory in use before and the memory in use
++     after starting and joining THREADS threads.  We almost always grow
++     memory slightly, but not much. Consider that if even 1-byte leaked
++     per thread we'd have THREADS bytes of additional memory, and in
++     general the in-use at the start of main is quite low.  We will
++     always leak a full malloc chunk, and never just 1-byte, therefore
++     anything above "+ threads" from the start (constant offset) is a
++     leak.  Obviously this assumes no thread-related malloc'd internal
++     libc data structures persist beyond the thread death, and any that
++     did would limit the number of times you could call pthread_create,
++     which is a QoI we'd want to detect and fix.  */
++  if (info_after.uordblks > (info_before.uordblks + threads))
++    FAIL_EXIT1 ("Memory usage after threads is too high.\n");
++
++  /* Did not detect excessive memory usage.  */
++  free (thread);
++  exit (0);
++}
++
++#include <support/test-driver.c>
diff --git a/gnu/packages/patches/glibc-2-26-0048.patch b/gnu/packages/patches/glibc-2-26-0048.patch
new file mode 100644
index 000000000..c000c3a68
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0048.patch
@@ -0,0 +1,18 @@
+From d5c6dea2d5b4b5c64625c5386f6baec7bf2d89b3 Mon Sep 17 00:00:00 2001
+From: Carlos O'Donell <carlos@systemhalted.org>
+Date: Fri, 6 Oct 2017 13:31:05 -0700
+Subject: [PATCH 48/90] Update NEWS for bug 22111.
+
+
+diff --git a/NEWS b/NEWS
+index 5b05edeb4f..d6d1f90008 100644
+--- a/NEWS
++++ b/NEWS
+@@ -33,6 +33,7 @@ The following bugs are resolved with this release:
+   [22051] libc: zero terminator in the middle of glibc's .eh_frame
+   [22095] resolv: Fix memory leak with OOM during resolv.conf parsing
+   [22096] resolv: __resolv_conf_attach must not free passed conf object
++  [22111] malloc: per thread cache is not returned when thread exits
+   [22146] Let fpclassify use the builtin when optimizing for size in C++ mode
+   [22225] math: nearbyint arithmetic moved before feholdexcept
+   [22235] Add C++ versions of iscanonical for ldbl-96 and ldbl-128ibm
diff --git a/gnu/packages/patches/glibc-2-26-0049.patch b/gnu/packages/patches/glibc-2-26-0049.patch
new file mode 100644
index 000000000..21c749181
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0049.patch
@@ -0,0 +1,837 @@
+From b21ec6c6b80e316143b0914a5c81e9543bbdcc5b Mon Sep 17 00:00:00 2001
+From: Siddhesh Poyarekar <siddhesh@sourceware.org>
+Date: Tue, 10 Oct 2017 15:43:52 +0530
+Subject: [PATCH 49/90] aarch64: Optimized memcpy for Qualcomm Falkor processor
+
+This is an optimized implementation of the memcpy routine that gives a
+significant gain in performance for all sizes of copies on the
+Qualcomm Falkor processor.  A detailed rationale of the implementation
+is written in a comment in the patch.
+
+This implementation improves time for copies up to 128 bytes by up to
+15% and for larger copies by up to 35% in the glibc
+microbenchmark. The memcpy-random benchmark sees improvements in all
+sizes in the range of 13%-18%.
+
+Here are the full numbers extracted from the glibc microbenchmark
+using the commands:
+
+../benchtests/scripts/compare_strings.py benchtests/bench-memcpy.out \
+		../benchtests/scripts/benchout_strings.schema.json \
+		-base=__memcpy_generic length align1 align2
+
+../benchtests/scripts/compare_strings.py benchtests/bench-memcpy-large.out \
+		../benchtests/scripts/benchout_strings.schema.json \
+		-base=__memcpy_generic length align1 align2
+
+../benchtests/scripts/compare_strings.py benchtests/bench-memcpy-random.out \
+		../benchtests/scripts/benchout_strings.schema.json \
+		-base=__memcpy_generic max-size
+
+Function: memcpy
+__memcpy_thunderx       __memcpy_falkor __memcpy_generic
+Variant: default
+================================================================================
+length=1,align1=0,align2=0:     33.59 (-115.00%)        15.62 (0.00%)   15.62
+length=1,align1=0,align2=0:     16.41 (-10.53%) 14.06 (5.26%)   14.84
+length=1,align1=0,align2=0:     14.84 (0.00%)   14.84 (0.00%)   14.84
+length=1,align1=0,align2=0:     15.62 (-5.26%)  14.06 (5.26%)   14.84
+length=2,align1=0,align2=0:     15.62 (-5.26%)  14.06 (5.26%)   14.84
+length=2,align1=1,align2=0:     15.62 (-5.26%)  14.06 (5.26%)   14.84
+length=2,align1=0,align2=1:     14.84 (0.00%)   14.06 (5.26%)   14.84
+length=2,align1=1,align2=1:     14.84 (-5.56%)  14.06 (0.00%)   14.06
+length=4,align1=0,align2=0:     14.06 (0.00%)   14.06 (0.00%)   14.06
+length=4,align1=2,align2=0:     14.06 (-5.88%)  14.06 (-5.88%)  13.28
+length=4,align1=0,align2=2:     14.06 (0.00%)   14.06 (0.00%)   14.06
+length=4,align1=2,align2=2:     14.06 (-5.88%)  14.06 (-5.88%)  13.28
+length=8,align1=0,align2=0:     14.84 (-5.56%)  13.28 (5.56%)   14.06
+length=8,align1=3,align2=0:     14.06 (0.00%)   13.28 (5.56%)   14.06
+length=8,align1=0,align2=3:     13.28 (0.00%)   13.28 (0.00%)   13.28
+length=8,align1=3,align2=3:     13.28 (-6.25%)  13.28 (-6.25%)  12.50
+length=16,align1=0,align2=0:    13.28 (0.00%)   13.28 (0.00%)   13.28
+length=16,align1=4,align2=0:    13.28 (0.00%)   12.50 (5.88%)   13.28
+length=16,align1=0,align2=4:    13.28 (0.00%)   13.28 (0.00%)   13.28
+length=16,align1=4,align2=4:    13.28 (-6.25%)  12.50 (0.00%)   12.50
+length=32,align1=0,align2=0:    14.06 (0.00%)   12.50 (11.11%)  14.06
+length=32,align1=5,align2=0:    13.28 (0.00%)   12.50 (5.88%)   13.28
+length=32,align1=0,align2=5:    14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=32,align1=5,align2=5:    14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=64,align1=0,align2=0:    14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=64,align1=6,align2=0:    13.28 (0.00%)   13.28 (0.00%)   13.28
+length=64,align1=0,align2=6:    14.06 (5.26%)   14.06 (5.26%)   14.84
+length=64,align1=6,align2=6:    14.84 (-11.77%) 14.06 (-5.88%)  13.28
+length=128,align1=0,align2=0:   17.19 (-4.76%)  14.84 (9.52%)   16.41
+length=128,align1=7,align2=0:   16.41 (4.55%)   15.62 (9.09%)   17.19
+length=128,align1=0,align2=7:   16.41 (0.00%)   14.06 (14.29%)  16.41
+length=128,align1=7,align2=7:   16.41 (4.55%)   15.62 (9.09%)   17.19
+length=256,align1=0,align2=0:   21.88 (-3.70%)  21.09 (0.00%)   21.09
+length=256,align1=8,align2=0:   21.09 (-3.85%)  21.09 (-3.85%)  20.31
+length=256,align1=0,align2=8:   20.31 (-4.00%)  20.31 (-4.00%)  19.53
+length=256,align1=8,align2=8:   21.88 (-7.69%)  20.31 (0.00%)   20.31
+length=512,align1=0,align2=0:   28.91 (-2.78%)  28.91 (-2.78%)  28.12
+length=512,align1=9,align2=0:   30.47 (-2.63%)  30.47 (-2.63%)  29.69
+length=512,align1=0,align2=9:   29.69 (0.00%)   29.69 (0.00%)   29.69
+length=512,align1=9,align2=9:   28.12 (-2.86%)  28.12 (-2.86%)  27.34
+length=1024,align1=0,align2=0:  44.53 (0.00%)   44.53 (0.00%)   44.53
+length=1024,align1=10,align2=0:         50.00 (0.00%)   50.00 (0.00%)   50.00
+length=1024,align1=0,align2=10:         49.22 (1.56%)   50.78 (-1.56%)  50.00
+length=1024,align1=10,align2=10:        44.53 (-1.79%)  43.75 (0.00%)   43.75
+length=2048,align1=0,align2=0:  77.34 (-1.02%)  76.56 (0.00%)   76.56
+length=2048,align1=11,align2=0:         89.84 (0.00%)   89.84 (0.00%)   89.84
+length=2048,align1=0,align2=11:         89.84 (0.00%)   89.84 (0.00%)   89.84
+length=2048,align1=11,align2=11:        75.78 (0.00%)   75.78 (0.00%)   75.78
+length=4096,align1=0,align2=0:  141.41 (-0.56%) 140.62 (0.00%)  140.62
+length=4096,align1=12,align2=0:         171.09 (-0.46%) 170.31 (0.00%)  170.31
+length=4096,align1=0,align2=12:         170.31 (0.00%)  170.31 (0.00%)  170.31
+length=4096,align1=12,align2=12:        140.62 (0.00%)  140.62 (0.00%)  140.62
+length=8192,align1=0,align2=0:  278.91 (-0.28%) 275.78 (0.84%)  278.12
+length=8192,align1=13,align2=0:         338.28 (0.23%)  335.94 (0.92%)  339.06
+length=8192,align1=0,align2=13:         338.28 (0.00%)  455.47 (-34.64%)        338.28
+length=8192,align1=13,align2=13:        278.12 (-0.28%) 275.78 (0.56%)  277.34
+length=16384,align1=0,align2=0:         535.94 (-0.15%) 531.25 (0.73%)  535.16
+length=16384,align1=14,align2=0:        659.38 (0.12%)  659.38 (0.12%)  660.16
+length=16384,align1=0,align2=14:        659.38 (0.00%)  657.03 (0.36%)  659.38
+length=16384,align1=14,align2=14:       535.16 (0.44%)  532.81 (0.87%)  537.50
+length=32768,align1=0,align2=0:         1260.94 (10.68%)        1121.88 (20.53%)        1411.72
+length=32768,align1=15,align2=0:        1368.75 (10.02%)        1376.56 (9.50%) 1521.09
+length=32768,align1=0,align2=15:        1333.59 (10.91%)        1373.44 (8.25%) 1496.88
+length=32768,align1=15,align2=15:       1256.25 (13.96%)        1125.78 (22.90%)        1460.16
+length=65536,align1=0,align2=0:         2853.91 (30.11%)        2589.06 (36.60%)        4083.59
+length=65536,align1=16,align2=0:        2850.00 (30.14%)        2589.84 (36.52%)        4079.69
+length=65536,align1=0,align2=16:        2853.12 (30.60%)        2589.84 (37.00%)        4110.94
+length=65536,align1=16,align2=16:       2850.78 (30.07%)        2589.06 (36.49%)        4076.56
+length=0,align1=0,align2=0:     15.62 (-5.26%)  16.41 (-10.53%) 14.84
+length=0,align1=0,align2=0:     14.84 (-5.56%)  14.84 (-5.56%)  14.06
+length=0,align1=0,align2=0:     14.84 (0.00%)   14.84 (0.00%)   14.84
+length=0,align1=0,align2=0:     16.41 (-16.67%) 14.84 (-5.56%)  14.06
+length=1,align1=0,align2=0:     15.62 (4.76%)   15.62 (4.76%)   16.41
+length=1,align1=1,align2=0:     15.62 (0.00%)   14.84 (5.00%)   15.62
+length=1,align1=0,align2=1:     14.84 (0.00%)   14.84 (0.00%)   14.84
+length=1,align1=1,align2=1:     14.84 (0.00%)   14.06 (5.26%)   14.84
+length=2,align1=0,align2=0:     14.84 (0.00%)   14.06 (5.26%)   14.84
+length=2,align1=2,align2=0:     14.84 (0.00%)   14.06 (5.26%)   14.84
+length=2,align1=0,align2=2:     14.84 (-5.56%)  14.06 (0.00%)   14.06
+length=2,align1=2,align2=2:     14.84 (0.00%)   14.06 (5.26%)   14.84
+length=3,align1=0,align2=0:     14.84 (0.00%)   14.84 (0.00%)   14.84
+length=3,align1=3,align2=0:     14.84 (-5.56%)  14.06 (0.00%)   14.06
+length=3,align1=0,align2=3:     15.62 (-11.11%) 14.06 (0.00%)   14.06
+length=3,align1=3,align2=3:     14.84 (0.00%)   14.06 (5.26%)   14.84
+length=4,align1=0,align2=0:     17.97 (-27.78%) 14.06 (0.00%)   14.06
+length=4,align1=4,align2=0:     13.28 (5.56%)   14.06 (0.00%)   14.06
+length=4,align1=0,align2=4:     14.06 (0.00%)   13.28 (5.56%)   14.06
+length=4,align1=4,align2=4:     13.28 (5.56%)   13.28 (5.56%)   14.06
+length=5,align1=0,align2=0:     13.28 (5.56%)   13.28 (5.56%)   14.06
+length=5,align1=5,align2=0:     14.06 (0.00%)   14.06 (0.00%)   14.06
+length=5,align1=0,align2=5:     14.06 (0.00%)   13.28 (5.56%)   14.06
+length=5,align1=5,align2=5:     14.06 (-5.88%)  14.06 (-5.88%)  13.28
+length=6,align1=0,align2=0:     14.06 (-5.88%)  14.06 (-5.88%)  13.28
+length=6,align1=6,align2=0:     14.06 (0.00%)   14.06 (0.00%)   14.06
+length=6,align1=0,align2=6:     14.06 (0.00%)   13.28 (5.56%)   14.06
+length=6,align1=6,align2=6:     14.06 (0.00%)   13.28 (5.56%)   14.06
+length=7,align1=0,align2=0:     14.84 (-11.77%) 14.06 (-5.88%)  13.28
+length=7,align1=7,align2=0:     13.28 (0.00%)   14.06 (-5.88%)  13.28
+length=7,align1=0,align2=7:     14.06 (0.00%)   14.06 (0.00%)   14.06
+length=7,align1=7,align2=7:     14.06 (0.00%)   14.06 (0.00%)   14.06
+length=8,align1=0,align2=0:     14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=8,align1=8,align2=0:     14.06 (0.00%)   13.28 (5.56%)   14.06
+length=8,align1=0,align2=8:     13.28 (0.00%)   13.28 (0.00%)   13.28
+length=8,align1=8,align2=8:     14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=9,align1=0,align2=0:     13.28 (0.00%)   13.28 (0.00%)   13.28
+length=9,align1=9,align2=0:     13.28 (0.00%)   13.28 (0.00%)   13.28
+length=9,align1=0,align2=9:     13.28 (0.00%)   14.06 (-5.88%)  13.28
+length=9,align1=9,align2=9:     14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=10,align1=0,align2=0:    14.06 (0.00%)   13.28 (5.56%)   14.06
+length=10,align1=10,align2=0:   14.06 (-5.88%)  14.06 (-5.88%)  13.28
+length=10,align1=0,align2=10:   14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=10,align1=10,align2=10:  14.06 (0.00%)   13.28 (5.56%)   14.06
+length=11,align1=0,align2=0:    14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=11,align1=11,align2=0:   14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=11,align1=0,align2=11:   13.28 (0.00%)   13.28 (0.00%)   13.28
+length=11,align1=11,align2=11:  13.28 (0.00%)   13.28 (0.00%)   13.28
+length=12,align1=0,align2=0:    14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=12,align1=12,align2=0:   14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=12,align1=0,align2=12:   14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=12,align1=12,align2=12:  14.06 (0.00%)   13.28 (5.56%)   14.06
+length=13,align1=0,align2=0:    14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=13,align1=13,align2=0:   14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=13,align1=0,align2=13:   14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=13,align1=13,align2=13:  13.28 (0.00%)   13.28 (0.00%)   13.28
+length=14,align1=0,align2=0:    13.28 (0.00%)   13.28 (0.00%)   13.28
+length=14,align1=14,align2=0:   13.28 (5.56%)   13.28 (5.56%)   14.06
+length=14,align1=0,align2=14:   14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=14,align1=14,align2=14:  14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=15,align1=0,align2=0:    14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=15,align1=15,align2=0:   14.06 (-5.88%)  14.06 (-5.88%)  13.28
+length=15,align1=0,align2=15:   13.28 (0.00%)   13.28 (0.00%)   13.28
+length=15,align1=15,align2=15:  13.28 (0.00%)   14.06 (-5.88%)  13.28
+length=16,align1=0,align2=0:    14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=16,align1=16,align2=0:   13.28 (5.56%)   14.06 (0.00%)   14.06
+length=16,align1=0,align2=16:   14.84 (-11.77%) 13.28 (0.00%)   13.28
+length=16,align1=16,align2=16:  13.28 (-6.25%)  12.50 (0.00%)   12.50
+length=17,align1=0,align2=0:    14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=17,align1=17,align2=0:   14.84 (-11.77%) 12.50 (5.88%)   13.28
+length=17,align1=0,align2=17:   14.84 (-5.56%)  12.50 (11.11%)  14.06
+length=17,align1=17,align2=17:  14.84 (-11.77%) 12.50 (5.88%)   13.28
+length=18,align1=0,align2=0:    14.06 (0.00%)   12.50 (11.11%)  14.06
+length=18,align1=18,align2=0:   13.28 (5.56%)   12.50 (11.11%)  14.06
+length=18,align1=0,align2=18:   14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=18,align1=18,align2=18:  14.06 (0.00%)   12.50 (11.11%)  14.06
+length=19,align1=0,align2=0:    14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=19,align1=19,align2=0:   14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=19,align1=0,align2=19:   14.84 (-5.56%)  12.50 (11.11%)  14.06
+length=19,align1=19,align2=19:  14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=20,align1=0,align2=0:    14.84 (-11.77%) 12.50 (5.88%)   13.28
+length=20,align1=20,align2=0:   14.06 (0.00%)   12.50 (11.11%)  14.06
+length=20,align1=0,align2=20:   14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=20,align1=20,align2=20:  14.06 (0.00%)   13.28 (5.56%)   14.06
+length=21,align1=0,align2=0:    14.84 (-5.56%)  12.50 (11.11%)  14.06
+length=21,align1=21,align2=0:   14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=21,align1=0,align2=21:   14.84 (-11.77%) 12.50 (5.88%)   13.28
+length=21,align1=21,align2=21:  13.28 (5.56%)   13.28 (5.56%)   14.06
+length=22,align1=0,align2=0:    14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=22,align1=22,align2=0:   14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=22,align1=0,align2=22:   14.06 (0.00%)   12.50 (11.11%)  14.06
+length=22,align1=22,align2=22:  14.06 (0.00%)   12.50 (11.11%)  14.06
+length=23,align1=0,align2=0:    14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=23,align1=23,align2=0:   14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=23,align1=0,align2=23:   14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=23,align1=23,align2=23:  14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=24,align1=0,align2=0:    14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=24,align1=24,align2=0:   14.06 (0.00%)   13.28 (5.56%)   14.06
+length=24,align1=0,align2=24:   14.84 (-11.77%) 12.50 (5.88%)   13.28
+length=24,align1=24,align2=24:  14.06 (-5.88%)  13.28 (0.00%)   13.28
+length=25,align1=0,align2=0:    14.06 (0.00%)   12.50 (11.11%)  14.06
+length=25,align1=25,align2=0:   14.06 (0.00%)   13.28 (5.56%)   14.06
+length=25,align1=0,align2=25:   14.06 (0.00%)   12.50 (11.11%)  14.06
+length=25,align1=25,align2=25:  13.28 (0.00%)   13.28 (0.00%)   13.28
+length=26,align1=0,align2=0:    14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=26,align1=26,align2=0:   14.06 (0.00%)   13.28 (5.56%)   14.06
+length=26,align1=0,align2=26:   14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=26,align1=26,align2=26:  14.06 (0.00%)   13.28 (5.56%)   14.06
+length=27,align1=0,align2=0:    14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=27,align1=27,align2=0:   14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=27,align1=0,align2=27:   14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=27,align1=27,align2=27:  14.06 (0.00%)   12.50 (11.11%)  14.06
+length=28,align1=0,align2=0:    14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=28,align1=28,align2=0:   14.06 (0.00%)   12.50 (11.11%)  14.06
+length=28,align1=0,align2=28:   14.06 (0.00%)   12.50 (11.11%)  14.06
+length=28,align1=28,align2=28:  14.84 (-11.77%) 13.28 (0.00%)   13.28
+length=29,align1=0,align2=0:    14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=29,align1=29,align2=0:   13.28 (0.00%)   12.50 (5.88%)   13.28
+length=29,align1=0,align2=29:   14.06 (0.00%)   12.50 (11.11%)  14.06
+length=29,align1=29,align2=29:  13.28 (5.56%)   12.50 (11.11%)  14.06
+length=30,align1=0,align2=0:    14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=30,align1=30,align2=0:   13.28 (5.56%)   12.50 (11.11%)  14.06
+length=30,align1=0,align2=30:   14.06 (-5.88%)  12.50 (5.88%)   13.28
+length=30,align1=30,align2=30:  13.28 (0.00%)   12.50 (5.88%)   13.28
+length=31,align1=0,align2=0:    13.28 (0.00%)   12.50 (5.88%)   13.28
+length=31,align1=31,align2=0:   14.06 (0.00%)   12.50 (11.11%)  14.06
+length=31,align1=0,align2=31:   13.28 (0.00%)   12.50 (5.88%)   13.28
+length=31,align1=31,align2=31:  14.06 (0.00%)   12.50 (11.11%)  14.06
+length=48,align1=0,align2=0:    14.06 (0.00%)   14.06 (0.00%)   14.06
+length=48,align1=3,align2=0:    14.06 (0.00%)   14.06 (0.00%)   14.06
+length=48,align1=0,align2=3:    14.06 (-5.88%)  14.06 (-5.88%)  13.28
+length=48,align1=3,align2=3:    13.28 (5.56%)   14.06 (0.00%)   14.06
+length=80,align1=0,align2=0:    15.62 (-11.11%) 14.84 (-5.56%)  14.06
+length=80,align1=5,align2=0:    15.62 (-11.11%) 16.41 (-16.67%) 14.06
+length=80,align1=0,align2=5:    14.06 (0.00%)   15.62 (-11.11%) 14.06
+length=80,align1=5,align2=5:    15.62 (-5.26%)  17.19 (-15.79%) 14.84
+length=96,align1=0,align2=0:    14.06 (0.00%)   14.84 (-5.56%)  14.06
+length=96,align1=6,align2=0:    14.84 (-5.56%)  16.41 (-16.67%) 14.06
+length=96,align1=0,align2=6:    14.06 (0.00%)   14.84 (-5.56%)  14.06
+length=96,align1=6,align2=6:    14.84 (-5.56%)  17.19 (-22.22%) 14.06
+length=112,align1=0,align2=0:   17.19 (-4.76%)  14.06 (14.29%)  16.41
+length=112,align1=7,align2=0:   17.19 (0.00%)   16.41 (4.55%)   17.19
+length=112,align1=0,align2=7:   16.41 (0.00%)   14.84 (9.52%)   16.41
+length=112,align1=7,align2=7:   17.19 (0.00%)   17.19 (0.00%)   17.19
+length=144,align1=0,align2=0:   17.19 (-10.00%) 17.97 (-15.00%) 15.62
+length=144,align1=9,align2=0:   17.19 (-4.76%)  18.75 (-14.29%) 16.41
+length=144,align1=0,align2=9:   20.31 (-8.33%)  18.75 (0.00%)   18.75
+length=144,align1=9,align2=9:   18.75 (-4.35%)  18.75 (-4.35%)  17.97
+length=160,align1=0,align2=0:   18.75 (-4.35%)  17.97 (0.00%)   17.97
+length=160,align1=10,align2=0:  18.75 (4.00%)   18.75 (4.00%)   19.53
+length=160,align1=0,align2=10:  19.53 (-4.17%)  17.97 (4.17%)   18.75
+length=160,align1=10,align2=10:         18.75 (-4.35%)  18.75 (-4.35%)  17.97
+length=176,align1=0,align2=0:   18.75 (-4.35%)  17.19 (4.35%)   17.97
+length=176,align1=11,align2=0:  19.53 (0.00%)   19.53 (0.00%)   19.53
+length=176,align1=0,align2=11:  19.53 (-4.17%)  18.75 (0.00%)   18.75
+length=176,align1=11,align2=11:         18.75 (0.00%)   17.97 (4.17%)   18.75
+length=192,align1=0,align2=0:   18.75 (0.00%)   17.97 (4.17%)   18.75
+length=192,align1=12,align2=0:  21.09 (-8.00%)  18.75 (4.00%)   19.53
+length=192,align1=0,align2=12:  18.75 (0.00%)   18.75 (0.00%)   18.75
+length=192,align1=12,align2=12:         18.75 (0.00%)   17.97 (4.17%)   18.75
+length=208,align1=0,align2=0:   17.97 (0.00%)   20.31 (-13.04%) 17.97
+length=208,align1=13,align2=0:  19.53 (7.41%)   21.09 (0.00%)   21.09
+length=208,align1=0,align2=13:  23.44 (-11.11%) 21.09 (0.00%)   21.09
+length=208,align1=13,align2=13:         21.09 (-3.85%)  21.09 (-3.85%)  20.31
+length=224,align1=0,align2=0:   21.09 (-8.00%)  20.31 (-4.00%)  19.53
+length=224,align1=14,align2=0:  23.44 (-11.11%) 20.31 (3.70%)   21.09
+length=224,align1=0,align2=14:  21.09 (3.57%)   20.31 (7.14%)   21.88
+length=224,align1=14,align2=14:         20.31 (0.00%)   19.53 (3.85%)   20.31
+length=240,align1=0,align2=0:   20.31 (-4.00%)  19.53 (0.00%)   19.53
+length=240,align1=15,align2=0:  22.66 (0.00%)   20.31 (10.34%)  22.66
+length=240,align1=0,align2=15:  20.31 (-4.00%)  20.31 (-4.00%)  19.53
+length=240,align1=15,align2=15:         21.88 (0.00%)   21.09 (3.57%)   21.88
+length=272,align1=0,align2=0:   20.31 (0.00%)   28.12 (-38.46%) 20.31
+length=272,align1=17,align2=0:  22.66 (0.00%)   27.34 (-20.69%) 22.66
+length=272,align1=0,align2=17:  25.78 (-10.00%) 28.12 (-20.00%) 23.44
+length=272,align1=17,align2=17:         22.66 (-3.57%)  27.34 (-25.00%) 21.88
+length=288,align1=0,align2=0:   23.44 (-7.14%)  27.34 (-25.00%) 21.88
+length=288,align1=18,align2=0:  22.66 (0.00%)   27.34 (-20.69%) 22.66
+length=288,align1=0,align2=18:  23.44 (-3.45%)  25.00 (-10.35%) 22.66
+length=288,align1=18,align2=18:         22.66 (-3.57%)  21.88 (0.00%)   21.88
+length=304,align1=0,align2=0:   21.88 (0.00%)   21.88 (0.00%)   21.88
+length=304,align1=19,align2=0:  23.44 (-3.45%)  22.66 (0.00%)   22.66
+length=304,align1=0,align2=19:  22.66 (0.00%)   22.66 (0.00%)   22.66
+length=304,align1=19,align2=19:         22.66 (-3.57%)  21.88 (0.00%)   21.88
+length=320,align1=0,align2=0:   22.66 (-3.57%)  21.88 (0.00%)   21.88
+length=320,align1=20,align2=0:  22.66 (0.00%)   22.66 (0.00%)   22.66
+length=320,align1=0,align2=20:  22.66 (0.00%)   22.66 (0.00%)   22.66
+length=320,align1=20,align2=20:         22.66 (-3.57%)  21.88 (0.00%)   21.88
+length=336,align1=0,align2=0:   21.88 (0.00%)   24.22 (-10.71%) 21.88
+length=336,align1=21,align2=0:  22.66 (0.00%)   25.00 (-10.35%) 22.66
+length=336,align1=0,align2=21:  25.78 (0.00%)   25.00 (3.03%)   25.78
+length=336,align1=21,align2=21:         25.00 (0.00%)   23.44 (6.25%)   25.00
+length=352,align1=0,align2=0:   24.22 (0.00%)   24.22 (0.00%)   24.22
+length=352,align1=22,align2=0:  25.00 (0.00%)   25.00 (0.00%)   25.00
+length=352,align1=0,align2=22:  25.00 (-3.23%)  25.00 (-3.23%)  24.22
+length=352,align1=22,align2=22:         25.00 (-3.23%)  24.22 (0.00%)   24.22
+length=368,align1=0,align2=0:   25.00 (-3.23%)  23.44 (3.23%)   24.22
+length=368,align1=23,align2=0:  25.00 (0.00%)   24.22 (3.12%)   25.00
+length=368,align1=0,align2=23:  25.00 (-3.23%)  25.00 (-3.23%)  24.22
+length=368,align1=23,align2=23:         25.00 (-6.67%)  23.44 (0.00%)   23.44
+length=384,align1=0,align2=0:   24.22 (0.00%)   24.22 (0.00%)   24.22
+length=384,align1=24,align2=0:  25.00 (0.00%)   24.22 (3.12%)   25.00
+length=384,align1=0,align2=24:  25.00 (0.00%)   25.78 (-3.12%)  25.00
+length=384,align1=24,align2=24:         24.22 (-3.33%)  23.44 (0.00%)   23.44
+length=400,align1=0,align2=0:   25.00 (-3.23%)  26.56 (-9.68%)  24.22
+length=400,align1=25,align2=0:  25.78 (-3.12%)  27.34 (-9.38%)  25.00
+length=400,align1=0,align2=25:  27.34 (0.00%)   27.34 (0.00%)   27.34
+length=400,align1=25,align2=25:         26.56 (0.00%)   25.78 (2.94%)   26.56
+length=416,align1=0,align2=0:   26.56 (-3.03%)  25.78 (0.00%)   25.78
+length=416,align1=26,align2=0:  28.12 (-2.86%)  27.34 (0.00%)   27.34
+length=416,align1=0,align2=26:  27.34 (-2.94%)  28.12 (-5.88%)  26.56
+length=416,align1=26,align2=26:         25.78 (0.00%)   26.56 (-3.03%)  25.78
+length=432,align1=0,align2=0:   27.34 (-2.94%)  25.78 (2.94%)   26.56
+length=432,align1=27,align2=0:  28.12 (-2.86%)  27.34 (0.00%)   27.34
+length=432,align1=0,align2=27:  27.34 (0.00%)   28.12 (-2.86%)  27.34
+length=432,align1=27,align2=27:         25.78 (0.00%)   25.78 (0.00%)   25.78
+length=448,align1=0,align2=0:   26.56 (-3.03%)  25.78 (0.00%)   25.78
+length=448,align1=28,align2=0:  27.34 (0.00%)   27.34 (0.00%)   27.34
+length=448,align1=0,align2=28:  27.34 (0.00%)   28.12 (-2.86%)  27.34
+length=448,align1=28,align2=28:         25.78 (0.00%)   25.78 (0.00%)   25.78
+length=464,align1=0,align2=0:   25.78 (0.00%)   28.12 (-9.09%)  25.78
+length=464,align1=29,align2=0:  28.12 (-2.86%)  29.69 (-8.57%)  27.34
+length=464,align1=0,align2=29:  30.47 (0.00%)   30.47 (0.00%)   30.47
+length=464,align1=29,align2=29:         28.12 (0.00%)   27.34 (2.78%)   28.12
+length=480,align1=0,align2=0:   29.69 (-5.56%)  28.12 (0.00%)   28.12
+length=480,align1=30,align2=0:  31.25 (-2.56%)  29.69 (2.56%)   30.47
+length=480,align1=0,align2=30:  29.69 (0.00%)   30.47 (-2.63%)  29.69
+length=480,align1=30,align2=30:         28.12 (0.00%)   28.12 (0.00%)   28.12
+length=496,align1=0,align2=0:   28.12 (0.00%)   27.34 (2.78%)   28.12
+length=496,align1=31,align2=0:  30.47 (-2.63%)  29.69 (0.00%)   29.69
+length=496,align1=0,align2=31:  29.69 (0.00%)   30.47 (-2.63%)  29.69
+length=496,align1=31,align2=31:         28.12 (-2.86%)  28.12 (-2.86%)  27.34
+length=1024,align1=0,align2=0:  44.53 (0.00%)   44.53 (0.00%)   44.53
+length=1024,align1=32,align2=0:         44.53 (-1.79%)  44.53 (-1.79%)  43.75
+length=1024,align1=0,align2=32:         44.53 (-1.79%)  43.75 (0.00%)   43.75
+length=1024,align1=32,align2=32:        43.75 (1.75%)   43.75 (1.75%)   44.53
+length=1056,align1=0,align2=0:  46.88 (-1.69%)  46.88 (-1.69%)  46.09
+length=1056,align1=33,align2=0:         53.12 (0.00%)   52.34 (1.47%)   53.12
+length=1056,align1=0,align2=33:         52.34 (0.00%)   53.12 (-1.49%)  52.34
+length=1056,align1=33,align2=33:        46.09 (0.00%)   46.88 (-1.69%)  46.09
+length=1088,align1=0,align2=0:  46.88 (-1.69%)  46.09 (0.00%)   46.09
+length=1088,align1=34,align2=0:         52.34 (0.00%)   52.34 (0.00%)   52.34
+length=1088,align1=0,align2=34:         53.12 (-3.03%)  53.12 (-3.03%)  51.56
+length=1088,align1=34,align2=34:        46.09 (0.00%)   46.88 (-1.69%)  46.09
+length=1120,align1=0,align2=0:  49.22 (-1.61%)  48.44 (0.00%)   48.44
+length=1120,align1=35,align2=0:         54.69 (1.41%)   55.47 (0.00%)   55.47
+length=1120,align1=0,align2=35:         57.03 (0.00%)   55.47 (2.74%)   57.03
+length=1120,align1=35,align2=35:        48.44 (0.00%)   49.22 (-1.61%)  48.44
+length=1152,align1=0,align2=0:  47.66 (1.61%)   48.44 (0.00%)   48.44
+length=1152,align1=36,align2=0:         55.47 (-1.43%)  55.47 (-1.43%)  54.69
+length=1152,align1=0,align2=36:         58.59 (-1.35%)  55.47 (4.05%)   57.81
+length=1152,align1=36,align2=36:        48.44 (0.00%)   49.22 (-1.61%)  48.44
+length=1184,align1=0,align2=0:  53.12 (-3.03%)  50.78 (1.52%)   51.56
+length=1184,align1=37,align2=0:         61.72 (-2.60%)  57.03 (5.19%)   60.16
+length=1184,align1=0,align2=37:         62.50 (-1.27%)  57.03 (7.60%)   61.72
+length=1184,align1=37,align2=37:        53.12 (-1.49%)  50.78 (2.99%)   52.34
+length=1216,align1=0,align2=0:  53.91 (-4.55%)  50.78 (1.52%)   51.56
+length=1216,align1=38,align2=0:         60.94 (0.00%)   57.03 (6.41%)   60.94
+length=1216,align1=0,align2=38:         60.16 (0.00%)   57.81 (3.90%)   60.16
+length=1216,align1=38,align2=38:        52.34 (-1.52%)  50.00 (3.03%)   51.56
+length=1248,align1=0,align2=0:  54.69 (-2.94%)  53.12 (0.00%)   53.12
+length=1248,align1=39,align2=0:         64.06 (-1.23%)  60.16 (4.94%)   63.28
+length=1248,align1=0,align2=39:         60.94 (-2.63%)  60.16 (-1.32%)  59.38
+length=1248,align1=39,align2=39:        53.12 (0.00%)   52.34 (1.47%)   53.12
+length=1280,align1=0,align2=0:  52.34 (-1.52%)  52.34 (-1.52%)  51.56
+length=1280,align1=40,align2=0:         61.72 (3.66%)   59.38 (7.32%)   64.06
+length=1280,align1=0,align2=40:         60.94 (-2.63%)  60.16 (-1.32%)  59.38
+length=1280,align1=40,align2=40:        52.34 (-1.52%)  52.34 (-1.52%)  51.56
+length=1312,align1=0,align2=0:  54.69 (-1.45%)  55.47 (-2.90%)  53.91
+length=1312,align1=41,align2=0:         63.28 (0.00%)   62.50 (1.23%)   63.28
+length=1312,align1=0,align2=41:         62.50 (0.00%)   62.50 (0.00%)   62.50
+length=1312,align1=41,align2=41:        53.91 (0.00%)   54.69 (-1.45%)  53.91
+length=1344,align1=0,align2=0:  54.69 (0.00%)   54.69 (0.00%)   54.69
+length=1344,align1=42,align2=0:         62.50 (0.00%)   62.50 (0.00%)   62.50
+length=1344,align1=0,align2=42:         62.50 (-1.27%)  62.50 (-1.27%)  61.72
+length=1344,align1=42,align2=42:        53.91 (0.00%)   53.91 (0.00%)   53.91
+length=1376,align1=0,align2=0:  65.62 (-16.67%) 68.75 (-22.22%) 56.25
+length=1376,align1=43,align2=0:         71.88 (-9.52%)  73.44 (-11.90%) 65.62
+length=1376,align1=0,align2=43:         72.66 (-12.05%) 74.22 (-14.46%) 64.84
+length=1376,align1=43,align2=43:        64.06 (-13.89%) 67.97 (-20.83%) 56.25
+length=1408,align1=0,align2=0:  57.03 (-1.39%)  68.75 (-22.22%) 56.25
+length=1408,align1=44,align2=0:         65.62 (-1.20%)  73.44 (-13.25%) 64.84
+length=1408,align1=0,align2=44:         64.84 (0.00%)   74.22 (-14.46%) 64.84
+length=1408,align1=44,align2=44:        56.25 (-1.41%)  68.75 (-23.94%) 55.47
+length=1440,align1=0,align2=0:  67.97 (-14.47%) 64.84 (-9.21%)  59.38
+length=1440,align1=45,align2=0:         74.22 (-10.47%) 68.75 (-2.33%)  67.19
+length=1440,align1=0,align2=45:         72.66 (-6.90%)  69.53 (-2.30%)  67.97
+length=1440,align1=45,align2=45:        65.62 (-13.51%) 58.59 (-1.35%)  57.81
+length=1472,align1=0,align2=0:  66.41 (-14.86%) 58.59 (-1.35%)  57.81
+length=1472,align1=46,align2=0:         73.44 (-9.30%)  67.19 (0.00%)   67.19
+length=1472,align1=0,align2=46:         70.31 (-4.65%)  67.97 (-1.16%)  67.19
+length=1472,align1=46,align2=46:        57.81 (0.00%)   58.59 (-1.35%)  57.81
+length=1504,align1=0,align2=0:  60.94 (0.00%)   60.94 (0.00%)   60.94
+length=1504,align1=47,align2=0:         71.09 (-1.11%)  70.31 (0.00%)   70.31
+length=1504,align1=0,align2=47:         70.31 (-1.12%)  70.31 (-1.12%)  69.53
+length=1504,align1=47,align2=47:        60.94 (-1.30%)  60.16 (0.00%)   60.16
+length=1536,align1=0,align2=0:  62.50 (-3.90%)  60.16 (0.00%)   60.16
+length=1536,align1=48,align2=0:         60.94 (-1.30%)  60.16 (0.00%)   60.16
+length=1536,align1=0,align2=48:         61.72 (-3.95%)  60.16 (-1.32%)  59.38
+length=1536,align1=48,align2=48:        60.94 (-1.30%)  60.16 (0.00%)   60.16
+length=1568,align1=0,align2=0:  80.47 (-27.16%) 63.28 (0.00%)   63.28
+length=1568,align1=49,align2=0:         86.72 (-18.09%) 72.66 (1.06%)   73.44
+length=1568,align1=0,align2=49:         74.22 (-3.26%)  74.22 (-3.26%)  71.88
+length=1568,align1=49,align2=49:        62.50 (0.00%)   61.72 (1.25%)   62.50
+length=1600,align1=0,align2=0:  62.50 (-1.27%)  62.50 (-1.27%)  61.72
+length=1600,align1=50,align2=0:         73.44 (0.00%)   71.88 (2.13%)   73.44
+length=1600,align1=0,align2=50:         72.66 (0.00%)   73.44 (-1.08%)  72.66
+length=1600,align1=50,align2=50:        62.50 (-1.27%)  62.50 (-1.27%)  61.72
+length=1632,align1=0,align2=0:  64.84 (0.00%)   64.84 (0.00%)   64.84
+length=1632,align1=51,align2=0:         75.78 (0.00%)   75.00 (1.03%)   75.78
+length=1632,align1=0,align2=51:         78.91 (0.00%)   75.78 (3.96%)   78.91
+length=1632,align1=51,align2=51:        64.84 (-2.47%)  64.84 (-2.47%)  63.28
+length=1664,align1=0,align2=0:  64.84 (-1.22%)  64.84 (-1.22%)  64.06
+length=1664,align1=52,align2=0:         75.78 (0.00%)   75.00 (1.03%)   75.78
+length=1664,align1=0,align2=52:         80.47 (-0.98%)  75.78 (4.90%)   79.69
+length=1664,align1=52,align2=52:        64.06 (-1.23%)  65.62 (-3.70%)  63.28
+length=1696,align1=0,align2=0:  69.53 (-3.49%)  72.66 (-8.14%)  67.19
+length=1696,align1=53,align2=0:         80.47 (-0.98%)  82.03 (-2.94%)  79.69
+length=1696,align1=0,align2=53:         80.47 (0.96%)   82.03 (-0.96%)  81.25
+length=1696,align1=53,align2=53:        68.75 (-2.33%)  72.66 (-8.14%)  67.19
+length=1728,align1=0,align2=0:  67.97 (0.00%)   72.66 (-6.90%)  67.97
+length=1728,align1=54,align2=0:         80.47 (-0.98%)  82.81 (-3.92%)  79.69
+length=1728,align1=0,align2=54:         78.91 (-1.00%)  82.03 (-5.00%)  78.12
+length=1728,align1=54,align2=54:        68.75 (0.00%)   72.66 (-5.68%)  68.75
+length=1760,align1=0,align2=0:  77.34 (-12.50%) 68.75 (0.00%)   68.75
+length=1760,align1=55,align2=0:         91.41 (-8.33%)  79.69 (5.56%)   84.38
+length=1760,align1=0,align2=55:         88.28 (-10.78%) 80.47 (-0.98%)  79.69
+length=1760,align1=55,align2=55:        77.34 (-11.24%) 68.75 (1.12%)   69.53
+length=1792,align1=0,align2=0:  78.12 (-14.94%) 68.75 (-1.15%)  67.97
+length=1792,align1=56,align2=0:         88.28 (-4.63%)  79.69 (5.56%)   84.38
+length=1792,align1=0,align2=56:         88.28 (-9.71%)  80.47 (0.00%)   80.47
+length=1792,align1=56,align2=56:        77.34 (-11.24%) 68.75 (1.12%)   69.53
+length=1824,align1=0,align2=0:  72.66 (7.92%)   70.31 (10.89%)  78.91
+length=1824,align1=57,align2=0:         85.94 (5.17%)   82.03 (9.48%)   90.62
+length=1824,align1=0,align2=57:         82.03 (3.67%)   82.81 (2.75%)   85.16
+length=1824,align1=57,align2=57:        70.31 (-1.12%)  70.31 (-1.12%)  69.53
+length=1856,align1=0,align2=0:  70.31 (-1.12%)  70.31 (-1.12%)  69.53
+length=1856,align1=58,align2=0:         83.59 (-0.94%)  82.03 (0.94%)   82.81
+length=1856,align1=0,align2=58:         178.12 (-115.09%)       82.81 (0.00%)   82.81
+length=1856,align1=58,align2=58:        70.31 (-1.12%)  70.31 (-1.12%)  69.53
+length=1888,align1=0,align2=0:  73.44 (-1.08%)  78.91 (-8.60%)  72.66
+length=1888,align1=59,align2=0:         85.94 (0.00%)   89.84 (-4.55%)  85.94
+length=1888,align1=0,align2=59:         84.38 (0.00%)   89.06 (-5.56%)  84.38
+length=1888,align1=59,align2=59:        72.66 (-1.09%)  78.12 (-8.70%)  71.88
+length=1920,align1=0,align2=0:  72.66 (-1.09%)  78.12 (-8.70%)  71.88
+length=1920,align1=60,align2=0:         85.94 (0.00%)   89.84 (-4.55%)  85.94
+length=1920,align1=0,align2=60:         85.16 (0.00%)   89.06 (-4.59%)  85.16
+length=1920,align1=60,align2=60:        72.66 (-1.09%)  78.91 (-9.78%)  71.88
+length=1952,align1=0,align2=0:  75.00 (-1.05%)  75.00 (-1.05%)  74.22
+length=1952,align1=61,align2=0:         88.28 (0.00%)   87.50 (0.88%)   88.28
+length=1952,align1=0,align2=61:         87.50 (0.00%)   88.28 (-0.89%)  87.50
+length=1952,align1=61,align2=61:        74.22 (0.00%)   74.22 (0.00%)   74.22
+length=1984,align1=0,align2=0:  75.00 (-1.05%)  73.44 (1.05%)   74.22
+length=1984,align1=62,align2=0:         89.06 (-0.89%)  87.50 (0.88%)   88.28
+length=1984,align1=0,align2=62:         87.50 (0.00%)   88.28 (-0.89%)  87.50
+length=1984,align1=62,align2=62:        74.22 (0.00%)   74.22 (0.00%)   74.22
+length=2016,align1=0,align2=0:  77.34 (-1.02%)  76.56 (0.00%)   76.56
+length=2016,align1=63,align2=0:         91.41 (-0.86%)  90.62 (0.00%)   90.62
+length=2016,align1=0,align2=63:         89.84 (0.00%)   90.62 (-0.87%)  89.84
+length=2016,align1=63,align2=63:        77.34 (-1.02%)  76.56 (0.00%)   76.56
+length=4096,align1=0,align2=0:  141.41 (-0.56%) 146.88 (-4.44%) 140.62
+
+Function: memcpy
+__memcpy_thunderx       __memcpy_falkor __memcpy_generic
+Variant: large
+================================================================================
+length=65543,align1=0,align2=0:         4018.75 (3.09%) 2634.38 (36.47%)        4146.88
+length=65551,align1=0,align2=3:         4425.00 (-6.47%)        3134.38 (24.59%)        4156.25
+length=65567,align1=3,align2=0:         2909.38 (29.95%)        3134.38 (24.53%)        4153.12
+length=65599,align1=3,align2=5:         4415.62 (-6.16%)        3134.38 (24.64%)        4159.38
+length=131079,align1=0,align2=0:        5765.62 (30.38%)        5240.62 (36.72%)        8281.25
+length=131087,align1=0,align2=3:        8831.25 (-6.56%)        6271.88 (24.32%)        8287.50
+length=131103,align1=3,align2=0:        5793.75 (29.05%)        6268.75 (23.23%)        8165.62
+length=131135,align1=3,align2=5:        5806.25 (29.97%)        6259.38 (24.50%)        8290.62
+length=262151,align1=0,align2=0:        11850.00 (28.91%)       10762.50 (35.43%)       16668.80
+length=262159,align1=0,align2=3:        12043.80 (27.72%)       12700.00 (23.78%)       16662.50
+length=262175,align1=3,align2=0:        12046.90 (27.90%)       12687.50 (24.07%)       16709.40
+length=262207,align1=3,align2=5:        11984.40 (28.08%)       12678.10 (23.91%)       16662.50
+length=524295,align1=0,align2=0:        24825.00 (25.00%)       24268.80 (27.34%)       33400.00
+length=524303,align1=0,align2=3:        35731.20 (-6.53%)       25678.10 (23.44%)       33540.60
+length=524319,align1=3,align2=0:        25893.80 (22.71%)       25725.00 (23.22%)       33503.10
+length=524351,align1=3,align2=5:        25887.50 (22.86%)       25690.60 (23.45%)       33559.40
+length=1048583,align1=0,align2=0:       50621.90 (0.30%)        50600.00 (0.34%)        50771.90
+length=1048591,align1=0,align2=3:       53206.20 (0.54%)        51081.20 (4.51%)        53493.80
+length=1048607,align1=3,align2=0:       53221.90 (0.32%)        51975.00 (2.66%)        53393.80
+length=1048639,align1=3,align2=5:       53240.60 (0.36%)        51953.10 (2.77%)        53431.20
+length=2097159,align1=0,align2=0:       103744.00 (-2.00%)      102447.00 (-1.00%)      102425.00
+length=2097167,align1=0,align2=3:       108588.00 (-1.00%)      105159.00 (2.00%)       107606.00
+length=2097183,align1=3,align2=0:       107678.00 (0.00%)       105250.00 (2.00%)       108125.00
+length=2097215,align1=3,align2=5:       107906.00 (1.00%)       105841.00 (3.00%)       109475.00
+length=4194311,align1=0,align2=0:       202994.00 (0.00%)       202500.00 (1.00%)       204809.00
+length=4194319,align1=0,align2=3:       213350.00 (0.00%)       205997.00 (3.00%)       213384.00
+length=4194335,align1=3,align2=0:       212653.00 (0.00%)       206444.00 (3.00%)       212900.00
+length=4194367,align1=3,align2=5:       213044.00 (0.00%)       206084.00 (3.00%)       213847.00
+length=8388615,align1=0,align2=0:       401294.00 (0.00%)       401231.00 (0.00%)       401944.00
+length=8388623,align1=0,align2=3:       480872.00 (-14.00%)     406444.00 (3.00%)       422900.00
+length=8388639,align1=3,align2=0:       422147.00 (0.00%)       407750.00 (3.00%)       422803.00
+length=8388671,align1=3,align2=5:       442003.00 (-5.00%)      407125.00 (3.00%)       423509.00
+length=16777223,align1=0,align2=0:      799809.00 (0.00%)       800000.00 (0.00%)       801756.00
+length=16777231,align1=0,align2=3:      841184.00 (0.00%)       808525.00 (4.00%)       843775.00
+length=16777247,align1=3,align2=0:      841166.00 (0.00%)       810147.00 (3.00%)       843147.00
+length=16777279,align1=3,align2=5:      972569.00 (-16.00%)     808588.00 (4.00%)       843731.00
+length=33554439,align1=0,align2=0:      1842240.00 (-0.01%)     1863590.00 (-1.17%)     1841990.00
+length=33554447,align1=0,align2=3:      2103470.00 (-2.74%)     1919460.00 (6.25%)      2047440.00
+length=33554463,align1=3,align2=0:      2075690.00 (-1.07%)     1930040.00 (6.02%)      2053720.00
+length=33554495,align1=3,align2=5:      2110590.00 (-2.82%)     1924440.00 (6.25%)      2052650.00
+
+Function: memcpy
+__memcpy_thunderx       __memcpy_falkor __memcpy_generic
+Variant: random
+================================================================================
+max-size=4096:  44061.90 (5.85%)        38568.20 (17.59%)       46799.90
+max-size=8192:  42790.90 (5.27%)        38158.90 (15.52%)       45171.50
+max-size=16384:         44912.10 (2.25%)        38710.40 (15.75%)       45945.00
+max-size=32768:         43577.90 (1.23%)        37975.10 (13.93%)       44120.00
+max-size=65536:         44375.50 (1.04%)        38474.20 (14.20%)       44840.60
+
+	* manual/tunables.texi (Tunable glibc.tune.cpu): Add falkor.
+	* sysdeps/aarch64/multiarch/Makefile (sysdep_routines): Add
+	memcpy_falkor.
+	* sysdeps/aarch64/multiarch/ifunc-impl-list.c (MAX_IFUNC):
+	Bump.
+	(__libc_ifunc_impl_list): Add __memcpy_falkor.
+	* sysdeps/aarch64/multiarch/memcpy.c: Likewise.
+	* sysdeps/aarch64/multiarch/memcpy_falkor.S: New file.
+	* sysdeps/unix/sysv/linux/aarch64/cpu-features.c (cpu_list):
+	Add falkor.
+	* sysdeps/unix/sysv/linux/aarch64/cpu-features.h (IS_FALKOR):
+	New macro.
+
+diff --git a/ChangeLog b/ChangeLog
+index bfcdc1ebbf..0ef88b0c87 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,18 @@
++2017-10-10  Siddhesh Poyarekar  <siddhesh@sourceware.org>
++
++	* manual/tunables.texi (Tunable glibc.tune.cpu): Add falkor.
++	* sysdeps/aarch64/multiarch/Makefile (sysdep_routines): Add
++	memcpy_falkor.
++	* sysdeps/aarch64/multiarch/ifunc-impl-list.c (MAX_IFUNC):
++	Bump.
++	(__libc_ifunc_impl_list): Add __memcpy_falkor.
++	* sysdeps/aarch64/multiarch/memcpy.c: Likewise.
++	* sysdeps/aarch64/multiarch/memcpy_falkor.S: New file.
++	* sysdeps/unix/sysv/linux/aarch64/cpu-features.c (cpu_list):
++	Add falkor.
++	* sysdeps/unix/sysv/linux/aarch64/cpu-features.h (IS_FALKOR):
++	New macro.
++
+ 2017-10-06  Carlos O'Donell  <carlos@redhat.com>
+ 
+ 	[BZ #22111]
+diff --git a/manual/tunables.texi b/manual/tunables.texi
+index 4c658bf3df..3c19567a28 100644
+--- a/manual/tunables.texi
++++ b/manual/tunables.texi
+@@ -267,7 +267,7 @@ This tunable is specific to i386 and x86-64.
+ @deftp Tunable glibc.tune.cpu
+ The @code{glibc.tune.cpu=xxx} tunable allows the user to tell @theglibc{} to
+ assume that the CPU is @code{xxx} where xxx may have one of these values:
+-@code{generic}, @code{thunderxt88}.
++@code{generic}, @code{falkor}, @code{thunderxt88}.
+ 
+ This tunable is specific to aarch64.
+ @end deftp
+diff --git a/sysdeps/aarch64/multiarch/Makefile b/sysdeps/aarch64/multiarch/Makefile
+index 78d52c717d..164ba1ae4b 100644
+--- a/sysdeps/aarch64/multiarch/Makefile
++++ b/sysdeps/aarch64/multiarch/Makefile
+@@ -1,3 +1,3 @@
+ ifeq ($(subdir),string)
+-sysdep_routines += memcpy_generic memcpy_thunderx
++sysdep_routines += memcpy_generic memcpy_thunderx memcpy_falkor
+ endif
+diff --git a/sysdeps/aarch64/multiarch/ifunc-impl-list.c b/sysdeps/aarch64/multiarch/ifunc-impl-list.c
+index 32056bcec3..8e873b3d9f 100644
+--- a/sysdeps/aarch64/multiarch/ifunc-impl-list.c
++++ b/sysdeps/aarch64/multiarch/ifunc-impl-list.c
+@@ -25,7 +25,7 @@
+ #include <stdio.h>
+ 
+ /* Maximum number of IFUNC implementations.  */
+-#define MAX_IFUNC	2
++#define MAX_IFUNC	3
+ 
+ size_t
+ __libc_ifunc_impl_list (const char *name, struct libc_ifunc_impl *array,
+@@ -40,6 +40,7 @@ __libc_ifunc_impl_list (const char *name, struct libc_ifunc_impl *array,
+   /* Support sysdeps/aarch64/multiarch/memcpy.c and memmove.c.  */
+   IFUNC_IMPL (i, name, memcpy,
+ 	      IFUNC_IMPL_ADD (array, i, memcpy, 1, __memcpy_thunderx)
++	      IFUNC_IMPL_ADD (array, i, memcpy, 1, __memcpy_falkor)
+ 	      IFUNC_IMPL_ADD (array, i, memcpy, 1, __memcpy_generic))
+   IFUNC_IMPL (i, name, memmove,
+ 	      IFUNC_IMPL_ADD (array, i, memmove, 1, __memmove_thunderx)
+diff --git a/sysdeps/aarch64/multiarch/memcpy.c b/sysdeps/aarch64/multiarch/memcpy.c
+index 9f73efbba7..b395df1c63 100644
+--- a/sysdeps/aarch64/multiarch/memcpy.c
++++ b/sysdeps/aarch64/multiarch/memcpy.c
+@@ -30,9 +30,14 @@ extern __typeof (__redirect_memcpy) __libc_memcpy;
+ 
+ extern __typeof (__redirect_memcpy) __memcpy_generic attribute_hidden;
+ extern __typeof (__redirect_memcpy) __memcpy_thunderx attribute_hidden;
++extern __typeof (__redirect_memcpy) __memcpy_falkor attribute_hidden;
+ 
+ libc_ifunc (__libc_memcpy,
+-            IS_THUNDERX (midr) ? __memcpy_thunderx : __memcpy_generic);
++            (IS_THUNDERX (midr)
++	     ? __memcpy_thunderx
++	     : (IS_FALKOR (midr)
++		? __memcpy_falkor
++		: __memcpy_generic)));
+ 
+ # undef memcpy
+ strong_alias (__libc_memcpy, memcpy);
+diff --git a/sysdeps/aarch64/multiarch/memcpy_falkor.S b/sysdeps/aarch64/multiarch/memcpy_falkor.S
+new file mode 100644
+index 0000000000..3708281147
+--- /dev/null
++++ b/sysdeps/aarch64/multiarch/memcpy_falkor.S
+@@ -0,0 +1,187 @@
++/* Optimized memcpy for Qualcomm Falkor processor.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#include <sysdep.h>
++
++/* Assumptions:
++ *
++ * ARMv8-a, AArch64, falkor, unaligned accesses.
++ *
++ */
++
++#define dstin	x0
++#define src	x1
++#define count	x2
++#define dst	x3
++#define srcend	x4
++#define dstend	x5
++#define A_l	x6
++#define A_lw	w6
++#define A_h	x7
++#define A_hw	w7
++#define tmp1	x14
++
++/* Copies are split into 3 main cases:
++
++   1. Small copies of up to 32 bytes
++   2. Medium copies of 33..128 bytes which are fully unrolled
++   3. Large copies of more than 128 bytes.
++
++   Large copies align the sourceto a quad word and use an unrolled loop
++   processing 64 bytes per iteration.
++
++   FALKOR-SPECIFIC DESIGN:
++
++   The smallest copies (32 bytes or less) focus on optimal pipeline usage,
++   which is why the redundant copies of 0-3 bytes have been replaced with
++   conditionals, since the former would unnecessarily break across multiple
++   issue groups.  The medium copy group has been enlarged to 128 bytes since
++   bumping up the small copies up to 32 bytes allows us to do that without
++   cost and also allows us the reduce the size of the prep code before loop64.
++
++   All copies are done only via two registers r6 and r7.  This is to ensure
++   that all loads hit a single hardware prefetcher which can get correctly
++   trained to prefetch a single stream.
++
++   The non-temporal stores help optimize cache utilization.
++*/
++
++#if IS_IN (libc)
++ENTRY_ALIGN (__memcpy_falkor, 6)
++
++	cmp	count, 32
++	add	srcend, src, count
++	add	dstend, dstin, count
++	b.ls	L(copy32)
++	ldp	A_l, A_h, [src]
++	cmp	count, 128
++	stp	A_l, A_h, [dstin]
++	b.hi	L(copy_long)
++
++	/* Medium copies: 33..128 bytes.  */
++	sub	tmp1, count, 1
++	ldp	A_l, A_h, [src, 16]
++	stp	A_l, A_h, [dstin, 16]
++	tbz	tmp1, 6, 1f
++	ldp	A_l, A_h, [src, 32]
++	stp	A_l, A_h, [dstin, 32]
++	ldp	A_l, A_h, [src, 48]
++	stp	A_l, A_h, [dstin, 48]
++	ldp	A_l, A_h, [srcend, -64]
++	stp	A_l, A_h, [dstend, -64]
++	ldp	A_l, A_h, [srcend, -48]
++	stp	A_l, A_h, [dstend, -48]
++1:
++	ldp	A_l, A_h, [srcend, -32]
++	stp	A_l, A_h, [dstend, -32]
++	ldp	A_l, A_h, [srcend, -16]
++	stp	A_l, A_h, [dstend, -16]
++	ret
++
++	.p2align 4
++	/* Small copies: 0..32 bytes.  */
++L(copy32):
++	/* 16-32 */
++	cmp	count, 16
++	b.lo	1f
++	ldp	A_l, A_h, [src]
++	stp	A_l, A_h, [dstin]
++	ldp	A_l, A_h, [srcend, -16]
++	stp	A_l, A_h, [dstend, -16]
++	ret
++	.p2align 4
++1:
++	/* 8-15 */
++	tbz	count, 3, 1f
++	ldr	A_l, [src]
++	str	A_l, [dstin]
++	ldr	A_l, [srcend, -8]
++	str	A_l, [dstend, -8]
++	ret
++	.p2align 4
++1:
++	/* 4-7 */
++	tbz	count, 2, 1f
++	ldr	A_lw, [src]
++	str	A_lw, [dstin]
++	ldr	A_lw, [srcend, -4]
++	str	A_lw, [dstend, -4]
++	ret
++	.p2align 4
++1:
++	/* 2-3 */
++	tbz	count, 1, 1f
++	ldrh	A_lw, [src]
++	strh	A_lw, [dstin]
++	ldrh	A_lw, [srcend, -2]
++	strh	A_lw, [dstend, -2]
++	ret
++	.p2align 4
++1:
++	/* 0-1 */
++	tbz	count, 0, 1f
++	ldrb	A_lw, [src]
++	strb	A_lw, [dstin]
++1:
++	ret
++
++	/* Align SRC to 16 bytes and copy; that way at least one of the
++	   accesses is aligned throughout the copy sequence.
++
++	   The count is off by 0 to 15 bytes, but this is OK because we trim
++	   off the last 64 bytes to copy off from the end.  Due to this the
++	   loop never runs out of bounds.  */
++	.p2align 6
++L(copy_long):
++	sub	count, count, 64 + 16
++	and	tmp1, src, 15
++	bic	src, src, 15
++	sub	dst, dstin, tmp1
++	add	count, count, tmp1
++
++L(loop64):
++	ldp	A_l, A_h, [src, 16]!
++	stnp	A_l, A_h, [dst, 16]
++	ldp	A_l, A_h, [src, 16]!
++	subs	count, count, 64
++	stnp	A_l, A_h, [dst, 32]
++	ldp	A_l, A_h, [src, 16]!
++	stnp	A_l, A_h, [dst, 48]
++	ldp	A_l, A_h, [src, 16]!
++	stnp	A_l, A_h, [dst, 64]
++	add	dst, dst, 64
++	b.hi	L(loop64)
++
++	/* Write the last full set of 64 bytes.  The remainder is at most 64
++	   bytes, so it is safe to always copy 64 bytes from the end even if
++	   there is just 1 byte left.  */
++L(last64):
++	ldp	A_l, A_h, [srcend, -64]
++	stnp	A_l, A_h, [dstend, -64]
++	ldp	A_l, A_h, [srcend, -48]
++	stnp	A_l, A_h, [dstend, -48]
++	ldp	A_l, A_h, [srcend, -32]
++	stnp	A_l, A_h, [dstend, -32]
++	ldp	A_l, A_h, [srcend, -16]
++	stnp	A_l, A_h, [dstend, -16]
++	ret
++
++END (__memcpy_falkor)
++libc_hidden_builtin_def (__memcpy_falkor)
++#endif
+diff --git a/sysdeps/unix/sysv/linux/aarch64/cpu-features.c b/sysdeps/unix/sysv/linux/aarch64/cpu-features.c
+index 0275d11c7f..18f5e60f4c 100644
+--- a/sysdeps/unix/sysv/linux/aarch64/cpu-features.c
++++ b/sysdeps/unix/sysv/linux/aarch64/cpu-features.c
+@@ -28,6 +28,7 @@ struct cpu_list
+ };
+ 
+ static struct cpu_list cpu_list[] = {
++      {"falkor",	0x510FC000},
+       {"thunderxt88",	0x430F0A10},
+       {"generic", 	0x0}
+ };
+diff --git a/sysdeps/unix/sysv/linux/aarch64/cpu-features.h b/sysdeps/unix/sysv/linux/aarch64/cpu-features.h
+index c92b650984..73cb53da9a 100644
+--- a/sysdeps/unix/sysv/linux/aarch64/cpu-features.h
++++ b/sysdeps/unix/sysv/linux/aarch64/cpu-features.h
+@@ -41,6 +41,9 @@
+ #define IS_THUNDERX(midr) (MIDR_IMPLEMENTOR(midr) == 'C'	\
+ 			   && MIDR_PARTNUM(midr) == 0x0a1)
+ 
++#define IS_FALKOR(midr) (MIDR_IMPLEMENTOR(midr) == 'Q'			      \
++                        && MIDR_PARTNUM(midr) == 0xc00)
++
+ struct cpu_features
+ {
+   uint64_t midr_el1;
diff --git a/gnu/packages/patches/glibc-2-26-0050.patch b/gnu/packages/patches/glibc-2-26-0050.patch
new file mode 100644
index 000000000..834378c7c
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0050.patch
@@ -0,0 +1,53 @@
+From e39de9fa74e81b03c91377a3770d06df9933d645 Mon Sep 17 00:00:00 2001
+From: Siddhesh Poyarekar <siddhesh@sourceware.org>
+Date: Tue, 10 Oct 2017 15:44:39 +0530
+Subject: [PATCH 50/90] memcpy_falkor: Fix code style in comments
+
+
+diff --git a/ChangeLog b/ChangeLog
+index 0ef88b0c87..e1e0cdd9b2 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,5 +1,8 @@
+ 2017-10-10  Siddhesh Poyarekar  <siddhesh@sourceware.org>
+ 
++	* sysdeps/aarch64/multiarch/memcpy_falkor.S: Fix code style in
++	comments.
++
+ 	* manual/tunables.texi (Tunable glibc.tune.cpu): Add falkor.
+ 	* sysdeps/aarch64/multiarch/Makefile (sysdep_routines): Add
+ 	memcpy_falkor.
+diff --git a/sysdeps/aarch64/multiarch/memcpy_falkor.S b/sysdeps/aarch64/multiarch/memcpy_falkor.S
+index 3708281147..dea4f225ee 100644
+--- a/sysdeps/aarch64/multiarch/memcpy_falkor.S
++++ b/sysdeps/aarch64/multiarch/memcpy_falkor.S
+@@ -20,10 +20,8 @@
+ #include <sysdep.h>
+ 
+ /* Assumptions:
+- *
+- * ARMv8-a, AArch64, falkor, unaligned accesses.
+- *
+- */
++
++   ARMv8-a, AArch64, falkor, unaligned accesses.  */
+ 
+ #define dstin	x0
+ #define src	x1
+@@ -53,14 +51,13 @@
+    conditionals, since the former would unnecessarily break across multiple
+    issue groups.  The medium copy group has been enlarged to 128 bytes since
+    bumping up the small copies up to 32 bytes allows us to do that without
+-   cost and also allows us the reduce the size of the prep code before loop64.
++   cost and also allows us to reduce the size of the prep code before loop64.
+ 
+    All copies are done only via two registers r6 and r7.  This is to ensure
+    that all loads hit a single hardware prefetcher which can get correctly
+    trained to prefetch a single stream.
+ 
+-   The non-temporal stores help optimize cache utilization.
+-*/
++   The non-temporal stores help optimize cache utilization.  */
+ 
+ #if IS_IN (libc)
+ ENTRY_ALIGN (__memcpy_falkor, 6)
diff --git a/gnu/packages/patches/glibc-2-26-0051.patch b/gnu/packages/patches/glibc-2-26-0051.patch
new file mode 100644
index 000000000..aae93f11c
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0051.patch
@@ -0,0 +1,2933 @@
+From de84fc77f823051b1df336b7e5c257e4c3de984e Mon Sep 17 00:00:00 2001
+From: Siddhesh Poyarekar <siddhesh@sourceware.org>
+Date: Mon, 11 Sep 2017 05:50:49 +0530
+Subject: [PATCH 51/90] Update translations
+
+
+diff --git a/ChangeLog b/ChangeLog
+index e1e0cdd9b2..2aa1711834 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,5 +1,8 @@
+ 2017-10-10  Siddhesh Poyarekar  <siddhesh@sourceware.org>
+ 
++	* po/sv.po: Update translations.
++	* po/fr.po: Likewise.
++
+ 	* sysdeps/aarch64/multiarch/memcpy_falkor.S: Fix code style in
+ 	comments.
+ 
+diff --git a/po/fr.po b/po/fr.po
+index 5a79695125..6764655d25 100644
+--- a/po/fr.po
++++ b/po/fr.po
+@@ -5920,7 +5920,7 @@ msgstr "Le fichier existe"
+ #. TRANS also when you rename a file with @code{rename} (@pxref{Renaming Files}).
+ #: sysdeps/gnu/errlist.c:211
+ msgid "Invalid cross-device link"
+-msgstr "Lien croisé de périphéque invalide"
++msgstr "Lien physique inter-périphérique invalide"
+ 
+ #. TRANS The wrong type of device was given to a function that expects a
+ #. TRANS particular sort of device.
+diff --git a/po/sv.po b/po/sv.po
+index 0ebfec5b7f..d10bfad482 100644
+--- a/po/sv.po
++++ b/po/sv.po
+@@ -5,12 +5,12 @@
+ # Jan Djärv <jan.h.d@swipnet.se>, 1996, 1998, 2001, 2002, 2003, 2006, 2007, 2008, 2009, 2011, 2012, 2013, 2014, 2015.
+ # Göran Uddeborg <goeran@uddeborg.se>, 2016, 2017.
+ #
+-# $Revision: 1.7 $
++# $Revision: 1.10 $
+ msgid ""
+ msgstr ""
+-"Project-Id-Version: libc 2.25-pre1\n"
+-"POT-Creation-Date: 2017-01-11 17:27+0530\n"
+-"PO-Revision-Date: 2017-05-30 12:14+0200\n"
++"Project-Id-Version: libc 2.25.90\n"
++"POT-Creation-Date: 2017-07-25 12:32+0530\n"
++"PO-Revision-Date: 2017-08-20 18:21+0200\n"
+ "Last-Translator: Göran Uddeborg <goeran@uddeborg.se>\n"
+ "Language-Team: Swedish <tp-sv@listor.tp-sv.se>\n"
+ "Language: sv\n"
+@@ -478,19 +478,19 @@ msgstr "FEL I DYNAMISK LÄNKARE!!!"
+ msgid "error while loading shared libraries"
+ msgstr "fel när delade bibliotek laddades"
+ 
+-#: elf/dl-fptr.c:88 sysdeps/hppa/dl-fptr.c:94
++#: elf/dl-fptr.c:88 sysdeps/hppa/dl-fptr.c:95
+ msgid "cannot map pages for fdesc table"
+ msgstr "kan inte minnesmappa sidor för fdesc-tabell"
+ 
+-#: elf/dl-fptr.c:192 sysdeps/hppa/dl-fptr.c:207
++#: elf/dl-fptr.c:192 sysdeps/hppa/dl-fptr.c:213
+ msgid "cannot map pages for fptr table"
+ msgstr "kan inte minnesmappa sidor för fptr-tabell"
+ 
+-#: elf/dl-fptr.c:221 sysdeps/hppa/dl-fptr.c:236
++#: elf/dl-fptr.c:221 sysdeps/hppa/dl-fptr.c:242
+ msgid "internal error: symidx out of range of fptr table"
+ msgstr "internt fel: symidx är utanför intervallet för fptr-tabellen"
+ 
+-#: elf/dl-hwcaps.c:184 elf/dl-hwcaps.c:196
++#: elf/dl-hwcaps.c:191 elf/dl-hwcaps.c:203
+ msgid "cannot create capability list"
+ msgstr "kan inte skapa egenskapslista"
+ 
+@@ -670,20 +670,20 @@ msgstr "ogiltig målnamnrymd för dlmopen()"
+ msgid "cannot allocate memory in static TLS block"
+ msgstr "kan inte allokera minne i statiskt TLS-block"
+ 
+-#: elf/dl-reloc.c:212
++#: elf/dl-reloc.c:206
+ msgid "cannot make segment writable for relocation"
+ msgstr "kan inte göra segment skrivbart för relokering"
+ 
+-#: elf/dl-reloc.c:283
++#: elf/dl-reloc.c:277
+ #, c-format
+ msgid "%s: out of memory to store relocation results for %s\n"
+ msgstr "%s: slut på minne för att lagra relokeringsresultat för %s\n"
+ 
+-#: elf/dl-reloc.c:299
++#: elf/dl-reloc.c:293
+ msgid "cannot restore segment prot after reloc"
+ msgstr "kan inte återställa segmenträttigheter efter relokering"
+ 
+-#: elf/dl-reloc.c:330
++#: elf/dl-reloc.c:324
+ msgid "cannot apply additional memory protection after relocation"
+ msgstr "kan inte applicera extra minnesskydd efter relokering"
+ 
+@@ -959,14 +959,14 @@ msgstr "Försök med \"ldd --help\" för mer information."
+ msgid "missing file arguments"
+ msgstr "filargument saknas"
+ 
+-#. TRANS No such file or directory.  This is a ``file doesn't exist'' error
++#. TRANS This is a ``file doesn't exist'' error
+ #. TRANS for ordinary files that are referenced in contexts where they are
+ #. TRANS expected to already exist.
+ #: elf/ldd.bash.in:147 sysdeps/gnu/errlist.c:37
+ msgid "No such file or directory"
+ msgstr "Filen eller katalogen finns inte"
+ 
+-#: elf/ldd.bash.in:150 inet/rcmd.c:475
++#: elf/ldd.bash.in:150 inet/rcmd.c:480
+ msgid "not regular file"
+ msgstr "inte en normal fil"
+ 
+@@ -1540,68 +1540,68 @@ msgstr "vid insättning i sökträd"
+ msgid "cannot generate output file"
+ msgstr "kan inte generera utfil"
+ 
+-#: inet/rcmd.c:155
++#: inet/rcmd.c:157
+ msgid "rcmd: Cannot allocate memory\n"
+ msgstr "rcmd: Kan inte allokera minne\n"
+ 
+-#: inet/rcmd.c:170
++#: inet/rcmd.c:174
+ msgid "rcmd: socket: All ports in use\n"
+ msgstr "rcmd: uttag (socket): Alla portar används\n"
+ 
+-#: inet/rcmd.c:198
++#: inet/rcmd.c:202
+ #, c-format
+ msgid "connect to address %s: "
+ msgstr "anslut till adress %s: "
+ 
+-#: inet/rcmd.c:211
++#: inet/rcmd.c:215
+ #, c-format
+ msgid "Trying %s...\n"
+ msgstr "Provar %s...\n"
+ 
+-#: inet/rcmd.c:247
++#: inet/rcmd.c:251
+ #, c-format
+ msgid "rcmd: write (setting up stderr): %m\n"
+ msgstr "rcmd: write: (sätter upp standard fel): %m\n"
+ 
+-#: inet/rcmd.c:263
++#: inet/rcmd.c:267
+ #, c-format
+ msgid "rcmd: poll (setting up stderr): %m\n"
+ msgstr "rcmd: poll (sätter upp standard fel): %m\n"
+ 
+-#: inet/rcmd.c:266
++#: inet/rcmd.c:270
+ msgid "poll: protocol failure in circuit setup\n"
+ msgstr "poll: protokollfel i förbindelseuppsättning\n"
+ 
+-#: inet/rcmd.c:298
++#: inet/rcmd.c:302
+ msgid "socket: protocol failure in circuit setup\n"
+ msgstr "uttag (socket): protokollfel i förbindelseuppsättning\n"
+ 
+-#: inet/rcmd.c:322
++#: inet/rcmd.c:326
+ #, c-format
+ msgid "rcmd: %s: short read"
+ msgstr "rcmd: %s: läsning gav för lite data"
+ 
+-#: inet/rcmd.c:473
++#: inet/rcmd.c:478
+ msgid "lstat failed"
+ msgstr "misslyckades ta status (lstat)"
+ 
+-#: inet/rcmd.c:480
++#: inet/rcmd.c:485
+ msgid "cannot open"
+ msgstr "kan inte öppna"
+ 
+-#: inet/rcmd.c:482
++#: inet/rcmd.c:487
+ msgid "fstat failed"
+ msgstr "misslyckades ta status (fstat)"
+ 
+-#: inet/rcmd.c:484
++#: inet/rcmd.c:489
+ msgid "bad owner"
+ msgstr "felaktig ägare"
+ 
+-#: inet/rcmd.c:486
++#: inet/rcmd.c:491
+ msgid "writeable by other than owner"
+ msgstr "skrivbar för andra än ägaren"
+ 
+-#: inet/rcmd.c:488
++#: inet/rcmd.c:493
+ msgid "hard linked somewhere"
+ msgstr "hårdlänkad någonstans"
+ 
+@@ -3143,7 +3143,7 @@ msgstr "Okänt systemfel"
+ msgid "unable to free arguments"
+ msgstr "kan inte avallokera argument"
+ 
+-#: nis/nis_error.h:1 nis/ypclnt.c:817 nis/ypclnt.c:905 posix/regcomp.c:137
++#: nis/nis_error.h:1 nis/ypclnt.c:824 nis/ypclnt.c:913 posix/regcomp.c:137
+ #: sysdeps/gnu/errlist.c:21
+ msgid "Success"
+ msgstr "Lyckat"
+@@ -3184,8 +3184,8 @@ msgstr "Generiskt systemfel"
+ msgid "First/next chain broken"
+ msgstr "Första/Nästa-kedja bruten"
+ 
+-#. TRANS Permission denied; the file permissions do not allow the attempted operation.
+-#: nis/nis_error.h:11 nis/ypclnt.c:862 sysdeps/gnu/errlist.c:158
++#. TRANS The file permissions do not allow the attempted operation.
++#: nis/nis_error.h:11 nis/ypclnt.c:869 sysdeps/gnu/errlist.c:158
+ msgid "Permission denied"
+ msgstr "Åtkomst nekas"
+ 
+@@ -3337,128 +3337,128 @@ msgstr "Kan inte skapa process hos server"
+ msgid "Master server busy, full dump rescheduled."
+ msgstr "Huvudserver är upptagen, full dump åter schemalagd."
+ 
+-#: nis/nis_local_names.c:121
++#: nis/nis_local_names.c:122
+ #, c-format
+ msgid "LOCAL entry for UID %d in directory %s not unique\n"
+ msgstr "LOCAL-post för UID %d i katalog %s är inte unik\n"
+ 
+-#: nis/nis_print.c:51
++#: nis/nis_print.c:52
+ msgid "UNKNOWN"
+ msgstr "OKÄND"
+ 
+-#: nis/nis_print.c:109
++#: nis/nis_print.c:110
+ msgid "BOGUS OBJECT\n"
+ msgstr "SKENOBJEKT\n"
+ 
+-#: nis/nis_print.c:112
++#: nis/nis_print.c:113
+ msgid "NO OBJECT\n"
+ msgstr "INGET OBJEKT\n"
+ 
+-#: nis/nis_print.c:115
++#: nis/nis_print.c:116
+ msgid "DIRECTORY\n"
+ msgstr "KATALOG\n"
+ 
+-#: nis/nis_print.c:118
++#: nis/nis_print.c:119
+ msgid "GROUP\n"
+ msgstr "GRUPP\n"
+ 
+-#: nis/nis_print.c:121
++#: nis/nis_print.c:122
+ msgid "TABLE\n"
+ msgstr "TABELL\n"
+ 
+-#: nis/nis_print.c:124
++#: nis/nis_print.c:125
+ msgid "ENTRY\n"
+ msgstr "POST\n"
+ 
+-#: nis/nis_print.c:127
++#: nis/nis_print.c:128
+ msgid "LINK\n"
+ msgstr "LÄNK\n"
+ 
+-#: nis/nis_print.c:130
++#: nis/nis_print.c:131
+ msgid "PRIVATE\n"
+ msgstr "PRIVAT\n"
+ 
+-#: nis/nis_print.c:133
++#: nis/nis_print.c:134
+ msgid "(Unknown object)\n"
+ msgstr "(Okänt objekt)\n"
+ 
+-#: nis/nis_print.c:167
++#: nis/nis_print.c:168
+ #, c-format
+ msgid "Name : `%s'\n"
+ msgstr "Namn: \"%s\"\n"
+ 
+-#: nis/nis_print.c:168
++#: nis/nis_print.c:169
+ #, c-format
+ msgid "Type : %s\n"
+ msgstr "Typ: %s\n"
+ 
+-#: nis/nis_print.c:173
++#: nis/nis_print.c:174
+ msgid "Master Server :\n"
+ msgstr "Huvudserver:\n"
+ 
+-#: nis/nis_print.c:175
++#: nis/nis_print.c:176
+ msgid "Replicate :\n"
+ msgstr "Replikera:\n"
+ 
+-#: nis/nis_print.c:176
++#: nis/nis_print.c:177
+ #, c-format
+ msgid "\tName       : %s\n"
+ msgstr "\tNamn       : %s\n"
+ 
+-#: nis/nis_print.c:177
++#: nis/nis_print.c:178
+ msgid "\tPublic Key : "
+ msgstr "\tPublik nyckel: "
+ 
+-#: nis/nis_print.c:181
++#: nis/nis_print.c:182
+ msgid "None.\n"
+ msgstr "Ingen.\n"
+ 
+-#: nis/nis_print.c:184
++#: nis/nis_print.c:185
+ #, c-format
+ msgid "Diffie-Hellmann (%d bits)\n"
+ msgstr "Diffie-Hellmann (%d bitar)\n"
+ 
+-#: nis/nis_print.c:189
++#: nis/nis_print.c:190
+ #, c-format
+ msgid "RSA (%d bits)\n"
+ msgstr "RSA (%d bitar)\n"
+ 
+-#: nis/nis_print.c:192
++#: nis/nis_print.c:193
+ msgid "Kerberos.\n"
+ msgstr "Kerberos.\n"
+ 
+-#: nis/nis_print.c:195
++#: nis/nis_print.c:196
+ #, c-format
+ msgid "Unknown (type = %d, bits = %d)\n"
+ msgstr "Okänd (typ = %d, bitar = %d)\n"
+ 
+-#: nis/nis_print.c:206
++#: nis/nis_print.c:207
+ #, c-format
+ msgid "\tUniversal addresses (%u)\n"
+ msgstr "\tUniversella adresser (%u)\n"
+ 
+-#: nis/nis_print.c:228
++#: nis/nis_print.c:229
+ msgid "Time to live : "
+ msgstr "Livslängd: "
+ 
+-#: nis/nis_print.c:230
++#: nis/nis_print.c:231
+ msgid "Default Access rights :\n"
+ msgstr "Standard åtkomsträttigheter:\n"
+ 
+-#: nis/nis_print.c:239
++#: nis/nis_print.c:240
+ #, c-format
+ msgid "\tType         : %s\n"
+ msgstr "\tTyp          : %s\n"
+ 
+-#: nis/nis_print.c:240
++#: nis/nis_print.c:241
+ msgid "\tAccess rights: "
+ msgstr "\tRättigheter  : "
+ 
+-#: nis/nis_print.c:254
++#: nis/nis_print.c:255
+ msgid "Group Flags :"
+ msgstr "Gruppflaggor: "
+ 
+-#: nis/nis_print.c:257
++#: nis/nis_print.c:258
+ msgid ""
+ "\n"
+ "Group Members :\n"
+@@ -3466,95 +3466,95 @@ msgstr ""
+ "\n"
+ "Gruppmedlemmar:\n"
+ 
+-#: nis/nis_print.c:269
++#: nis/nis_print.c:270
+ #, c-format
+ msgid "Table Type          : %s\n"
+ msgstr "Tabelltyp           : %s\n"
+ 
+-#: nis/nis_print.c:270
++#: nis/nis_print.c:271
+ #, c-format
+ msgid "Number of Columns   : %d\n"
+ msgstr "Antal kolumner      : %d\n"
+ 
+-#: nis/nis_print.c:271
++#: nis/nis_print.c:272
+ #, c-format
+ msgid "Character Separator : %c\n"
+ msgstr "Teckenseparator     : %c\n"
+ 
+-#: nis/nis_print.c:272
++#: nis/nis_print.c:273
+ #, c-format
+ msgid "Search Path         : %s\n"
+ msgstr "Sökväg              : %s\n"
+ 
+-#: nis/nis_print.c:273
++#: nis/nis_print.c:274
+ msgid "Columns             :\n"
+ msgstr "Kolumner            :\n"
+ 
+-#: nis/nis_print.c:276
++#: nis/nis_print.c:277
+ #, c-format
+ msgid "\t[%d]\tName          : %s\n"
+ msgstr "\t[%d]\tNamn          : %s\n"
+ 
+-#: nis/nis_print.c:278
++#: nis/nis_print.c:279
+ msgid "\t\tAttributes    : "
+ msgstr "\t\tAttribut      : "
+ 
+-#: nis/nis_print.c:280
++#: nis/nis_print.c:281
+ msgid "\t\tAccess Rights : "
+ msgstr "\t\tRättigheter   : "
+ 
+-#: nis/nis_print.c:290
++#: nis/nis_print.c:291
+ msgid "Linked Object Type : "
+ msgstr "Länkad objekttyp   : "
+ 
+-#: nis/nis_print.c:292
++#: nis/nis_print.c:293
+ #, c-format
+ msgid "Linked to : %s\n"
+ msgstr "Länkad till: %s\n"
+ 
+-#: nis/nis_print.c:302
++#: nis/nis_print.c:303
+ #, c-format
+ msgid "\tEntry data of type %s\n"
+ msgstr "\tPostdata av typ %s\n"
+ 
+-#: nis/nis_print.c:305
++#: nis/nis_print.c:306
+ #, c-format
+ msgid "\t[%u] - [%u bytes] "
+ msgstr "\t[%u] - [%u byte] "
+ 
+-#: nis/nis_print.c:308
++#: nis/nis_print.c:309
+ msgid "Encrypted data\n"
+ msgstr "Krypterat data\n"
+ 
+-#: nis/nis_print.c:310
++#: nis/nis_print.c:311
+ msgid "Binary data\n"
+ msgstr "Binärdata\n"
+ 
+-#: nis/nis_print.c:326
++#: nis/nis_print.c:327
+ #, c-format
+ msgid "Object Name   : %s\n"
+ msgstr "Objektnamn    : %s\n"
+ 
+-#: nis/nis_print.c:327
++#: nis/nis_print.c:328
+ #, c-format
+ msgid "Directory     : %s\n"
+ msgstr "Katalog       : %s\n"
+ 
+-#: nis/nis_print.c:328
++#: nis/nis_print.c:329
+ #, c-format
+ msgid "Owner         : %s\n"
+ msgstr "Ägare         : %s\n"
+ 
+-#: nis/nis_print.c:329
++#: nis/nis_print.c:330
+ #, c-format
+ msgid "Group         : %s\n"
+ msgstr "Grupp         : %s\n"
+ 
+-#: nis/nis_print.c:330
++#: nis/nis_print.c:331
+ msgid "Access Rights : "
+ msgstr "Rättigheter   : "
+ 
+-#: nis/nis_print.c:332
++#: nis/nis_print.c:333
+ #, c-format
+ msgid ""
+ "\n"
+@@ -3563,90 +3563,90 @@ msgstr ""
+ "\n"
+ "Livslängd     : "
+ 
+-#: nis/nis_print.c:335
++#: nis/nis_print.c:336
+ #, c-format
+ msgid "Creation Time : %s"
+ msgstr "Skapad        : %s"
+ 
+-#: nis/nis_print.c:337
++#: nis/nis_print.c:338
+ #, c-format
+ msgid "Mod. Time     : %s"
+ msgstr "Ändr. tid     : %s"
+ 
+-#: nis/nis_print.c:338
++#: nis/nis_print.c:339
+ msgid "Object Type   : "
+ msgstr "Objekttyp     : "
+ 
+-#: nis/nis_print.c:358
++#: nis/nis_print.c:359
+ #, c-format
+ msgid "    Data Length = %u\n"
+ msgstr "    Datalängd = %u\n"
+ 
+-#: nis/nis_print.c:372
++#: nis/nis_print.c:373
+ #, c-format
+ msgid "Status            : %s\n"
+ msgstr "Status            : %s\n"
+ 
+-#: nis/nis_print.c:373
++#: nis/nis_print.c:374
+ #, c-format
+ msgid "Number of objects : %u\n"
+ msgstr "Antal objekt      : %u\n"
+ 
+-#: nis/nis_print.c:377
++#: nis/nis_print.c:378
+ #, c-format
+ msgid "Object #%d:\n"
+ msgstr "Objekt nr %d:\n"
+ 
+-#: nis/nis_print_group_entry.c:116
++#: nis/nis_print_group_entry.c:117
+ #, c-format
+ msgid "Group entry for \"%s.%s\" group:\n"
+ msgstr "Gruppost för \"%s.%s\" grupp:\n"
+ 
+-#: nis/nis_print_group_entry.c:124
++#: nis/nis_print_group_entry.c:125
+ msgid "    Explicit members:\n"
+ msgstr "    Explicita medlemmar:\n"
+ 
+-#: nis/nis_print_group_entry.c:129
++#: nis/nis_print_group_entry.c:130
+ msgid "    No explicit members\n"
+ msgstr "    Inga explicita medlemmar\n"
+ 
+-#: nis/nis_print_group_entry.c:132
++#: nis/nis_print_group_entry.c:133
+ msgid "    Implicit members:\n"
+ msgstr "    Implicita medlemmar:\n"
+ 
+-#: nis/nis_print_group_entry.c:137
++#: nis/nis_print_group_entry.c:138
+ msgid "    No implicit members\n"
+ msgstr "    Inga implicita medlemmar\n"
+ 
+-#: nis/nis_print_group_entry.c:140
++#: nis/nis_print_group_entry.c:141
+ msgid "    Recursive members:\n"
+ msgstr "    Rekursiva medlemmar:\n"
+ 
+-#: nis/nis_print_group_entry.c:145
++#: nis/nis_print_group_entry.c:146
+ msgid "    No recursive members\n"
+ msgstr "    Inga rekursiva medlemmar\n"
+ 
+-#: nis/nis_print_group_entry.c:148
++#: nis/nis_print_group_entry.c:149
+ msgid "    Explicit nonmembers:\n"
+ msgstr "    Explicita icke-medlemmar:\n"
+ 
+-#: nis/nis_print_group_entry.c:153
++#: nis/nis_print_group_entry.c:154
+ msgid "    No explicit nonmembers\n"
+ msgstr "    Inga explicita icke-medlemmar\n"
+ 
+-#: nis/nis_print_group_entry.c:156
++#: nis/nis_print_group_entry.c:157
+ msgid "    Implicit nonmembers:\n"
+ msgstr "    Implicita icke-medlemmar:\n"
+ 
+-#: nis/nis_print_group_entry.c:161
++#: nis/nis_print_group_entry.c:162
+ msgid "    No implicit nonmembers\n"
+ msgstr "    Inga implicita icke-medlemmar\n"
+ 
+-#: nis/nis_print_group_entry.c:164
++#: nis/nis_print_group_entry.c:165
+ msgid "    Recursive nonmembers:\n"
+ msgstr "    Rekursiva icke-medlemmar:\n"
+ 
+-#: nis/nis_print_group_entry.c:169
++#: nis/nis_print_group_entry.c:170
+ msgid "    No recursive nonmembers\n"
+ msgstr "    Inga rekursiva icke-medlemmar\n"
+ 
+@@ -3688,100 +3688,100 @@ msgstr "netname2user: LOCAL-post för %s i katalog %s är inte unik"
+ msgid "netname2user: should not have uid 0"
+ msgstr "netname2user: borde inte ha uid 0"
+ 
+-#: nis/ypclnt.c:820
++#: nis/ypclnt.c:827
+ msgid "Request arguments bad"
+ msgstr "Argument för förfrågan felaktiga"
+ 
+-#: nis/ypclnt.c:823
++#: nis/ypclnt.c:830
+ msgid "RPC failure on NIS operation"
+ msgstr "RPC-fel vid NIS-operation"
+ 
+-#: nis/ypclnt.c:826
++#: nis/ypclnt.c:833
+ msgid "Can't bind to server which serves this domain"
+ msgstr "Kan inte ansluta till servern som betjänar denna domän"
+ 
+-#: nis/ypclnt.c:829
++#: nis/ypclnt.c:836
+ msgid "No such map in server's domain"
+ msgstr "Ingen sådan tabell i serverns domän"
+ 
+-#: nis/ypclnt.c:832
++#: nis/ypclnt.c:839
+ msgid "No such key in map"
+ msgstr "Ingen sådan nyckel i tabellen"
+ 
+-#: nis/ypclnt.c:835
++#: nis/ypclnt.c:842
+ msgid "Internal NIS error"
+ msgstr "Internt NIS-fel"
+ 
+-#: nis/ypclnt.c:838
++#: nis/ypclnt.c:845
+ msgid "Local resource allocation failure"
+ msgstr "Allokeringsfel för lokal resurs"
+ 
+-#: nis/ypclnt.c:841
++#: nis/ypclnt.c:848
+ msgid "No more records in map database"
+ msgstr "Inga fler poster i tabelldatabasen"
+ 
+-#: nis/ypclnt.c:844
++#: nis/ypclnt.c:851
+ msgid "Can't communicate with portmapper"
+ msgstr "Kan inte kommunicera med portmapper"
+ 
+-#: nis/ypclnt.c:847
++#: nis/ypclnt.c:854
+ msgid "Can't communicate with ypbind"
+ msgstr "Kan inte kommunicera med ypbind"
+ 
+-#: nis/ypclnt.c:850
++#: nis/ypclnt.c:857
+ msgid "Can't communicate with ypserv"
+ msgstr "Kan inte kommunicera med ypserv"
+ 
+-#: nis/ypclnt.c:853
++#: nis/ypclnt.c:860
+ msgid "Local domain name not set"
+ msgstr "Lokalt domännamn inte satt"
+ 
+-#: nis/ypclnt.c:856
++#: nis/ypclnt.c:863
+ msgid "NIS map database is bad"
+ msgstr "NIS tabelldatabas är felaktig"
+ 
+-#: nis/ypclnt.c:859
++#: nis/ypclnt.c:866
+ msgid "NIS client/server version mismatch - can't supply service"
+ msgstr "NIS versionsskillnad klient/server - kan inte betjäna"
+ 
+-#: nis/ypclnt.c:865
++#: nis/ypclnt.c:872
+ msgid "Database is busy"
+ msgstr "Databasen är upptagen"
+ 
+-#: nis/ypclnt.c:868
++#: nis/ypclnt.c:875
+ msgid "Unknown NIS error code"
+ msgstr "Okänd NIS-felkod"
+ 
+-#: nis/ypclnt.c:908
++#: nis/ypclnt.c:916
+ msgid "Internal ypbind error"
+ msgstr "Internt ypbind-fel"
+ 
+-#: nis/ypclnt.c:911
++#: nis/ypclnt.c:919
+ msgid "Domain not bound"
+ msgstr "Domän inte bunden"
+ 
+-#: nis/ypclnt.c:914
++#: nis/ypclnt.c:922
+ msgid "System resource allocation failure"
+ msgstr "Allokeringsfel för systemresurs"
+ 
+-#: nis/ypclnt.c:917
++#: nis/ypclnt.c:925
+ msgid "Unknown ypbind error"
+ msgstr "Okänt ypbind-fel"
+ 
+-#: nis/ypclnt.c:958
++#: nis/ypclnt.c:966
+ msgid "yp_update: cannot convert host to netname\n"
+ msgstr "yp_update: kan inte omvandla värd till nätnamn\n"
+ 
+-#: nis/ypclnt.c:976
++#: nis/ypclnt.c:984
+ msgid "yp_update: cannot get server address\n"
+ msgstr "yp_update: kan inte hämta serveradress\n"
+ 
+-#: nscd/aicache.c:84 nscd/hstcache.c:485
++#: nscd/aicache.c:85 nscd/hstcache.c:485
+ #, c-format
+ msgid "Haven't found \"%s\" in hosts cache!"
+ msgstr "Hittar inte \"%s\" i värdcache!"
+ 
+-#: nscd/aicache.c:86 nscd/hstcache.c:487
++#: nscd/aicache.c:87 nscd/hstcache.c:487
+ #, c-format
+ msgid "Reloading \"%s\" in hosts cache!"
+ msgstr "Omladdar \"%s\" i värdcache!"
+@@ -3815,269 +3815,264 @@ msgstr "beskär %s cache; tid %ld"
+ msgid "considering %s entry \"%s\", timeout %<PRIu64>"
+ msgstr "överväger %s-post \"%s\", tidsgräns %<PRIu64>"
+ 
+-#: nscd/connections.c:548
++#: nscd/connections.c:537
+ #, c-format
+ msgid "invalid persistent database file \"%s\": %s"
+ msgstr "ogiltig persistent databasfil \"%s\": %s"
+ 
+-#: nscd/connections.c:556
++#: nscd/connections.c:545
+ msgid "uninitialized header"
+ msgstr "oinitierat huvud"
+ 
+-#: nscd/connections.c:561
++#: nscd/connections.c:550
+ msgid "header size does not match"
+ msgstr "huvudstorlek stämmer inte"
+ 
+-#: nscd/connections.c:571
++#: nscd/connections.c:560
+ msgid "file size does not match"
+ msgstr "filstorlek stämmer inte"
+ 
+-#: nscd/connections.c:588
++#: nscd/connections.c:577
+ msgid "verification failed"
+ msgstr "verifikation misslyckades"
+ 
+-#: nscd/connections.c:602
++#: nscd/connections.c:591
+ #, c-format
+ msgid "suggested size of table for database %s larger than the persistent database's table"
+ msgstr "föreslagen storlek på tabellen för databas %s är större än den persistenta databasens tabell"
+ 
+-#: nscd/connections.c:613 nscd/connections.c:697
++#: nscd/connections.c:602 nscd/connections.c:686
+ #, c-format
+ msgid "cannot create read-only descriptor for \"%s\"; no mmap"
+ msgstr "kan inte skapa läsbar filidentifierare för \"%s\", ingen mmap"
+ 
+-#: nscd/connections.c:629
++#: nscd/connections.c:618
+ #, c-format
+ msgid "cannot access '%s'"
+ msgstr "kan inte komma åt \"%s\""
+ 
+-#: nscd/connections.c:677
++#: nscd/connections.c:666
+ #, c-format
+ msgid "database for %s corrupted or simultaneously used; remove %s manually if necessary and restart"
+ msgstr "databas för %s korrupt eller använd av flera samtidigt; ta bort %s manuellt om det behövs och starta om"
+ 
+-#: nscd/connections.c:683
++#: nscd/connections.c:672
+ #, c-format
+ msgid "cannot create %s; no persistent database used"
+ msgstr "kan inte skapa %s; ingen persistent databas används"
+ 
+-#: nscd/connections.c:686
++#: nscd/connections.c:675
+ #, c-format
+ msgid "cannot create %s; no sharing possible"
+ msgstr "kan inte skapa %s; ingen delning möjlig"
+ 
+-#: nscd/connections.c:757
++#: nscd/connections.c:746
+ #, c-format
+ msgid "cannot write to database file %s: %s"
+ msgstr "kan inte skriva till databasfil %s: %s"
+ 
+-#: nscd/connections.c:796
+-#, c-format
+-msgid "cannot set socket to close on exec: %s; disabling paranoia mode"
+-msgstr "kan inte sätta uttag (socket) att stängas vid programstart: %s; kopplar ur paranoialäge"
+-
+-#: nscd/connections.c:831
++#: nscd/connections.c:802
+ #, c-format
+ msgid "cannot open socket: %s"
+ msgstr "kan inte öppna uttag (socket): %s"
+ 
+-#: nscd/connections.c:850
++#: nscd/connections.c:821
+ #, c-format
+ msgid "cannot enable socket to accept connections: %s"
+ msgstr "kan inte få uttag (socket) att acceptera förbindelser: %s"
+ 
+-#: nscd/connections.c:907
++#: nscd/connections.c:878
+ #, c-format
+ msgid "disabled inotify-based monitoring for file `%s': %s"
+ msgstr "avaktiverade inotify-baserad övervakning för filen ”%s”: %s"
+ 
+-#: nscd/connections.c:911
++#: nscd/connections.c:882
+ #, c-format
+ msgid "monitoring file `%s` (%d)"
+ msgstr "övervakar filen ”%s” (%d)"
+ 
+-#: nscd/connections.c:924
++#: nscd/connections.c:895
+ #, c-format
+ msgid "disabled inotify-based monitoring for directory `%s': %s"
+ msgstr "avaktiverade inotify-baserad övervakning av katalogen ”%s”: %s"
+ 
+-#: nscd/connections.c:928
++#: nscd/connections.c:899
+ #, c-format
+ msgid "monitoring directory `%s` (%d)"
+ msgstr "övervakar katalogen ”%s” (%d)"
+ 
+-#: nscd/connections.c:956
++#: nscd/connections.c:927
+ #, c-format
+ msgid "monitoring file %s for database %s"
+ msgstr "övervakar filen %s för databas %s"
+ 
+-#: nscd/connections.c:966
++#: nscd/connections.c:937
+ #, c-format
+ msgid "stat failed for file `%s'; will try again later: %s"
+ msgstr "stat misslyckades för filen ”%s”; kommer försöka igen senare: %s"
+ 
+-#: nscd/connections.c:1085
++#: nscd/connections.c:1056
+ #, c-format
+ msgid "provide access to FD %d, for %s"
+ msgstr "ge åtkomst till FD %d, för %s"
+ 
+-#: nscd/connections.c:1097
++#: nscd/connections.c:1068
+ #, c-format
+ msgid "cannot handle old request version %d; current version is %d"
+ msgstr "kan inte hantera äldre förfrågansversion %d, nuvarande version är %d"
+ 
+-#: nscd/connections.c:1119
++#: nscd/connections.c:1090
+ #, c-format
+ msgid "request from %ld not handled due to missing permission"
+ msgstr "begäran från %ld inte hanterad för att rättigheter saknas"
+ 
+-#: nscd/connections.c:1124
++#: nscd/connections.c:1095
+ #, c-format
+ msgid "request from '%s' [%ld] not handled due to missing permission"
+ msgstr "begäran från \"%s\" [%ld] inte hanterad för att rättigheter saknas"
+ 
+-#: nscd/connections.c:1129
++#: nscd/connections.c:1100
+ msgid "request not handled due to missing permission"
+ msgstr "begäran inte hanterad för att rättigheter saknas"
+ 
+-#: nscd/connections.c:1167 nscd/connections.c:1220
++#: nscd/connections.c:1138 nscd/connections.c:1191
+ #, c-format
+ msgid "cannot write result: %s"
+ msgstr "kan inte skriva resultat: %s"
+ 
+-#: nscd/connections.c:1311
++#: nscd/connections.c:1282
+ #, c-format
+ msgid "error getting caller's id: %s"
+ msgstr "kunde inte hämta anropandes identitet: %s"
+ 
+-#: nscd/connections.c:1371
++#: nscd/connections.c:1342
+ #, c-format
+ msgid "cannot open /proc/self/cmdline: %s; disabling paranoia mode"
+ msgstr "kan inte öppna /proc/slef/cmdline: %s, kopplar ur paranoialäge"
+ 
+-#: nscd/connections.c:1385
++#: nscd/connections.c:1356
+ #, c-format
+ msgid "cannot read /proc/self/cmdline: %s; disabling paranoia mode"
+ msgstr "kan inte läsa /proc/self/cmdline: %s, kopplar ur paranoialäge"
+ 
+-#: nscd/connections.c:1425
++#: nscd/connections.c:1396
+ #, c-format
+ msgid "cannot change to old UID: %s; disabling paranoia mode"
+ msgstr "kan inte byta till föregående UID: %s; kopplar ur paranoialäge"
+ 
+-#: nscd/connections.c:1435
++#: nscd/connections.c:1406
+ #, c-format
+ msgid "cannot change to old GID: %s; disabling paranoia mode"
+ msgstr "kan inte byta till föregående GID: %s; kopplar ur paranoialäge"
+ 
+-#: nscd/connections.c:1448
++#: nscd/connections.c:1419
+ #, c-format
+ msgid "cannot change to old working directory: %s; disabling paranoia mode"
+ msgstr "kan inte byta till föregående arbetskatalog: %s; kopplar ur paranoialäge"
+ 
+-#: nscd/connections.c:1494
++#: nscd/connections.c:1465
+ #, c-format
+ msgid "re-exec failed: %s; disabling paranoia mode"
+ msgstr "återstart misslyckades: %s; kopplar ur paranoialäge"
+ 
+-#: nscd/connections.c:1503
++#: nscd/connections.c:1474
+ #, c-format
+ msgid "cannot change current working directory to \"/\": %s"
+ msgstr "kan inte byta aktuell katalog till \"/\": %s"
+ 
+-#: nscd/connections.c:1696
++#: nscd/connections.c:1657
+ #, c-format
+ msgid "short read while reading request: %s"
+ msgstr "fattas data vid läsning av begäran: %s"
+ 
+-#: nscd/connections.c:1729
++#: nscd/connections.c:1690
+ #, c-format
+ msgid "key length in request too long: %d"
+ msgstr "nyckellängd i begäran för lång: %d"
+ 
+-#: nscd/connections.c:1742
++#: nscd/connections.c:1703
+ #, c-format
+ msgid "short read while reading request key: %s"
+ msgstr "fattas data vid läsning av begäransnyckel: %s"
+ 
+-#: nscd/connections.c:1752
++#: nscd/connections.c:1713
+ #, c-format
+ msgid "handle_request: request received (Version = %d) from PID %ld"
+ msgstr "handle_request: begäran mottagen (Version = %d) från PID %ld"
+ 
+-#: nscd/connections.c:1757
++#: nscd/connections.c:1718
+ #, c-format
+ msgid "handle_request: request received (Version = %d)"
+ msgstr "handle_request: begäran mottagen (Version = %d)"
+ 
+-#: nscd/connections.c:1897
++#: nscd/connections.c:1858
+ #, c-format
+ msgid "ignored inotify event for `%s` (file exists)"
+ msgstr "ignorerade inotify-händelse för ”%s” (filen finns)"
+ 
+-#: nscd/connections.c:1902
++#: nscd/connections.c:1863
+ #, c-format
+ msgid "monitored file `%s` was %s, removing watch"
+ msgstr "den övervakade filen ”%s” var %s, tar bort vakten"
+ 
+-#: nscd/connections.c:1910 nscd/connections.c:1952
++#: nscd/connections.c:1871 nscd/connections.c:1913
+ #, c-format
+ msgid "failed to remove file watch `%s`: %s"
+ msgstr "misslyckades att ta bort filvakt ”%s”: %s"
+ 
+-#: nscd/connections.c:1925
++#: nscd/connections.c:1886
+ #, c-format
+ msgid "monitored file `%s` was written to"
+ msgstr "den övervakade filen ”%s” skrevs till"
+ 
+-#: nscd/connections.c:1949
++#: nscd/connections.c:1910
+ #, c-format
+ msgid "monitored parent directory `%s` was %s, removing watch on `%s`"
+ msgstr "den övervakade föräldrakatalogen ”%s” var %s, tar bort vakten av ”%s”"
+ 
+-#: nscd/connections.c:1975
++#: nscd/connections.c:1936
+ #, c-format
+ msgid "monitored file `%s` was %s, adding watch"
+ msgstr "den övervakade filen ”%s” var %s, lägger till vakt"
+ 
+-#: nscd/connections.c:1987
++#: nscd/connections.c:1948
+ #, c-format
+ msgid "failed to add file watch `%s`: %s"
+ msgstr "misslyckades med att lägga till filvakt ”%s”: %s"
+ 
+-#: nscd/connections.c:2181 nscd/connections.c:2362
++#: nscd/connections.c:2126 nscd/connections.c:2291
+ #, c-format
+ msgid "disabled inotify-based monitoring after read error %d"
+ msgstr "avaktiverade inotify-baserad övervakning efter läsfel %d"
+ 
+-#: nscd/connections.c:2477
++#: nscd/connections.c:2406
+ msgid "could not initialize conditional variable"
+ msgstr "kan inte initiera villkorsvariabel"
+ 
+-#: nscd/connections.c:2485
++#: nscd/connections.c:2414
+ msgid "could not start clean-up thread; terminating"
+ msgstr "kunde inte starta städtråd; avslutar"
+ 
+-#: nscd/connections.c:2499
++#: nscd/connections.c:2428
+ msgid "could not start any worker thread; terminating"
+ msgstr "kunde inte starta någon arbetstråd; avslutar"
+ 
+-#: nscd/connections.c:2554 nscd/connections.c:2556 nscd/connections.c:2572
+-#: nscd/connections.c:2582 nscd/connections.c:2600 nscd/connections.c:2611
+-#: nscd/connections.c:2621
++#: nscd/connections.c:2483 nscd/connections.c:2485 nscd/connections.c:2501
++#: nscd/connections.c:2511 nscd/connections.c:2529 nscd/connections.c:2540
++#: nscd/connections.c:2550
+ #, c-format
+ msgid "Failed to run nscd as user '%s'"
+ msgstr "Misslyckades att köra nscd som användare \"%s\""
+ 
+-#: nscd/connections.c:2574
++#: nscd/connections.c:2503
+ msgid "initial getgrouplist failed"
+ msgstr "första getgrouplist misslyckades"
+ 
+-#: nscd/connections.c:2583
++#: nscd/connections.c:2512
+ msgid "getgrouplist failed"
+ msgstr "getgrouplist misslyckades"
+ 
+-#: nscd/connections.c:2601
++#: nscd/connections.c:2530
+ msgid "setgroups failed"
+ msgstr "setgroups misslyckades"
+ 
+@@ -4760,62 +4755,41 @@ msgstr "odefinierad"
+ msgid "Unrecognized variable `%s'"
+ msgstr "Okänd variabel \"%s\""
+ 
+-#: posix/getopt.c:592 posix/getopt.c:621
++#: posix/getopt.c:277
+ #, c-format
+-msgid "%s: option '%s' is ambiguous; possibilities:"
+-msgstr "%s: flaggan \"%s\" är tvetydig; alternativ:"
++msgid "%s: option '%s%s' is ambiguous\n"
++msgstr "%s: flaggan ”%s%s” är tvetydig\n"
+ 
+-#: posix/getopt.c:662 posix/getopt.c:666
++#: posix/getopt.c:283
+ #, c-format
+-msgid "%s: option '--%s' doesn't allow an argument\n"
+-msgstr "%s: flaggan \"--%s\" tar inget argument\n"
++msgid "%s: option '%s%s' is ambiguous; possibilities:"
++msgstr "%s: flaggan ”%s%s” är tvetydig; alternativ:"
+ 
+-#: posix/getopt.c:675 posix/getopt.c:680
++#: posix/getopt.c:318
+ #, c-format
+-msgid "%s: option '%c%s' doesn't allow an argument\n"
+-msgstr "%s: flaggan \"%c%s\" tar inget argument\n"
++msgid "%s: unrecognized option '%s%s'\n"
++msgstr "%s: okänd flagga ”%s%s”\n"
+ 
+-#: posix/getopt.c:723 posix/getopt.c:742
++#: posix/getopt.c:344
+ #, c-format
+-msgid "%s: option '--%s' requires an argument\n"
+-msgstr "%s: flaggan \"--%s\" kräver ett argument\n"
++msgid "%s: option '%s%s' doesn't allow an argument\n"
++msgstr "%s: flaggan ”%s%s” tar inget argument\n"
+ 
+-#: posix/getopt.c:780 posix/getopt.c:783
++#: posix/getopt.c:359
+ #, c-format
+-msgid "%s: unrecognized option '--%s'\n"
+-msgstr "%s: okänd flagga \"--%s\"\n"
++msgid "%s: option '%s%s' requires an argument\n"
++msgstr "%s: flaggan ”%s%s” kräver ett argument\n"
+ 
+-#: posix/getopt.c:791 posix/getopt.c:794
+-#, c-format
+-msgid "%s: unrecognized option '%c%s'\n"
+-msgstr "%s: okänd flagga \"%c%s\"\n"
+-
+-#: posix/getopt.c:843 posix/getopt.c:846
++#: posix/getopt.c:620
+ #, c-format
+ msgid "%s: invalid option -- '%c'\n"
+ msgstr "%s: ogiltig flagga -- \"%c\"\n"
+ 
+-#: posix/getopt.c:899 posix/getopt.c:916 posix/getopt.c:1126
+-#: posix/getopt.c:1144
++#: posix/getopt.c:635 posix/getopt.c:681
+ #, c-format
+ msgid "%s: option requires an argument -- '%c'\n"
+ msgstr "%s: flaggan kräver ett argument -- \"%c\"\n"
+ 
+-#: posix/getopt.c:972 posix/getopt.c:988
+-#, c-format
+-msgid "%s: option '-W %s' is ambiguous\n"
+-msgstr "%s: flaggan \"-W %s\" är tvetydig\n"
+-
+-#: posix/getopt.c:1012 posix/getopt.c:1030
+-#, c-format
+-msgid "%s: option '-W %s' doesn't allow an argument\n"
+-msgstr "%s: flaggan \"-W %s\" tar inget argument\n"
+-
+-#: posix/getopt.c:1051 posix/getopt.c:1069
+-#, c-format
+-msgid "%s: option '-W %s' requires an argument\n"
+-msgstr "%s: flaggan \"-W %s\" kräver ett argument\n"
+-
+ #: posix/regcomp.c:140
+ msgid "No match"
+ msgstr "Ingen träff"
+@@ -4884,7 +4858,7 @@ msgstr "Obalanserade ) eller \\)"
+ msgid "No previous regular expression"
+ msgstr "Inget föregående reguljärt uttryck"
+ 
+-#: posix/wordexp.c:1852
++#: posix/wordexp.c:1822
+ msgid "parameter null or not set"
+ msgstr "parameter är tom eller inte satt"
+ 
+@@ -5069,7 +5043,7 @@ msgstr "Buffertplats för utdata tillgängligt"
+ msgid "Input message available"
+ msgstr "Inkommande meddelande tillgängligt"
+ 
+-#: stdio-common/psiginfo-data.h:46 timezone/zdump.c:541 timezone/zic.c:483
++#: stdio-common/psiginfo-data.h:46 timezone/zdump.c:381 timezone/zic.c:520
+ msgid "I/O error"
+ msgstr "I/O-fel"
+ 
+@@ -5149,170 +5123,170 @@ msgstr "Realtidssignal %d"
+ msgid "Unknown signal %d"
+ msgstr "Okänd signal %d"
+ 
+-#: sunrpc/auth_unix.c:111 sunrpc/clnt_tcp.c:123 sunrpc/clnt_udp.c:135
+-#: sunrpc/clnt_unix.c:124 sunrpc/svc_tcp.c:188 sunrpc/svc_tcp.c:233
+-#: sunrpc/svc_udp.c:160 sunrpc/svc_unix.c:188 sunrpc/svc_unix.c:229
+-#: sunrpc/xdr.c:627 sunrpc/xdr.c:787 sunrpc/xdr_array.c:101
+-#: sunrpc/xdr_rec.c:152 sunrpc/xdr_ref.c:78
++#: sunrpc/auth_unix.c:112 sunrpc/clnt_tcp.c:124 sunrpc/clnt_udp.c:139
++#: sunrpc/clnt_unix.c:125 sunrpc/svc_tcp.c:189 sunrpc/svc_tcp.c:234
++#: sunrpc/svc_udp.c:161 sunrpc/svc_unix.c:189 sunrpc/svc_unix.c:230
++#: sunrpc/xdr.c:628 sunrpc/xdr.c:788 sunrpc/xdr_array.c:102
++#: sunrpc/xdr_rec.c:153 sunrpc/xdr_ref.c:79
+ msgid "out of memory\n"
+ msgstr "minnet slut\n"
+ 
+-#: sunrpc/auth_unix.c:349
++#: sunrpc/auth_unix.c:350
+ msgid "auth_unix.c: Fatal marshalling problem"
+ msgstr "auth_unix.c: Fatalt kodningsproblem"
+ 
+-#: sunrpc/clnt_perr.c:95 sunrpc/clnt_perr.c:111
++#: sunrpc/clnt_perr.c:96 sunrpc/clnt_perr.c:112
+ #, c-format
+ msgid "%s: %s; low version = %lu, high version = %lu"
+ msgstr "%s: %s; undre version = %lu, övre version = %lu"
+ 
+-#: sunrpc/clnt_perr.c:102
++#: sunrpc/clnt_perr.c:103
+ #, c-format
+ msgid "%s: %s; why = %s\n"
+ msgstr "%s: %s; varför = %s\n"
+ 
+-#: sunrpc/clnt_perr.c:104
++#: sunrpc/clnt_perr.c:105
+ #, c-format
+ msgid "%s: %s; why = (unknown authentication error - %d)\n"
+ msgstr "%s: %s; varför = (okänt fel vid äkthetskontroll - %d)\n"
+ 
+-#: sunrpc/clnt_perr.c:153
++#: sunrpc/clnt_perr.c:154
+ msgid "RPC: Success"
+ msgstr "RPC: Lyckat"
+ 
+-#: sunrpc/clnt_perr.c:156
++#: sunrpc/clnt_perr.c:157
+ msgid "RPC: Can't encode arguments"
+ msgstr "RPC: Kan inte koda argumentet"
+ 
+-#: sunrpc/clnt_perr.c:160
++#: sunrpc/clnt_perr.c:161
+ msgid "RPC: Can't decode result"
+ msgstr "RPC: Kan inte avkoda resultatet"
+ 
+-#: sunrpc/clnt_perr.c:164
++#: sunrpc/clnt_perr.c:165
+ msgid "RPC: Unable to send"
+ msgstr "RPC: Kan inte skicka"
+ 
+-#: sunrpc/clnt_perr.c:168
++#: sunrpc/clnt_perr.c:169
+ msgid "RPC: Unable to receive"
+ msgstr "RPC: Kan inte ta emot"
+ 
+-#: sunrpc/clnt_perr.c:172
++#: sunrpc/clnt_perr.c:173
+ msgid "RPC: Timed out"
+ msgstr "RPC: Tiden löpte ut"
+ 
+-#: sunrpc/clnt_perr.c:176
++#: sunrpc/clnt_perr.c:177
+ msgid "RPC: Incompatible versions of RPC"
+ msgstr "RPC: Inkompatibla versioner av RPC"
+ 
+-#: sunrpc/clnt_perr.c:180
++#: sunrpc/clnt_perr.c:181
+ msgid "RPC: Authentication error"
+ msgstr "RPC: Fel vid äkthetskontroll"
+ 
+-#: sunrpc/clnt_perr.c:184
++#: sunrpc/clnt_perr.c:185
+ msgid "RPC: Program unavailable"
+ msgstr "RPC: Programmet otillgängligt"
+ 
+-#: sunrpc/clnt_perr.c:188
++#: sunrpc/clnt_perr.c:189
+ msgid "RPC: Program/version mismatch"
+ msgstr "RPC: Program/version-inkompatibilitet"
+ 
+-#: sunrpc/clnt_perr.c:192
++#: sunrpc/clnt_perr.c:193
+ msgid "RPC: Procedure unavailable"
+ msgstr "RPC: Procedur inte tillgänglig"
+ 
+-#: sunrpc/clnt_perr.c:196
++#: sunrpc/clnt_perr.c:197
+ msgid "RPC: Server can't decode arguments"
+ msgstr "RPC: Server kan inte avkoda argumenten"
+ 
+-#: sunrpc/clnt_perr.c:200
++#: sunrpc/clnt_perr.c:201
+ msgid "RPC: Remote system error"
+ msgstr "RPC: Fjärrsystemsfel"
+ 
+-#: sunrpc/clnt_perr.c:204
++#: sunrpc/clnt_perr.c:205
+ msgid "RPC: Unknown host"
+ msgstr "RPC: Okänd värdmaskin"
+ 
+-#: sunrpc/clnt_perr.c:208
++#: sunrpc/clnt_perr.c:209
+ msgid "RPC: Unknown protocol"
+ msgstr "RPC: Okänt protokoll"
+ 
+-#: sunrpc/clnt_perr.c:212
++#: sunrpc/clnt_perr.c:213
+ msgid "RPC: Port mapper failure"
+ msgstr "RPC: Fel i portöversättare"
+ 
+-#: sunrpc/clnt_perr.c:216
++#: sunrpc/clnt_perr.c:217
+ msgid "RPC: Program not registered"
+ msgstr "RPC: Programmet inte registrerat"
+ 
+-#: sunrpc/clnt_perr.c:220
++#: sunrpc/clnt_perr.c:221
+ msgid "RPC: Failed (unspecified error)"
+ msgstr "RPC: Misslyckades (ospecificerat fel)"
+ 
+-#: sunrpc/clnt_perr.c:261
++#: sunrpc/clnt_perr.c:262
+ msgid "RPC: (unknown error code)"
+ msgstr "RPC: (okänd felkod)"
+ 
+-#: sunrpc/clnt_perr.c:333
++#: sunrpc/clnt_perr.c:334
+ msgid "Authentication OK"
+ msgstr "Äkthetskontroll OK"
+ 
+-#: sunrpc/clnt_perr.c:336
++#: sunrpc/clnt_perr.c:337
+ msgid "Invalid client credential"
+ msgstr "Ogiltiga klientreferenser"
+ 
+-#: sunrpc/clnt_perr.c:340
++#: sunrpc/clnt_perr.c:341
+ msgid "Server rejected credential"
+ msgstr "Server förkastade kreditiv"
+ 
+-#: sunrpc/clnt_perr.c:344
++#: sunrpc/clnt_perr.c:345
+ msgid "Invalid client verifier"
+ msgstr "Ogiltig klientverifierare"
+ 
+-#: sunrpc/clnt_perr.c:348
++#: sunrpc/clnt_perr.c:349
+ msgid "Server rejected verifier"
+ msgstr "Server förkastade verifierare"
+ 
+-#: sunrpc/clnt_perr.c:352
++#: sunrpc/clnt_perr.c:353
+ msgid "Client credential too weak"
+ msgstr "Klientens referenser är för svaga"
+ 
+-#: sunrpc/clnt_perr.c:356
++#: sunrpc/clnt_perr.c:357
+ msgid "Invalid server verifier"
+ msgstr "Ogiltig serververifierare"
+ 
+-#: sunrpc/clnt_perr.c:360
++#: sunrpc/clnt_perr.c:361
+ msgid "Failed (unspecified error)"
+ msgstr "Misslyckades (ospecificerat fel)"
+ 
+-#: sunrpc/clnt_raw.c:115
++#: sunrpc/clnt_raw.c:116
+ msgid "clnt_raw.c: fatal header serialization error"
+ msgstr "clnt_raw.c: fatalt fel vid serialisering"
+ 
+-#: sunrpc/pm_getmaps.c:77
++#: sunrpc/pm_getmaps.c:78
+ msgid "pmap_getmaps.c: rpc problem"
+ msgstr "pmap_getmaps.c rpc problem"
+ 
+-#: sunrpc/pmap_clnt.c:127
++#: sunrpc/pmap_clnt.c:128
+ msgid "Cannot register service"
+ msgstr "Kan inte registrera tjänst"
+ 
+-#: sunrpc/pmap_rmt.c:244
++#: sunrpc/pmap_rmt.c:245
+ msgid "Cannot create socket for broadcast rpc"
+ msgstr "Kan inte skapa uttag (socket) för utsändnings-rpc"
+ 
+-#: sunrpc/pmap_rmt.c:251
++#: sunrpc/pmap_rmt.c:252
+ msgid "Cannot set socket option SO_BROADCAST"
+ msgstr "Kan inte sätta uttagsflaggan (socket option) SO_BROADCAST"
+ 
+-#: sunrpc/pmap_rmt.c:303
++#: sunrpc/pmap_rmt.c:304
+ msgid "Cannot send broadcast packet"
+ msgstr "Kan inte skicka utsändningspaket"
+ 
+-#: sunrpc/pmap_rmt.c:328
++#: sunrpc/pmap_rmt.c:329
+ msgid "Broadcast poll problem"
+ msgstr "Problem med poll vid utsändning"
+ 
+-#: sunrpc/pmap_rmt.c:341
++#: sunrpc/pmap_rmt.c:342
+ msgid "Cannot receive reply to broadcast"
+ msgstr "Kan inte ta emot svar på utsändning"
+ 
+@@ -5595,11 +5569,11 @@ msgstr "tom teckensträng"
+ msgid "preprocessor error"
+ msgstr "preprocessorfel"
+ 
+-#: sunrpc/svc_run.c:71
++#: sunrpc/svc_run.c:72
+ msgid "svc_run: - out of memory"
+ msgstr "svc_run: - minnet slut"
+ 
+-#: sunrpc/svc_run.c:91
++#: sunrpc/svc_run.c:92
+ msgid "svc_run: - poll failed"
+ msgstr "svc_run: - poll misslyckades"
+ 
+@@ -5631,204 +5605,204 @@ msgstr "problem att svara till prog %d\n"
+ msgid "never registered prog %d\n"
+ msgstr "aldrig registrerat prog %d\n"
+ 
+-#: sunrpc/svc_tcp.c:164
++#: sunrpc/svc_tcp.c:165
+ msgid "svc_tcp.c - tcp socket creation problem"
+ msgstr "svc_tcp.c - problem att skapa tcp-uttag (socket)"
+ 
+-#: sunrpc/svc_tcp.c:179
++#: sunrpc/svc_tcp.c:180
+ msgid "svc_tcp.c - cannot getsockname or listen"
+ msgstr "svc_tcp.c - kan inte anropa getsockname eller listen"
+ 
+-#: sunrpc/svc_udp.c:135
++#: sunrpc/svc_udp.c:136
+ msgid "svcudp_create: socket creation problem"
+ msgstr "svcudp_create: problem att skapa uttag (socket)"
+ 
+-#: sunrpc/svc_udp.c:149
++#: sunrpc/svc_udp.c:150
+ msgid "svcudp_create - cannot getsockname"
+ msgstr "svcudp_create - kan inte anropa getsockname"
+ 
+-#: sunrpc/svc_udp.c:181
++#: sunrpc/svc_udp.c:182
+ msgid "svcudp_create: xp_pad is too small for IP_PKTINFO\n"
+ msgstr "svcudp_create: xp_pad är för liten för IP_PKTINFO\n"
+ 
+-#: sunrpc/svc_udp.c:480
++#: sunrpc/svc_udp.c:481
+ msgid "enablecache: cache already enabled"
+ msgstr "enablecache: cache redan påslagen"
+ 
+-#: sunrpc/svc_udp.c:486
++#: sunrpc/svc_udp.c:487
+ msgid "enablecache: could not allocate cache"
+ msgstr "enablecache: kunde inte allokera cache"
+ 
+-#: sunrpc/svc_udp.c:495
++#: sunrpc/svc_udp.c:496
+ msgid "enablecache: could not allocate cache data"
+ msgstr "enablecache: kunde inte allokera cache-data"
+ 
+-#: sunrpc/svc_udp.c:503
++#: sunrpc/svc_udp.c:504
+ msgid "enablecache: could not allocate cache fifo"
+ msgstr "enablecache: kunde inte allokera cache-fifo"
+ 
+-#: sunrpc/svc_udp.c:539
++#: sunrpc/svc_udp.c:540
+ msgid "cache_set: victim not found"
+ msgstr "cache_set: offer hittades inte"
+ 
+-#: sunrpc/svc_udp.c:550
++#: sunrpc/svc_udp.c:551
+ msgid "cache_set: victim alloc failed"
+ msgstr "cache_set: offerallokering misslyckades"
+ 
+-#: sunrpc/svc_udp.c:557
++#: sunrpc/svc_udp.c:558
+ msgid "cache_set: could not allocate new rpc_buffer"
+ msgstr "cache_set: kunde inte allokera ny rpc-buffert"
+ 
+-#: sunrpc/svc_unix.c:162
++#: sunrpc/svc_unix.c:163
+ msgid "svc_unix.c - AF_UNIX socket creation problem"
+ msgstr "svc_unix.c - problem att skapa AF_UNIX uttag (socket)"
+ 
+-#: sunrpc/svc_unix.c:178
++#: sunrpc/svc_unix.c:179
+ msgid "svc_unix.c - cannot getsockname or listen"
+ msgstr "svc_unix.c - kan inte anropa getsockname eller listen"
+ 
+-#: sysdeps/generic/siglist.h:28
++#: sysdeps/generic/siglist.h:29
+ msgid "Hangup"
+ msgstr "Avringd"
+ 
+-#: sysdeps/generic/siglist.h:29
++#: sysdeps/generic/siglist.h:30
+ msgid "Interrupt"
+ msgstr "Avbruten (SIGINT)"
+ 
+-#: sysdeps/generic/siglist.h:30
++#: sysdeps/generic/siglist.h:31
+ msgid "Quit"
+ msgstr "Lämnad"
+ 
+-#: sysdeps/generic/siglist.h:31
++#: sysdeps/generic/siglist.h:32
+ msgid "Illegal instruction"
+ msgstr "Otillåten instruktion"
+ 
+-#: sysdeps/generic/siglist.h:32
++#: sysdeps/generic/siglist.h:33
+ msgid "Trace/breakpoint trap"
+ msgstr "Spårningsfälla"
+ 
+-#: sysdeps/generic/siglist.h:33
++#: sysdeps/generic/siglist.h:34
+ msgid "Aborted"
+ msgstr "Avbruten (SIGABRT)"
+ 
+-#: sysdeps/generic/siglist.h:34
++#: sysdeps/generic/siglist.h:35
+ msgid "Floating point exception"
+ msgstr "Flyttalsfel"
+ 
+-#: sysdeps/generic/siglist.h:35
++#: sysdeps/generic/siglist.h:36
+ msgid "Killed"
+ msgstr "Dödad"
+ 
+-#: sysdeps/generic/siglist.h:36
++#: sysdeps/generic/siglist.h:37
+ msgid "Bus error"
+ msgstr "Bussfel"
+ 
+-#: sysdeps/generic/siglist.h:37
++#: sysdeps/generic/siglist.h:38
++msgid "Bad system call"
++msgstr "Felaktigt systemanrop"
++
++#: sysdeps/generic/siglist.h:39
+ msgid "Segmentation fault"
+ msgstr "Segmenteringsfel"
+ 
+-#. TRANS Broken pipe; there is no process reading from the other end of a pipe.
++#. TRANS There is no process reading from the other end of a pipe.
+ #. TRANS Every library function that returns this error code also generates a
+ #. TRANS @code{SIGPIPE} signal; this signal terminates the program if not handled
+ #. TRANS or blocked.  Thus, your program will never actually see @code{EPIPE}
+ #. TRANS unless it has handled or blocked @code{SIGPIPE}.
+-#: sysdeps/generic/siglist.h:38 sysdeps/gnu/errlist.c:360
++#: sysdeps/generic/siglist.h:40 sysdeps/gnu/errlist.c:360
+ msgid "Broken pipe"
+ msgstr "Brutet rör"
+ 
+-#: sysdeps/generic/siglist.h:39
++#: sysdeps/generic/siglist.h:41
+ msgid "Alarm clock"
+ msgstr "Alarmklocka"
+ 
+-#: sysdeps/generic/siglist.h:40
++#: sysdeps/generic/siglist.h:42
+ msgid "Terminated"
+ msgstr "Avslutad"
+ 
+-#: sysdeps/generic/siglist.h:41
++#: sysdeps/generic/siglist.h:43
+ msgid "Urgent I/O condition"
+ msgstr "Akut I/O-tillstånd"
+ 
+-#: sysdeps/generic/siglist.h:42
++#: sysdeps/generic/siglist.h:44
+ msgid "Stopped (signal)"
+ msgstr "Stoppad (signal)"
+ 
+-#: sysdeps/generic/siglist.h:43
++#: sysdeps/generic/siglist.h:45
+ msgid "Stopped"
+ msgstr "Stoppad"
+ 
+-#: sysdeps/generic/siglist.h:44
++#: sysdeps/generic/siglist.h:46
+ msgid "Continued"
+ msgstr "Återupptagen"
+ 
+-#: sysdeps/generic/siglist.h:45
++#: sysdeps/generic/siglist.h:47
+ msgid "Child exited"
+ msgstr "Barnprocess avslutad"
+ 
+-#: sysdeps/generic/siglist.h:46
++#: sysdeps/generic/siglist.h:48
+ msgid "Stopped (tty input)"
+ msgstr "Stoppad (terminalläsning)"
+ 
+-#: sysdeps/generic/siglist.h:47
++#: sysdeps/generic/siglist.h:49
+ msgid "Stopped (tty output)"
+ msgstr "Stoppad (terminalskrivning)"
+ 
+-#: sysdeps/generic/siglist.h:48
++#: sysdeps/generic/siglist.h:50
+ msgid "I/O possible"
+ msgstr "I/O möjligt"
+ 
+-#: sysdeps/generic/siglist.h:49
++#: sysdeps/generic/siglist.h:51
+ msgid "CPU time limit exceeded"
+ msgstr "Begränsning av CPU-tid överskriden"
+ 
+-#: sysdeps/generic/siglist.h:50
++#: sysdeps/generic/siglist.h:52
+ msgid "File size limit exceeded"
+ msgstr "Begränsning av filstorlek överskriden"
+ 
+-#: sysdeps/generic/siglist.h:51
++#: sysdeps/generic/siglist.h:53
+ msgid "Virtual timer expired"
+ msgstr "Alarmklocka - virtuell tid"
+ 
+-#: sysdeps/generic/siglist.h:52
++#: sysdeps/generic/siglist.h:54
+ msgid "Profiling timer expired"
+ msgstr "Profileringsklocka"
+ 
+-#: sysdeps/generic/siglist.h:53
++#: sysdeps/generic/siglist.h:55
+ msgid "User defined signal 1"
+ msgstr "Användarsignal 1"
+ 
+-#: sysdeps/generic/siglist.h:54
++#: sysdeps/generic/siglist.h:56
+ msgid "User defined signal 2"
+ msgstr "Användarsignal 2"
+ 
+-#: sysdeps/generic/siglist.h:58
+-msgid "EMT trap"
+-msgstr "Emulatorfälla"
++#: sysdeps/generic/siglist.h:57
++msgid "Window changed"
++msgstr "Ändrat fönster"
+ 
+ #: sysdeps/generic/siglist.h:61
+-msgid "Bad system call"
+-msgstr "Felaktigt systemanrop"
++msgid "EMT trap"
++msgstr "Emulatorfälla"
+ 
+ #: sysdeps/generic/siglist.h:64
+ msgid "Stack fault"
+ msgstr "Stackfel"
+ 
+ #: sysdeps/generic/siglist.h:67
+-msgid "Information request"
+-msgstr "Informationsbegäran"
+-
+-#: sysdeps/generic/siglist.h:69
+ msgid "Power failure"
+ msgstr "Strömavbrott"
+ 
+-#: sysdeps/generic/siglist.h:72
++#: sysdeps/generic/siglist.h:70
++msgid "Information request"
++msgstr "Informationsbegäran"
++
++#: sysdeps/generic/siglist.h:73
+ msgid "Resource lost"
+ msgstr "Förlorad resurs"
+ 
+-#: sysdeps/generic/siglist.h:75
+-msgid "Window changed"
+-msgstr "Ändrat fönster"
+-
+-#. TRANS Operation not permitted; only the owner of the file (or other resource)
++#. TRANS Only the owner of the file (or other resource)
+ #. TRANS or processes with special privileges can perform the operation.
+ #: sysdeps/gnu/errlist.c:26
+ msgid "Operation not permitted"
+@@ -5839,7 +5813,7 @@ msgstr "Operationen inte tillåten"
+ msgid "No such process"
+ msgstr "Processen finns inte"
+ 
+-#. TRANS Interrupted function call; an asynchronous signal occurred and prevented
++#. TRANS An asynchronous signal occurred and prevented
+ #. TRANS completion of the call.  When this happens, you should try the call
+ #. TRANS again.
+ #. TRANS
+@@ -5850,12 +5824,12 @@ msgstr "Processen finns inte"
+ msgid "Interrupted system call"
+ msgstr "Avbrutet systemanrop"
+ 
+-#. TRANS Input/output error; usually used for physical read or write errors.
++#. TRANS Usually used for physical read or write errors.
+ #: sysdeps/gnu/errlist.c:70
+ msgid "Input/output error"
+ msgstr "In/ut-fel"
+ 
+-#. TRANS No such device or address.  The system tried to use the device
++#. TRANS The system tried to use the device
+ #. TRANS represented by a file you specified, and it couldn't find the device.
+ #. TRANS This can mean that the device file was installed incorrectly, or that
+ #. TRANS the physical device is missing or not correctly attached to the
+@@ -5864,7 +5838,7 @@ msgstr "In/ut-fel"
+ msgid "No such device or address"
+ msgstr "Enheten eller adressen finns inte"
+ 
+-#. TRANS Argument list too long; used when the arguments passed to a new program
++#. TRANS Used when the arguments passed to a new program
+ #. TRANS being executed with one of the @code{exec} functions (@pxref{Executing a
+ #. TRANS File}) occupy too much memory space.  This condition never arises on
+ #. TRANS @gnuhurdsystems{}.
+@@ -5878,21 +5852,21 @@ msgstr "Argumentlistan för lång"
+ msgid "Exec format error"
+ msgstr "Formatfel på körbar fil"
+ 
+-#. TRANS Bad file descriptor; for example, I/O on a descriptor that has been
++#. TRANS For example, I/O on a descriptor that has been
+ #. TRANS closed or reading from a descriptor open only for writing (or vice
+ #. TRANS versa).
+ #: sysdeps/gnu/errlist.c:116
+ msgid "Bad file descriptor"
+ msgstr "Felaktig filidentifierare"
+ 
+-#. TRANS There are no child processes.  This error happens on operations that are
++#. TRANS This error happens on operations that are
+ #. TRANS supposed to manipulate child processes, when there aren't any processes
+ #. TRANS to manipulate.
+ #: sysdeps/gnu/errlist.c:127
+ msgid "No child processes"
+ msgstr "Inga barnprocesser"
+ 
+-#. TRANS Deadlock avoided; allocating a system resource would have resulted in a
++#. TRANS Allocating a system resource would have resulted in a
+ #. TRANS deadlock situation.  The system does not guarantee that it will notice
+ #. TRANS all such situations.  This error means you got lucky and the system
+ #. TRANS noticed; it might just hang.  @xref{File Locks}, for an example.
+@@ -5900,13 +5874,13 @@ msgstr "Inga barnprocesser"
+ msgid "Resource deadlock avoided"
+ msgstr "Resursdödläge undveks"
+ 
+-#. TRANS No memory available.  The system cannot allocate more virtual memory
++#. TRANS The system cannot allocate more virtual memory
+ #. TRANS because its capacity is full.
+ #: sysdeps/gnu/errlist.c:149
+ msgid "Cannot allocate memory"
+ msgstr "Kan inte allokera minne"
+ 
+-#. TRANS Bad address; an invalid pointer was detected.
++#. TRANS An invalid pointer was detected.
+ #. TRANS On @gnuhurdsystems{}, this error never happens; you get a signal instead.
+ #: sysdeps/gnu/errlist.c:168
+ msgid "Bad address"
+@@ -5919,14 +5893,14 @@ msgstr "Felaktig adress"
+ msgid "Block device required"
+ msgstr "Blockenhet krävs"
+ 
+-#. TRANS Resource busy; a system resource that can't be shared is already in use.
++#. TRANS A system resource that can't be shared is already in use.
+ #. TRANS For example, if you try to delete a file that is the root of a currently
+ #. TRANS mounted filesystem, you get this error.
+ #: sysdeps/gnu/errlist.c:190
+ msgid "Device or resource busy"
+ msgstr "Enhet eller resurs upptagen"
+ 
+-#. TRANS File exists; an existing file was specified in a context where it only
++#. TRANS An existing file was specified in a context where it only
+ #. TRANS makes sense to specify a new file.
+ #: sysdeps/gnu/errlist.c:200
+ msgid "File exists"
+@@ -5950,13 +5924,13 @@ msgstr "Enheten finns inte"
+ msgid "Not a directory"
+ msgstr "Inte en katalog"
+ 
+-#. TRANS File is a directory; you cannot open a directory for writing,
++#. TRANS You cannot open a directory for writing,
+ #. TRANS or create or remove hard links to it.
+ #: sysdeps/gnu/errlist.c:240
+ msgid "Is a directory"
+ msgstr "Är en katalog"
+ 
+-#. TRANS Invalid argument.  This is used to indicate various kinds of problems
++#. TRANS This is used to indicate various kinds of problems
+ #. TRANS with passing the wrong argument to a library function.
+ #: sysdeps/gnu/errlist.c:250
+ msgid "Invalid argument"
+@@ -5995,12 +5969,12 @@ msgstr "Olämplig ioctl för enheten"
+ msgid "Text file busy"
+ msgstr "Kodfil upptagen"
+ 
+-#. TRANS File too big; the size of a file would be larger than allowed by the system.
++#. TRANS The size of a file would be larger than allowed by the system.
+ #: sysdeps/gnu/errlist.c:308
+ msgid "File too large"
+ msgstr "För stor fil"
+ 
+-#. TRANS No space left on device; write operation on a file failed because the
++#. TRANS Write operation on a file failed because the
+ #. TRANS disk is full.
+ #: sysdeps/gnu/errlist.c:318
+ msgid "No space left on device"
+@@ -6016,26 +5990,26 @@ msgstr "Otillåten sökning"
+ msgid "Read-only file system"
+ msgstr "Skrivskyddat filsystem"
+ 
+-#. TRANS Too many links; the link count of a single file would become too large.
++#. TRANS The link count of a single file would become too large.
+ #. TRANS @code{rename} can cause this error if the file being renamed already has
+ #. TRANS as many links as it can take (@pxref{Renaming Files}).
+ #: sysdeps/gnu/errlist.c:347
+ msgid "Too many links"
+ msgstr "För många länkar"
+ 
+-#. TRANS Domain error; used by mathematical functions when an argument value does
++#. TRANS Used by mathematical functions when an argument value does
+ #. TRANS not fall into the domain over which the function is defined.
+ #: sysdeps/gnu/errlist.c:370
+ msgid "Numerical argument out of domain"
+ msgstr "Numeriskt argument är utanför området"
+ 
+-#. TRANS Range error; used by mathematical functions when the result value is
++#. TRANS Used by mathematical functions when the result value is
+ #. TRANS not representable because of overflow or underflow.
+ #: sysdeps/gnu/errlist.c:380
+ msgid "Numerical result out of range"
+ msgstr "Numeriskt resultat är utanför giltigt intervall"
+ 
+-#. TRANS Resource temporarily unavailable; the call might work if you try again
++#. TRANS The call might work if you try again
+ #. TRANS later.  The macro @code{EWOULDBLOCK} is another name for @code{EAGAIN};
+ #. TRANS they are always the same in @theglibc{}.
+ #. TRANS
+@@ -6223,76 +6197,75 @@ msgstr "Destinationsadress krävs"
+ msgid "Cannot send after transport endpoint shutdown"
+ msgstr "Kan inte skicka efter att transportslutpunkten stängts"
+ 
+-#. TRANS ???
+-#: sysdeps/gnu/errlist.c:677
++#: sysdeps/gnu/errlist.c:676
+ msgid "Too many references: cannot splice"
+ msgstr "För många referenser: kan inte skarva"
+ 
+ #. TRANS A socket operation with a specified timeout received no response during
+ #. TRANS the timeout period.
+-#: sysdeps/gnu/errlist.c:687
++#: sysdeps/gnu/errlist.c:686
+ msgid "Connection timed out"
+ msgstr "Förbindelsens tidsgräns löpte ut"
+ 
+ #. TRANS A remote host refused to allow the network connection (typically because
+ #. TRANS it is not running the requested service).
+-#: sysdeps/gnu/errlist.c:697
++#: sysdeps/gnu/errlist.c:696
+ msgid "Connection refused"
+ msgstr "Förbindelsen förvägrad"
+ 
+ #. TRANS Too many levels of symbolic links were encountered in looking up a file name.
+ #. TRANS This often indicates a cycle of symbolic links.
+-#: sysdeps/gnu/errlist.c:707
++#: sysdeps/gnu/errlist.c:706
+ msgid "Too many levels of symbolic links"
+ msgstr "För många nivåer av symboliska länkar"
+ 
+ #. TRANS Filename too long (longer than @code{PATH_MAX}; @pxref{Limits for
+ #. TRANS Files}) or host name too long (in @code{gethostname} or
+ #. TRANS @code{sethostname}; @pxref{Host Identification}).
+-#: sysdeps/gnu/errlist.c:718
++#: sysdeps/gnu/errlist.c:717
+ msgid "File name too long"
+ msgstr "För långt filnamn"
+ 
+ #. TRANS The remote host for a requested network connection is down.
+-#: sysdeps/gnu/errlist.c:727
++#: sysdeps/gnu/errlist.c:726
+ msgid "Host is down"
+ msgstr "Värddator är nere"
+ 
+ #. TRANS The remote host for a requested network connection is not reachable.
+-#: sysdeps/gnu/errlist.c:736
++#: sysdeps/gnu/errlist.c:735
+ msgid "No route to host"
+ msgstr "Ingen väg till värd"
+ 
+ #. TRANS Directory not empty, where an empty directory was expected.  Typically,
+ #. TRANS this error occurs when you are trying to delete a directory.
+-#: sysdeps/gnu/errlist.c:746
++#: sysdeps/gnu/errlist.c:745
+ msgid "Directory not empty"
+ msgstr "Katalog inte tom"
+ 
+ #. TRANS This means that the per-user limit on new process would be exceeded by
+ #. TRANS an attempted @code{fork}.  @xref{Limits on Resources}, for details on
+ #. TRANS the @code{RLIMIT_NPROC} limit.
+-#: sysdeps/gnu/errlist.c:757
++#: sysdeps/gnu/errlist.c:756
+ msgid "Too many processes"
+ msgstr "För många processer"
+ 
+ #. TRANS The file quota system is confused because there are too many users.
+ #. TRANS @c This can probably happen in a GNU system when using NFS.
+-#: sysdeps/gnu/errlist.c:767
++#: sysdeps/gnu/errlist.c:766
+ msgid "Too many users"
+ msgstr "För många användare"
+ 
+ #. TRANS The user's disk quota was exceeded.
+-#: sysdeps/gnu/errlist.c:776
++#: sysdeps/gnu/errlist.c:775
+ msgid "Disk quota exceeded"
+ msgstr "Diskkvot överskriden"
+ 
+-#. TRANS Stale file handle.  This indicates an internal confusion in the
++#. TRANS This indicates an internal confusion in the
+ #. TRANS file system which is due to file system rearrangements on the server host
+ #. TRANS for NFS file systems or corruption in other file systems.
+ #. TRANS Repairing this condition usually requires unmounting, possibly repairing
+ #. TRANS and remounting the file system.
+-#: sysdeps/gnu/errlist.c:789
++#: sysdeps/gnu/errlist.c:788
+ msgid "Stale file handle"
+ msgstr "Förlegat filhandtag"
+ 
+@@ -6300,72 +6273,65 @@ msgstr "Förlegat filhandtag"
+ #. TRANS already specifies an NFS-mounted file.
+ #. TRANS (This is an error on some operating systems, but we expect it to work
+ #. TRANS properly on @gnuhurdsystems{}, making this error code impossible.)
+-#: sysdeps/gnu/errlist.c:801
++#: sysdeps/gnu/errlist.c:800
+ msgid "Object is remote"
+ msgstr "Är ett fjärrobjekt"
+ 
+-#. TRANS ???
+-#: sysdeps/gnu/errlist.c:810
++#: sysdeps/gnu/errlist.c:808
+ msgid "RPC struct is bad"
+ msgstr "RPC-strukturen är felaktig"
+ 
+-#. TRANS ???
+-#: sysdeps/gnu/errlist.c:819
++#: sysdeps/gnu/errlist.c:816
+ msgid "RPC version wrong"
+ msgstr "RPC-versionen är felaktig"
+ 
+-#. TRANS ???
+-#: sysdeps/gnu/errlist.c:828
++#: sysdeps/gnu/errlist.c:824
+ msgid "RPC program not available"
+ msgstr "RPC-programmet inte tillgängligt"
+ 
+-#. TRANS ???
+-#: sysdeps/gnu/errlist.c:837
++#: sysdeps/gnu/errlist.c:832
+ msgid "RPC program version wrong"
+ msgstr "RPC-programversionen är felaktig"
+ 
+-#. TRANS ???
+-#: sysdeps/gnu/errlist.c:846
++#: sysdeps/gnu/errlist.c:840
+ msgid "RPC bad procedure for program"
+ msgstr "Felaktig RPC-procedur för programmet"
+ 
+-#. TRANS No locks available.  This is used by the file locking facilities; see
++#. TRANS This is used by the file locking facilities; see
+ #. TRANS @ref{File Locks}.  This error is never generated by @gnuhurdsystems{}, but
+ #. TRANS it can result from an operation to an NFS server running another
+ #. TRANS operating system.
+-#: sysdeps/gnu/errlist.c:858
++#: sysdeps/gnu/errlist.c:852
+ msgid "No locks available"
+ msgstr "Inga lås tillgängliga"
+ 
+-#. TRANS Inappropriate file type or format.  The file was the wrong type for the
++#. TRANS The file was the wrong type for the
+ #. TRANS operation, or a data file had the wrong format.
+ #. TRANS
+ #. TRANS On some systems @code{chmod} returns this error if you try to set the
+ #. TRANS sticky bit on a non-directory file; @pxref{Setting Permissions}.
+-#: sysdeps/gnu/errlist.c:871
++#: sysdeps/gnu/errlist.c:865
+ msgid "Inappropriate file type or format"
+ msgstr "Filtyp eller format olämplig"
+ 
+-#. TRANS ???
+-#: sysdeps/gnu/errlist.c:880
++#: sysdeps/gnu/errlist.c:873
+ msgid "Authentication error"
+ msgstr "Autentiseringsfel"
+ 
+-#. TRANS ???
+-#: sysdeps/gnu/errlist.c:889
++#: sysdeps/gnu/errlist.c:881
+ msgid "Need authenticator"
+ msgstr "Behöver autentiserare"
+ 
+-#. TRANS Function not implemented.  This indicates that the function called is
++#. TRANS This indicates that the function called is
+ #. TRANS not implemented at all, either in the C library itself or in the
+ #. TRANS operating system.  When you get this error, you can be sure that this
+ #. TRANS particular function will always fail with @code{ENOSYS} unless you
+ #. TRANS install a new version of the C library or the operating system.
+-#: sysdeps/gnu/errlist.c:902
++#: sysdeps/gnu/errlist.c:894
+ msgid "Function not implemented"
+ msgstr "Funktion inte implementerad"
+ 
+-#. TRANS Not supported.  A function returns this error when certain parameter
++#. TRANS A function returns this error when certain parameter
+ #. TRANS values are valid, but the functionality they request is not available.
+ #. TRANS This can mean that the function does not implement a particular command
+ #. TRANS or option value or flag bit at all.  For functions that operate on some
+@@ -6377,13 +6343,13 @@ msgstr "Funktion inte implementerad"
+ #. TRANS
+ #. TRANS If the entire function is not available at all in the implementation,
+ #. TRANS it returns @code{ENOSYS} instead.
+-#: sysdeps/gnu/errlist.c:922
++#: sysdeps/gnu/errlist.c:914
+ msgid "Not supported"
+ msgstr "Stöds ej"
+ 
+ #. TRANS While decoding a multibyte character the function came along an invalid
+ #. TRANS or an incomplete sequence of bytes or the given wide character is invalid.
+-#: sysdeps/gnu/errlist.c:932
++#: sysdeps/gnu/errlist.c:924
+ msgid "Invalid or incomplete multibyte or wide character"
+ msgstr "Ogiltigt eller ofullständigt flerbyte- eller brett tecken"
+ 
+@@ -6393,276 +6359,276 @@ msgstr "Ogiltigt eller ofullständigt flerbyte- eller brett tecken"
+ #. TRANS error because functions such as @code{read} and @code{write} translate
+ #. TRANS it into a @code{SIGTTIN} or @code{SIGTTOU} signal.  @xref{Job Control},
+ #. TRANS for information on process groups and these signals.
+-#: sysdeps/gnu/errlist.c:946
++#: sysdeps/gnu/errlist.c:938
+ msgid "Inappropriate operation for background process"
+ msgstr "Operation för bakgrundsprocess olämplig"
+ 
+ #. TRANS On @gnuhurdsystems{}, opening a file returns this error when the file is
+ #. TRANS translated by a program and the translator program dies while starting
+ #. TRANS up, before it has connected to the file.
+-#: sysdeps/gnu/errlist.c:957
++#: sysdeps/gnu/errlist.c:949
+ msgid "Translator died"
+ msgstr "Översättaren dog"
+ 
+ #. TRANS The experienced user will know what is wrong.
+ #. TRANS @c This error code is a joke.  Its perror text is part of the joke.
+ #. TRANS @c Don't change it.
+-#: sysdeps/gnu/errlist.c:968
++#: sysdeps/gnu/errlist.c:960
+ msgid "?"
+ msgstr "?"
+ 
+ #. TRANS You did @strong{what}?
+-#: sysdeps/gnu/errlist.c:977
++#: sysdeps/gnu/errlist.c:969
+ msgid "You really blew it this time"
+ msgstr "Du strulade till det den här gången"
+ 
+ #. TRANS Go home and have a glass of warm, dairy-fresh milk.
+-#: sysdeps/gnu/errlist.c:986
++#: sysdeps/gnu/errlist.c:978
+ msgid "Computer bought the farm"
+ msgstr "Datorn packade ihop"
+ 
+ #. TRANS This error code has no purpose.
+-#: sysdeps/gnu/errlist.c:995
++#: sysdeps/gnu/errlist.c:987
+ msgid "Gratuitous error"
+ msgstr "Omotiverat fel"
+ 
+-#: sysdeps/gnu/errlist.c:1003
++#: sysdeps/gnu/errlist.c:995
+ msgid "Bad message"
+ msgstr "Felaktigt meddelande"
+ 
+-#: sysdeps/gnu/errlist.c:1011
++#: sysdeps/gnu/errlist.c:1003
+ msgid "Identifier removed"
+ msgstr "Identifierare borttagen"
+ 
+-#: sysdeps/gnu/errlist.c:1019
++#: sysdeps/gnu/errlist.c:1011
+ msgid "Multihop attempted"
+ msgstr "Flerhopp försöktes"
+ 
+-#: sysdeps/gnu/errlist.c:1027
++#: sysdeps/gnu/errlist.c:1019
+ msgid "No data available"
+ msgstr "Inga data tillgängliga"
+ 
+-#: sysdeps/gnu/errlist.c:1035
++#: sysdeps/gnu/errlist.c:1027
+ msgid "Link has been severed"
+ msgstr "Länken har brutits"
+ 
+-#: sysdeps/gnu/errlist.c:1043
++#: sysdeps/gnu/errlist.c:1035
+ msgid "No message of desired type"
+ msgstr "Inget meddelande av önskad typ"
+ 
+-#: sysdeps/gnu/errlist.c:1051
++#: sysdeps/gnu/errlist.c:1043
+ msgid "Out of streams resources"
+ msgstr "Stream-resurserna är slut"
+ 
+-#: sysdeps/gnu/errlist.c:1059
++#: sysdeps/gnu/errlist.c:1051
+ msgid "Device not a stream"
+ msgstr "Enheten är inte en stream"
+ 
+-#: sysdeps/gnu/errlist.c:1067
++#: sysdeps/gnu/errlist.c:1059
+ msgid "Value too large for defined data type"
+ msgstr "Värdet för stort för definierad datatyp"
+ 
+-#: sysdeps/gnu/errlist.c:1075
++#: sysdeps/gnu/errlist.c:1067
+ msgid "Protocol error"
+ msgstr "Protokollfel"
+ 
+-#: sysdeps/gnu/errlist.c:1083
++#: sysdeps/gnu/errlist.c:1075
+ msgid "Timer expired"
+ msgstr "Klockan ringde"
+ 
+-#. TRANS Operation canceled; an asynchronous operation was canceled before it
++#. TRANS An asynchronous operation was canceled before it
+ #. TRANS completed.  @xref{Asynchronous I/O}.  When you call @code{aio_cancel},
+ #. TRANS the normal result is for the operations affected to complete with this
+ #. TRANS error; @pxref{Cancel AIO Operations}.
+-#: sysdeps/gnu/errlist.c:1095
++#: sysdeps/gnu/errlist.c:1087
+ msgid "Operation canceled"
+ msgstr "Operationen avbruten"
+ 
+-#: sysdeps/gnu/errlist.c:1103
++#: sysdeps/gnu/errlist.c:1095
+ msgid "Interrupted system call should be restarted"
+ msgstr "Avbrutet systemanrop borde omstartas"
+ 
+-#: sysdeps/gnu/errlist.c:1111
++#: sysdeps/gnu/errlist.c:1103
+ msgid "Channel number out of range"
+ msgstr "Kanalnummer utanför giltigt intervall"
+ 
+-#: sysdeps/gnu/errlist.c:1119
++#: sysdeps/gnu/errlist.c:1111
+ msgid "Level 2 not synchronized"
+ msgstr "Nivå 2 inte synkroniserad"
+ 
+-#: sysdeps/gnu/errlist.c:1127
++#: sysdeps/gnu/errlist.c:1119
+ msgid "Level 3 halted"
+ msgstr "Nivå 3 stannad"
+ 
+-#: sysdeps/gnu/errlist.c:1135
++#: sysdeps/gnu/errlist.c:1127
+ msgid "Level 3 reset"
+ msgstr "Nivå 3 omstartad"
+ 
+-#: sysdeps/gnu/errlist.c:1143
++#: sysdeps/gnu/errlist.c:1135
+ msgid "Link number out of range"
+ msgstr "Länkantal utanför giltigt intervall"
+ 
+-#: sysdeps/gnu/errlist.c:1151
++#: sysdeps/gnu/errlist.c:1143
+ msgid "Protocol driver not attached"
+ msgstr "Styrprogram för protokoll inte anslutet"
+ 
+-#: sysdeps/gnu/errlist.c:1159
++#: sysdeps/gnu/errlist.c:1151
+ msgid "No CSI structure available"
+ msgstr "Inga CSI-strukturer tillgängliga"
+ 
+-#: sysdeps/gnu/errlist.c:1167
++#: sysdeps/gnu/errlist.c:1159
+ msgid "Level 2 halted"
+ msgstr "Nivå 2 stannad"
+ 
+-#: sysdeps/gnu/errlist.c:1175
++#: sysdeps/gnu/errlist.c:1167
+ msgid "Invalid exchange"
+ msgstr "Ogiltig växel"
+ 
+-#: sysdeps/gnu/errlist.c:1183
++#: sysdeps/gnu/errlist.c:1175
+ msgid "Invalid request descriptor"
+-msgstr "Ogiltig begärandeidendiferare"
++msgstr "Ogiltig begärandeidentifierare"
+ 
+-#: sysdeps/gnu/errlist.c:1191
++#: sysdeps/gnu/errlist.c:1183
+ msgid "Exchange full"
+ msgstr "Växeln full"
+ 
+-#: sysdeps/gnu/errlist.c:1199
++#: sysdeps/gnu/errlist.c:1191
+ msgid "No anode"
+ msgstr "Ingen anod"
+ 
+-#: sysdeps/gnu/errlist.c:1207
++#: sysdeps/gnu/errlist.c:1199
+ msgid "Invalid request code"
+ msgstr "Ogiltig begärandekod"
+ 
+-#: sysdeps/gnu/errlist.c:1215
++#: sysdeps/gnu/errlist.c:1207
+ msgid "Invalid slot"
+ msgstr "Ogiltig plats"
+ 
+-#: sysdeps/gnu/errlist.c:1223
++#: sysdeps/gnu/errlist.c:1215
+ msgid "File locking deadlock error"
+ msgstr "Fillåsning gav dödläge"
+ 
+-#: sysdeps/gnu/errlist.c:1231
++#: sysdeps/gnu/errlist.c:1223
+ msgid "Bad font file format"
+ msgstr "Felaktigt format på typsnittsfil"
+ 
+-#: sysdeps/gnu/errlist.c:1239
++#: sysdeps/gnu/errlist.c:1231
+ msgid "Machine is not on the network"
+ msgstr "Maskinen finns inte på nätverket"
+ 
+-#: sysdeps/gnu/errlist.c:1247
++#: sysdeps/gnu/errlist.c:1239
+ msgid "Package not installed"
+ msgstr "Paketet är inte installerat"
+ 
+-#: sysdeps/gnu/errlist.c:1255
++#: sysdeps/gnu/errlist.c:1247
+ msgid "Advertise error"
+ msgstr "Annonseringsfel"
+ 
+-#: sysdeps/gnu/errlist.c:1263
++#: sysdeps/gnu/errlist.c:1255
+ msgid "Srmount error"
+ msgstr "Srmount-fel"
+ 
+-#: sysdeps/gnu/errlist.c:1271
++#: sysdeps/gnu/errlist.c:1263
+ msgid "Communication error on send"
+ msgstr "Kommunikationsfel vid sändning"
+ 
+-#: sysdeps/gnu/errlist.c:1279
++#: sysdeps/gnu/errlist.c:1271
+ msgid "RFS specific error"
+ msgstr "RFS-specifikt fel"
+ 
+-#: sysdeps/gnu/errlist.c:1287
++#: sysdeps/gnu/errlist.c:1279
+ msgid "Name not unique on network"
+ msgstr "Namnet inte unikt i nätverket"
+ 
+-#: sysdeps/gnu/errlist.c:1295
++#: sysdeps/gnu/errlist.c:1287
+ msgid "File descriptor in bad state"
+ msgstr "Filidentifierare i felaktigt tillstånd"
+ 
+-#: sysdeps/gnu/errlist.c:1303
++#: sysdeps/gnu/errlist.c:1295
+ msgid "Remote address changed"
+ msgstr "Fjärradress ändrades"
+ 
+-#: sysdeps/gnu/errlist.c:1311
++#: sysdeps/gnu/errlist.c:1303
+ msgid "Can not access a needed shared library"
+ msgstr "Kan inte komma åt ett nödvändigt delat bibliotek"
+ 
+-#: sysdeps/gnu/errlist.c:1319
++#: sysdeps/gnu/errlist.c:1311
+ msgid "Accessing a corrupted shared library"
+ msgstr "Öppnar ett korrupt delat bibliotek"
+ 
+-#: sysdeps/gnu/errlist.c:1327
++#: sysdeps/gnu/errlist.c:1319
+ msgid ".lib section in a.out corrupted"
+ msgstr ".lib-sektion i a.out korrupt"
+ 
+-#: sysdeps/gnu/errlist.c:1335
++#: sysdeps/gnu/errlist.c:1327
+ msgid "Attempting to link in too many shared libraries"
+ msgstr "Försöker att länka in för många delade bibliotek"
+ 
+-#: sysdeps/gnu/errlist.c:1343
++#: sysdeps/gnu/errlist.c:1335
+ msgid "Cannot exec a shared library directly"
+ msgstr "Kan inte köra ett delat bibliotek direkt"
+ 
+-#: sysdeps/gnu/errlist.c:1351
++#: sysdeps/gnu/errlist.c:1343
+ msgid "Streams pipe error"
+ msgstr "Streams-rörfel"
+ 
+-#: sysdeps/gnu/errlist.c:1359
++#: sysdeps/gnu/errlist.c:1351
+ msgid "Structure needs cleaning"
+ msgstr "Strukturen behöver städas"
+ 
+-#: sysdeps/gnu/errlist.c:1367
++#: sysdeps/gnu/errlist.c:1359
+ msgid "Not a XENIX named type file"
+ msgstr "Inte en XENIX-namngiven fil"
+ 
+-#: sysdeps/gnu/errlist.c:1375
++#: sysdeps/gnu/errlist.c:1367
+ msgid "No XENIX semaphores available"
+ msgstr "Inga XENIX-semaforer tillgängliga"
+ 
+-#: sysdeps/gnu/errlist.c:1383
++#: sysdeps/gnu/errlist.c:1375
+ msgid "Is a named type file"
+ msgstr "Är av typ namnfil"
+ 
+-#: sysdeps/gnu/errlist.c:1391
++#: sysdeps/gnu/errlist.c:1383
+ msgid "Remote I/O error"
+ msgstr "I/O-fel på fjärrmaskin"
+ 
+-#: sysdeps/gnu/errlist.c:1399
++#: sysdeps/gnu/errlist.c:1391
+ msgid "No medium found"
+ msgstr "Inget medium funnet"
+ 
+-#: sysdeps/gnu/errlist.c:1407
++#: sysdeps/gnu/errlist.c:1399
+ msgid "Wrong medium type"
+ msgstr "Fel medietyp"
+ 
+-#: sysdeps/gnu/errlist.c:1415
++#: sysdeps/gnu/errlist.c:1407
+ msgid "Required key not available"
+ msgstr "Obligatorisk nyckel inte tillgänglig"
+ 
+-#: sysdeps/gnu/errlist.c:1423
++#: sysdeps/gnu/errlist.c:1415
+ msgid "Key has expired"
+ msgstr "Nyckeln har gått ut"
+ 
+-#: sysdeps/gnu/errlist.c:1431
++#: sysdeps/gnu/errlist.c:1423
+ msgid "Key has been revoked"
+ msgstr "Nyckeln har återkallats"
+ 
+-#: sysdeps/gnu/errlist.c:1439
++#: sysdeps/gnu/errlist.c:1431
+ msgid "Key was rejected by service"
+ msgstr "Nyckeln accepterades inte av tjänsten"
+ 
+-#: sysdeps/gnu/errlist.c:1447
++#: sysdeps/gnu/errlist.c:1439
+ msgid "Owner died"
+ msgstr "Ägaren dog"
+ 
+-#: sysdeps/gnu/errlist.c:1455
++#: sysdeps/gnu/errlist.c:1447
+ msgid "State not recoverable"
+ msgstr "Det går inte att återhämta från tillståndet"
+ 
+-#: sysdeps/gnu/errlist.c:1463
++#: sysdeps/gnu/errlist.c:1455
+ msgid "Operation not possible due to RF-kill"
+ msgstr "Operationen inte möjlig p.g.a. RF-kill"
+ 
+-#: sysdeps/gnu/errlist.c:1471
++#: sysdeps/gnu/errlist.c:1463
+ msgid "Memory page has hardware error"
+ msgstr "Minnessida har hårdvarufel"
+ 
+@@ -6767,73 +6733,90 @@ msgstr "kan inte öppna \"%s\""
+ msgid "cannot read header from `%s'"
+ msgstr "kan inte läsa huvud från \"%s\""
+ 
+-#: timezone/zdump.c:494
++#: timezone/zdump.c:338
+ msgid "has fewer than 3 characters"
+ msgstr "har färre än 3 tecken"
+ 
+-#: timezone/zdump.c:496
++#: timezone/zdump.c:340
+ msgid "has more than 6 characters"
+ msgstr "har fler än 6 tecken"
+ 
+-#: timezone/zdump.c:498
++#: timezone/zdump.c:342
+ msgid "has characters other than ASCII alphanumerics, '-' or '+'"
+ msgstr "har andra tecken än ASCII alfanumeriska, ”-” eller ”+”"
+ 
+-#: timezone/zdump.c:503
++#: timezone/zdump.c:347
+ #, c-format
+ msgid "%s: warning: zone \"%s\" abbreviation \"%s\" %s\n"
+ msgstr "%s: varning: zon \"%s\" förkortning \"%s\": %s\n"
+ 
+-#: timezone/zdump.c:553
++#: timezone/zdump.c:393
+ #, c-format
+ msgid ""
+-"%s: usage: %s [--version] [--help] [-{vV}] [-{ct} [lo,]hi] zonename ...\n"
++"%s: usage: %s OPTIONS ZONENAME ...\n"
++"Options include:\n"
++"  -c [L,]U   Start at year L (default -500), end before year U (default 2500)\n"
++"  -t [L,]U   Start at time L, end before time U (in seconds since 1970)\n"
++"  -i         List transitions briefly (format is experimental)\n"
++"  -v         List transitions verbosely\n"
++"  -V         List transitions a bit less verbosely\n"
++"  --help     Output this help\n"
++"  --version  Output version info\n"
+ "\n"
+ "Report bugs to %s.\n"
+ msgstr ""
+-"%s: användning: %s [ --version ] [ --help ] [ -{vV} ] [ -{ct} [start,]slut] zonnamn ...\n"
++"%s: användning: %s FLAGGOR ZONNAMN …\n"
++"Flaggorna inkluderar:\n"
++"  -c [L,]Ö   Starta vid år L (standard -500), och sluta före år Ö (standard 2500)\n"
++"  -t [L,]Ö   Starta vid tid L, och sluta före tid Ö (i sekunder sedan 1970)\n"
++"  -i         Lista övergångar kort (formatet är experimentellt)\n"
++"  -v         Lista övergångar utförligt\n"
++"  -V         Lista övergångar lite mindre utförligt\n"
++"  --help     Skriv ut denna hjälp\n"
++"  --version  Skriv ut versionsinformation\n"
++"\n"
+ "Rapportera fel till %s.\n"
+ "Rapportera fel eller synpunkter på översättningen till <tp-sv@listor.tp-sv.se>.\n"
+ 
+-#: timezone/zdump.c:635
++#: timezone/zdump.c:479
+ #, c-format
+ msgid "%s: wild -c argument %s\n"
+ msgstr "%s: argument \"%s\" till flaggan -c har fel format\n"
+ 
+-#: timezone/zdump.c:668
++#: timezone/zdump.c:512
+ #, c-format
+ msgid "%s: wild -t argument %s\n"
+ msgstr "%s: argument \"%s\" till flaggan -t har fel format\n"
+ 
+-#: timezone/zic.c:361
++#: timezone/zic.c:398
+ #, c-format
+ msgid "%s: Memory exhausted: %s\n"
+ msgstr "%s: Minnet slut: %s\n"
+ 
+-#: timezone/zic.c:369
++#: timezone/zic.c:406
+ msgid "size overflow"
+ msgstr "för stor storlek"
+ 
+-#: timezone/zic.c:416
+-msgid "int overflow"
+-msgstr "för stort heltal"
++#: timezone/zic.c:454
++msgid "integer overflow"
++msgstr "heltalsspill"
+ 
+-#: timezone/zic.c:451
++#: timezone/zic.c:488
+ #, c-format
+-msgid "\"%s\", line %d: "
+-msgstr "\"%s\", rad %d: "
++msgid "\"%s\", line %<PRIdMAX>: "
++msgstr "”%s”, rad %<PRIdMAX>: "
+ 
+-#: timezone/zic.c:454
++#: timezone/zic.c:491
+ #, c-format
+-msgid " (rule from \"%s\", line %d)"
+-msgstr " (regel från \"%s\", rad %d)"
++msgid " (rule from \"%s\", line %<PRIdMAX>)"
++msgstr " (regel från ”%s”, rad %<PRIdMAX>)"
+ 
+-#: timezone/zic.c:473
++#: timezone/zic.c:510
+ #, c-format
+ msgid "warning: "
+ msgstr "varning: "
+ 
+-#: timezone/zic.c:498
++#: timezone/zic.c:535
+ #, c-format
+ msgid ""
+ "%s: usage is %s [ --version ] [ --help ] [ -v ] \\\n"
+@@ -6849,361 +6832,382 @@ msgstr ""
+ "Rapportera fel till %s.\n"
+ "Rapportera fel eller synpunkter på översättningen till <tp-sv@listor.tp-sv.se>.\n"
+ 
+-#: timezone/zic.c:534
++#: timezone/zic.c:558
++#, c-format
++msgid "%s: Can't chdir to %s: %s\n"
++msgstr "%s: Kan inte byta katalog till %s: %s\n"
++
++#: timezone/zic.c:590
+ msgid "wild compilation-time specification of zic_t"
+ msgstr "definitionen av zic_t vid kompilering är orimlig"
+ 
+-#: timezone/zic.c:554
++#: timezone/zic.c:610
+ #, c-format
+ msgid "%s: More than one -d option specified\n"
+ msgstr "%s: Flaggan -d given mer än en gång\n"
+ 
+-#: timezone/zic.c:564
++#: timezone/zic.c:620
+ #, c-format
+ msgid "%s: More than one -l option specified\n"
+ msgstr "%s: Flaggan -l given mer än en gång\n"
+ 
+-#: timezone/zic.c:574
++#: timezone/zic.c:630
+ #, c-format
+ msgid "%s: More than one -p option specified\n"
+ msgstr "%s: Flaggan -p given mer än en gång\n"
+ 
+-#: timezone/zic.c:584
++#: timezone/zic.c:640
+ #, c-format
+ msgid "%s: More than one -y option specified\n"
+ msgstr "%s: Flaggan -y given mer än en gång\n"
+ 
+-#: timezone/zic.c:594
++#: timezone/zic.c:650
+ #, c-format
+ msgid "%s: More than one -L option specified\n"
+ msgstr "%s: Flaggan -L given mer än en gång\n"
+ 
+-#: timezone/zic.c:603
++#: timezone/zic.c:659
+ msgid "-s ignored"
+ msgstr "-s ignoreras"
+ 
+-#: timezone/zic.c:641
++#: timezone/zic.c:698
+ msgid "link to link"
+ msgstr "länk till länk"
+ 
+-#: timezone/zic.c:644 timezone/zic.c:648
++#: timezone/zic.c:701 timezone/zic.c:705
+ msgid "command line"
+ msgstr "kommandorad"
+ 
+-#: timezone/zic.c:664
++#: timezone/zic.c:721
+ msgid "empty file name"
+ msgstr "tomt filnamn"
+ 
+-#: timezone/zic.c:667
++#: timezone/zic.c:724
+ #, c-format
+ msgid "file name '%s' begins with '/'"
+ msgstr "filnamnet ”%s” börjar med ”/”"
+ 
+-#: timezone/zic.c:676
++#: timezone/zic.c:734
+ #, c-format
+ msgid "file name '%s' contains '%.*s' component"
+ msgstr "filnamnet ”%s” innehåller en komponent ”%.*s”"
+ 
+-#: timezone/zic.c:682
++#: timezone/zic.c:740
+ #, c-format
+ msgid "file name '%s' component contains leading '-'"
+ msgstr "en komponent i filnamnet ”%s” innehåller en inledande ”-”"
+ 
+-#: timezone/zic.c:685
++#: timezone/zic.c:743
+ #, c-format
+ msgid "file name '%s' contains overlength component '%.*s...'"
+ msgstr "filnamnet ”%s” innehåller en för lång komponent ”%.*s…”"
+ 
+-#: timezone/zic.c:713
++#: timezone/zic.c:771
+ #, c-format
+ msgid "file name '%s' contains byte '%c'"
+ msgstr "filnamnet ”%s” innehåller en byte ”%c”"
+ 
+-#: timezone/zic.c:714
++#: timezone/zic.c:772
+ #, c-format
+ msgid "file name '%s' contains byte '\\%o'"
+ msgstr "filnamnet ”%s” innehåller en byte ”\\%o”"
+ 
+-#: timezone/zic.c:757
++#: timezone/zic.c:842
++#, c-format
++msgid "%s: link from %s/%s failed: %s\n"
++msgstr "%s: länk från %s/%s misslyckades: %s\n"
++
++#: timezone/zic.c:852 timezone/zic.c:1815
++#, c-format
++msgid "%s: Can't remove %s/%s: %s\n"
++msgstr "%s: Kan inte ta bort %s/%s: %s\n"
++
++#: timezone/zic.c:874
+ #, c-format
+-msgid "%s: link from %s failed: %s"
+-msgstr "%s: länk från %s misslyckades: %s"
++msgid "symbolic link used because hard link failed: %s"
++msgstr "symbolisk länk använd eftersom en hård länk misslyckades: %s"
+ 
+-#: timezone/zic.c:792
+-msgid "hard link failed, symbolic link used"
+-msgstr "hård länk misslyckades, använder symbolisk länk"
++#: timezone/zic.c:882
++#, c-format
++msgid "%s: Can't read %s/%s: %s\n"
++msgstr "%s: Kan inte läsa %s/%s: %s\n"
+ 
+-#: timezone/zic.c:802
++#: timezone/zic.c:889 timezone/zic.c:1828
+ #, c-format
+-msgid "%s: Can't read %s: %s\n"
+-msgstr "%s: Kan inte läsa %s: %s\n"
++msgid "%s: Can't create %s/%s: %s\n"
++msgstr "%s: Kan inte skapa %s/%s: %s\n"
+ 
+-#: timezone/zic.c:810 timezone/zic.c:1701
++#: timezone/zic.c:898
+ #, c-format
+-msgid "%s: Can't create %s: %s\n"
+-msgstr "%s: Kan inte skapa %s: %s\n"
++msgid "copy used because hard link failed: %s"
++msgstr "kopiering använd eftersom en hård länk misslyckades: %s"
+ 
+-#: timezone/zic.c:818
+-msgid "link failed, copy used"
+-msgstr "länka misslyckades, kopia skapad"
++#: timezone/zic.c:901
++#, c-format
++msgid "copy used because symbolic link failed: %s"
++msgstr "kopiering använd eftersom en symbolisk länk misslyckades: %s"
+ 
+-#: timezone/zic.c:913 timezone/zic.c:915
++#: timezone/zic.c:1013 timezone/zic.c:1015
+ msgid "same rule name in multiple files"
+ msgstr "samma regelnamn i flera filer"
+ 
+-#: timezone/zic.c:956
++#: timezone/zic.c:1056
+ msgid "unruly zone"
+ msgstr "besvärlig zon"
+ 
+-#: timezone/zic.c:963
++#: timezone/zic.c:1063
+ #, c-format
+ msgid "%s in ruleless zone"
+ msgstr "%s i zon utan regler"
+ 
+-#: timezone/zic.c:983
++#: timezone/zic.c:1083
+ msgid "standard input"
+ msgstr "standard in"
+ 
+-#: timezone/zic.c:988
++#: timezone/zic.c:1088
+ #, c-format
+ msgid "%s: Can't open %s: %s\n"
+ msgstr "%s: Kan inte öppna %s: %s\n"
+ 
+-#: timezone/zic.c:999
++#: timezone/zic.c:1099
+ msgid "line too long"
+ msgstr "för lång rad"
+ 
+-#: timezone/zic.c:1019
++#: timezone/zic.c:1119
+ msgid "input line of unknown type"
+ msgstr "inrad av okänd typ"
+ 
+-#: timezone/zic.c:1034
++#: timezone/zic.c:1134
+ #, c-format
+ msgid "%s: Leap line in non leap seconds file %s"
+ msgstr "%s: \"Leap\"-rad i fil %s som inte är skottsekundsfil"
+ 
+-#: timezone/zic.c:1042 timezone/zic.c:1447 timezone/zic.c:1469
++#: timezone/zic.c:1142 timezone/zic.c:1547 timezone/zic.c:1569
+ #, c-format
+ msgid "%s: panic: Invalid l_value %d\n"
+ msgstr "%s: panik: Ogiltigt l_value %d\n"
+ 
+-#: timezone/zic.c:1051
++#: timezone/zic.c:1151
+ msgid "expected continuation line not found"
+ msgstr "förväntad fortsättningsrad inte funnen"
+ 
+-#: timezone/zic.c:1093 timezone/zic.c:2826
++#: timezone/zic.c:1193 timezone/zic.c:2976
+ msgid "time overflow"
+ msgstr "för stort tidsvärde"
+ 
+-#: timezone/zic.c:1098
++#: timezone/zic.c:1198
+ msgid "values over 24 hours not handled by pre-2007 versions of zic"
+ msgstr "värden större än 24 timmar hanteras inte av zic-versioner före 2007"
+ 
+-#: timezone/zic.c:1109
++#: timezone/zic.c:1209
+ msgid "wrong number of fields on Rule line"
+ msgstr "fel antal fält på \"Rule\"-rad"
+ 
+-#: timezone/zic.c:1113
++#: timezone/zic.c:1213
+ msgid "nameless rule"
+ msgstr "namnlös regel"
+ 
+-#: timezone/zic.c:1118
++#: timezone/zic.c:1218
+ msgid "invalid saved time"
+ msgstr "ogiltig sparad tid"
+ 
+-#: timezone/zic.c:1135
++#: timezone/zic.c:1235
+ msgid "wrong number of fields on Zone line"
+ msgstr "fel antal fält på \"Zone\"-rad"
+ 
+-#: timezone/zic.c:1140
++#: timezone/zic.c:1240
+ #, c-format
+ msgid "\"Zone %s\" line and -l option are mutually exclusive"
+ msgstr "\"Zone %s\"-rad och flaggan -l är ömsesidigt uteslutande"
+ 
+-#: timezone/zic.c:1146
++#: timezone/zic.c:1246
+ #, c-format
+ msgid "\"Zone %s\" line and -p option are mutually exclusive"
+ msgstr "\"Zone %s\"-rad och flaggan -p är ömsesidigt uteslutande"
+ 
+-#: timezone/zic.c:1154
++#: timezone/zic.c:1253
+ #, c-format
+-msgid "duplicate zone name %s (file \"%s\", line %d)"
+-msgstr "dubblerat zonnamn %s (fil \"%s\", rad %d)"
++msgid "duplicate zone name %s (file \"%s\", line %<PRIdMAX>)"
++msgstr "dubblerat zonnamn %s (filen ”%s”, rad %<PRIdMAX>)"
+ 
+-#: timezone/zic.c:1167
++#: timezone/zic.c:1267
+ msgid "wrong number of fields on Zone continuation line"
+ msgstr "fel antal fält på \"Zone\"-fortsättningsrad"
+ 
+-#: timezone/zic.c:1207
++#: timezone/zic.c:1307
+ msgid "invalid UT offset"
+ msgstr "ogiltigt UT-tillägg"
+ 
+-#: timezone/zic.c:1211
++#: timezone/zic.c:1311
+ msgid "invalid abbreviation format"
+ msgstr "ogiltigt förkortningsformat"
+ 
+-#: timezone/zic.c:1220
++#: timezone/zic.c:1320
+ #, c-format
+ msgid "format '%s' not handled by pre-2015 versions of zic"
+ msgstr "formatet ”%s” hanteras inte av versioner av zic före 2015"
+ 
+-#: timezone/zic.c:1247
++#: timezone/zic.c:1347
+ msgid "Zone continuation line end time is not after end time of previous line"
+ msgstr "Zon-fortsättningsradens sluttid är inte efter sluttiden på föregående rad"
+ 
+-#: timezone/zic.c:1274
++#: timezone/zic.c:1374
+ msgid "wrong number of fields on Leap line"
+ msgstr "fel antal fält på \"Leap\"-rad"
+ 
+-#: timezone/zic.c:1283
++#: timezone/zic.c:1383
+ msgid "invalid leaping year"
+ msgstr "ogiltigt skottår"
+ 
+-#: timezone/zic.c:1303 timezone/zic.c:1401
++#: timezone/zic.c:1403 timezone/zic.c:1501
+ msgid "invalid month name"
+ msgstr "ogiltigt månadsnamn"
+ 
+-#: timezone/zic.c:1316 timezone/zic.c:1514 timezone/zic.c:1528
++#: timezone/zic.c:1416 timezone/zic.c:1614 timezone/zic.c:1628
+ msgid "invalid day of month"
+ msgstr "ogiltig dag i månaden"
+ 
+-#: timezone/zic.c:1321
++#: timezone/zic.c:1421
+ msgid "time too small"
+ msgstr "tid för kort"
+ 
+-#: timezone/zic.c:1325
++#: timezone/zic.c:1425
+ msgid "time too large"
+ msgstr "tid för lång"
+ 
+-#: timezone/zic.c:1329 timezone/zic.c:1430
++#: timezone/zic.c:1429 timezone/zic.c:1530
+ msgid "invalid time of day"
+ msgstr "ogiltig tid på dagen"
+ 
+-#: timezone/zic.c:1348
++#: timezone/zic.c:1448
+ msgid "illegal CORRECTION field on Leap line"
+ msgstr "otillåtet \"CORRECTION\"-fält på \"Leap\"-rad"
+ 
+-#: timezone/zic.c:1353
++#: timezone/zic.c:1453
+ msgid "illegal Rolling/Stationary field on Leap line"
+ msgstr "otillåtet \"Rolling/Stationary\"-fält på \"Leap\"-rad"
+ 
+-#: timezone/zic.c:1359
++#: timezone/zic.c:1459
+ msgid "leap second precedes Big Bang"
+ msgstr "skottsekund föregår Big Bang"
+ 
+-#: timezone/zic.c:1372
++#: timezone/zic.c:1472
+ msgid "wrong number of fields on Link line"
+ msgstr "fel antal fält på \"Link\"-rad"
+ 
+-#: timezone/zic.c:1376
++#: timezone/zic.c:1476
+ msgid "blank FROM field on Link line"
+ msgstr "tomt \"FROM\"-fält på \"Link\"-rad"
+ 
+-#: timezone/zic.c:1451
++#: timezone/zic.c:1551
+ msgid "invalid starting year"
+ msgstr "ogiltigt startår"
+ 
+-#: timezone/zic.c:1473
++#: timezone/zic.c:1573
+ msgid "invalid ending year"
+ msgstr "ogiltigt slutår"
+ 
+-#: timezone/zic.c:1477
++#: timezone/zic.c:1577
+ msgid "starting year greater than ending year"
+ msgstr "startår är större än slutår"
+ 
+-#: timezone/zic.c:1484
++#: timezone/zic.c:1584
+ msgid "typed single year"
+ msgstr "satte typ på endast ett år"
+ 
+-#: timezone/zic.c:1519
++#: timezone/zic.c:1619
+ msgid "invalid weekday name"
+ msgstr "ogiltigt veckodagsnamn"
+ 
+-#: timezone/zic.c:1638
++#: timezone/zic.c:1743
++#, c-format
++msgid "reference clients mishandle more than %d transition times"
++msgstr "referensklienter hanterar fler än %d övergångstider felaktigt"
++
++#: timezone/zic.c:1747
+ msgid "pre-2014 clients may mishandle more than 1200 transition times"
+ msgstr "klienter från före 2014 kan hantera fler än 1200 övergångstider felaktigt"
+ 
+-#: timezone/zic.c:1691
+-#, c-format
+-msgid "%s: Can't remove %s: %s\n"
+-msgstr "%s: Kan inte ta bort %s: %s\n"
++#: timezone/zic.c:1858
++msgid "too many transition times"
++msgstr "för många övergångstider"
+ 
+-#: timezone/zic.c:1918
++#: timezone/zic.c:2047
+ #, c-format
+ msgid "%%z UTC offset magnitude exceeds 99:59:59"
+ msgstr "%%z storleken på avståndet från UTC överstiger 99.59.59"
+ 
+-#: timezone/zic.c:2291
++#: timezone/zic.c:2424
+ msgid "no POSIX environment variable for zone"
+ msgstr "ingen POSIX-miljövariabel för zon"
+ 
+-#: timezone/zic.c:2297
++#: timezone/zic.c:2430
+ #, c-format
+ msgid "%s: pre-%d clients may mishandle distant timestamps"
+ msgstr "%s: klienter före %d kan hantera avlägsna tidsstämplar felaktigt"
+ 
+-#: timezone/zic.c:2428
++#: timezone/zic.c:2566
+ msgid "two rules for same instant"
+ msgstr "två regler för samma tillfälle"
+ 
+-#: timezone/zic.c:2485
++#: timezone/zic.c:2627
+ msgid "can't determine time zone abbreviation to use just after until time"
+ msgstr "kan inte avgöra tidszonsförkortning att använda just efter \"until\"-tid"
+ 
+-#: timezone/zic.c:2531 timezone/zic.c:2593
++#: timezone/zic.c:2725
+ msgid "too many local time types"
+ msgstr "för många lokala tidstyper"
+ 
+-#: timezone/zic.c:2597
++#: timezone/zic.c:2729
+ msgid "UT offset out of range"
+ msgstr "UT-offset utanför giltigt intervall"
+ 
+-#: timezone/zic.c:2621
++#: timezone/zic.c:2753
+ msgid "too many leap seconds"
+ msgstr "för många skottsekunder"
+ 
+-#: timezone/zic.c:2627
++#: timezone/zic.c:2759
+ msgid "repeated leap second moment"
+ msgstr "upprepat skottsekundstillfälle"
+ 
+-#: timezone/zic.c:2677
++#: timezone/zic.c:2830
+ msgid "Wild result from command execution"
+ msgstr "Vilt resultat från kommandokörning"
+ 
+-#: timezone/zic.c:2678
++#: timezone/zic.c:2831
+ #, c-format
+ msgid "%s: command was '%s', result was %d\n"
+ msgstr "%s: kommandot var \"%s\", resultatet blev %d\n"
+ 
+-#: timezone/zic.c:2810
++#: timezone/zic.c:2961
+ msgid "Odd number of quotation marks"
+ msgstr "Ojämnt antal citationstecken"
+ 
+-#: timezone/zic.c:2896
++#: timezone/zic.c:3046
+ msgid "use of 2/29 in non leap-year"
+ msgstr "använder 29/2 i icke-skottår"
+ 
+-#: timezone/zic.c:2931
++#: timezone/zic.c:3081
+ msgid "rule goes past start/end of month; will not work with pre-2004 versions of zic"
+ msgstr "regeln går utanför start/slut på månad; fungerar inte med versioner av zic före 2004"
+ 
+-#: timezone/zic.c:2958
++#: timezone/zic.c:3108
+ msgid "time zone abbreviation has fewer than 3 characters"
+ msgstr "tidszonsförkortning har färre än 3 tecken"
+ 
+-#: timezone/zic.c:2960
++#: timezone/zic.c:3110
+ msgid "time zone abbreviation has too many characters"
+ msgstr "tidszonsförkortning har för många tecken"
+ 
+-#: timezone/zic.c:2962
++#: timezone/zic.c:3112
+ msgid "time zone abbreviation differs from POSIX standard"
+ msgstr "tidszonsförkortning skiljer sig från POSIX-standarden"
+ 
+-#: timezone/zic.c:2968
++#: timezone/zic.c:3118
+ msgid "too many, or too long, time zone abbreviations"
+ msgstr "för många eller för långa tidszonsförkortningar"
+ 
+-#: timezone/zic.c:3004
++#: timezone/zic.c:3161
+ #, c-format
+ msgid "%s: Can't create directory %s: %s"
+ msgstr "%s: Kan inte skapa katalog %s: %s"
diff --git a/gnu/packages/patches/glibc-2-26-0052.patch b/gnu/packages/patches/glibc-2-26-0052.patch
new file mode 100644
index 000000000..9437b9bf7
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0052.patch
@@ -0,0 +1,406 @@
+From 290ba1089ecdca306cb2a0fbf3c7dc9cc29bc56f Mon Sep 17 00:00:00 2001
+From: Siddhesh Poyarekar <siddhesh@sourceware.org>
+Date: Thu, 5 Oct 2017 21:55:31 +0530
+Subject: [PATCH 52/90] aarch64: Optimized implementation of memmove for
+ Qualcomm Falkor
+
+This is an optimized memmove implementation for the Qualcomm Falkor
+processor core.  Due to the way the falkor memcpy needs to be written,
+code cannot be easily shared between memmove and memcpy like in case
+of other aarch64 memcpy implementations due to which this routine is
+separate.  The underlying principle is the same as that of memcpy
+where it tries to use registers with the same lower 4 bits for
+fetching the same stream, thus optimizing hardware prefetcher
+performance.
+
+The memcpy copy loop copies 64 bytes at a time using the same register
+pair since that's the way to train the hardware prefetcher on the
+falkor core.  memmove cannot quite do that since it needs to avoid
+overlaps, so it does the next best thing, i.e. has a 32 byte loop with
+a 32 byte end (prefetch a loop ahead to account for overlapping
+locations) with register pairs that alias so that they hit the same
+prefetcher.  Due to this difference in loop size, they have to
+currently be separate implementations but efforts are on to try and
+get memmove to fall back into memcpy whenever it can without simply
+duplicating all of the code.
+
+Performance:
+
+The routine fares around 20-25% better than the generic memmove for
+most medium to large sizes (i.e. > 128 bytes) for the new walking
+memmove benchmark (memmove-walk) with an unexplained regression
+between 1K and 2K.  The minor regression is something worth looking
+into for us, but the remaining gains are significant enough that we
+would like this included upstream as we looking into the cause for the
+regression.  Here is a snippet of the numbers as generated from the
+microbenchmark by the compare_strings script.  Comparisons are against
+__memmove_generic:
+
+Function: memmove
+Variant: walk
+                                    __memmove_thunderx	__memmove_falkor	__memmove_generic
+========================================================================================================================
+<snip>
+                        length=16384:  12508800.00 (  6.09%)	 11486800.00 ( 13.76%)	 13319600.00
+                        length=16400:  13614200.00 ( -0.67%)	 11585000.00 ( 14.33%)	 13523600.00
+                        length=16385:  13448400.00 (  0.10%)	 11732700.00 ( 12.84%)	 13461200.00
+                        length=16399:  13594100.00 ( -0.22%)	 11859600.00 ( 12.57%)	 13564400.00
+                        length=16386:  13211600.00 (  1.13%)	 11503800.00 ( 13.91%)	 13362400.00
+                        length=16398:  13218600.00 (  2.12%)	 11573200.00 ( 14.30%)	 13504700.00
+                        length=16387:  13510900.00 ( -0.37%)	 11744200.00 ( 12.76%)	 13461300.00
+                        length=16397:  13603700.00 ( -0.15%)	 11878200.00 ( 12.55%)	 13583200.00
+                        length=16388:  13461700.00 ( -0.13%)	 11558000.00 ( 14.03%)	 13444100.00
+                        length=16396:  13517500.00 ( -0.03%)	 11561300.00 ( 14.45%)	 13513900.00
+                        length=16389:  13534100.00 (  0.17%)	 11756800.00 ( 13.28%)	 13556900.00
+                        length=16395:  13585600.00 (  0.11%)	 11791800.00 ( 13.30%)	 13601200.00
+                        length=16390:  13480100.00 ( -0.13%)	 11685500.00 ( 13.20%)	 13462100.00
+                        length=16394:  13529900.00 ( -0.23%)	 11549800.00 ( 14.43%)	 13498200.00
+                        length=16391:  13595400.00 ( -0.26%)	 11768200.00 ( 13.22%)	 13560600.00
+                        length=16393:  13567000.00 (  0.20%)	 11779700.00 ( 13.35%)	 13594700.00
+                        length=32768:  71308800.00 ( -6.53%)	 50220800.00 ( 24.98%)	 66939200.00
+                        length=32784:  72100800.00 (-11.55%)	 50114100.00 ( 22.47%)	 64636300.00
+                        length=32769:  71767000.00 ( -7.10%)	 51238400.00 ( 23.54%)	 67010000.00
+                        length=32783:  70113700.00 (-40.95%)	 51129000.00 ( -2.78%)	 49744400.00
+                        length=32770:  71367600.00 ( -6.52%)	 50244700.00 ( 25.01%)	 67000900.00
+                        length=32782:  64366700.00 (  4.71%)	 50101400.00 ( 25.83%)	 67545600.00
+                        length=32771:  71440100.00 ( -6.51%)	 51263900.00 ( 23.57%)	 67074900.00
+                        length=32781:  66993000.00 (  0.34%)	 51108300.00 ( 23.97%)	 67220300.00
+                        length=32772:  71443900.00 (-60.50%)	 50062100.00 (-12.47%)	 44512600.00
+                        length=32780:  71759100.00 ( -6.58%)	 50263200.00 ( 25.35%)	 67328600.00
+                        length=32773:  71714900.00 (-33.21%)	 51076600.00 (  5.12%)	 53835400.00
+                        length=32779:  71756900.00 ( -6.56%)	 51290800.00 ( 23.83%)	 67337800.00
+                        length=32774:  59689300.00 (-34.55%)	 50068400.00 (-12.86%)	 44363300.00
+                        length=32778:  71847500.00 (-18.20%)	 50084100.00 ( 17.61%)	 60786500.00
+                        length=32775:  71599300.00 ( -6.54%)	 51278200.00 ( 23.70%)	 67204800.00
+                        length=32777:  71862900.00 (-60.85%)	 51094000.00 (-14.36%)	 44677900.00
+                        length=65536: 282848000.00 ( -6.60%)	199187000.00 ( 24.93%)	265325000.00
+                        length=65552: 243285000.00 (-41.61%)	198512000.00 (-15.54%)	171805000.00
+                        length=65537: 255415000.00 (-23.47%)	202499000.00 (  2.11%)	206858000.00
+                        length=65551: 280122000.00 (-62.95%)	203349000.00 (-18.29%)	171911000.00
+                        length=65538: 283676000.00 (-14.46%)	198368000.00 ( 19.96%)	247848000.00
+                        length=65550: 275566000.00 (-51.76%)	198494000.00 ( -9.31%)	181581000.00
+                        length=65539: 283699000.00 ( -6.58%)	203453000.00 ( 23.57%)	266195000.00
+                        length=65549: 286572000.00 ( -6.65%)	202607000.00 ( 24.60%)	268712000.00
+                        length=65540: 283710000.00 ( -6.59%)	199161000.00 ( 25.17%)	266160000.00
+                        length=65548: 237573000.00 ( 11.48%)	198462000.00 ( 26.06%)	268395000.00
+                        length=65541: 284150000.00 ( -6.58%)	203273000.00 ( 23.75%)	266600000.00
+                        length=65547: 286250000.00 ( -6.70%)	202594000.00 ( 24.48%)	268263000.00
+                        length=65542: 284167000.00 ( -6.60%)	199122000.00 ( 25.31%)	266584000.00
+                        length=65546: 285656000.00 ( -6.59%)	198443000.00 ( 25.95%)	268002000.00
+                        length=65543: 284600000.00 ( -6.58%)	203247000.00 ( 23.89%)	267030000.00
+                        length=65545: 285665000.00 ( -6.40%)	202575000.00 ( 24.55%)	268472000.00
+<snip>
+
+	* sysdeps/aarch64/multiarch/Makefile (sysdep_routines): Add
+	memmove_falkor.
+	* sysdeps/aarch64/multiarch/ifunc-impl-list.c
+	(__libc_ifunc_impl_list): Likewise.
+	* sysdeps/aarch64/multiarch/memmove.c: Likewise.
+	* sysdeps/aarch64/multiarch/memmove_falkor.S: New file.
+
+diff --git a/ChangeLog b/ChangeLog
+index 2aa1711834..d478f5d8e4 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,5 +1,21 @@
+ 2017-10-10  Siddhesh Poyarekar  <siddhesh@sourceware.org>
+ 
++	* sysdeps/aarch64/multiarch/Makefile (sysdep_routines): Add
++	memmove_falkor.
++	* sysdeps/aarch64/multiarch/ifunc-impl-list.c
++	(__libc_ifunc_impl_list): Likewise.
++	* sysdeps/aarch64/multiarch/memmove.c: Likewise.
++	* sysdeps/aarch64/multiarch/memmove_falkor.S: New file.
++
++	* benchtests/bench-memmove-walk.c: New file.
++	* benchtests/Makefile (string-benchset): Add it.
++
++	* benchtests/bench-memset-walk.c: New file.
++	* benchtests/Makefile (string-benchset): Add it.
++
++	* benchtests/bench-memcpy-walk.c: New file.
++	* benchtests/Makefile (string-benchset): Add it.
++
+ 	* po/sv.po: Update translations.
+ 	* po/fr.po: Likewise.
+ 
+diff --git a/sysdeps/aarch64/multiarch/Makefile b/sysdeps/aarch64/multiarch/Makefile
+index 164ba1ae4b..9aa1e79a80 100644
+--- a/sysdeps/aarch64/multiarch/Makefile
++++ b/sysdeps/aarch64/multiarch/Makefile
+@@ -1,3 +1,4 @@
+ ifeq ($(subdir),string)
+-sysdep_routines += memcpy_generic memcpy_thunderx memcpy_falkor
++sysdep_routines += memcpy_generic memcpy_thunderx memcpy_falkor \
++		   memmove_falkor
+ endif
+diff --git a/sysdeps/aarch64/multiarch/ifunc-impl-list.c b/sysdeps/aarch64/multiarch/ifunc-impl-list.c
+index 8e873b3d9f..2cb74d5b43 100644
+--- a/sysdeps/aarch64/multiarch/ifunc-impl-list.c
++++ b/sysdeps/aarch64/multiarch/ifunc-impl-list.c
+@@ -44,6 +44,7 @@ __libc_ifunc_impl_list (const char *name, struct libc_ifunc_impl *array,
+ 	      IFUNC_IMPL_ADD (array, i, memcpy, 1, __memcpy_generic))
+   IFUNC_IMPL (i, name, memmove,
+ 	      IFUNC_IMPL_ADD (array, i, memmove, 1, __memmove_thunderx)
++	      IFUNC_IMPL_ADD (array, i, memmove, 1, __memmove_falkor)
+ 	      IFUNC_IMPL_ADD (array, i, memmove, 1, __memmove_generic))
+ 
+   return i;
+diff --git a/sysdeps/aarch64/multiarch/memmove.c b/sysdeps/aarch64/multiarch/memmove.c
+index 34c6b29bd5..016f03ee50 100644
+--- a/sysdeps/aarch64/multiarch/memmove.c
++++ b/sysdeps/aarch64/multiarch/memmove.c
+@@ -30,9 +30,14 @@ extern __typeof (__redirect_memmove) __libc_memmove;
+ 
+ extern __typeof (__redirect_memmove) __memmove_generic attribute_hidden;
+ extern __typeof (__redirect_memmove) __memmove_thunderx attribute_hidden;
++extern __typeof (__redirect_memmove) __memmove_falkor attribute_hidden;
+ 
+ libc_ifunc (__libc_memmove,
+-            IS_THUNDERX (midr) ? __memmove_thunderx : __memmove_generic);
++            (IS_THUNDERX (midr)
++	     ? __memmove_thunderx
++	     : (IS_FALKOR (midr)
++		? __memmove_falkor
++		: __memmove_generic)));
+ 
+ # undef memmove
+ strong_alias (__libc_memmove, memmove);
+diff --git a/sysdeps/aarch64/multiarch/memmove_falkor.S b/sysdeps/aarch64/multiarch/memmove_falkor.S
+new file mode 100644
+index 0000000000..3a4e6a2a8e
+--- /dev/null
++++ b/sysdeps/aarch64/multiarch/memmove_falkor.S
+@@ -0,0 +1,232 @@
++/* Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#include <sysdep.h>
++
++/* Assumptions: ARMv8-a, AArch64, falkor, unaligned accesses.  */
++
++#define dstin	x0
++#define src	x1
++#define count	x2
++#define dstlen	x3
++#define dst	x3
++#define srcend	x4
++#define dstend	x5
++#define A_l	x6
++#define A_lw	w6
++#define A_h	x7
++#define A_hw	w7
++#define B_l	x8
++#define B_lw	w8
++#define B_h	x9
++#define C_l	x10
++#define C_h	x11
++#define D_l	x12
++#define D_h	x13
++#define E_l	src
++#define E_h	count
++#define F_l	srcend
++#define F_h	dst
++#define tmp1	x14
++
++/* Alias with A_l and A_h to train the prefetcher.  */
++#define Q_l	x22
++#define Q_h	x23
++
++/* RATIONALE:
++
++   The copy has 4 distinct parts:
++   * Small copies of 16 bytes and under
++   * Medium sized copies of 17-96 bytes
++   * Large copies where the source address is higher than the destination
++     (forward copies)
++   * Large copies where the destination address is higher than the source
++     (copy backward, or move).
++
++   We use only two registerpairs x6,x7 and x22,x23 for the copies and copy 32
++   bytes at a time to correctly train the hardware prefetcher for better
++   throughput.  */
++ENTRY_ALIGN (__memmove_falkor, 6)
++
++	sub	tmp1, dstin, src
++	add	srcend, src, count
++	add	dstend, dstin, count
++	cmp	count, 96
++	ccmp	tmp1, count, 2, hi
++	b.lo	L(move_long)
++
++	cmp	count, 16
++	b.ls	L(copy16)
++	cmp	count, 96
++	b.hi	L(copy_long)
++
++	/* Medium copies: 17..96 bytes.  */
++	sub	tmp1, count, 1
++	ldp	A_l, A_h, [src]
++	tbnz	tmp1, 6, L(copy96)
++	ldp	D_l, D_h, [srcend, -16]
++	tbz	tmp1, 5, 1f
++	ldp	B_l, B_h, [src, 16]
++	ldp	C_l, C_h, [srcend, -32]
++	stp	B_l, B_h, [dstin, 16]
++	stp	C_l, C_h, [dstend, -32]
++1:
++	stp	A_l, A_h, [dstin]
++	stp	D_l, D_h, [dstend, -16]
++	ret
++
++	.p2align 4
++	/* Small copies: 0..16 bytes.  */
++L(copy16):
++	cmp	count, 8
++	b.lo	1f
++	ldr	A_l, [src]
++	ldr	A_h, [srcend, -8]
++	str	A_l, [dstin]
++	str	A_h, [dstend, -8]
++	ret
++	.p2align 4
++1:
++	/* 4-7 */
++	tbz	count, 2, 1f
++	ldr	A_lw, [src]
++	ldr	A_hw, [srcend, -4]
++	str	A_lw, [dstin]
++	str	A_hw, [dstend, -4]
++	ret
++	.p2align 4
++1:
++	/* 2-3 */
++	tbz	count, 1, 1f
++	ldrh	A_lw, [src]
++	ldrh	A_hw, [srcend, -2]
++	strh	A_lw, [dstin]
++	strh	A_hw, [dstend, -2]
++	ret
++	.p2align 4
++1:
++	/* 0-1 */
++	tbz	count, 0, 1f
++	ldrb	A_lw, [src]
++	strb	A_lw, [dstin]
++1:	ret
++
++	.p2align 4
++	/* Copy 64..96 bytes.  Copy 64 bytes from the start and
++	   32 bytes from the end.  */
++L(copy96):
++	ldp	B_l, B_h, [src, 16]
++	ldp	C_l, C_h, [src, 32]
++	ldp	D_l, D_h, [src, 48]
++	ldp	E_l, E_h, [srcend, -32]
++	ldp	F_l, F_h, [srcend, -16]
++	stp	A_l, A_h, [dstin]
++	stp	B_l, B_h, [dstin, 16]
++	stp	C_l, C_h, [dstin, 32]
++	stp	D_l, D_h, [dstin, 48]
++	stp	E_l, E_h, [dstend, -32]
++	stp	F_l, F_h, [dstend, -16]
++	ret
++
++	/* Align SRC to 16 byte alignment so that we don't cross cache line
++	   boundaries on both loads and stores.  There are at least 96 bytes
++	   to copy, so copy 16 bytes unaligned and then align.  The loop
++	   copies 32 bytes per iteration and prefetches one iteration ahead.  */
++
++	.p2align 4
++L(copy_long):
++	sub	count, count, 64 + 16	/* Test and readjust count.  */
++	mov	B_l, Q_l
++	mov	B_h, Q_h
++	ldp	A_l, A_h, [src]
++	and	tmp1, src, 15
++	bic	src, src, 15
++	sub	dst, dstin, tmp1
++	add	count, count, tmp1	/* Count is now 16 too large.  */
++	ldp	Q_l, Q_h, [src, 16]!
++	stp	A_l, A_h, [dstin]
++	ldp	A_l, A_h, [src, 16]!
++
++L(loop64):
++	subs	count, count, 32
++	stp	Q_l, Q_h, [dst, 16]
++	ldp	Q_l, Q_h, [src, 16]!
++	stp	A_l, A_h, [dst, 32]!
++	ldp	A_l, A_h, [src, 16]!
++	b.hi	L(loop64)
++
++	/* Write the last full set of 32 bytes.  The remainder is at most 32
++	   bytes, so it is safe to always copy 32 bytes from the end even if
++	   there is just 1 byte left.  */
++L(last64):
++	ldp	C_l, C_h, [srcend, -32]
++	stp	Q_l, Q_h, [dst, 16]
++	ldp	Q_l, Q_h, [srcend, -16]
++	stp	A_l, A_h, [dst, 32]
++	stp	C_l, C_h, [dstend, -32]
++	stp	Q_l, Q_h, [dstend, -16]
++	mov	Q_l, B_l
++	mov	Q_h, B_h
++	ret
++
++	.p2align 4
++L(move_long):
++	cbz	tmp1, 3f
++
++	mov	B_l, Q_l
++	mov	B_h, Q_h
++
++	/* Align SRCEND to 16 byte alignment so that we don't cross cache line
++	   boundaries on both loads and stores.  There are at least 96 bytes
++	   to copy, so copy 16 bytes unaligned and then align.  The loop
++	   copies 32 bytes per iteration and prefetches one iteration ahead.  */
++
++	ldp	A_l, A_h, [srcend, -16]
++	and	tmp1, srcend, 15
++	sub	srcend, srcend, tmp1
++	ldp	Q_l, Q_h, [srcend, -16]!
++	stp	A_l, A_h, [dstend, -16]
++	sub	count, count, tmp1
++	ldp	A_l, A_h, [srcend, -16]!
++	sub	dstend, dstend, tmp1
++	sub	count, count, 64
++
++1:
++	subs	count, count, 32
++	stp	Q_l, Q_h, [dstend, -16]
++	ldp	Q_l, Q_h, [srcend, -16]!
++	stp	A_l, A_h, [dstend, -32]!
++	ldp	A_l, A_h, [srcend, -16]!
++	b.hi	1b
++
++	/* Write the last full set of 32 bytes.  The remainder is at most 32
++	   bytes, so it is safe to always copy 32 bytes from the start even if
++	   there is just 1 byte left.  */
++2:
++	ldp	C_l, C_h, [src, 16]
++	stp	Q_l, Q_h, [dstend, -16]
++	ldp	Q_l, Q_h, [src]
++	stp	A_l, A_h, [dstend, -32]
++	stp	C_l, C_h, [dstin, 16]
++	stp	Q_l, Q_h, [dstin]
++	mov	Q_l, B_l
++	mov	Q_h, B_h
++3:	ret
++
++END (__memmove_falkor)
++libc_hidden_builtin_def (__memmove_falkor)
diff --git a/gnu/packages/patches/glibc-2-26-0053.patch b/gnu/packages/patches/glibc-2-26-0053.patch
new file mode 100644
index 000000000..c2b2dd94a
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0053.patch
@@ -0,0 +1,34 @@
+From 1f1239c389f7839e963b02794f64ed85df81396f Mon Sep 17 00:00:00 2001
+From: Steve Ellcey <sellcey@caviumnetworks.com>
+Date: Tue, 10 Oct 2017 15:53:55 +0530
+Subject: [PATCH 53/90] Fix glibc.tune.cpu tunable handling
+
+	* sysdeps/unix/sysv/linux/aarch64/cpu-features.c (get_midr_from_mcpu):
+	Use strcmp instead of tunable_is_name.
+
+diff --git a/ChangeLog b/ChangeLog
+index d478f5d8e4..ff9bc2b7eb 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-10-10  Steve Ellcey  <sellcey@cavium.com>
++
++	* sysdeps/unix/sysv/linux/aarch64/cpu-features.c (get_midr_from_mcpu):
++	Use strcmp instead of tunable_is_name.
++
+ 2017-10-10  Siddhesh Poyarekar  <siddhesh@sourceware.org>
+ 
+ 	* sysdeps/aarch64/multiarch/Makefile (sysdep_routines): Add
+diff --git a/sysdeps/unix/sysv/linux/aarch64/cpu-features.c b/sysdeps/unix/sysv/linux/aarch64/cpu-features.c
+index 18f5e60f4c..0c7e13f4fa 100644
+--- a/sysdeps/unix/sysv/linux/aarch64/cpu-features.c
++++ b/sysdeps/unix/sysv/linux/aarch64/cpu-features.c
+@@ -37,7 +37,7 @@ static uint64_t
+ get_midr_from_mcpu (const char *mcpu)
+ {
+   for (int i = 0; i < sizeof (cpu_list) / sizeof (struct cpu_list); i++)
+-    if (tunable_is_name (mcpu, cpu_list[i].name) == 0)
++    if (strcmp (mcpu, cpu_list[i].name) == 0)
+       return cpu_list[i].midr;
+ 
+   return UINT64_MAX;
diff --git a/gnu/packages/patches/glibc-2-26-0054.patch b/gnu/packages/patches/glibc-2-26-0054.patch
new file mode 100644
index 000000000..d13a4cf8e
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0054.patch
@@ -0,0 +1,56 @@
+From 356a2df52a65c6f299181a8edc730dcbde1441bb Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gabriel@inconstante.eti.br>
+Date: Mon, 4 Sep 2017 12:48:31 -0300
+Subject: [PATCH 54/90] powerpc64le: Add -mfloat128 to tst-strtod-nan-locale
+ testcase
+
+On powerpc64le, not all files can have the flag -mfloat128 passed as an
+option on the compile command, since that could conflict with other
+flags, such as -mno-vsx.  Each file that needs the flag, gets it through
+a CFLAGS-filename variable on sysdeps/powerpc/powerpc64le/Makefile.
+
+The test cases tst-strtod-nan-locale and tst-wcstod-nan-locale are
+missing this flag.
+
+Tested for powerpc64le.
+
+	* sysdeps/powerpc/powerpc64le/Makefile
+	(CFLAGS-tst-strtod-nan-locale.c): New variable.
+	(CFLAGS-tst-wcstod-nan-locale.c): New variable.
+
+(cherry picked from commit ffa448041beb4d5899ad0258843ecca4c106d1cd)
+
+diff --git a/ChangeLog b/ChangeLog
+index ff9bc2b7eb..60a1554fac 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-09-21  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
++
++	* sysdeps/powerpc/powerpc64le/Makefile
++	(CFLAGS-tst-strtod-nan-locale.c): New variable.
++	(CFLAGS-tst-wcstod-nan-locale.c): New variable.
++
+ 2017-10-10  Steve Ellcey  <sellcey@cavium.com>
+ 
+ 	* sysdeps/unix/sysv/linux/aarch64/cpu-features.c (get_midr_from_mcpu):
+diff --git a/sysdeps/powerpc/powerpc64le/Makefile b/sysdeps/powerpc/powerpc64le/Makefile
+index cf2dbfb673..f554a791b7 100644
+--- a/sysdeps/powerpc/powerpc64le/Makefile
++++ b/sysdeps/powerpc/powerpc64le/Makefile
+@@ -34,12 +34,15 @@ CFLAGS-bug-strtod.c += -mfloat128
+ CFLAGS-bug-strtod2.c += -mfloat128
+ CFLAGS-tst-strtod-round.c += -mfloat128
+ CFLAGS-tst-wcstod-round.c += -mfloat128
++CFLAGS-tst-strtod-nan-locale.c += -mfloat128
++CFLAGS-tst-wcstod-nan-locale.c += -mfloat128
+ CFLAGS-tst-strtod6.c += -mfloat128
+ CFLAGS-tst-strfrom.c += -mfloat128
+ CFLAGS-tst-strfrom-locale.c += -mfloat128
+ CFLAGS-strfrom-skeleton.c += -mfloat128
+ $(foreach test,bug-strtod bug-strtod2 bug-strtod2 tst-strtod-round \
+ tst-wcstod-round tst-strtod6 tst-strrom tst-strfrom-locale \
++tst-strtod-nan-locale tst-wcstod-nan-locale \
+ strfrom-skeleton,$(objpfx)$(test)): gnulib-tests += $(f128-loader-link)
+ 
+ # When building glibc with support for _Float128, the powers of ten tables in
diff --git a/gnu/packages/patches/glibc-2-26-0055.patch b/gnu/packages/patches/glibc-2-26-0055.patch
new file mode 100644
index 000000000..57ace5285
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0055.patch
@@ -0,0 +1,157 @@
+From c9163eeb6e10c6559796b283702b04eed5349fd3 Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gabriel@inconstante.eti.br>
+Date: Mon, 4 Sep 2017 13:07:18 -0300
+Subject: [PATCH 55/90] powerpc: Add redirection for finitef128, isinf128, and
+ isnanf128
+
+On powerpc64le, compiler support for float128 is not enabled by default
+on gcc.  To enable it, the flag -mfloat128 must be passed as a command
+line option to the compiler.  This means that only the few files that
+actively have -mfloat128 passed as an argument get compiler support for
+float128, whereas all other files don't.
+
+When -mfloat128 becomes enabled by default on powerpc [1], all the files
+that do not currently have compiler support for float128 enabled during
+their compilation, will start to have it.  This will lead to build
+errors in s_finite.c, s_isinf.c, and s_isnan.c.
+
+The errors are due to the unintended macro expansion of __finitef128 to
+__redirect_finitef128 in math/bits/mathcalls-helper-functions.h.  In
+that header, __MATHDECL_1 takes '__finite' and 'f128' as arguments and
+concatenates them.  However, since '__finite' has been redefined in
+s_finite.c, the function declaration becomes __redirect_finitef128:
+
+    extern int __redirect___finitef128 (_Float128 __value) __attribute__ ((__nothrow__ )) __attribute__ ((__const__));
+
+This declaration itself is OK.  The problem arises when include/math.h
+creates the hidden prototype ('hidden_proto (__finitef128)'), which
+expands to:
+
+    extern __typeof (__finitef128) __finitef128 __attribute__ ((visibility ("hidden")));
+
+Since __finitef128 is not declared, __typeof fails.  This effect was
+already true for the 'float' and 'long double' versions and is now true
+for float128.  Likewise for isinsff128 and isnanf128.
+
+This patch defines __finitef128 as __redirect___finitef128 in
+sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite.c, similarly to what's
+done for the float and long double versions of these functions, to get
+rid of the build error.  Likewise for isinff128 and isnanf128.
+
+[1] https://gcc.gnu.org/ml/gcc-patches/2017-08/msg01028.html
+
+Tested for powerpc64 and powerpc64le.
+
+	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite.c
+	(__finitef128): Define to __redirect___finitef128.
+	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf.c
+	(__isinff128): Define to __redirect___isinff128.
+	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_isnan.c
+	(__isnanf128): Define to __redirect___isnanf128.
+
+(cherry picked from commit e010deb231113e92f5f351315645a8197857dffd)
+
+diff --git a/ChangeLog b/ChangeLog
+index 60a1554fac..9ecf757e81 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,12 @@
++2017-09-21  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
++
++	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite.c
++	(__finitef128): Define to __redirect___finitef128.
++	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf.c
++	(__isinff128): Define to __redirect___isinff128.
++	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_isnan.c
++	(__isnanf128): Define to __redirect___isnanf128.
++
+ 2017-09-21  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
+ 
+ 	* sysdeps/powerpc/powerpc64le/Makefile
+diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite.c b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite.c
+index a5ec36b72f..7efc84b56a 100644
+--- a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite.c
++++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite.c
+@@ -17,8 +17,16 @@
+    <http://www.gnu.org/licenses/>.  */
+ 
+ #define __finite __redirect___finite
++
++/* The following definitions, although not related to the 'double'
++   version of 'finite', are required to guarantee macro expansions
++   (e.g.: from __finitef to __redirect_finitef) in include/math.h, thus
++   compensating for the unintended macro expansions in
++   math/bits/mathcalls-helper-functions.h.  */
+ #define __finitef __redirect___finitef
+ #define __finitel __redirect___finitel
++#define __finitef128 __redirect___finitef128
++
+ #include <math.h>
+ #include <math_ldbl_opt.h>
+ #include <shlib-compat.h>
+@@ -30,6 +38,7 @@ extern __typeof (__finite) __finite_power8 attribute_hidden;
+ #undef __finite
+ #undef __finitef
+ #undef __finitel
++#undef __finitef128
+ 
+ libc_ifunc_redirected (__redirect___finite, __finite,
+ 		       (hwcap2 & PPC_FEATURE2_ARCH_2_07)
+diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf.c b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf.c
+index 9c6789c7bd..b79bdd5edd 100644
+--- a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf.c
++++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf.c
+@@ -17,8 +17,16 @@
+    <http://www.gnu.org/licenses/>.  */
+ 
+ #define __isinf __redirect___isinf
++
++/* The following definitions, although not related to the 'double'
++   version of 'isinf', are required to guarantee macro expansions
++   (e.g.: from __isinff to __redirect_isinff) in include/math.h, thus
++   compensating for the unintended macro expansions in
++   math/bits/mathcalls-helper-functions.h.  */
+ #define __isinff __redirect___isinff
+ #define __isinfl __redirect___isinfl
++#define __isinff128 __redirect___isinff128
++
+ #include <math.h>
+ #include <math_ldbl_opt.h>
+ #include <shlib-compat.h>
+@@ -30,6 +38,7 @@ extern __typeof (__isinf) __isinf_power8 attribute_hidden;
+ #undef __isinf
+ #undef __isinff
+ #undef __isinfl
++#undef __isinff128
+ 
+ libc_ifunc_redirected (__redirect___isinf, __isinf,
+ 		       (hwcap2 & PPC_FEATURE2_ARCH_2_07)
+diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isnan.c b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isnan.c
+index 3cfe1793da..a8127e89f7 100644
+--- a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isnan.c
++++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isnan.c
+@@ -17,8 +17,16 @@
+    <http://www.gnu.org/licenses/>.  */
+ 
+ #define __isnan __redirect___isnan
++
++/* The following definitions, although not related to the 'double'
++   version of 'isnan', are required to guarantee macro expansions
++   (e.g.: from __isnanf to __redirect_isnanf) in include/math.h, thus
++   compensating for the unintended macro expansions in
++   math/bits/mathcalls-helper-functions.h.  */
+ #define __isnanf __redirect___isnanf
+ #define __isnanl __redirect___isnanl
++#define __isnanf128 __redirect___isnanf128
++
+ #include <math.h>
+ #include <math_ldbl_opt.h>
+ #include <shlib-compat.h>
+@@ -33,6 +41,7 @@ extern __typeof (__isnan) __isnan_power8 attribute_hidden;
+ #undef __isnan
+ #undef __isnanf
+ #undef __isnanl
++#undef __isnanf128
+ 
+ libc_ifunc_redirected (__redirect___isnan, __isnan,
+ 		       (hwcap2 & PPC_FEATURE2_ARCH_2_07)
diff --git a/gnu/packages/patches/glibc-2-26-0056.patch b/gnu/packages/patches/glibc-2-26-0056.patch
new file mode 100644
index 000000000..2e69de6e5
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0056.patch
@@ -0,0 +1,3930 @@
+From 4f11fe97c3934292226007f88c9cec7dd56978b0 Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gabriel@inconstante.eti.br>
+Date: Mon, 4 Sep 2017 14:34:04 -0300
+Subject: [PATCH 56/90] ldbl-128ibm: Copy implementations from ldbl-128 instead
+ of including them
+
+Some files under sysdeps/ieee754/ldbl-128ibm/ are able to reuse the
+implementation in sysdeps/ieee754/ldbl-128/ by defining _Float128 to
+long double.  This relied on compiler support for _Float128 being
+disabled.  On powerpc, such support was disabled by default, however, it
+got enabled by default [1] in GCC 8.
+
+This patch copies the implementations from ldbl-128 to ldbl-128ibm.  The
+uses of _Float128 and L() are kept intact in this patch and are replaced
+with a script in a subsequent patch.
+
+[1] https://gcc.gnu.org/ml/gcc-patches/2017-08/msg01028.html
+
+Tested for powerpc64 and powerpc64le.
+
+	* sysdeps/ieee754/ldbl-128ibm/e_expl.c: Include tables from
+	sysdeps/ieee754/ldbl-128ibm.
+	* sysdeps/ieee754/ldbl-128ibm/e_j0l.c: Copy contents from the
+	equivalent implementation in sysdeps/ieee754/ldbl-128/ instead
+	of including it.  Keep _Float128 and L() intact.  These will be
+	reviewed by a separate patch.
+	* sysdeps/ieee754/ldbl-128ibm/e_j1l.c: Likewise.
+	* sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c: Likewise.
+	* sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c: Likewise.
+	* sysdeps/ieee754/ldbl-128ibm/t_expl.h: Likewise.
+
+(cherry picked from commit c5c2e667bf834951ea95fc5124da4ef093711ebe)
+
+diff --git a/ChangeLog b/ChangeLog
+index 9ecf757e81..9713fd8e21 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,16 @@
++2017-09-21  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
++
++	* sysdeps/ieee754/ldbl-128ibm/e_expl.c: Include tables from
++	sysdeps/ieee754/ldbl-128ibm.
++	* sysdeps/ieee754/ldbl-128ibm/e_j0l.c: Copy contents from the
++	equivalent implementation in sysdeps/ieee754/ldbl-128/ instead
++	of including it.  Keep _Float128 and L() intact.  These will be
++	reviewed by a separate patch.
++	* sysdeps/ieee754/ldbl-128ibm/e_j1l.c: Likewise.
++	* sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c: Likewise.
++	* sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c: Likewise.
++	* sysdeps/ieee754/ldbl-128ibm/t_expl.h: Likewise.
++
+ 2017-09-21  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
+ 
+ 	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite.c
+diff --git a/sysdeps/ieee754/ldbl-128ibm/e_expl.c b/sysdeps/ieee754/ldbl-128ibm/e_expl.c
+index 10df6bb7d5..db812e9b82 100644
+--- a/sysdeps/ieee754/ldbl-128ibm/e_expl.c
++++ b/sysdeps/ieee754/ldbl-128ibm/e_expl.c
+@@ -69,7 +69,7 @@
+ #define _Float128 long double
+ #define L(x) x ## L
+ 
+-#include <sysdeps/ieee754/ldbl-128/t_expl.h>
++#include "t_expl.h"
+ 
+ static const long double C[] = {
+ /* Smallest integer x for which e^x overflows.  */
+diff --git a/sysdeps/ieee754/ldbl-128ibm/e_j0l.c b/sysdeps/ieee754/ldbl-128ibm/e_j0l.c
+index 00bce29284..d437926bb1 100644
+--- a/sysdeps/ieee754/ldbl-128ibm/e_j0l.c
++++ b/sysdeps/ieee754/ldbl-128ibm/e_j0l.c
+@@ -1,5 +1,866 @@
+-/* Looks like we can use ieee854 e_j0l.c as is for IBM extended format. */
++/* Bessel function of order zero.  IBM Extended Precision version.
++   Copyright 2001 by Stephen L. Moshier (moshier@na-net.ornl.gov).
++
++   This 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.
++
++   This 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 this library; if not, see
++   <http://www.gnu.org/licenses/>.  */
++
++/* This file was copied from sysdeps/ieee754/ldbl-128/e_j0l.c.  */
++
+ #define _Float128 long double
+ #define L(x) x ## L
+-#include <sysdeps/ieee754/ldbl-128/e_j0l.c>
+ 
++#include <math.h>
++#include <math_private.h>
++#include <float.h>
++
++/* 1 / sqrt(pi) */
++static const _Float128 ONEOSQPI = L(5.6418958354775628694807945156077258584405E-1);
++/* 2 / pi */
++static const _Float128 TWOOPI = L(6.3661977236758134307553505349005744813784E-1);
++static const _Float128 zero = 0;
++
++/* J0(x) = 1 - x^2/4 + x^2 x^2 R(x^2)
++   Peak relative error 3.4e-37
++   0 <= x <= 2  */
++#define NJ0_2N 6
++static const _Float128 J0_2N[NJ0_2N + 1] = {
++  L(3.133239376997663645548490085151484674892E16),
++ L(-5.479944965767990821079467311839107722107E14),
++  L(6.290828903904724265980249871997551894090E12),
++ L(-3.633750176832769659849028554429106299915E10),
++  L(1.207743757532429576399485415069244807022E8),
++ L(-2.107485999925074577174305650549367415465E5),
++  L(1.562826808020631846245296572935547005859E2),
++};
++#define NJ0_2D 6
++static const _Float128 J0_2D[NJ0_2D + 1] = {
++  L(2.005273201278504733151033654496928968261E18),
++  L(2.063038558793221244373123294054149790864E16),
++  L(1.053350447931127971406896594022010524994E14),
++  L(3.496556557558702583143527876385508882310E11),
++  L(8.249114511878616075860654484367133976306E8),
++  L(1.402965782449571800199759247964242790589E6),
++  L(1.619910762853439600957801751815074787351E3),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J0(x)cosX + Y0(x)sinX = sqrt( 2/(pi x)) P0(x), P0(x) = 1 + 1/x^2 R(1/x^2),
++   0 <= 1/x <= .0625
++   Peak relative error 3.3e-36  */
++#define NP16_IN 9
++static const _Float128 P16_IN[NP16_IN + 1] = {
++  L(-1.901689868258117463979611259731176301065E-16),
++  L(-1.798743043824071514483008340803573980931E-13),
++  L(-6.481746687115262291873324132944647438959E-11),
++  L(-1.150651553745409037257197798528294248012E-8),
++  L(-1.088408467297401082271185599507222695995E-6),
++  L(-5.551996725183495852661022587879817546508E-5),
++  L(-1.477286941214245433866838787454880214736E-3),
++  L(-1.882877976157714592017345347609200402472E-2),
++  L(-9.620983176855405325086530374317855880515E-2),
++  L(-1.271468546258855781530458854476627766233E-1),
++};
++#define NP16_ID 9
++static const _Float128 P16_ID[NP16_ID + 1] = {
++  L(2.704625590411544837659891569420764475007E-15),
++  L(2.562526347676857624104306349421985403573E-12),
++  L(9.259137589952741054108665570122085036246E-10),
++  L(1.651044705794378365237454962653430805272E-7),
++  L(1.573561544138733044977714063100859136660E-5),
++  L(8.134482112334882274688298469629884804056E-4),
++  L(2.219259239404080863919375103673593571689E-2),
++  L(2.976990606226596289580242451096393862792E-1),
++  L(1.713895630454693931742734911930937246254E0),
++  L(3.231552290717904041465898249160757368855E0),
++  /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J0(x)cosX + Y0(x)sinX = sqrt( 2/(pi x)) P0(x), P0(x) = 1 + 1/x^2 R(1/x^2)
++    0.0625 <= 1/x <= 0.125
++    Peak relative error 2.4e-35  */
++#define NP8_16N 10
++static const _Float128 P8_16N[NP8_16N + 1] = {
++  L(-2.335166846111159458466553806683579003632E-15),
++  L(-1.382763674252402720401020004169367089975E-12),
++  L(-3.192160804534716696058987967592784857907E-10),
++  L(-3.744199606283752333686144670572632116899E-8),
++  L(-2.439161236879511162078619292571922772224E-6),
++  L(-9.068436986859420951664151060267045346549E-5),
++  L(-1.905407090637058116299757292660002697359E-3),
++  L(-2.164456143936718388053842376884252978872E-2),
++  L(-1.212178415116411222341491717748696499966E-1),
++  L(-2.782433626588541494473277445959593334494E-1),
++  L(-1.670703190068873186016102289227646035035E-1),
++};
++#define NP8_16D 10
++static const _Float128 P8_16D[NP8_16D + 1] = {
++  L(3.321126181135871232648331450082662856743E-14),
++  L(1.971894594837650840586859228510007703641E-11),
++  L(4.571144364787008285981633719513897281690E-9),
++  L(5.396419143536287457142904742849052402103E-7),
++  L(3.551548222385845912370226756036899901549E-5),
++  L(1.342353874566932014705609788054598013516E-3),
++  L(2.899133293006771317589357444614157734385E-2),
++  L(3.455374978185770197704507681491574261545E-1),
++  L(2.116616964297512311314454834712634820514E0),
++  L(5.850768316827915470087758636881584174432E0),
++  L(5.655273858938766830855753983631132928968E0),
++  /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J0(x)cosX + Y0(x)sinX = sqrt( 2/(pi x)) P0(x), P0(x) = 1 + 1/x^2 R(1/x^2)
++  0.125 <= 1/x <= 0.1875
++  Peak relative error 2.7e-35  */
++#define NP5_8N 10
++static const _Float128 P5_8N[NP5_8N + 1] = {
++  L(-1.270478335089770355749591358934012019596E-12),
++  L(-4.007588712145412921057254992155810347245E-10),
++  L(-4.815187822989597568124520080486652009281E-8),
++  L(-2.867070063972764880024598300408284868021E-6),
++  L(-9.218742195161302204046454768106063638006E-5),
++  L(-1.635746821447052827526320629828043529997E-3),
++  L(-1.570376886640308408247709616497261011707E-2),
++  L(-7.656484795303305596941813361786219477807E-2),
++  L(-1.659371030767513274944805479908858628053E-1),
++  L(-1.185340550030955660015841796219919804915E-1),
++  L(-8.920026499909994671248893388013790366712E-3),
++};
++#define NP5_8D 9
++static const _Float128 P5_8D[NP5_8D + 1] = {
++  L(1.806902521016705225778045904631543990314E-11),
++  L(5.728502760243502431663549179135868966031E-9),
++  L(6.938168504826004255287618819550667978450E-7),
++  L(4.183769964807453250763325026573037785902E-5),
++  L(1.372660678476925468014882230851637878587E-3),
++  L(2.516452105242920335873286419212708961771E-2),
++  L(2.550502712902647803796267951846557316182E-1),
++  L(1.365861559418983216913629123778747617072E0),
++  L(3.523825618308783966723472468855042541407E0),
++  L(3.656365803506136165615111349150536282434E0),
++  /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J0(x)cosX + Y0(x)sinX = sqrt( 2/(pi x)) P0(x), P0(x) = 1 + 1/x^2 R(1/x^2)
++   Peak relative error 3.5e-35
++   0.1875 <= 1/x <= 0.25  */
++#define NP4_5N 9
++static const _Float128 P4_5N[NP4_5N + 1] = {
++  L(-9.791405771694098960254468859195175708252E-10),
++  L(-1.917193059944531970421626610188102836352E-7),
++  L(-1.393597539508855262243816152893982002084E-5),
++  L(-4.881863490846771259880606911667479860077E-4),
++  L(-8.946571245022470127331892085881699269853E-3),
++  L(-8.707474232568097513415336886103899434251E-2),
++  L(-4.362042697474650737898551272505525973766E-1),
++  L(-1.032712171267523975431451359962375617386E0),
++  L(-9.630502683169895107062182070514713702346E-1),
++  L(-2.251804386252969656586810309252357233320E-1),
++};
++#define NP4_5D 9
++static const _Float128 P4_5D[NP4_5D + 1] = {
++  L(1.392555487577717669739688337895791213139E-8),
++  L(2.748886559120659027172816051276451376854E-6),
++  L(2.024717710644378047477189849678576659290E-4),
++  L(7.244868609350416002930624752604670292469E-3),
++  L(1.373631762292244371102989739300382152416E-1),
++  L(1.412298581400224267910294815260613240668E0),
++  L(7.742495637843445079276397723849017617210E0),
++  L(2.138429269198406512028307045259503811861E1),
++  L(2.651547684548423476506826951831712762610E1),
++  L(1.167499382465291931571685222882909166935E1),
++  /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J0(x)cosX + Y0(x)sinX = sqrt( 2/(pi x)) P0(x), P0(x) = 1 + 1/x^2 R(1/x^2)
++   Peak relative error 2.3e-36
++   0.25 <= 1/x <= 0.3125  */
++#define NP3r2_4N 9
++static const _Float128 P3r2_4N[NP3r2_4N + 1] = {
++  L(-2.589155123706348361249809342508270121788E-8),
++  L(-3.746254369796115441118148490849195516593E-6),
++  L(-1.985595497390808544622893738135529701062E-4),
++  L(-5.008253705202932091290132760394976551426E-3),
++  L(-6.529469780539591572179155511840853077232E-2),
++  L(-4.468736064761814602927408833818990271514E-1),
++  L(-1.556391252586395038089729428444444823380E0),
++  L(-2.533135309840530224072920725976994981638E0),
++  L(-1.605509621731068453869408718565392869560E0),
++  L(-2.518966692256192789269859830255724429375E-1),
++};
++#define NP3r2_4D 9
++static const _Float128 P3r2_4D[NP3r2_4D + 1] = {
++  L(3.682353957237979993646169732962573930237E-7),
++  L(5.386741661883067824698973455566332102029E-5),
++  L(2.906881154171822780345134853794241037053E-3),
++  L(7.545832595801289519475806339863492074126E-2),
++  L(1.029405357245594877344360389469584526654E0),
++  L(7.565706120589873131187989560509757626725E0),
++  L(2.951172890699569545357692207898667665796E1),
++  L(5.785723537170311456298467310529815457536E1),
++  L(5.095621464598267889126015412522773474467E1),
++  L(1.602958484169953109437547474953308401442E1),
++  /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J0(x)cosX + Y0(x)sinX = sqrt( 2/(pi x)) P0(x), P0(x) = 1 + 1/x^2 R(1/x^2)
++   Peak relative error 1.0e-35
++   0.3125 <= 1/x <= 0.375  */
++#define NP2r7_3r2N 9
++static const _Float128 P2r7_3r2N[NP2r7_3r2N + 1] = {
++  L(-1.917322340814391131073820537027234322550E-7),
++  L(-1.966595744473227183846019639723259011906E-5),
++  L(-7.177081163619679403212623526632690465290E-4),
++  L(-1.206467373860974695661544653741899755695E-2),
++  L(-1.008656452188539812154551482286328107316E-1),
++  L(-4.216016116408810856620947307438823892707E-1),
++  L(-8.378631013025721741744285026537009814161E-1),
++  L(-6.973895635309960850033762745957946272579E-1),
++  L(-1.797864718878320770670740413285763554812E-1),
++  L(-4.098025357743657347681137871388402849581E-3),
++};
++#define NP2r7_3r2D 8
++static const _Float128 P2r7_3r2D[NP2r7_3r2D + 1] = {
++  L(2.726858489303036441686496086962545034018E-6),
++  L(2.840430827557109238386808968234848081424E-4),
++  L(1.063826772041781947891481054529454088832E-2),
++  L(1.864775537138364773178044431045514405468E-1),
++  L(1.665660052857205170440952607701728254211E0),
++  L(7.723745889544331153080842168958348568395E0),
++  L(1.810726427571829798856428548102077799835E1),
++  L(1.986460672157794440666187503833545388527E1),
++  L(8.645503204552282306364296517220055815488E0),
++  /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J0(x)cosX + Y0(x)sinX = sqrt( 2/(pi x)) P0(x), P0(x) = 1 + 1/x^2 R(1/x^2)
++   Peak relative error 1.3e-36
++   0.3125 <= 1/x <= 0.4375  */
++#define NP2r3_2r7N 9
++static const _Float128 P2r3_2r7N[NP2r3_2r7N + 1] = {
++  L(-1.594642785584856746358609622003310312622E-6),
++  L(-1.323238196302221554194031733595194539794E-4),
++  L(-3.856087818696874802689922536987100372345E-3),
++  L(-5.113241710697777193011470733601522047399E-2),
++  L(-3.334229537209911914449990372942022350558E-1),
++  L(-1.075703518198127096179198549659283422832E0),
++  L(-1.634174803414062725476343124267110981807E0),
++  L(-1.030133247434119595616826842367268304880E0),
++  L(-1.989811539080358501229347481000707289391E-1),
++  L(-3.246859189246653459359775001466924610236E-3),
++};
++#define NP2r3_2r7D 8
++static const _Float128 P2r3_2r7D[NP2r3_2r7D + 1] = {
++  L(2.267936634217251403663034189684284173018E-5),
++  L(1.918112982168673386858072491437971732237E-3),
++  L(5.771704085468423159125856786653868219522E-2),
++  L(8.056124451167969333717642810661498890507E-1),
++  L(5.687897967531010276788680634413789328776E0),
++  L(2.072596760717695491085444438270778394421E1),
++  L(3.801722099819929988585197088613160496684E1),
++  L(3.254620235902912339534998592085115836829E1),
++  L(1.104847772130720331801884344645060675036E1),
++  /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J0(x)cosX + Y0(x)sinX = sqrt( 2/(pi x)) P0(x), P0(x) = 1 + 1/x^2 R(1/x^2)
++   Peak relative error 1.2e-35
++   0.4375 <= 1/x <= 0.5  */
++#define NP2_2r3N 8
++static const _Float128 P2_2r3N[NP2_2r3N + 1] = {
++  L(-1.001042324337684297465071506097365389123E-4),
++  L(-6.289034524673365824853547252689991418981E-3),
++  L(-1.346527918018624234373664526930736205806E-1),
++  L(-1.268808313614288355444506172560463315102E0),
++  L(-5.654126123607146048354132115649177406163E0),
++  L(-1.186649511267312652171775803270911971693E1),
++  L(-1.094032424931998612551588246779200724257E1),
++  L(-3.728792136814520055025256353193674625267E0),
++  L(-3.000348318524471807839934764596331810608E-1),
++};
++#define NP2_2r3D 8
++static const _Float128 P2_2r3D[NP2_2r3D + 1] = {
++  L(1.423705538269770974803901422532055612980E-3),
++  L(9.171476630091439978533535167485230575894E-2),
++  L(2.049776318166637248868444600215942828537E0),
++  L(2.068970329743769804547326701946144899583E1),
++  L(1.025103500560831035592731539565060347709E2),
++  L(2.528088049697570728252145557167066708284E2),
++  L(2.992160327587558573740271294804830114205E2),
++  L(1.540193761146551025832707739468679973036E2),
++  L(2.779516701986912132637672140709452502650E1),
++  /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* Y0(x)cosX - J0(x)sinX = sqrt( 2/(pi x)) Q0(x),
++   Q0(x) = 1/x (-.125 + 1/x^2 R(1/x^2))
++   Peak relative error 2.2e-35
++   0 <= 1/x <= .0625  */
++#define NQ16_IN 10
++static const _Float128 Q16_IN[NQ16_IN + 1] = {
++  L(2.343640834407975740545326632205999437469E-18),
++  L(2.667978112927811452221176781536278257448E-15),
++  L(1.178415018484555397390098879501969116536E-12),
++  L(2.622049767502719728905924701288614016597E-10),
++  L(3.196908059607618864801313380896308968673E-8),
++  L(2.179466154171673958770030655199434798494E-6),
++  L(8.139959091628545225221976413795645177291E-5),
++  L(1.563900725721039825236927137885747138654E-3),
++  L(1.355172364265825167113562519307194840307E-2),
++  L(3.928058355906967977269780046844768588532E-2),
++  L(1.107891967702173292405380993183694932208E-2),
++};
++#define NQ16_ID 9
++static const _Float128 Q16_ID[NQ16_ID + 1] = {
++  L(3.199850952578356211091219295199301766718E-17),
++  L(3.652601488020654842194486058637953363918E-14),
++  L(1.620179741394865258354608590461839031281E-11),
++  L(3.629359209474609630056463248923684371426E-9),
++  L(4.473680923894354600193264347733477363305E-7),
++  L(3.106368086644715743265603656011050476736E-5),
++  L(1.198239259946770604954664925153424252622E-3),
++  L(2.446041004004283102372887804475767568272E-2),
++  L(2.403235525011860603014707768815113698768E-1),
++  L(9.491006790682158612266270665136910927149E-1),
++ /* 1.000000000000000000000000000000000000000E0 */
++ };
++
++/* Y0(x)cosX - J0(x)sinX = sqrt( 2/(pi x)) Q0(x),
++   Q0(x) = 1/x (-.125 + 1/x^2 R(1/x^2))
++   Peak relative error 5.1e-36
++   0.0625 <= 1/x <= 0.125  */
++#define NQ8_16N 11
++static const _Float128 Q8_16N[NQ8_16N + 1] = {
++  L(1.001954266485599464105669390693597125904E-17),
++  L(7.545499865295034556206475956620160007849E-15),
++  L(2.267838684785673931024792538193202559922E-12),
++  L(3.561909705814420373609574999542459912419E-10),
++  L(3.216201422768092505214730633842924944671E-8),
++  L(1.731194793857907454569364622452058554314E-6),
++  L(5.576944613034537050396518509871004586039E-5),
++  L(1.051787760316848982655967052985391418146E-3),
++  L(1.102852974036687441600678598019883746959E-2),
++  L(5.834647019292460494254225988766702933571E-2),
++  L(1.290281921604364618912425380717127576529E-1),
++  L(7.598886310387075708640370806458926458301E-2),
++};
++#define NQ8_16D 11
++static const _Float128 Q8_16D[NQ8_16D + 1] = {
++  L(1.368001558508338469503329967729951830843E-16),
++  L(1.034454121857542147020549303317348297289E-13),
++  L(3.128109209247090744354764050629381674436E-11),
++  L(4.957795214328501986562102573522064468671E-9),
++  L(4.537872468606711261992676606899273588899E-7),
++  L(2.493639207101727713192687060517509774182E-5),
++  L(8.294957278145328349785532236663051405805E-4),
++  L(1.646471258966713577374948205279380115839E-2),
++  L(1.878910092770966718491814497982191447073E-1),
++  L(1.152641605706170353727903052525652504075E0),
++  L(3.383550240669773485412333679367792932235E0),
++  L(3.823875252882035706910024716609908473970E0),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* Y0(x)cosX - J0(x)sinX = sqrt( 2/(pi x)) Q0(x),
++   Q0(x) = 1/x (-.125 + 1/x^2 R(1/x^2))
++   Peak relative error 3.9e-35
++   0.125 <= 1/x <= 0.1875  */
++#define NQ5_8N 10
++static const _Float128 Q5_8N[NQ5_8N + 1] = {
++  L(1.750399094021293722243426623211733898747E-13),
++  L(6.483426211748008735242909236490115050294E-11),
++  L(9.279430665656575457141747875716899958373E-9),
++  L(6.696634968526907231258534757736576340266E-7),
++  L(2.666560823798895649685231292142838188061E-5),
++  L(6.025087697259436271271562769707550594540E-4),
++  L(7.652807734168613251901945778921336353485E-3),
++  L(5.226269002589406461622551452343519078905E-2),
++  L(1.748390159751117658969324896330142895079E-1),
++  L(2.378188719097006494782174902213083589660E-1),
++  L(8.383984859679804095463699702165659216831E-2),
++};
++#define NQ5_8D 10
++static const _Float128 Q5_8D[NQ5_8D + 1] = {
++  L(2.389878229704327939008104855942987615715E-12),
++  L(8.926142817142546018703814194987786425099E-10),
++  L(1.294065862406745901206588525833274399038E-7),
++  L(9.524139899457666250828752185212769682191E-6),
++  L(3.908332488377770886091936221573123353489E-4),
++  L(9.250427033957236609624199884089916836748E-3),
++  L(1.263420066165922645975830877751588421451E-1),
++  L(9.692527053860420229711317379861733180654E-1),
++  L(3.937813834630430172221329298841520707954E0),
++  L(7.603126427436356534498908111445191312181E0),
++  L(5.670677653334105479259958485084550934305E0),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* Y0(x)cosX - J0(x)sinX = sqrt( 2/(pi x)) Q0(x),
++   Q0(x) = 1/x (-.125 + 1/x^2 R(1/x^2))
++   Peak relative error 3.2e-35
++   0.1875 <= 1/x <= 0.25  */
++#define NQ4_5N 10
++static const _Float128 Q4_5N[NQ4_5N + 1] = {
++  L(2.233870042925895644234072357400122854086E-11),
++  L(5.146223225761993222808463878999151699792E-9),
++  L(4.459114531468296461688753521109797474523E-7),
++  L(1.891397692931537975547242165291668056276E-5),
++  L(4.279519145911541776938964806470674565504E-4),
++  L(5.275239415656560634702073291768904783989E-3),
++  L(3.468698403240744801278238473898432608887E-2),
++  L(1.138773146337708415188856882915457888274E-1),
++  L(1.622717518946443013587108598334636458955E-1),
++  L(7.249040006390586123760992346453034628227E-2),
++  L(1.941595365256460232175236758506411486667E-3),
++};
++#define NQ4_5D 9
++static const _Float128 Q4_5D[NQ4_5D + 1] = {
++  L(3.049977232266999249626430127217988047453E-10),
++  L(7.120883230531035857746096928889676144099E-8),
++  L(6.301786064753734446784637919554359588859E-6),
++  L(2.762010530095069598480766869426308077192E-4),
++  L(6.572163250572867859316828886203406361251E-3),
++  L(8.752566114841221958200215255461843397776E-2),
++  L(6.487654992874805093499285311075289932664E-1),
++  L(2.576550017826654579451615283022812801435E0),
++  L(5.056392229924022835364779562707348096036E0),
++  L(4.179770081068251464907531367859072157773E0),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* Y0(x)cosX - J0(x)sinX = sqrt( 2/(pi x)) Q0(x),
++   Q0(x) = 1/x (-.125 + 1/x^2 R(1/x^2))
++   Peak relative error 1.4e-36
++   0.25 <= 1/x <= 0.3125  */
++#define NQ3r2_4N 10
++static const _Float128 Q3r2_4N[NQ3r2_4N + 1] = {
++  L(6.126167301024815034423262653066023684411E-10),
++  L(1.043969327113173261820028225053598975128E-7),
++  L(6.592927270288697027757438170153763220190E-6),
++  L(2.009103660938497963095652951912071336730E-4),
++  L(3.220543385492643525985862356352195896964E-3),
++  L(2.774405975730545157543417650436941650990E-2),
++  L(1.258114008023826384487378016636555041129E-1),
++  L(2.811724258266902502344701449984698323860E-1),
++  L(2.691837665193548059322831687432415014067E-1),
++  L(7.949087384900985370683770525312735605034E-2),
++  L(1.229509543620976530030153018986910810747E-3),
++};
++#define NQ3r2_4D 9
++static const _Float128 Q3r2_4D[NQ3r2_4D + 1] = {
++  L(8.364260446128475461539941389210166156568E-9),
++  L(1.451301850638956578622154585560759862764E-6),
++  L(9.431830010924603664244578867057141839463E-5),
++  L(3.004105101667433434196388593004526182741E-3),
++  L(5.148157397848271739710011717102773780221E-2),
++  L(4.901089301726939576055285374953887874895E-1),
++  L(2.581760991981709901216967665934142240346E0),
++  L(7.257105880775059281391729708630912791847E0),
++  L(1.006014717326362868007913423810737369312E1),
++  L(5.879416600465399514404064187445293212470E0),
++ /* 1.000000000000000000000000000000000000000E0*/
++};
++
++/* Y0(x)cosX - J0(x)sinX = sqrt( 2/(pi x)) Q0(x),
++   Q0(x) = 1/x (-.125 + 1/x^2 R(1/x^2))
++   Peak relative error 3.8e-36
++   0.3125 <= 1/x <= 0.375  */
++#define NQ2r7_3r2N 9
++static const _Float128 Q2r7_3r2N[NQ2r7_3r2N + 1] = {
++  L(7.584861620402450302063691901886141875454E-8),
++  L(9.300939338814216296064659459966041794591E-6),
++  L(4.112108906197521696032158235392604947895E-4),
++  L(8.515168851578898791897038357239630654431E-3),
++  L(8.971286321017307400142720556749573229058E-2),
++  L(4.885856732902956303343015636331874194498E-1),
++  L(1.334506268733103291656253500506406045846E0),
++  L(1.681207956863028164179042145803851824654E0),
++  L(8.165042692571721959157677701625853772271E-1),
++  L(9.805848115375053300608712721986235900715E-2),
++};
++#define NQ2r7_3r2D 9
++static const _Float128 Q2r7_3r2D[NQ2r7_3r2D + 1] = {
++  L(1.035586492113036586458163971239438078160E-6),
++  L(1.301999337731768381683593636500979713689E-4),
++  L(5.993695702564527062553071126719088859654E-3),
++  L(1.321184892887881883489141186815457808785E-1),
++  L(1.528766555485015021144963194165165083312E0),
++  L(9.561463309176490874525827051566494939295E0),
++  L(3.203719484883967351729513662089163356911E1),
++  L(5.497294687660930446641539152123568668447E1),
++  L(4.391158169390578768508675452986948391118E1),
++  L(1.347836630730048077907818943625789418378E1),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* Y0(x)cosX - J0(x)sinX = sqrt( 2/(pi x)) Q0(x),
++   Q0(x) = 1/x (-.125 + 1/x^2 R(1/x^2))
++   Peak relative error 2.2e-35
++   0.375 <= 1/x <= 0.4375  */
++#define NQ2r3_2r7N 9
++static const _Float128 Q2r3_2r7N[NQ2r3_2r7N + 1] = {
++  L(4.455027774980750211349941766420190722088E-7),
++  L(4.031998274578520170631601850866780366466E-5),
++  L(1.273987274325947007856695677491340636339E-3),
++  L(1.818754543377448509897226554179659122873E-2),
++  L(1.266748858326568264126353051352269875352E-1),
++  L(4.327578594728723821137731555139472880414E-1),
++  L(6.892532471436503074928194969154192615359E-1),
++  L(4.490775818438716873422163588640262036506E-1),
++  L(8.649615949297322440032000346117031581572E-2),
++  L(7.261345286655345047417257611469066147561E-4),
++};
++#define NQ2r3_2r7D 8
++static const _Float128 Q2r3_2r7D[NQ2r3_2r7D + 1] = {
++  L(6.082600739680555266312417978064954793142E-6),
++  L(5.693622538165494742945717226571441747567E-4),
++  L(1.901625907009092204458328768129666975975E-2),
++  L(2.958689532697857335456896889409923371570E-1),
++  L(2.343124711045660081603809437993368799568E0),
++  L(9.665894032187458293568704885528192804376E0),
++  L(2.035273104990617136065743426322454881353E1),
++  L(2.044102010478792896815088858740075165531E1),
++  L(8.445937177863155827844146643468706599304E0),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* Y0(x)cosX - J0(x)sinX = sqrt( 2/(pi x)) Q0(x),
++   Q0(x) = 1/x (-.125 + 1/x^2 R(1/x^2))
++   Peak relative error 3.1e-36
++   0.4375 <= 1/x <= 0.5  */
++#define NQ2_2r3N 9
++static const _Float128 Q2_2r3N[NQ2_2r3N + 1] = {
++  L(2.817566786579768804844367382809101929314E-6),
++  L(2.122772176396691634147024348373539744935E-4),
++  L(5.501378031780457828919593905395747517585E-3),
++  L(6.355374424341762686099147452020466524659E-2),
++  L(3.539652320122661637429658698954748337223E-1),
++  L(9.571721066119617436343740541777014319695E-1),
++  L(1.196258777828426399432550698612171955305E0),
++  L(6.069388659458926158392384709893753793967E-1),
++  L(9.026746127269713176512359976978248763621E-2),
++  L(5.317668723070450235320878117210807236375E-4),
++};
++#define NQ2_2r3D 8
++static const _Float128 Q2_2r3D[NQ2_2r3D + 1] = {
++  L(3.846924354014260866793741072933159380158E-5),
++  L(3.017562820057704325510067178327449946763E-3),
++  L(8.356305620686867949798885808540444210935E-2),
++  L(1.068314930499906838814019619594424586273E0),
++  L(6.900279623894821067017966573640732685233E0),
++  L(2.307667390886377924509090271780839563141E1),
++  L(3.921043465412723970791036825401273528513E1),
++  L(3.167569478939719383241775717095729233436E1),
++  L(1.051023841699200920276198346301543665909E1),
++ /* 1.000000000000000000000000000000000000000E0*/
++};
++
++
++/* Evaluate P[n] x^n  +  P[n-1] x^(n-1)  +  ...  +  P[0] */
++
++static _Float128
++neval (_Float128 x, const _Float128 *p, int n)
++{
++  _Float128 y;
++
++  p += n;
++  y = *p--;
++  do
++    {
++      y = y * x + *p--;
++    }
++  while (--n > 0);
++  return y;
++}
++
++
++/* Evaluate x^n+1  +  P[n] x^(n)  +  P[n-1] x^(n-1)  +  ...  +  P[0] */
++
++static _Float128
++deval (_Float128 x, const _Float128 *p, int n)
++{
++  _Float128 y;
++
++  p += n;
++  y = x + *p--;
++  do
++    {
++      y = y * x + *p--;
++    }
++  while (--n > 0);
++  return y;
++}
++
++
++/* Bessel function of the first kind, order zero.  */
++
++_Float128
++__ieee754_j0l (_Float128 x)
++{
++  _Float128 xx, xinv, z, p, q, c, s, cc, ss;
++
++  if (! isfinite (x))
++    {
++      if (x != x)
++	return x + x;
++      else
++	return 0;
++    }
++  if (x == 0)
++    return 1;
++
++  xx = fabsl (x);
++  if (xx <= 2)
++    {
++      if (xx < L(0x1p-57))
++	return 1;
++      /* 0 <= x <= 2 */
++      z = xx * xx;
++      p = z * z * neval (z, J0_2N, NJ0_2N) / deval (z, J0_2D, NJ0_2D);
++      p -= L(0.25) * z;
++      p += 1;
++      return p;
++    }
++
++  /* X = x - pi/4
++     cos(X) = cos(x) cos(pi/4) + sin(x) sin(pi/4)
++     = 1/sqrt(2) * (cos(x) + sin(x))
++     sin(X) = sin(x) cos(pi/4) - cos(x) sin(pi/4)
++     = 1/sqrt(2) * (sin(x) - cos(x))
++     sin(x) +- cos(x) = -cos(2x)/(sin(x) -+ cos(x))
++     cf. Fdlibm.  */
++  __sincosl (xx, &s, &c);
++  ss = s - c;
++  cc = s + c;
++  if (xx <= LDBL_MAX / 2)
++    {
++      z = -__cosl (xx + xx);
++      if ((s * c) < 0)
++	cc = z / ss;
++      else
++	ss = z / cc;
++    }
++
++  if (xx > L(0x1p256))
++    return ONEOSQPI * cc / __ieee754_sqrtl (xx);
++
++  xinv = 1 / xx;
++  z = xinv * xinv;
++  if (xinv <= 0.25)
++    {
++      if (xinv <= 0.125)
++	{
++	  if (xinv <= 0.0625)
++	    {
++	      p = neval (z, P16_IN, NP16_IN) / deval (z, P16_ID, NP16_ID);
++	      q = neval (z, Q16_IN, NQ16_IN) / deval (z, Q16_ID, NQ16_ID);
++	    }
++	  else
++	    {
++	      p = neval (z, P8_16N, NP8_16N) / deval (z, P8_16D, NP8_16D);
++	      q = neval (z, Q8_16N, NQ8_16N) / deval (z, Q8_16D, NQ8_16D);
++	    }
++	}
++      else if (xinv <= 0.1875)
++	{
++	  p = neval (z, P5_8N, NP5_8N) / deval (z, P5_8D, NP5_8D);
++	  q = neval (z, Q5_8N, NQ5_8N) / deval (z, Q5_8D, NQ5_8D);
++	}
++      else
++	{
++	  p = neval (z, P4_5N, NP4_5N) / deval (z, P4_5D, NP4_5D);
++	  q = neval (z, Q4_5N, NQ4_5N) / deval (z, Q4_5D, NQ4_5D);
++	}
++    }				/* .25 */
++  else /* if (xinv <= 0.5) */
++    {
++      if (xinv <= 0.375)
++	{
++	  if (xinv <= 0.3125)
++	    {
++	      p = neval (z, P3r2_4N, NP3r2_4N) / deval (z, P3r2_4D, NP3r2_4D);
++	      q = neval (z, Q3r2_4N, NQ3r2_4N) / deval (z, Q3r2_4D, NQ3r2_4D);
++	    }
++	  else
++	    {
++	      p = neval (z, P2r7_3r2N, NP2r7_3r2N)
++		  / deval (z, P2r7_3r2D, NP2r7_3r2D);
++	      q = neval (z, Q2r7_3r2N, NQ2r7_3r2N)
++		  / deval (z, Q2r7_3r2D, NQ2r7_3r2D);
++	    }
++	}
++      else if (xinv <= 0.4375)
++	{
++	  p = neval (z, P2r3_2r7N, NP2r3_2r7N)
++	      / deval (z, P2r3_2r7D, NP2r3_2r7D);
++	  q = neval (z, Q2r3_2r7N, NQ2r3_2r7N)
++	      / deval (z, Q2r3_2r7D, NQ2r3_2r7D);
++	}
++      else
++	{
++	  p = neval (z, P2_2r3N, NP2_2r3N) / deval (z, P2_2r3D, NP2_2r3D);
++	  q = neval (z, Q2_2r3N, NQ2_2r3N) / deval (z, Q2_2r3D, NQ2_2r3D);
++	}
++    }
++  p = 1 + z * p;
++  q = z * xinv * q;
++  q = q - L(0.125) * xinv;
++  z = ONEOSQPI * (p * cc - q * ss) / __ieee754_sqrtl (xx);
++  return z;
++}
++strong_alias (__ieee754_j0l, __j0l_finite)
++
++
++/* Y0(x) = 2/pi * log(x) * J0(x) + R(x^2)
++   Peak absolute error 1.7e-36 (relative where Y0 > 1)
++   0 <= x <= 2   */
++#define NY0_2N 7
++static _Float128 Y0_2N[NY0_2N + 1] = {
++ L(-1.062023609591350692692296993537002558155E19),
++  L(2.542000883190248639104127452714966858866E19),
++ L(-1.984190771278515324281415820316054696545E18),
++  L(4.982586044371592942465373274440222033891E16),
++ L(-5.529326354780295177243773419090123407550E14),
++  L(3.013431465522152289279088265336861140391E12),
++ L(-7.959436160727126750732203098982718347785E9),
++  L(8.230845651379566339707130644134372793322E6),
++};
++#define NY0_2D 7
++static _Float128 Y0_2D[NY0_2D + 1] = {
++  L(1.438972634353286978700329883122253752192E20),
++  L(1.856409101981569254247700169486907405500E18),
++  L(1.219693352678218589553725579802986255614E16),
++  L(5.389428943282838648918475915779958097958E13),
++  L(1.774125762108874864433872173544743051653E11),
++  L(4.522104832545149534808218252434693007036E8),
++  L(8.872187401232943927082914504125234454930E5),
++  L(1.251945613186787532055610876304669413955E3),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++static const _Float128 U0 = L(-7.3804295108687225274343927948483016310862e-02);
++
++/* Bessel function of the second kind, order zero.  */
++
++_Float128
++ __ieee754_y0l(_Float128 x)
++{
++  _Float128 xx, xinv, z, p, q, c, s, cc, ss;
++
++  if (! isfinite (x))
++    return 1 / (x + x * x);
++  if (x <= 0)
++    {
++      if (x < 0)
++	return (zero / (zero * x));
++      return -1 / zero; /* -inf and divide by zero exception.  */
++    }
++  xx = fabsl (x);
++  if (xx <= 0x1p-57)
++    return U0 + TWOOPI * __ieee754_logl (x);
++  if (xx <= 2)
++    {
++      /* 0 <= x <= 2 */
++      z = xx * xx;
++      p = neval (z, Y0_2N, NY0_2N) / deval (z, Y0_2D, NY0_2D);
++      p = TWOOPI * __ieee754_logl (x) * __ieee754_j0l (x) + p;
++      return p;
++    }
++
++  /* X = x - pi/4
++     cos(X) = cos(x) cos(pi/4) + sin(x) sin(pi/4)
++     = 1/sqrt(2) * (cos(x) + sin(x))
++     sin(X) = sin(x) cos(pi/4) - cos(x) sin(pi/4)
++     = 1/sqrt(2) * (sin(x) - cos(x))
++     sin(x) +- cos(x) = -cos(2x)/(sin(x) -+ cos(x))
++     cf. Fdlibm.  */
++  __sincosl (x, &s, &c);
++  ss = s - c;
++  cc = s + c;
++  if (xx <= LDBL_MAX / 2)
++    {
++      z = -__cosl (x + x);
++      if ((s * c) < 0)
++	cc = z / ss;
++      else
++	ss = z / cc;
++    }
++
++  if (xx > L(0x1p256))
++    return ONEOSQPI * ss / __ieee754_sqrtl (x);
++
++  xinv = 1 / xx;
++  z = xinv * xinv;
++  if (xinv <= 0.25)
++    {
++      if (xinv <= 0.125)
++	{
++	  if (xinv <= 0.0625)
++	    {
++	      p = neval (z, P16_IN, NP16_IN) / deval (z, P16_ID, NP16_ID);
++	      q = neval (z, Q16_IN, NQ16_IN) / deval (z, Q16_ID, NQ16_ID);
++	    }
++	  else
++	    {
++	      p = neval (z, P8_16N, NP8_16N) / deval (z, P8_16D, NP8_16D);
++	      q = neval (z, Q8_16N, NQ8_16N) / deval (z, Q8_16D, NQ8_16D);
++	    }
++	}
++      else if (xinv <= 0.1875)
++	{
++	  p = neval (z, P5_8N, NP5_8N) / deval (z, P5_8D, NP5_8D);
++	  q = neval (z, Q5_8N, NQ5_8N) / deval (z, Q5_8D, NQ5_8D);
++	}
++      else
++	{
++	  p = neval (z, P4_5N, NP4_5N) / deval (z, P4_5D, NP4_5D);
++	  q = neval (z, Q4_5N, NQ4_5N) / deval (z, Q4_5D, NQ4_5D);
++	}
++    }				/* .25 */
++  else /* if (xinv <= 0.5) */
++    {
++      if (xinv <= 0.375)
++	{
++	  if (xinv <= 0.3125)
++	    {
++	      p = neval (z, P3r2_4N, NP3r2_4N) / deval (z, P3r2_4D, NP3r2_4D);
++	      q = neval (z, Q3r2_4N, NQ3r2_4N) / deval (z, Q3r2_4D, NQ3r2_4D);
++	    }
++	  else
++	    {
++	      p = neval (z, P2r7_3r2N, NP2r7_3r2N)
++		  / deval (z, P2r7_3r2D, NP2r7_3r2D);
++	      q = neval (z, Q2r7_3r2N, NQ2r7_3r2N)
++		  / deval (z, Q2r7_3r2D, NQ2r7_3r2D);
++	    }
++	}
++      else if (xinv <= 0.4375)
++	{
++	  p = neval (z, P2r3_2r7N, NP2r3_2r7N)
++	      / deval (z, P2r3_2r7D, NP2r3_2r7D);
++	  q = neval (z, Q2r3_2r7N, NQ2r3_2r7N)
++	      / deval (z, Q2r3_2r7D, NQ2r3_2r7D);
++	}
++      else
++	{
++	  p = neval (z, P2_2r3N, NP2_2r3N) / deval (z, P2_2r3D, NP2_2r3D);
++	  q = neval (z, Q2_2r3N, NQ2_2r3N) / deval (z, Q2_2r3D, NQ2_2r3D);
++	}
++    }
++  p = 1 + z * p;
++  q = z * xinv * q;
++  q = q - L(0.125) * xinv;
++  z = ONEOSQPI * (p * ss + q * cc) / __ieee754_sqrtl (x);
++  return z;
++}
++strong_alias (__ieee754_y0l, __y0l_finite)
+diff --git a/sysdeps/ieee754/ldbl-128ibm/e_j1l.c b/sysdeps/ieee754/ldbl-128ibm/e_j1l.c
+index da9fd9eeca..3cedeec438 100644
+--- a/sysdeps/ieee754/ldbl-128ibm/e_j1l.c
++++ b/sysdeps/ieee754/ldbl-128ibm/e_j1l.c
+@@ -1,4 +1,886 @@
+-/* Looks like we can use ieee854 e_j1l.c as is for IBM extended format. */
++/* Bessel function of order one.  IBM Extended Precision version.
++   Copyright 2001 by Stephen L. Moshier (moshier@na-net.onrl.gov).
++
++   This 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.
++
++   This 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 this library; if not, see
++   <http://www.gnu.org/licenses/>.  */
++
++/* This file was copied from sysdeps/ieee754/ldbl-128/e_j0l.c.  */
++
+ #define _Float128 long double
+ #define L(x) x ## L
+-#include <sysdeps/ieee754/ldbl-128/e_j1l.c>
++
++#include <errno.h>
++#include <math.h>
++#include <math_private.h>
++#include <float.h>
++
++/* 1 / sqrt(pi) */
++static const _Float128 ONEOSQPI = L(5.6418958354775628694807945156077258584405E-1);
++/* 2 / pi */
++static const _Float128 TWOOPI = L(6.3661977236758134307553505349005744813784E-1);
++static const _Float128 zero = 0;
++
++/* J1(x) = .5x + x x^2 R(x^2)
++   Peak relative error 1.9e-35
++   0 <= x <= 2  */
++#define NJ0_2N 6
++static const _Float128 J0_2N[NJ0_2N + 1] = {
++ L(-5.943799577386942855938508697619735179660E16),
++  L(1.812087021305009192259946997014044074711E15),
++ L(-2.761698314264509665075127515729146460895E13),
++  L(2.091089497823600978949389109350658815972E11),
++ L(-8.546413231387036372945453565654130054307E8),
++  L(1.797229225249742247475464052741320612261E6),
++ L(-1.559552840946694171346552770008812083969E3)
++};
++#define NJ0_2D 6
++static const _Float128 J0_2D[NJ0_2D + 1] = {
++  L(9.510079323819108569501613916191477479397E17),
++  L(1.063193817503280529676423936545854693915E16),
++  L(5.934143516050192600795972192791775226920E13),
++  L(2.168000911950620999091479265214368352883E11),
++  L(5.673775894803172808323058205986256928794E8),
++  L(1.080329960080981204840966206372671147224E6),
++  L(1.411951256636576283942477881535283304912E3),
++ /* 1.000000000000000000000000000000000000000E0L */
++};
++
++/* J1(x)cosX + Y1(x)sinX = sqrt( 2/(pi x)) P1(x), P1(x) = 1 + 1/x^2 R(1/x^2),
++   0 <= 1/x <= .0625
++   Peak relative error 3.6e-36  */
++#define NP16_IN 9
++static const _Float128 P16_IN[NP16_IN + 1] = {
++  L(5.143674369359646114999545149085139822905E-16),
++  L(4.836645664124562546056389268546233577376E-13),
++  L(1.730945562285804805325011561498453013673E-10),
++  L(3.047976856147077889834905908605310585810E-8),
++  L(2.855227609107969710407464739188141162386E-6),
++  L(1.439362407936705484122143713643023998457E-4),
++  L(3.774489768532936551500999699815873422073E-3),
++  L(4.723962172984642566142399678920790598426E-2),
++  L(2.359289678988743939925017240478818248735E-1),
++  L(3.032580002220628812728954785118117124520E-1),
++};
++#define NP16_ID 9
++static const _Float128 P16_ID[NP16_ID + 1] = {
++  L(4.389268795186898018132945193912677177553E-15),
++  L(4.132671824807454334388868363256830961655E-12),
++  L(1.482133328179508835835963635130894413136E-9),
++  L(2.618941412861122118906353737117067376236E-7),
++  L(2.467854246740858470815714426201888034270E-5),
++  L(1.257192927368839847825938545925340230490E-3),
++  L(3.362739031941574274949719324644120720341E-2),
++  L(4.384458231338934105875343439265370178858E-1),
++  L(2.412830809841095249170909628197264854651E0),
++  L(4.176078204111348059102962617368214856874E0),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J1(x)cosX + Y1(x)sinX = sqrt( 2/(pi x)) P1(x), P1(x) = 1 + 1/x^2 R(1/x^2),
++    0.0625 <= 1/x <= 0.125
++    Peak relative error 1.9e-36  */
++#define NP8_16N 11
++static const _Float128 P8_16N[NP8_16N + 1] = {
++  L(2.984612480763362345647303274082071598135E-16),
++  L(1.923651877544126103941232173085475682334E-13),
++  L(4.881258879388869396043760693256024307743E-11),
++  L(6.368866572475045408480898921866869811889E-9),
++  L(4.684818344104910450523906967821090796737E-7),
++  L(2.005177298271593587095982211091300382796E-5),
++  L(4.979808067163957634120681477207147536182E-4),
++  L(6.946005761642579085284689047091173581127E-3),
++  L(5.074601112955765012750207555985299026204E-2),
++  L(1.698599455896180893191766195194231825379E-1),
++  L(1.957536905259237627737222775573623779638E-1),
++  L(2.991314703282528370270179989044994319374E-2),
++};
++#define NP8_16D 10
++static const _Float128 P8_16D[NP8_16D + 1] = {
++  L(2.546869316918069202079580939942463010937E-15),
++  L(1.644650111942455804019788382157745229955E-12),
++  L(4.185430770291694079925607420808011147173E-10),
++  L(5.485331966975218025368698195861074143153E-8),
++  L(4.062884421686912042335466327098932678905E-6),
++  L(1.758139661060905948870523641319556816772E-4),
++  L(4.445143889306356207566032244985607493096E-3),
++  L(6.391901016293512632765621532571159071158E-2),
++  L(4.933040207519900471177016015718145795434E-1),
++  L(1.839144086168947712971630337250761842976E0),
++  L(2.715120873995490920415616716916149586579E0),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J1(x)cosX + Y1(x)sinX = sqrt( 2/(pi x)) P1(x), P1(x) = 1 + 1/x^2 R(1/x^2),
++  0.125 <= 1/x <= 0.1875
++  Peak relative error 1.3e-36  */
++#define NP5_8N 10
++static const _Float128 P5_8N[NP5_8N + 1] = {
++  L(2.837678373978003452653763806968237227234E-12),
++  L(9.726641165590364928442128579282742354806E-10),
++  L(1.284408003604131382028112171490633956539E-7),
++  L(8.524624695868291291250573339272194285008E-6),
++  L(3.111516908953172249853673787748841282846E-4),
++  L(6.423175156126364104172801983096596409176E-3),
++  L(7.430220589989104581004416356260692450652E-2),
++  L(4.608315409833682489016656279567605536619E-1),
++  L(1.396870223510964882676225042258855977512E0),
++  L(1.718500293904122365894630460672081526236E0),
++  L(5.465927698800862172307352821870223855365E-1)
++};
++#define NP5_8D 10
++static const _Float128 P5_8D[NP5_8D + 1] = {
++  L(2.421485545794616609951168511612060482715E-11),
++  L(8.329862750896452929030058039752327232310E-9),
++  L(1.106137992233383429630592081375289010720E-6),
++  L(7.405786153760681090127497796448503306939E-5),
++  L(2.740364785433195322492093333127633465227E-3),
++  L(5.781246470403095224872243564165254652198E-2),
++  L(6.927711353039742469918754111511109983546E-1),
++  L(4.558679283460430281188304515922826156690E0),
++  L(1.534468499844879487013168065728837900009E1),
++  L(2.313927430889218597919624843161569422745E1),
++  L(1.194506341319498844336768473218382828637E1),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J1(x)cosX + Y1(x)sinX = sqrt( 2/(pi x)) P1(x), P1(x) = 1 + 1/x^2 R(1/x^2),
++   Peak relative error 1.4e-36
++   0.1875 <= 1/x <= 0.25  */
++#define NP4_5N 10
++static const _Float128 P4_5N[NP4_5N + 1] = {
++  L(1.846029078268368685834261260420933914621E-10),
++  L(3.916295939611376119377869680335444207768E-8),
++  L(3.122158792018920627984597530935323997312E-6),
++  L(1.218073444893078303994045653603392272450E-4),
++  L(2.536420827983485448140477159977981844883E-3),
++  L(2.883011322006690823959367922241169171315E-2),
++  L(1.755255190734902907438042414495469810830E-1),
++  L(5.379317079922628599870898285488723736599E-1),
++  L(7.284904050194300773890303361501726561938E-1),
++  L(3.270110346613085348094396323925000362813E-1),
++  L(1.804473805689725610052078464951722064757E-2),
++};
++#define NP4_5D 9
++static const _Float128 P4_5D[NP4_5D + 1] = {
++  L(1.575278146806816970152174364308980863569E-9),
++  L(3.361289173657099516191331123405675054321E-7),
++  L(2.704692281550877810424745289838790693708E-5),
++  L(1.070854930483999749316546199273521063543E-3),
++  L(2.282373093495295842598097265627962125411E-2),
++  L(2.692025460665354148328762368240343249830E-1),
++  L(1.739892942593664447220951225734811133759E0),
++  L(5.890727576752230385342377570386657229324E0),
++  L(9.517442287057841500750256954117735128153E0),
++  L(6.100616353935338240775363403030137736013E0),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J1(x)cosX + Y1(x)sinX = sqrt( 2/(pi x)) P1(x), P1(x) = 1 + 1/x^2 R(1/x^2),
++   Peak relative error 3.0e-36
++   0.25 <= 1/x <= 0.3125  */
++#define NP3r2_4N 9
++static const _Float128 P3r2_4N[NP3r2_4N + 1] = {
++  L(8.240803130988044478595580300846665863782E-8),
++  L(1.179418958381961224222969866406483744580E-5),
++  L(6.179787320956386624336959112503824397755E-4),
++  L(1.540270833608687596420595830747166658383E-2),
++  L(1.983904219491512618376375619598837355076E-1),
++  L(1.341465722692038870390470651608301155565E0),
++  L(4.617865326696612898792238245990854646057E0),
++  L(7.435574801812346424460233180412308000587E0),
++  L(4.671327027414635292514599201278557680420E0),
++  L(7.299530852495776936690976966995187714739E-1),
++};
++#define NP3r2_4D 9
++static const _Float128 P3r2_4D[NP3r2_4D + 1] = {
++  L(7.032152009675729604487575753279187576521E-7),
++  L(1.015090352324577615777511269928856742848E-4),
++  L(5.394262184808448484302067955186308730620E-3),
++  L(1.375291438480256110455809354836988584325E-1),
++  L(1.836247144461106304788160919310404376670E0),
++  L(1.314378564254376655001094503090935880349E1),
++  L(4.957184590465712006934452500894672343488E1),
++  L(9.287394244300647738855415178790263465398E1),
++  L(7.652563275535900609085229286020552768399E1),
++  L(2.147042473003074533150718117770093209096E1),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J1(x)cosX + Y1(x)sinX = sqrt( 2/(pi x)) P1(x), P1(x) = 1 + 1/x^2 R(1/x^2),
++   Peak relative error 1.0e-35
++   0.3125 <= 1/x <= 0.375  */
++#define NP2r7_3r2N 9
++static const _Float128 P2r7_3r2N[NP2r7_3r2N + 1] = {
++  L(4.599033469240421554219816935160627085991E-7),
++  L(4.665724440345003914596647144630893997284E-5),
++  L(1.684348845667764271596142716944374892756E-3),
++  L(2.802446446884455707845985913454440176223E-2),
++  L(2.321937586453963310008279956042545173930E-1),
++  L(9.640277413988055668692438709376437553804E-1),
++  L(1.911021064710270904508663334033003246028E0),
++  L(1.600811610164341450262992138893970224971E0),
++  L(4.266299218652587901171386591543457861138E-1),
++  L(1.316470424456061252962568223251247207325E-2),
++};
++#define NP2r7_3r2D 8
++static const _Float128 P2r7_3r2D[NP2r7_3r2D + 1] = {
++  L(3.924508608545520758883457108453520099610E-6),
++  L(4.029707889408829273226495756222078039823E-4),
++  L(1.484629715787703260797886463307469600219E-2),
++  L(2.553136379967180865331706538897231588685E-1),
++  L(2.229457223891676394409880026887106228740E0),
++  L(1.005708903856384091956550845198392117318E1),
++  L(2.277082659664386953166629360352385889558E1),
++  L(2.384726835193630788249826630376533988245E1),
++  L(9.700989749041320895890113781610939632410E0),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J1(x)cosX + Y1(x)sinX = sqrt( 2/(pi x)) P1(x), P1(x) = 1 + 1/x^2 R(1/x^2),
++   Peak relative error 1.7e-36
++   0.3125 <= 1/x <= 0.4375  */
++#define NP2r3_2r7N 9
++static const _Float128 P2r3_2r7N[NP2r3_2r7N + 1] = {
++  L(3.916766777108274628543759603786857387402E-6),
++  L(3.212176636756546217390661984304645137013E-4),
++  L(9.255768488524816445220126081207248947118E-3),
++  L(1.214853146369078277453080641911700735354E-1),
++  L(7.855163309847214136198449861311404633665E-1),
++  L(2.520058073282978403655488662066019816540E0),
++  L(3.825136484837545257209234285382183711466E0),
++  L(2.432569427554248006229715163865569506873E0),
++  L(4.877934835018231178495030117729800489743E-1),
++  L(1.109902737860249670981355149101343427885E-2),
++};
++#define NP2r3_2r7D 8
++static const _Float128 P2r3_2r7D[NP2r3_2r7D + 1] = {
++  L(3.342307880794065640312646341190547184461E-5),
++  L(2.782182891138893201544978009012096558265E-3),
++  L(8.221304931614200702142049236141249929207E-2),
++  L(1.123728246291165812392918571987858010949E0),
++  L(7.740482453652715577233858317133423434590E0),
++  L(2.737624677567945952953322566311201919139E1),
++  L(4.837181477096062403118304137851260715475E1),
++  L(3.941098643468580791437772701093795299274E1),
++  L(1.245821247166544627558323920382547533630E1),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* J1(x)cosX + Y1(x)sinX = sqrt( 2/(pi x)) P1(x), P1(x) = 1 + 1/x^2 R(1/x^2),
++   Peak relative error 1.7e-35
++   0.4375 <= 1/x <= 0.5  */
++#define NP2_2r3N 8
++static const _Float128 P2_2r3N[NP2_2r3N + 1] = {
++  L(3.397930802851248553545191160608731940751E-4),
++  L(2.104020902735482418784312825637833698217E-2),
++  L(4.442291771608095963935342749477836181939E-1),
++  L(4.131797328716583282869183304291833754967E0),
++  L(1.819920169779026500146134832455189917589E1),
++  L(3.781779616522937565300309684282401791291E1),
++  L(3.459605449728864218972931220783543410347E1),
++  L(1.173594248397603882049066603238568316561E1),
++  L(9.455702270242780642835086549285560316461E-1),
++};
++#define NP2_2r3D 8
++static const _Float128 P2_2r3D[NP2_2r3D + 1] = {
++  L(2.899568897241432883079888249845707400614E-3),
++  L(1.831107138190848460767699919531132426356E-1),
++  L(3.999350044057883839080258832758908825165E0),
++  L(3.929041535867957938340569419874195303712E1),
++  L(1.884245613422523323068802689915538908291E2),
++  L(4.461469948819229734353852978424629815929E2),
++  L(5.004998753999796821224085972610636347903E2),
++  L(2.386342520092608513170837883757163414100E2),
++  L(3.791322528149347975999851588922424189957E1),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* Y1(x)cosX - J1(x)sinX = sqrt( 2/(pi x)) Q1(x),
++   Q1(x) = 1/x (.375 + 1/x^2 R(1/x^2)),
++   Peak relative error 8.0e-36
++   0 <= 1/x <= .0625  */
++#define NQ16_IN 10
++static const _Float128 Q16_IN[NQ16_IN + 1] = {
++  L(-3.917420835712508001321875734030357393421E-18),
++  L(-4.440311387483014485304387406538069930457E-15),
++  L(-1.951635424076926487780929645954007139616E-12),
++  L(-4.318256438421012555040546775651612810513E-10),
++  L(-5.231244131926180765270446557146989238020E-8),
++  L(-3.540072702902043752460711989234732357653E-6),
++  L(-1.311017536555269966928228052917534882984E-4),
++  L(-2.495184669674631806622008769674827575088E-3),
++  L(-2.141868222987209028118086708697998506716E-2),
++  L(-6.184031415202148901863605871197272650090E-2),
++  L(-1.922298704033332356899546792898156493887E-2),
++};
++#define NQ16_ID 9
++static const _Float128 Q16_ID[NQ16_ID + 1] = {
++  L(3.820418034066293517479619763498400162314E-17),
++  L(4.340702810799239909648911373329149354911E-14),
++  L(1.914985356383416140706179933075303538524E-11),
++  L(4.262333682610888819476498617261895474330E-9),
++  L(5.213481314722233980346462747902942182792E-7),
++  L(3.585741697694069399299005316809954590558E-5),
++  L(1.366513429642842006385029778105539457546E-3),
++  L(2.745282599850704662726337474371355160594E-2),
++  L(2.637644521611867647651200098449903330074E-1),
++  L(1.006953426110765984590782655598680488746E0),
++ /* 1.000000000000000000000000000000000000000E0 */
++ };
++
++/* Y1(x)cosX - J1(x)sinX = sqrt( 2/(pi x)) Q1(x),
++   Q1(x) = 1/x (.375 + 1/x^2 R(1/x^2)),
++   Peak relative error 1.9e-36
++   0.0625 <= 1/x <= 0.125  */
++#define NQ8_16N 11
++static const _Float128 Q8_16N[NQ8_16N + 1] = {
++  L(-2.028630366670228670781362543615221542291E-17),
++  L(-1.519634620380959966438130374006858864624E-14),
++  L(-4.540596528116104986388796594639405114524E-12),
++  L(-7.085151756671466559280490913558388648274E-10),
++  L(-6.351062671323970823761883833531546885452E-8),
++  L(-3.390817171111032905297982523519503522491E-6),
++  L(-1.082340897018886970282138836861233213972E-4),
++  L(-2.020120801187226444822977006648252379508E-3),
++  L(-2.093169910981725694937457070649605557555E-2),
++  L(-1.092176538874275712359269481414448063393E-1),
++  L(-2.374790947854765809203590474789108718733E-1),
++  L(-1.365364204556573800719985118029601401323E-1),
++};
++#define NQ8_16D 11
++static const _Float128 Q8_16D[NQ8_16D + 1] = {
++  L(1.978397614733632533581207058069628242280E-16),
++  L(1.487361156806202736877009608336766720560E-13),
++  L(4.468041406888412086042576067133365913456E-11),
++  L(7.027822074821007443672290507210594648877E-9),
++  L(6.375740580686101224127290062867976007374E-7),
++  L(3.466887658320002225888644977076410421940E-5),
++  L(1.138625640905289601186353909213719596986E-3),
++  L(2.224470799470414663443449818235008486439E-2),
++  L(2.487052928527244907490589787691478482358E-1),
++  L(1.483927406564349124649083853892380899217E0),
++  L(4.182773513276056975777258788903489507705E0),
++  L(4.419665392573449746043880892524360870944E0),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* Y1(x)cosX - J1(x)sinX = sqrt( 2/(pi x)) Q1(x),
++   Q1(x) = 1/x (.375 + 1/x^2 R(1/x^2)),
++   Peak relative error 1.5e-35
++   0.125 <= 1/x <= 0.1875  */
++#define NQ5_8N 10
++static const _Float128 Q5_8N[NQ5_8N + 1] = {
++  L(-3.656082407740970534915918390488336879763E-13),
++  L(-1.344660308497244804752334556734121771023E-10),
++  L(-1.909765035234071738548629788698150760791E-8),
++  L(-1.366668038160120210269389551283666716453E-6),
++  L(-5.392327355984269366895210704976314135683E-5),
++  L(-1.206268245713024564674432357634540343884E-3),
++  L(-1.515456784370354374066417703736088291287E-2),
++  L(-1.022454301137286306933217746545237098518E-1),
++  L(-3.373438906472495080504907858424251082240E-1),
++  L(-4.510782522110845697262323973549178453405E-1),
++  L(-1.549000892545288676809660828213589804884E-1),
++};
++#define NQ5_8D 10
++static const _Float128 Q5_8D[NQ5_8D + 1] = {
++  L(3.565550843359501079050699598913828460036E-12),
++  L(1.321016015556560621591847454285330528045E-9),
++  L(1.897542728662346479999969679234270605975E-7),
++  L(1.381720283068706710298734234287456219474E-5),
++  L(5.599248147286524662305325795203422873725E-4),
++  L(1.305442352653121436697064782499122164843E-2),
++  L(1.750234079626943298160445750078631894985E-1),
++  L(1.311420542073436520965439883806946678491E0),
++  L(5.162757689856842406744504211089724926650E0),
++  L(9.527760296384704425618556332087850581308E0),
++  L(6.604648207463236667912921642545100248584E0),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* Y1(x)cosX - J1(x)sinX = sqrt( 2/(pi x)) Q1(x),
++   Q1(x) = 1/x (.375 + 1/x^2 R(1/x^2)),
++   Peak relative error 1.3e-35
++   0.1875 <= 1/x <= 0.25  */
++#define NQ4_5N 10
++static const _Float128 Q4_5N[NQ4_5N + 1] = {
++  L(-4.079513568708891749424783046520200903755E-11),
++  L(-9.326548104106791766891812583019664893311E-9),
++  L(-8.016795121318423066292906123815687003356E-7),
++  L(-3.372350544043594415609295225664186750995E-5),
++  L(-7.566238665947967882207277686375417983917E-4),
++  L(-9.248861580055565402130441618521591282617E-3),
++  L(-6.033106131055851432267702948850231270338E-2),
++  L(-1.966908754799996793730369265431584303447E-1),
++  L(-2.791062741179964150755788226623462207560E-1),
++  L(-1.255478605849190549914610121863534191666E-1),
++  L(-4.320429862021265463213168186061696944062E-3),
++};
++#define NQ4_5D 9
++static const _Float128 Q4_5D[NQ4_5D + 1] = {
++  L(3.978497042580921479003851216297330701056E-10),
++  L(9.203304163828145809278568906420772246666E-8),
++  L(8.059685467088175644915010485174545743798E-6),
++  L(3.490187375993956409171098277561669167446E-4),
++  L(8.189109654456872150100501732073810028829E-3),
++  L(1.072572867311023640958725265762483033769E-1),
++  L(7.790606862409960053675717185714576937994E-1),
++  L(3.016049768232011196434185423512777656328E0),
++  L(5.722963851442769787733717162314477949360E0),
++  L(4.510527838428473279647251350931380867663E0),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* Y1(x)cosX - J1(x)sinX = sqrt( 2/(pi x)) Q1(x),
++   Q1(x) = 1/x (.375 + 1/x^2 R(1/x^2)),
++   Peak relative error 2.1e-35
++   0.25 <= 1/x <= 0.3125  */
++#define NQ3r2_4N 9
++static const _Float128 Q3r2_4N[NQ3r2_4N + 1] = {
++  L(-1.087480809271383885936921889040388133627E-8),
++  L(-1.690067828697463740906962973479310170932E-6),
++  L(-9.608064416995105532790745641974762550982E-5),
++  L(-2.594198839156517191858208513873961837410E-3),
++  L(-3.610954144421543968160459863048062977822E-2),
++  L(-2.629866798251843212210482269563961685666E-1),
++  L(-9.709186825881775885917984975685752956660E-1),
++  L(-1.667521829918185121727268867619982417317E0),
++  L(-1.109255082925540057138766105229900943501E0),
++  L(-1.812932453006641348145049323713469043328E-1),
++};
++#define NQ3r2_4D 9
++static const _Float128 Q3r2_4D[NQ3r2_4D + 1] = {
++  L(1.060552717496912381388763753841473407026E-7),
++  L(1.676928002024920520786883649102388708024E-5),
++  L(9.803481712245420839301400601140812255737E-4),
++  L(2.765559874262309494758505158089249012930E-2),
++  L(4.117921827792571791298862613287549140706E-1),
++  L(3.323769515244751267093378361930279161413E0),
++  L(1.436602494405814164724810151689705353670E1),
++  L(3.163087869617098638064881410646782408297E1),
++  L(3.198181264977021649489103980298349589419E1),
++  L(1.203649258862068431199471076202897823272E1),
++ /* 1.000000000000000000000000000000000000000E0  */
++};
++
++/* Y1(x)cosX - J1(x)sinX = sqrt( 2/(pi x)) Q1(x),
++   Q1(x) = 1/x (.375 + 1/x^2 R(1/x^2)),
++   Peak relative error 1.6e-36
++   0.3125 <= 1/x <= 0.375  */
++#define NQ2r7_3r2N 9
++static const _Float128 Q2r7_3r2N[NQ2r7_3r2N + 1] = {
++  L(-1.723405393982209853244278760171643219530E-7),
++  L(-2.090508758514655456365709712333460087442E-5),
++  L(-9.140104013370974823232873472192719263019E-4),
++  L(-1.871349499990714843332742160292474780128E-2),
++  L(-1.948930738119938669637865956162512983416E-1),
++  L(-1.048764684978978127908439526343174139788E0),
++  L(-2.827714929925679500237476105843643064698E0),
++  L(-3.508761569156476114276988181329773987314E0),
++  L(-1.669332202790211090973255098624488308989E0),
++  L(-1.930796319299022954013840684651016077770E-1),
++};
++#define NQ2r7_3r2D 9
++static const _Float128 Q2r7_3r2D[NQ2r7_3r2D + 1] = {
++  L(1.680730662300831976234547482334347983474E-6),
++  L(2.084241442440551016475972218719621841120E-4),
++  L(9.445316642108367479043541702688736295579E-3),
++  L(2.044637889456631896650179477133252184672E-1),
++  L(2.316091982244297350829522534435350078205E0),
++  L(1.412031891783015085196708811890448488865E1),
++  L(4.583830154673223384837091077279595496149E1),
++  L(7.549520609270909439885998474045974122261E1),
++  L(5.697605832808113367197494052388203310638E1),
++  L(1.601496240876192444526383314589371686234E1),
++  /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* Y1(x)cosX - J1(x)sinX = sqrt( 2/(pi x)) Q1(x),
++   Q1(x) = 1/x (.375 + 1/x^2 R(1/x^2)),
++   Peak relative error 9.5e-36
++   0.375 <= 1/x <= 0.4375  */
++#define NQ2r3_2r7N 9
++static const _Float128 Q2r3_2r7N[NQ2r3_2r7N + 1] = {
++  L(-8.603042076329122085722385914954878953775E-7),
++  L(-7.701746260451647874214968882605186675720E-5),
++  L(-2.407932004380727587382493696877569654271E-3),
++  L(-3.403434217607634279028110636919987224188E-2),
++  L(-2.348707332185238159192422084985713102877E-1),
++  L(-7.957498841538254916147095255700637463207E-1),
++  L(-1.258469078442635106431098063707934348577E0),
++  L(-8.162415474676345812459353639449971369890E-1),
++  L(-1.581783890269379690141513949609572806898E-1),
++  L(-1.890595651683552228232308756569450822905E-3),
++};
++#define NQ2r3_2r7D 8
++static const _Float128 Q2r3_2r7D[NQ2r3_2r7D + 1] = {
++  L(8.390017524798316921170710533381568175665E-6),
++  L(7.738148683730826286477254659973968763659E-4),
++  L(2.541480810958665794368759558791634341779E-2),
++  L(3.878879789711276799058486068562386244873E-1),
++  L(3.003783779325811292142957336802456109333E0),
++  L(1.206480374773322029883039064575464497400E1),
++  L(2.458414064785315978408974662900438351782E1),
++  L(2.367237826273668567199042088835448715228E1),
++  L(9.231451197519171090875569102116321676763E0),
++ /* 1.000000000000000000000000000000000000000E0 */
++};
++
++/* Y1(x)cosX - J1(x)sinX = sqrt( 2/(pi x)) Q1(x),
++   Q1(x) = 1/x (.375 + 1/x^2 R(1/x^2)),
++   Peak relative error 1.4e-36
++   0.4375 <= 1/x <= 0.5  */
++#define NQ2_2r3N 9
++static const _Float128 Q2_2r3N[NQ2_2r3N + 1] = {
++  L(-5.552507516089087822166822364590806076174E-6),
++  L(-4.135067659799500521040944087433752970297E-4),
++  L(-1.059928728869218962607068840646564457980E-2),
++  L(-1.212070036005832342565792241385459023801E-1),
++  L(-6.688350110633603958684302153362735625156E-1),
++  L(-1.793587878197360221340277951304429821582E0),
++  L(-2.225407682237197485644647380483725045326E0),
++  L(-1.123402135458940189438898496348239744403E0),
++  L(-1.679187241566347077204805190763597299805E-1),
++  L(-1.458550613639093752909985189067233504148E-3),
++};
++#define NQ2_2r3D 8
++static const _Float128 Q2_2r3D[NQ2_2r3D + 1] = {
++  L(5.415024336507980465169023996403597916115E-5),
++  L(4.179246497380453022046357404266022870788E-3),
++  L(1.136306384261959483095442402929502368598E-1),
++  L(1.422640343719842213484515445393284072830E0),
++  L(8.968786703393158374728850922289204805764E0),
++  L(2.914542473339246127533384118781216495934E1),
++  L(4.781605421020380669870197378210457054685E1),
++  L(3.693865837171883152382820584714795072937E1),
++  L(1.153220502744204904763115556224395893076E1),
++  /* 1.000000000000000000000000000000000000000E0 */
++};
++
++
++/* Evaluate P[n] x^n  +  P[n-1] x^(n-1)  +  ...  +  P[0] */
++
++static _Float128
++neval (_Float128 x, const _Float128 *p, int n)
++{
++  _Float128 y;
++
++  p += n;
++  y = *p--;
++  do
++    {
++      y = y * x + *p--;
++    }
++  while (--n > 0);
++  return y;
++}
++
++
++/* Evaluate x^n+1  +  P[n] x^(n)  +  P[n-1] x^(n-1)  +  ...  +  P[0] */
++
++static _Float128
++deval (_Float128 x, const _Float128 *p, int n)
++{
++  _Float128 y;
++
++  p += n;
++  y = x + *p--;
++  do
++    {
++      y = y * x + *p--;
++    }
++  while (--n > 0);
++  return y;
++}
++
++
++/* Bessel function of the first kind, order one.  */
++
++_Float128
++__ieee754_j1l (_Float128 x)
++{
++  _Float128 xx, xinv, z, p, q, c, s, cc, ss;
++
++  if (! isfinite (x))
++    {
++      if (x != x)
++	return x + x;
++      else
++	return 0;
++    }
++  if (x == 0)
++    return x;
++  xx = fabsl (x);
++  if (xx <= L(0x1p-58))
++    {
++      _Float128 ret = x * L(0.5);
++      math_check_force_underflow (ret);
++      if (ret == 0)
++	__set_errno (ERANGE);
++      return ret;
++    }
++  if (xx <= 2)
++    {
++      /* 0 <= x <= 2 */
++      z = xx * xx;
++      p = xx * z * neval (z, J0_2N, NJ0_2N) / deval (z, J0_2D, NJ0_2D);
++      p += L(0.5) * xx;
++      if (x < 0)
++	p = -p;
++      return p;
++    }
++
++  /* X = x - 3 pi/4
++     cos(X) = cos(x) cos(3 pi/4) + sin(x) sin(3 pi/4)
++     = 1/sqrt(2) * (-cos(x) + sin(x))
++     sin(X) = sin(x) cos(3 pi/4) - cos(x) sin(3 pi/4)
++     = -1/sqrt(2) * (sin(x) + cos(x))
++     cf. Fdlibm.  */
++  __sincosl (xx, &s, &c);
++  ss = -s - c;
++  cc = s - c;
++  if (xx <= LDBL_MAX / 2)
++    {
++      z = __cosl (xx + xx);
++      if ((s * c) > 0)
++	cc = z / ss;
++      else
++	ss = z / cc;
++    }
++
++  if (xx > L(0x1p256))
++    {
++      z = ONEOSQPI * cc / __ieee754_sqrtl (xx);
++      if (x < 0)
++	z = -z;
++      return z;
++    }
++
++  xinv = 1 / xx;
++  z = xinv * xinv;
++  if (xinv <= 0.25)
++    {
++      if (xinv <= 0.125)
++	{
++	  if (xinv <= 0.0625)
++	    {
++	      p = neval (z, P16_IN, NP16_IN) / deval (z, P16_ID, NP16_ID);
++	      q = neval (z, Q16_IN, NQ16_IN) / deval (z, Q16_ID, NQ16_ID);
++	    }
++	  else
++	    {
++	      p = neval (z, P8_16N, NP8_16N) / deval (z, P8_16D, NP8_16D);
++	      q = neval (z, Q8_16N, NQ8_16N) / deval (z, Q8_16D, NQ8_16D);
++	    }
++	}
++      else if (xinv <= 0.1875)
++	{
++	  p = neval (z, P5_8N, NP5_8N) / deval (z, P5_8D, NP5_8D);
++	  q = neval (z, Q5_8N, NQ5_8N) / deval (z, Q5_8D, NQ5_8D);
++	}
++      else
++	{
++	  p = neval (z, P4_5N, NP4_5N) / deval (z, P4_5D, NP4_5D);
++	  q = neval (z, Q4_5N, NQ4_5N) / deval (z, Q4_5D, NQ4_5D);
++	}
++    }				/* .25 */
++  else /* if (xinv <= 0.5) */
++    {
++      if (xinv <= 0.375)
++	{
++	  if (xinv <= 0.3125)
++	    {
++	      p = neval (z, P3r2_4N, NP3r2_4N) / deval (z, P3r2_4D, NP3r2_4D);
++	      q = neval (z, Q3r2_4N, NQ3r2_4N) / deval (z, Q3r2_4D, NQ3r2_4D);
++	    }
++	  else
++	    {
++	      p = neval (z, P2r7_3r2N, NP2r7_3r2N)
++		  / deval (z, P2r7_3r2D, NP2r7_3r2D);
++	      q = neval (z, Q2r7_3r2N, NQ2r7_3r2N)
++		  / deval (z, Q2r7_3r2D, NQ2r7_3r2D);
++	    }
++	}
++      else if (xinv <= 0.4375)
++	{
++	  p = neval (z, P2r3_2r7N, NP2r3_2r7N)
++	      / deval (z, P2r3_2r7D, NP2r3_2r7D);
++	  q = neval (z, Q2r3_2r7N, NQ2r3_2r7N)
++	      / deval (z, Q2r3_2r7D, NQ2r3_2r7D);
++	}
++      else
++	{
++	  p = neval (z, P2_2r3N, NP2_2r3N) / deval (z, P2_2r3D, NP2_2r3D);
++	  q = neval (z, Q2_2r3N, NQ2_2r3N) / deval (z, Q2_2r3D, NQ2_2r3D);
++	}
++    }
++  p = 1 + z * p;
++  q = z * q;
++  q = q * xinv + L(0.375) * xinv;
++  z = ONEOSQPI * (p * cc - q * ss) / __ieee754_sqrtl (xx);
++  if (x < 0)
++    z = -z;
++  return z;
++}
++strong_alias (__ieee754_j1l, __j1l_finite)
++
++
++/* Y1(x) = 2/pi * (log(x) * J1(x) - 1/x) + x R(x^2)
++   Peak relative error 6.2e-38
++   0 <= x <= 2   */
++#define NY0_2N 7
++static _Float128 Y0_2N[NY0_2N + 1] = {
++  L(-6.804415404830253804408698161694720833249E19),
++  L(1.805450517967019908027153056150465849237E19),
++  L(-8.065747497063694098810419456383006737312E17),
++  L(1.401336667383028259295830955439028236299E16),
++  L(-1.171654432898137585000399489686629680230E14),
++  L(5.061267920943853732895341125243428129150E11),
++  L(-1.096677850566094204586208610960870217970E9),
++  L(9.541172044989995856117187515882879304461E5),
++};
++#define NY0_2D 7
++static _Float128 Y0_2D[NY0_2D + 1] = {
++  L(3.470629591820267059538637461549677594549E20),
++  L(4.120796439009916326855848107545425217219E18),
++  L(2.477653371652018249749350657387030814542E16),
++  L(9.954678543353888958177169349272167762797E13),
++  L(2.957927997613630118216218290262851197754E11),
++  L(6.748421382188864486018861197614025972118E8),
++  L(1.173453425218010888004562071020305709319E6),
++  L(1.450335662961034949894009554536003377187E3),
++  /* 1.000000000000000000000000000000000000000E0 */
++};
++
++
++/* Bessel function of the second kind, order one.  */
++
++_Float128
++__ieee754_y1l (_Float128 x)
++{
++  _Float128 xx, xinv, z, p, q, c, s, cc, ss;
++
++  if (! isfinite (x))
++    return 1 / (x + x * x);
++  if (x <= 0)
++    {
++      if (x < 0)
++	return (zero / (zero * x));
++      return -1 / zero; /* -inf and divide by zero exception.  */
++    }
++  xx = fabsl (x);
++  if (xx <= 0x1p-114)
++    {
++      z = -TWOOPI / x;
++      if (isinf (z))
++	__set_errno (ERANGE);
++      return z;
++    }
++  if (xx <= 2)
++    {
++      /* 0 <= x <= 2 */
++      SET_RESTORE_ROUNDL (FE_TONEAREST);
++      z = xx * xx;
++      p = xx * neval (z, Y0_2N, NY0_2N) / deval (z, Y0_2D, NY0_2D);
++      p = -TWOOPI / xx + p;
++      p = TWOOPI * __ieee754_logl (x) * __ieee754_j1l (x) + p;
++      return p;
++    }
++
++  /* X = x - 3 pi/4
++     cos(X) = cos(x) cos(3 pi/4) + sin(x) sin(3 pi/4)
++     = 1/sqrt(2) * (-cos(x) + sin(x))
++     sin(X) = sin(x) cos(3 pi/4) - cos(x) sin(3 pi/4)
++     = -1/sqrt(2) * (sin(x) + cos(x))
++     cf. Fdlibm.  */
++  __sincosl (xx, &s, &c);
++  ss = -s - c;
++  cc = s - c;
++  if (xx <= LDBL_MAX / 2)
++    {
++      z = __cosl (xx + xx);
++      if ((s * c) > 0)
++	cc = z / ss;
++      else
++	ss = z / cc;
++    }
++
++  if (xx > L(0x1p256))
++    return ONEOSQPI * ss / __ieee754_sqrtl (xx);
++
++  xinv = 1 / xx;
++  z = xinv * xinv;
++  if (xinv <= 0.25)
++    {
++      if (xinv <= 0.125)
++	{
++	  if (xinv <= 0.0625)
++	    {
++	      p = neval (z, P16_IN, NP16_IN) / deval (z, P16_ID, NP16_ID);
++	      q = neval (z, Q16_IN, NQ16_IN) / deval (z, Q16_ID, NQ16_ID);
++	    }
++	  else
++	    {
++	      p = neval (z, P8_16N, NP8_16N) / deval (z, P8_16D, NP8_16D);
++	      q = neval (z, Q8_16N, NQ8_16N) / deval (z, Q8_16D, NQ8_16D);
++	    }
++	}
++      else if (xinv <= 0.1875)
++	{
++	  p = neval (z, P5_8N, NP5_8N) / deval (z, P5_8D, NP5_8D);
++	  q = neval (z, Q5_8N, NQ5_8N) / deval (z, Q5_8D, NQ5_8D);
++	}
++      else
++	{
++	  p = neval (z, P4_5N, NP4_5N) / deval (z, P4_5D, NP4_5D);
++	  q = neval (z, Q4_5N, NQ4_5N) / deval (z, Q4_5D, NQ4_5D);
++	}
++    }				/* .25 */
++  else /* if (xinv <= 0.5) */
++    {
++      if (xinv <= 0.375)
++	{
++	  if (xinv <= 0.3125)
++	    {
++	      p = neval (z, P3r2_4N, NP3r2_4N) / deval (z, P3r2_4D, NP3r2_4D);
++	      q = neval (z, Q3r2_4N, NQ3r2_4N) / deval (z, Q3r2_4D, NQ3r2_4D);
++	    }
++	  else
++	    {
++	      p = neval (z, P2r7_3r2N, NP2r7_3r2N)
++		  / deval (z, P2r7_3r2D, NP2r7_3r2D);
++	      q = neval (z, Q2r7_3r2N, NQ2r7_3r2N)
++		  / deval (z, Q2r7_3r2D, NQ2r7_3r2D);
++	    }
++	}
++      else if (xinv <= 0.4375)
++	{
++	  p = neval (z, P2r3_2r7N, NP2r3_2r7N)
++	      / deval (z, P2r3_2r7D, NP2r3_2r7D);
++	  q = neval (z, Q2r3_2r7N, NQ2r3_2r7N)
++	      / deval (z, Q2r3_2r7D, NQ2r3_2r7D);
++	}
++      else
++	{
++	  p = neval (z, P2_2r3N, NP2_2r3N) / deval (z, P2_2r3D, NP2_2r3D);
++	  q = neval (z, Q2_2r3N, NQ2_2r3N) / deval (z, Q2_2r3D, NQ2_2r3D);
++	}
++    }
++  p = 1 + z * p;
++  q = z * q;
++  q = q * xinv + L(0.375) * xinv;
++  z = ONEOSQPI * (p * ss + q * cc) / __ieee754_sqrtl (xx);
++  return z;
++}
++strong_alias (__ieee754_y1l, __y1l_finite)
+diff --git a/sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c b/sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c
+index 8ac8283bd8..f3e184c622 100644
+--- a/sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c
++++ b/sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c
+@@ -1,5 +1,998 @@
+-/* Looks like we can use ieee854 e_lgammal_r.c as is for IBM extended format. */
++/* Natural logarithm of gamma function.  IBM Extended Precision version.
++   Copyright 2001 by Stephen L. Moshier <moshier@na-net.ornl.gov>
++
++   This 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.
++
++   This 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 this library; if not, see
++   <http://www.gnu.org/licenses/>.  */
++
++/* This file was copied from sysdeps/ieee754/ldbl-128/e_lgammal_r.c.  */
++
+ #define _Float128 long double
+ #define L(x) x ## L
+-#include <sysdeps/ieee754/ldbl-128/e_lgammal_r.c>
+ 
++#include <math.h>
++#include <math_private.h>
++#include <float.h>
++
++static const _Float128 PIL = L(3.1415926535897932384626433832795028841972E0);
++#if LDBL_MANT_DIG == 106
++static const _Float128 MAXLGM = L(0x5.d53649e2d469dbc1f01e99fd66p+1012);
++#else
++static const _Float128 MAXLGM = L(1.0485738685148938358098967157129705071571E4928);
++#endif
++static const _Float128 one = 1;
++static const _Float128 huge = LDBL_MAX;
++
++/* log gamma(x) = ( x - 0.5 ) * log(x) - x + LS2PI + 1/x P(1/x^2)
++   1/x <= 0.0741 (x >= 13.495...)
++   Peak relative error 1.5e-36  */
++static const _Float128 ls2pi = L(9.1893853320467274178032973640561763986140E-1);
++#define NRASY 12
++static const _Float128 RASY[NRASY + 1] =
++{
++  L(8.333333333333333333333333333310437112111E-2),
++ L(-2.777777777777777777777774789556228296902E-3),
++  L(7.936507936507936507795933938448586499183E-4),
++ L(-5.952380952380952041799269756378148574045E-4),
++  L(8.417508417507928904209891117498524452523E-4),
++ L(-1.917526917481263997778542329739806086290E-3),
++  L(6.410256381217852504446848671499409919280E-3),
++ L(-2.955064066900961649768101034477363301626E-2),
++  L(1.796402955865634243663453415388336954675E-1),
++ L(-1.391522089007758553455753477688592767741E0),
++  L(1.326130089598399157988112385013829305510E1),
++ L(-1.420412699593782497803472576479997819149E2),
++  L(1.218058922427762808938869872528846787020E3)
++};
++
++
++/* log gamma(x+13) = log gamma(13) +  x P(x)/Q(x)
++   -0.5 <= x <= 0.5
++   12.5 <= x+13 <= 13.5
++   Peak relative error 1.1e-36  */
++static const _Float128 lgam13a = L(1.9987213134765625E1);
++static const _Float128 lgam13b = L(1.3608962611495173623870550785125024484248E-6);
++#define NRN13 7
++static const _Float128 RN13[NRN13 + 1] =
++{
++  L(8.591478354823578150238226576156275285700E11),
++  L(2.347931159756482741018258864137297157668E11),
++  L(2.555408396679352028680662433943000804616E10),
++  L(1.408581709264464345480765758902967123937E9),
++  L(4.126759849752613822953004114044451046321E7),
++  L(6.133298899622688505854211579222889943778E5),
++  L(3.929248056293651597987893340755876578072E3),
++  L(6.850783280018706668924952057996075215223E0)
++};
++#define NRD13 6
++static const _Float128 RD13[NRD13 + 1] =
++{
++  L(3.401225382297342302296607039352935541669E11),
++  L(8.756765276918037910363513243563234551784E10),
++  L(8.873913342866613213078554180987647243903E9),
++  L(4.483797255342763263361893016049310017973E8),
++  L(1.178186288833066430952276702931512870676E7),
++  L(1.519928623743264797939103740132278337476E5),
++  L(7.989298844938119228411117593338850892311E2)
++ /* 1.0E0L */
++};
++
++
++/* log gamma(x+12) = log gamma(12) +  x P(x)/Q(x)
++   -0.5 <= x <= 0.5
++   11.5 <= x+12 <= 12.5
++   Peak relative error 4.1e-36  */
++static const _Float128 lgam12a = L(1.75023040771484375E1);
++static const _Float128 lgam12b = L(3.7687254483392876529072161996717039575982E-6);
++#define NRN12 7
++static const _Float128 RN12[NRN12 + 1] =
++{
++  L(4.709859662695606986110997348630997559137E11),
++  L(1.398713878079497115037857470168777995230E11),
++  L(1.654654931821564315970930093932954900867E10),
++  L(9.916279414876676861193649489207282144036E8),
++  L(3.159604070526036074112008954113411389879E7),
++  L(5.109099197547205212294747623977502492861E5),
++  L(3.563054878276102790183396740969279826988E3),
++  L(6.769610657004672719224614163196946862747E0)
++};
++#define NRD12 6
++static const _Float128 RD12[NRD12 + 1] =
++{
++  L(1.928167007860968063912467318985802726613E11),
++  L(5.383198282277806237247492369072266389233E10),
++  L(5.915693215338294477444809323037871058363E9),
++  L(3.241438287570196713148310560147925781342E8),
++  L(9.236680081763754597872713592701048455890E6),
++  L(1.292246897881650919242713651166596478850E5),
++  L(7.366532445427159272584194816076600211171E2)
++ /* 1.0E0L */
++};
++
++
++/* log gamma(x+11) = log gamma(11) +  x P(x)/Q(x)
++   -0.5 <= x <= 0.5
++   10.5 <= x+11 <= 11.5
++   Peak relative error 1.8e-35  */
++static const _Float128 lgam11a = L(1.5104400634765625E1);
++static const _Float128 lgam11b = L(1.1938309890295225709329251070371882250744E-5);
++#define NRN11 7
++static const _Float128 RN11[NRN11 + 1] =
++{
++  L(2.446960438029415837384622675816736622795E11),
++  L(7.955444974446413315803799763901729640350E10),
++  L(1.030555327949159293591618473447420338444E10),
++  L(6.765022131195302709153994345470493334946E8),
++  L(2.361892792609204855279723576041468347494E7),
++  L(4.186623629779479136428005806072176490125E5),
++  L(3.202506022088912768601325534149383594049E3),
++  L(6.681356101133728289358838690666225691363E0)
++};
++#define NRD11 6
++static const _Float128 RD11[NRD11 + 1] =
++{
++  L(1.040483786179428590683912396379079477432E11),
++  L(3.172251138489229497223696648369823779729E10),
++  L(3.806961885984850433709295832245848084614E9),
++  L(2.278070344022934913730015420611609620171E8),
++  L(7.089478198662651683977290023829391596481E6),
++  L(1.083246385105903533237139380509590158658E5),
++  L(6.744420991491385145885727942219463243597E2)
++ /* 1.0E0L */
++};
++
++
++/* log gamma(x+10) = log gamma(10) +  x P(x)/Q(x)
++   -0.5 <= x <= 0.5
++   9.5 <= x+10 <= 10.5
++   Peak relative error 5.4e-37  */
++static const _Float128 lgam10a = L(1.280181884765625E1);
++static const _Float128 lgam10b = L(8.6324252196112077178745667061642811492557E-6);
++#define NRN10 7
++static const _Float128 RN10[NRN10 + 1] =
++{
++  L(-1.239059737177249934158597996648808363783E14),
++  L(-4.725899566371458992365624673357356908719E13),
++  L(-7.283906268647083312042059082837754850808E12),
++  L(-5.802855515464011422171165179767478794637E11),
++  L(-2.532349691157548788382820303182745897298E10),
++  L(-5.884260178023777312587193693477072061820E8),
++  L(-6.437774864512125749845840472131829114906E6),
++  L(-2.350975266781548931856017239843273049384E4)
++};
++#define NRD10 7
++static const _Float128 RD10[NRD10 + 1] =
++{
++  L(-5.502645997581822567468347817182347679552E13),
++  L(-1.970266640239849804162284805400136473801E13),
++  L(-2.819677689615038489384974042561531409392E12),
++  L(-2.056105863694742752589691183194061265094E11),
++  L(-8.053670086493258693186307810815819662078E9),
++  L(-1.632090155573373286153427982504851867131E8),
++  L(-1.483575879240631280658077826889223634921E6),
++  L(-4.002806669713232271615885826373550502510E3)
++ /* 1.0E0L */
++};
++
++
++/* log gamma(x+9) = log gamma(9) +  x P(x)/Q(x)
++   -0.5 <= x <= 0.5
++   8.5 <= x+9 <= 9.5
++   Peak relative error 3.6e-36  */
++static const _Float128 lgam9a = L(1.06045989990234375E1);
++static const _Float128 lgam9b = L(3.9037218127284172274007216547549861681400E-6);
++#define NRN9 7
++static const _Float128 RN9[NRN9 + 1] =
++{
++  L(-4.936332264202687973364500998984608306189E13),
++  L(-2.101372682623700967335206138517766274855E13),
++  L(-3.615893404644823888655732817505129444195E12),
++  L(-3.217104993800878891194322691860075472926E11),
++  L(-1.568465330337375725685439173603032921399E10),
++  L(-4.073317518162025744377629219101510217761E8),
++  L(-4.983232096406156139324846656819246974500E6),
++  L(-2.036280038903695980912289722995505277253E4)
++};
++#define NRD9 7
++static const _Float128 RD9[NRD9 + 1] =
++{
++  L(-2.306006080437656357167128541231915480393E13),
++  L(-9.183606842453274924895648863832233799950E12),
++  L(-1.461857965935942962087907301194381010380E12),
++  L(-1.185728254682789754150068652663124298303E11),
++  L(-5.166285094703468567389566085480783070037E9),
++  L(-1.164573656694603024184768200787835094317E8),
++  L(-1.177343939483908678474886454113163527909E6),
++  L(-3.529391059783109732159524500029157638736E3)
++  /* 1.0E0L */
++};
++
++
++/* log gamma(x+8) = log gamma(8) +  x P(x)/Q(x)
++   -0.5 <= x <= 0.5
++   7.5 <= x+8 <= 8.5
++   Peak relative error 2.4e-37  */
++static const _Float128 lgam8a = L(8.525146484375E0);
++static const _Float128 lgam8b = L(1.4876690414300165531036347125050759667737E-5);
++#define NRN8 8
++static const _Float128 RN8[NRN8 + 1] =
++{
++  L(6.600775438203423546565361176829139703289E11),
++  L(3.406361267593790705240802723914281025800E11),
++  L(7.222460928505293914746983300555538432830E10),
++  L(8.102984106025088123058747466840656458342E9),
++  L(5.157620015986282905232150979772409345927E8),
++  L(1.851445288272645829028129389609068641517E7),
++  L(3.489261702223124354745894067468953756656E5),
++  L(2.892095396706665774434217489775617756014E3),
++  L(6.596977510622195827183948478627058738034E0)
++};
++#define NRD8 7
++static const _Float128 RD8[NRD8 + 1] =
++{
++  L(3.274776546520735414638114828622673016920E11),
++  L(1.581811207929065544043963828487733970107E11),
++  L(3.108725655667825188135393076860104546416E10),
++  L(3.193055010502912617128480163681842165730E9),
++  L(1.830871482669835106357529710116211541839E8),
++  L(5.790862854275238129848491555068073485086E6),
++  L(9.305213264307921522842678835618803553589E4),
++  L(6.216974105861848386918949336819572333622E2)
++  /* 1.0E0L */
++};
++
++
++/* log gamma(x+7) = log gamma(7) +  x P(x)/Q(x)
++   -0.5 <= x <= 0.5
++   6.5 <= x+7 <= 7.5
++   Peak relative error 3.2e-36  */
++static const _Float128 lgam7a = L(6.5792388916015625E0);
++static const _Float128 lgam7b = L(1.2320408538495060178292903945321122583007E-5);
++#define NRN7 8
++static const _Float128 RN7[NRN7 + 1] =
++{
++  L(2.065019306969459407636744543358209942213E11),
++  L(1.226919919023736909889724951708796532847E11),
++  L(2.996157990374348596472241776917953749106E10),
++  L(3.873001919306801037344727168434909521030E9),
++  L(2.841575255593761593270885753992732145094E8),
++  L(1.176342515359431913664715324652399565551E7),
++  L(2.558097039684188723597519300356028511547E5),
++  L(2.448525238332609439023786244782810774702E3),
++  L(6.460280377802030953041566617300902020435E0)
++};
++#define NRD7 7
++static const _Float128 RD7[NRD7 + 1] =
++{
++  L(1.102646614598516998880874785339049304483E11),
++  L(6.099297512712715445879759589407189290040E10),
++  L(1.372898136289611312713283201112060238351E10),
++  L(1.615306270420293159907951633566635172343E9),
++  L(1.061114435798489135996614242842561967459E8),
++  L(3.845638971184305248268608902030718674691E6),
++  L(7.081730675423444975703917836972720495507E4),
++  L(5.423122582741398226693137276201344096370E2)
++  /* 1.0E0L */
++};
++
++
++/* log gamma(x+6) = log gamma(6) +  x P(x)/Q(x)
++   -0.5 <= x <= 0.5
++   5.5 <= x+6 <= 6.5
++   Peak relative error 6.2e-37  */
++static const _Float128 lgam6a = L(4.7874908447265625E0);
++static const _Float128 lgam6b = L(8.9805548349424770093452324304839959231517E-7);
++#define NRN6 8
++static const _Float128 RN6[NRN6 + 1] =
++{
++  L(-3.538412754670746879119162116819571823643E13),
++  L(-2.613432593406849155765698121483394257148E13),
++  L(-8.020670732770461579558867891923784753062E12),
++  L(-1.322227822931250045347591780332435433420E12),
++  L(-1.262809382777272476572558806855377129513E11),
++  L(-7.015006277027660872284922325741197022467E9),
++  L(-2.149320689089020841076532186783055727299E8),
++  L(-3.167210585700002703820077565539658995316E6),
++  L(-1.576834867378554185210279285358586385266E4)
++};
++#define NRD6 8
++static const _Float128 RD6[NRD6 + 1] =
++{
++  L(-2.073955870771283609792355579558899389085E13),
++  L(-1.421592856111673959642750863283919318175E13),
++  L(-4.012134994918353924219048850264207074949E12),
++  L(-6.013361045800992316498238470888523722431E11),
++  L(-5.145382510136622274784240527039643430628E10),
++  L(-2.510575820013409711678540476918249524123E9),
++  L(-6.564058379709759600836745035871373240904E7),
++  L(-7.861511116647120540275354855221373571536E5),
++  L(-2.821943442729620524365661338459579270561E3)
++  /* 1.0E0L */
++};
++
++
++/* log gamma(x+5) = log gamma(5) +  x P(x)/Q(x)
++   -0.5 <= x <= 0.5
++   4.5 <= x+5 <= 5.5
++   Peak relative error 3.4e-37  */
++static const _Float128 lgam5a = L(3.17803955078125E0);
++static const _Float128 lgam5b = L(1.4279566695619646941601297055408873990961E-5);
++#define NRN5 9
++static const _Float128 RN5[NRN5 + 1] =
++{
++  L(2.010952885441805899580403215533972172098E11),
++  L(1.916132681242540921354921906708215338584E11),
++  L(7.679102403710581712903937970163206882492E10),
++  L(1.680514903671382470108010973615268125169E10),
++  L(2.181011222911537259440775283277711588410E9),
++  L(1.705361119398837808244780667539728356096E8),
++  L(7.792391565652481864976147945997033946360E6),
++  L(1.910741381027985291688667214472560023819E5),
++  L(2.088138241893612679762260077783794329559E3),
++  L(6.330318119566998299106803922739066556550E0)
++};
++#define NRD5 8
++static const _Float128 RD5[NRD5 + 1] =
++{
++  L(1.335189758138651840605141370223112376176E11),
++  L(1.174130445739492885895466097516530211283E11),
++  L(4.308006619274572338118732154886328519910E10),
++  L(8.547402888692578655814445003283720677468E9),
++  L(9.934628078575618309542580800421370730906E8),
++  L(6.847107420092173812998096295422311820672E7),
++  L(2.698552646016599923609773122139463150403E6),
++  L(5.526516251532464176412113632726150253215E4),
++  L(4.772343321713697385780533022595450486932E2)
++  /* 1.0E0L */
++};
++
++
++/* log gamma(x+4) = log gamma(4) +  x P(x)/Q(x)
++   -0.5 <= x <= 0.5
++   3.5 <= x+4 <= 4.5
++   Peak relative error 6.7e-37  */
++static const _Float128 lgam4a = L(1.791748046875E0);
++static const _Float128 lgam4b = L(1.1422353055000812477358380702272722990692E-5);
++#define NRN4 9
++static const _Float128 RN4[NRN4 + 1] =
++{
++  L(-1.026583408246155508572442242188887829208E13),
++  L(-1.306476685384622809290193031208776258809E13),
++  L(-7.051088602207062164232806511992978915508E12),
++  L(-2.100849457735620004967624442027793656108E12),
++  L(-3.767473790774546963588549871673843260569E11),
++  L(-4.156387497364909963498394522336575984206E10),
++  L(-2.764021460668011732047778992419118757746E9),
++  L(-1.036617204107109779944986471142938641399E8),
++  L(-1.895730886640349026257780896972598305443E6),
++  L(-1.180509051468390914200720003907727988201E4)
++};
++#define NRD4 9
++static const _Float128 RD4[NRD4 + 1] =
++{
++  L(-8.172669122056002077809119378047536240889E12),
++  L(-9.477592426087986751343695251801814226960E12),
++  L(-4.629448850139318158743900253637212801682E12),
++  L(-1.237965465892012573255370078308035272942E12),
++  L(-1.971624313506929845158062177061297598956E11),
++  L(-1.905434843346570533229942397763361493610E10),
++  L(-1.089409357680461419743730978512856675984E9),
++  L(-3.416703082301143192939774401370222822430E7),
++  L(-4.981791914177103793218433195857635265295E5),
++  L(-2.192507743896742751483055798411231453733E3)
++  /* 1.0E0L */
++};
++
++
++/* log gamma(x+3) = log gamma(3) +  x P(x)/Q(x)
++   -0.25 <= x <= 0.5
++   2.75 <= x+3 <= 3.5
++   Peak relative error 6.0e-37  */
++static const _Float128 lgam3a = L(6.93145751953125E-1);
++static const _Float128 lgam3b = L(1.4286068203094172321214581765680755001344E-6);
++
++#define NRN3 9
++static const _Float128 RN3[NRN3 + 1] =
++{
++  L(-4.813901815114776281494823863935820876670E11),
++  L(-8.425592975288250400493910291066881992620E11),
++  L(-6.228685507402467503655405482985516909157E11),
++  L(-2.531972054436786351403749276956707260499E11),
++  L(-6.170200796658926701311867484296426831687E10),
++  L(-9.211477458528156048231908798456365081135E9),
++  L(-8.251806236175037114064561038908691305583E8),
++  L(-4.147886355917831049939930101151160447495E7),
++  L(-1.010851868928346082547075956946476932162E6),
++  L(-8.333374463411801009783402800801201603736E3)
++};
++#define NRD3 9
++static const _Float128 RD3[NRD3 + 1] =
++{
++  L(-5.216713843111675050627304523368029262450E11),
++  L(-8.014292925418308759369583419234079164391E11),
++  L(-5.180106858220030014546267824392678611990E11),
++  L(-1.830406975497439003897734969120997840011E11),
++  L(-3.845274631904879621945745960119924118925E10),
++  L(-4.891033385370523863288908070309417710903E9),
++  L(-3.670172254411328640353855768698287474282E8),
++  L(-1.505316381525727713026364396635522516989E7),
++  L(-2.856327162923716881454613540575964890347E5),
++  L(-1.622140448015769906847567212766206894547E3)
++  /* 1.0E0L */
++};
++
++
++/* log gamma(x+2.5) = log gamma(2.5) +  x P(x)/Q(x)
++   -0.125 <= x <= 0.25
++   2.375 <= x+2.5 <= 2.75  */
++static const _Float128 lgam2r5a = L(2.8466796875E-1);
++static const _Float128 lgam2r5b = L(1.4901722919159632494669682701924320137696E-5);
++#define NRN2r5 8
++static const _Float128 RN2r5[NRN2r5 + 1] =
++{
++  L(-4.676454313888335499356699817678862233205E9),
++  L(-9.361888347911187924389905984624216340639E9),
++  L(-7.695353600835685037920815799526540237703E9),
++  L(-3.364370100981509060441853085968900734521E9),
++  L(-8.449902011848163568670361316804900559863E8),
++  L(-1.225249050950801905108001246436783022179E8),
++  L(-9.732972931077110161639900388121650470926E6),
++  L(-3.695711763932153505623248207576425983573E5),
++  L(-4.717341584067827676530426007495274711306E3)
++};
++#define NRD2r5 8
++static const _Float128 RD2r5[NRD2r5 + 1] =
++{
++  L(-6.650657966618993679456019224416926875619E9),
++  L(-1.099511409330635807899718829033488771623E10),
++  L(-7.482546968307837168164311101447116903148E9),
++  L(-2.702967190056506495988922973755870557217E9),
++  L(-5.570008176482922704972943389590409280950E8),
++  L(-6.536934032192792470926310043166993233231E7),
++  L(-4.101991193844953082400035444146067511725E6),
++  L(-1.174082735875715802334430481065526664020E5),
++  L(-9.932840389994157592102947657277692978511E2)
++  /* 1.0E0L */
++};
++
++
++/* log gamma(x+2) = x P(x)/Q(x)
++   -0.125 <= x <= +0.375
++   1.875 <= x+2 <= 2.375
++   Peak relative error 4.6e-36  */
++#define NRN2 9
++static const _Float128 RN2[NRN2 + 1] =
++{
++  L(-3.716661929737318153526921358113793421524E9),
++  L(-1.138816715030710406922819131397532331321E10),
++  L(-1.421017419363526524544402598734013569950E10),
++  L(-9.510432842542519665483662502132010331451E9),
++  L(-3.747528562099410197957514973274474767329E9),
++  L(-8.923565763363912474488712255317033616626E8),
++  L(-1.261396653700237624185350402781338231697E8),
++  L(-9.918402520255661797735331317081425749014E6),
++  L(-3.753996255897143855113273724233104768831E5),
++  L(-4.778761333044147141559311805999540765612E3)
++};
++#define NRD2 9
++static const _Float128 RD2[NRD2 + 1] =
++{
++  L(-8.790916836764308497770359421351673950111E9),
++  L(-2.023108608053212516399197678553737477486E10),
++  L(-1.958067901852022239294231785363504458367E10),
++  L(-1.035515043621003101254252481625188704529E10),
++  L(-3.253884432621336737640841276619272224476E9),
++  L(-6.186383531162456814954947669274235815544E8),
++  L(-6.932557847749518463038934953605969951466E7),
++  L(-4.240731768287359608773351626528479703758E6),
++  L(-1.197343995089189188078944689846348116630E5),
++  L(-1.004622911670588064824904487064114090920E3)
++/* 1.0E0 */
++};
++
++
++/* log gamma(x+1.75) = log gamma(1.75) +  x P(x)/Q(x)
++   -0.125 <= x <= +0.125
++   1.625 <= x+1.75 <= 1.875
++   Peak relative error 9.2e-37 */
++static const _Float128 lgam1r75a = L(-8.441162109375E-2);
++static const _Float128 lgam1r75b = L(1.0500073264444042213965868602268256157604E-5);
++#define NRN1r75 8
++static const _Float128 RN1r75[NRN1r75 + 1] =
++{
++  L(-5.221061693929833937710891646275798251513E7),
++  L(-2.052466337474314812817883030472496436993E8),
++  L(-2.952718275974940270675670705084125640069E8),
++  L(-2.132294039648116684922965964126389017840E8),
++  L(-8.554103077186505960591321962207519908489E7),
++  L(-1.940250901348870867323943119132071960050E7),
++  L(-2.379394147112756860769336400290402208435E6),
++  L(-1.384060879999526222029386539622255797389E5),
++  L(-2.698453601378319296159355612094598695530E3)
++};
++#define NRD1r75 8
++static const _Float128 RD1r75[NRD1r75 + 1] =
++{
++  L(-2.109754689501705828789976311354395393605E8),
++  L(-5.036651829232895725959911504899241062286E8),
++  L(-4.954234699418689764943486770327295098084E8),
++  L(-2.589558042412676610775157783898195339410E8),
++  L(-7.731476117252958268044969614034776883031E7),
++  L(-1.316721702252481296030801191240867486965E7),
++  L(-1.201296501404876774861190604303728810836E6),
++  L(-5.007966406976106636109459072523610273928E4),
++  L(-6.155817990560743422008969155276229018209E2)
++  /* 1.0E0L */
++};
++
++
++/* log gamma(x+x0) = y0 +  x^2 P(x)/Q(x)
++   -0.0867 <= x <= +0.1634
++   1.374932... <= x+x0 <= 1.625032...
++   Peak relative error 4.0e-36  */
++static const _Float128 x0a = L(1.4616241455078125);
++static const _Float128 x0b = L(7.9994605498412626595423257213002588621246E-6);
++static const _Float128 y0a = L(-1.21490478515625E-1);
++static const _Float128 y0b = L(4.1879797753919044854428223084178486438269E-6);
++#define NRN1r5 8
++static const _Float128 RN1r5[NRN1r5 + 1] =
++{
++  L(6.827103657233705798067415468881313128066E5),
++  L(1.910041815932269464714909706705242148108E6),
++  L(2.194344176925978377083808566251427771951E6),
++  L(1.332921400100891472195055269688876427962E6),
++  L(4.589080973377307211815655093824787123508E5),
++  L(8.900334161263456942727083580232613796141E4),
++  L(9.053840838306019753209127312097612455236E3),
++  L(4.053367147553353374151852319743594873771E2),
++  L(5.040631576303952022968949605613514584950E0)
++};
++#define NRD1r5 8
++static const _Float128 RD1r5[NRD1r5 + 1] =
++{
++  L(1.411036368843183477558773688484699813355E6),
++  L(4.378121767236251950226362443134306184849E6),
++  L(5.682322855631723455425929877581697918168E6),
++  L(3.999065731556977782435009349967042222375E6),
++  L(1.653651390456781293163585493620758410333E6),
++  L(4.067774359067489605179546964969435858311E5),
++  L(5.741463295366557346748361781768833633256E4),
++  L(4.226404539738182992856094681115746692030E3),
++  L(1.316980975410327975566999780608618774469E2),
++  /* 1.0E0L */
++};
++
++
++/* log gamma(x+1.25) = log gamma(1.25) +  x P(x)/Q(x)
++   -.125 <= x <= +.125
++   1.125 <= x+1.25 <= 1.375
++   Peak relative error = 4.9e-36 */
++static const _Float128 lgam1r25a = L(-9.82818603515625E-2);
++static const _Float128 lgam1r25b = L(1.0023929749338536146197303364159774377296E-5);
++#define NRN1r25 9
++static const _Float128 RN1r25[NRN1r25 + 1] =
++{
++  L(-9.054787275312026472896002240379580536760E4),
++  L(-8.685076892989927640126560802094680794471E4),
++  L(2.797898965448019916967849727279076547109E5),
++  L(6.175520827134342734546868356396008898299E5),
++  L(5.179626599589134831538516906517372619641E5),
++  L(2.253076616239043944538380039205558242161E5),
++  L(5.312653119599957228630544772499197307195E4),
++  L(6.434329437514083776052669599834938898255E3),
++  L(3.385414416983114598582554037612347549220E2),
++  L(4.907821957946273805080625052510832015792E0)
++};
++#define NRD1r25 8
++static const _Float128 RD1r25[NRD1r25 + 1] =
++{
++  L(3.980939377333448005389084785896660309000E5),
++  L(1.429634893085231519692365775184490465542E6),
++  L(2.145438946455476062850151428438668234336E6),
++  L(1.743786661358280837020848127465970357893E6),
++  L(8.316364251289743923178092656080441655273E5),
++  L(2.355732939106812496699621491135458324294E5),
++  L(3.822267399625696880571810137601310855419E4),
++  L(3.228463206479133236028576845538387620856E3),
++  L(1.152133170470059555646301189220117965514E2)
++  /* 1.0E0L */
++};
++
++
++/* log gamma(x + 1) = x P(x)/Q(x)
++   0.0 <= x <= +0.125
++   1.0 <= x+1 <= 1.125
++   Peak relative error 1.1e-35  */
++#define NRN1 8
++static const _Float128 RN1[NRN1 + 1] =
++{
++  L(-9.987560186094800756471055681088744738818E3),
++  L(-2.506039379419574361949680225279376329742E4),
++  L(-1.386770737662176516403363873617457652991E4),
++  L(1.439445846078103202928677244188837130744E4),
++  L(2.159612048879650471489449668295139990693E4),
++  L(1.047439813638144485276023138173676047079E4),
++  L(2.250316398054332592560412486630769139961E3),
++  L(1.958510425467720733041971651126443864041E2),
++  L(4.516830313569454663374271993200291219855E0)
++};
++#define NRD1 7
++static const _Float128 RD1[NRD1 + 1] =
++{
++  L(1.730299573175751778863269333703788214547E4),
++  L(6.807080914851328611903744668028014678148E4),
++  L(1.090071629101496938655806063184092302439E5),
++  L(9.124354356415154289343303999616003884080E4),
++  L(4.262071638655772404431164427024003253954E4),
++  L(1.096981664067373953673982635805821283581E4),
++  L(1.431229503796575892151252708527595787588E3),
++  L(7.734110684303689320830401788262295992921E1)
++ /* 1.0E0 */
++};
++
++
++/* log gamma(x + 1) = x P(x)/Q(x)
++   -0.125 <= x <= 0
++   0.875 <= x+1 <= 1.0
++   Peak relative error 7.0e-37  */
++#define NRNr9 8
++static const _Float128 RNr9[NRNr9 + 1] =
++{
++  L(4.441379198241760069548832023257571176884E5),
++  L(1.273072988367176540909122090089580368732E6),
++  L(9.732422305818501557502584486510048387724E5),
++  L(-5.040539994443998275271644292272870348684E5),
++  L(-1.208719055525609446357448132109723786736E6),
++  L(-7.434275365370936547146540554419058907156E5),
++  L(-2.075642969983377738209203358199008185741E5),
++  L(-2.565534860781128618589288075109372218042E4),
++  L(-1.032901669542994124131223797515913955938E3),
++};
++#define NRDr9 8
++static const _Float128 RDr9[NRDr9 + 1] =
++{
++  L(-7.694488331323118759486182246005193998007E5),
++  L(-3.301918855321234414232308938454112213751E6),
++  L(-5.856830900232338906742924836032279404702E6),
++  L(-5.540672519616151584486240871424021377540E6),
++  L(-3.006530901041386626148342989181721176919E6),
++  L(-9.350378280513062139466966374330795935163E5),
++  L(-1.566179100031063346901755685375732739511E5),
++  L(-1.205016539620260779274902967231510804992E4),
++  L(-2.724583156305709733221564484006088794284E2)
++/* 1.0E0 */
++};
++
++
++/* Evaluate P[n] x^n  +  P[n-1] x^(n-1)  +  ...  +  P[0] */
++
++static _Float128
++neval (_Float128 x, const _Float128 *p, int n)
++{
++  _Float128 y;
++
++  p += n;
++  y = *p--;
++  do
++    {
++      y = y * x + *p--;
++    }
++  while (--n > 0);
++  return y;
++}
++
++
++/* Evaluate x^n+1  +  P[n] x^(n)  +  P[n-1] x^(n-1)  +  ...  +  P[0] */
++
++static _Float128
++deval (_Float128 x, const _Float128 *p, int n)
++{
++  _Float128 y;
++
++  p += n;
++  y = x + *p--;
++  do
++    {
++      y = y * x + *p--;
++    }
++  while (--n > 0);
++  return y;
++}
++
++
++_Float128
++__ieee754_lgammal_r (_Float128 x, int *signgamp)
++{
++  _Float128 p, q, w, z, nx;
++  int i, nn;
++
++  *signgamp = 1;
++
++  if (! isfinite (x))
++    return x * x;
++
++  if (x == 0)
++    {
++      if (signbit (x))
++	*signgamp = -1;
++    }
++
++  if (x < 0)
++    {
++      if (x < -2 && x > (LDBL_MANT_DIG == 106 ? -48 : -50))
++	return __lgamma_negl (x, signgamp);
++      q = -x;
++      p = __floorl (q);
++      if (p == q)
++	return (one / __fabsl (p - p));
++      _Float128 halfp = p * L(0.5);
++      if (halfp == __floorl (halfp))
++	*signgamp = -1;
++      else
++	*signgamp = 1;
++      if (q < L(0x1p-120))
++	return -__logl (q);
++      z = q - p;
++      if (z > L(0.5))
++	{
++	  p += 1;
++	  z = p - q;
++	}
++      z = q * __sinl (PIL * z);
++      w = __ieee754_lgammal_r (q, &i);
++      z = __logl (PIL / z) - w;
++      return (z);
++    }
++
++  if (x < L(13.5))
++    {
++      p = 0;
++      nx = __floorl (x + L(0.5));
++      nn = nx;
++      switch (nn)
++	{
++	case 0:
++	  /* log gamma (x + 1) = log(x) + log gamma(x) */
++	  if (x < L(0x1p-120))
++	    return -__logl (x);
++	  else if (x <= 0.125)
++	    {
++	      p = x * neval (x, RN1, NRN1) / deval (x, RD1, NRD1);
++	    }
++	  else if (x <= 0.375)
++	    {
++	      z = x - L(0.25);
++	      p = z * neval (z, RN1r25, NRN1r25) / deval (z, RD1r25, NRD1r25);
++	      p += lgam1r25b;
++	      p += lgam1r25a;
++	    }
++	  else if (x <= 0.625)
++	    {
++	      z = x + (1 - x0a);
++	      z = z - x0b;
++	      p = neval (z, RN1r5, NRN1r5) / deval (z, RD1r5, NRD1r5);
++	      p = p * z * z;
++	      p = p + y0b;
++	      p = p + y0a;
++	    }
++	  else if (x <= 0.875)
++	    {
++	      z = x - L(0.75);
++	      p = z * neval (z, RN1r75, NRN1r75) / deval (z, RD1r75, NRD1r75);
++	      p += lgam1r75b;
++	      p += lgam1r75a;
++	    }
++	  else
++	    {
++	      z = x - 1;
++	      p = z * neval (z, RN2, NRN2) / deval (z, RD2, NRD2);
++	    }
++	  p = p - __logl (x);
++	  break;
++
++	case 1:
++	  if (x < L(0.875))
++	    {
++	      if (x <= 0.625)
++		{
++		  z = x + (1 - x0a);
++		  z = z - x0b;
++		  p = neval (z, RN1r5, NRN1r5) / deval (z, RD1r5, NRD1r5);
++		  p = p * z * z;
++		  p = p + y0b;
++		  p = p + y0a;
++		}
++	      else if (x <= 0.875)
++		{
++		  z = x - L(0.75);
++		  p = z * neval (z, RN1r75, NRN1r75)
++			/ deval (z, RD1r75, NRD1r75);
++		  p += lgam1r75b;
++		  p += lgam1r75a;
++		}
++	      else
++		{
++		  z = x - 1;
++		  p = z * neval (z, RN2, NRN2) / deval (z, RD2, NRD2);
++		}
++	      p = p - __logl (x);
++	    }
++	  else if (x < 1)
++	    {
++	      z = x - 1;
++	      p = z * neval (z, RNr9, NRNr9) / deval (z, RDr9, NRDr9);
++	    }
++	  else if (x == 1)
++	    p = 0;
++	  else if (x <= L(1.125))
++	    {
++	      z = x - 1;
++	      p = z * neval (z, RN1, NRN1) / deval (z, RD1, NRD1);
++	    }
++	  else if (x <= 1.375)
++	    {
++	      z = x - L(1.25);
++	      p = z * neval (z, RN1r25, NRN1r25) / deval (z, RD1r25, NRD1r25);
++	      p += lgam1r25b;
++	      p += lgam1r25a;
++	    }
++	  else
++	    {
++	      /* 1.375 <= x+x0 <= 1.625 */
++	      z = x - x0a;
++	      z = z - x0b;
++	      p = neval (z, RN1r5, NRN1r5) / deval (z, RD1r5, NRD1r5);
++	      p = p * z * z;
++	      p = p + y0b;
++	      p = p + y0a;
++	    }
++	  break;
++
++	case 2:
++	  if (x < L(1.625))
++	    {
++	      z = x - x0a;
++	      z = z - x0b;
++	      p = neval (z, RN1r5, NRN1r5) / deval (z, RD1r5, NRD1r5);
++	      p = p * z * z;
++	      p = p + y0b;
++	      p = p + y0a;
++	    }
++	  else if (x < L(1.875))
++	    {
++	      z = x - L(1.75);
++	      p = z * neval (z, RN1r75, NRN1r75) / deval (z, RD1r75, NRD1r75);
++	      p += lgam1r75b;
++	      p += lgam1r75a;
++	    }
++	  else if (x == 2)
++	    p = 0;
++	  else if (x < L(2.375))
++	    {
++	      z = x - 2;
++	      p = z * neval (z, RN2, NRN2) / deval (z, RD2, NRD2);
++	    }
++	  else
++	    {
++	      z = x - L(2.5);
++	      p = z * neval (z, RN2r5, NRN2r5) / deval (z, RD2r5, NRD2r5);
++	      p += lgam2r5b;
++	      p += lgam2r5a;
++	    }
++	  break;
++
++	case 3:
++	  if (x < 2.75)
++	    {
++	      z = x - L(2.5);
++	      p = z * neval (z, RN2r5, NRN2r5) / deval (z, RD2r5, NRD2r5);
++	      p += lgam2r5b;
++	      p += lgam2r5a;
++	    }
++	  else
++	    {
++	      z = x - 3;
++	      p = z * neval (z, RN3, NRN3) / deval (z, RD3, NRD3);
++	      p += lgam3b;
++	      p += lgam3a;
++	    }
++	  break;
++
++	case 4:
++	  z = x - 4;
++	  p = z * neval (z, RN4, NRN4) / deval (z, RD4, NRD4);
++	  p += lgam4b;
++	  p += lgam4a;
++	  break;
++
++	case 5:
++	  z = x - 5;
++	  p = z * neval (z, RN5, NRN5) / deval (z, RD5, NRD5);
++	  p += lgam5b;
++	  p += lgam5a;
++	  break;
++
++	case 6:
++	  z = x - 6;
++	  p = z * neval (z, RN6, NRN6) / deval (z, RD6, NRD6);
++	  p += lgam6b;
++	  p += lgam6a;
++	  break;
++
++	case 7:
++	  z = x - 7;
++	  p = z * neval (z, RN7, NRN7) / deval (z, RD7, NRD7);
++	  p += lgam7b;
++	  p += lgam7a;
++	  break;
++
++	case 8:
++	  z = x - 8;
++	  p = z * neval (z, RN8, NRN8) / deval (z, RD8, NRD8);
++	  p += lgam8b;
++	  p += lgam8a;
++	  break;
++
++	case 9:
++	  z = x - 9;
++	  p = z * neval (z, RN9, NRN9) / deval (z, RD9, NRD9);
++	  p += lgam9b;
++	  p += lgam9a;
++	  break;
++
++	case 10:
++	  z = x - 10;
++	  p = z * neval (z, RN10, NRN10) / deval (z, RD10, NRD10);
++	  p += lgam10b;
++	  p += lgam10a;
++	  break;
++
++	case 11:
++	  z = x - 11;
++	  p = z * neval (z, RN11, NRN11) / deval (z, RD11, NRD11);
++	  p += lgam11b;
++	  p += lgam11a;
++	  break;
++
++	case 12:
++	  z = x - 12;
++	  p = z * neval (z, RN12, NRN12) / deval (z, RD12, NRD12);
++	  p += lgam12b;
++	  p += lgam12a;
++	  break;
++
++	case 13:
++	  z = x - 13;
++	  p = z * neval (z, RN13, NRN13) / deval (z, RD13, NRD13);
++	  p += lgam13b;
++	  p += lgam13a;
++	  break;
++	}
++      return p;
++    }
++
++  if (x > MAXLGM)
++    return (*signgamp * huge * huge);
++
++  if (x > L(0x1p120))
++    return x * (__logl (x) - 1);
++  q = ls2pi - x;
++  q = (x - L(0.5)) * __logl (x) + q;
++  if (x > L(1.0e18))
++    return (q);
++
++  p = 1 / (x * x);
++  q += neval (p, RASY, NRASY) / x;
++  return (q);
++}
++strong_alias (__ieee754_lgammal_r, __lgammal_r_finite)
+diff --git a/sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c b/sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c
+index 64bfc46414..615707ca98 100644
+--- a/sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c
++++ b/sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c
+@@ -1,10 +1,104 @@
+-/* Looks like we can use ieee854 s_cbrtl.c as is for IBM extended format. */
+-#include <math_ldbl_opt.h>
+-#undef weak_alias
+-#define weak_alias(n,a)
++/* Implementation of cbrtl.  IBM Extended Precision version.
++   Cephes Math Library Release 2.2: January, 1991
++   Copyright 1984, 1991 by Stephen L. Moshier
++   Adapted for glibc October, 2001.
++
++   This 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.
++
++   This 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 this library; if not, see
++   <http://www.gnu.org/licenses/>.  */
++
++/* This file was copied from sysdeps/ieee754/ldbl-128/e_j0l.c.  */
+ 
+ #define _Float128 long double
+ #define L(x) x ## L
+ 
+-#include <sysdeps/ieee754/ldbl-128/s_cbrtl.c>
++#include <math_ldbl_opt.h>
++#include <math.h>
++#include <math_private.h>
++
++static const _Float128 CBRT2 = L(1.259921049894873164767210607278228350570251);
++static const _Float128 CBRT4 = L(1.587401051968199474751705639272308260391493);
++static const _Float128 CBRT2I = L(0.7937005259840997373758528196361541301957467);
++static const _Float128 CBRT4I = L(0.6299605249474365823836053036391141752851257);
++
++
++_Float128
++__cbrtl (_Float128 x)
++{
++  int e, rem, sign;
++  _Float128 z;
++
++  if (!isfinite (x))
++    return x + x;
++
++  if (x == 0)
++    return (x);
++
++  if (x > 0)
++    sign = 1;
++  else
++    {
++      sign = -1;
++      x = -x;
++    }
++
++  z = x;
++ /* extract power of 2, leaving mantissa between 0.5 and 1  */
++  x = __frexpl (x, &e);
++
++  /* Approximate cube root of number between .5 and 1,
++     peak relative error = 1.2e-6  */
++  x = ((((L(1.3584464340920900529734e-1) * x
++	  - L(6.3986917220457538402318e-1)) * x
++	 + L(1.2875551670318751538055e0)) * x
++	- L(1.4897083391357284957891e0)) * x
++       + L(1.3304961236013647092521e0)) * x + L(3.7568280825958912391243e-1);
++
++  /* exponent divided by 3 */
++  if (e >= 0)
++    {
++      rem = e;
++      e /= 3;
++      rem -= 3 * e;
++      if (rem == 1)
++	x *= CBRT2;
++      else if (rem == 2)
++	x *= CBRT4;
++    }
++  else
++    {				/* argument less than 1 */
++      e = -e;
++      rem = e;
++      e /= 3;
++      rem -= 3 * e;
++      if (rem == 1)
++	x *= CBRT2I;
++      else if (rem == 2)
++	x *= CBRT4I;
++      e = -e;
++    }
++
++  /* multiply by power of 2 */
++  x = __ldexpl (x, e);
++
++  /* Newton iteration */
++  x -= (x - (z / (x * x))) * L(0.3333333333333333333333333333333333333333);
++  x -= (x - (z / (x * x))) * L(0.3333333333333333333333333333333333333333);
++  x -= (x - (z / (x * x))) * L(0.3333333333333333333333333333333333333333);
++
++  if (sign < 0)
++    x = -x;
++  return (x);
++}
++
+ long_double_symbol (libm, __cbrtl, cbrtl);
+diff --git a/sysdeps/ieee754/ldbl-128ibm/t_expl.h b/sysdeps/ieee754/ldbl-128ibm/t_expl.h
+new file mode 100644
+index 0000000000..0ab0877301
+--- /dev/null
++++ b/sysdeps/ieee754/ldbl-128ibm/t_expl.h
+@@ -0,0 +1,972 @@
++/* Accurate table for expl().
++   Copyright (C) 1999-2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++/* __expl_table basically consists of four tables, T_EXPL_ARG{1,2} and
++   T_EXPL_RES{1,2}. All tables use positive and negative indexes, the 0 points
++   are marked by T_EXPL_* defines.
++   For ARG1 and RES1 tables lets B be 89 and S 256.0, for ARG2 and RES2 B is 65
++   and S 32768.0.
++   These table have the property that, for all integers -B <= i <= B
++   expl(__expl_table[T_EXPL_ARGN+2*i]+__expl_table[T_EXPL_ARGN+2*i+1]+r) ==
++   __expl_table[T_EXPL_RESN+i], __expl_table[T_EXPL_RESN+i] is some exact number
++   with the low 58 bits of the mantissa 0,
++   __expl_table[T_EXPL_ARGN+2*i] == i/S+s
++   where absl(s) <= 2^-54 and absl(r) <= 2^-212.  */
++
++#define _Float128 long double
++#define L(x) x ## L
++
++static const _Float128 __expl_table [] = {
++ L(-3.47656250000000000584188889839535373E-01), /* bffd640000000000002b1b04213cf000 */
++  L(6.90417668990715641167244540876988960E-32), /* 3f97667c3fdb588a6ae1af8748357a17 */
++ L(-3.43749999999999981853132895957607418E-01), /* bffd5ffffffffffffac4ff5f4050b000 */
++ L(-7.16021898043268093462818380603370350E-33), /* bf94296c8219427edc1431ac2498583e */
++ L(-3.39843750000000013418643523138766329E-01), /* bffd5c000000000003de1f027a30e000 */
++  L(8.16920774283317801641347327589583265E-32), /* 3f97a82b65774bdca1b4440d749ed8d3 */
++ L(-3.35937500000000014998092453039303051E-01), /* bffd5800000000000452a9f4d8857000 */
++ L(-6.55865578425428447938248396879359670E-32), /* bf97548b7d240f3d034b395e6eecfac8 */
++ L(-3.32031250000000000981984049529998541E-01), /* bffd540000000000004875277cda5000 */
++  L(6.91213046334032232108944519541512737E-32), /* 3f9766e5f925338a19045c94443b66e1 */
++ L(-3.28124999999999986646017645350399708E-01), /* bffd4ffffffffffffc26a667bf44d000 */
++ L(-6.16281060996110316602421505683742661E-32), /* bf973ffdcdcffb6fbffc86b2b8d42f5d */
++ L(-3.24218749999999991645717430645867963E-01), /* bffd4bfffffffffffd97901063e48000 */
++ L(-7.90797211087760527593856542417304137E-32), /* bf979a9afaaca1ada6a8ed1c80584d60 */
++ L(-3.20312499999999998918211610690789652E-01), /* bffd47ffffffffffffb02d9856d71000 */
++  L(8.64024799457616856987630373786503376E-32), /* 3f97c0a098623f95579d5d9b2b67342d */
++ L(-3.16406249999999998153974811017181883E-01), /* bffd43ffffffffffff77c991f1076000 */
++ L(-2.73176610180696076418536105483668404E-32), /* bf961baeccb32f9b1fcbb8e60468e95a */
++ L(-3.12500000000000011420976192575972779E-01), /* bffd400000000000034ab8240483d000 */
++  L(7.16573502812389453744433792609989420E-32), /* 3f977410f4c2cfc4335f28446c0fb363 */
++ L(-3.08593750000000001735496343854851414E-01), /* bffd3c000000000000800e995c176000 */
++ L(-1.56292999645122272621237565671593071E-32), /* bf95449b9cbdaff6ac1246adb2c826ac */
++ L(-3.04687499999999982592401295899221626E-01), /* bffd37fffffffffffafb8bc1e061a000 */
++  L(6.48993208584888904958594509625158417E-32), /* 3f9750f9fe8366d82d77afa0031a92e1 */
++ L(-3.00781249999999999230616898937763959E-01), /* bffd33ffffffffffffc73ac39da54000 */
++  L(6.57082437496961397305801409357792029E-32), /* 3f97552d3cb598ea80135cf3feb27ec4 */
++ L(-2.96874999999999998788769281703245722E-01), /* bffd2fffffffffffffa6a07fa5021000 */
++ L(-3.26588297198283968096426564544269170E-32), /* bf9653260fc1802f46b629aee171809b */
++ L(-2.92968750000000015318089182805941695E-01), /* bffd2c0000000000046a468614bd6000 */
++ L(-1.73291974845198589684358727559290718E-32), /* bf9567e9d158f52e483c8d8dcb5961dd */
++ L(-2.89062500000000007736778942676309681E-01), /* bffd280000000000023adf9f4c3d3000 */
++ L(-6.83629745986675744404029225571026236E-32), /* bf9762f5face6281c1daf1c6aedbdb45 */
++ L(-2.85156250000000001367091555763661937E-01), /* bffd2400000000000064dfa11e3fb000 */
++ L(-5.44898442619766878281110054067026237E-32), /* bf971aed6d2db9f542986a785edae072 */
++ L(-2.81249999999999986958718100227029406E-01), /* bffd1ffffffffffffc3db9265ca9d000 */
++  L(1.13007318374506125723591889451107046E-32), /* 3f94d569fe387f456a97902907ac3856 */
++ L(-2.77343750000000000356078829380495179E-01), /* bffd1c0000000000001a462390083000 */
++ L(-4.98979365468978332358409063436543102E-32), /* bf970315bbf3e0d14b5c94c900702d4c */
++ L(-2.73437499999999990276993957508540484E-01), /* bffd17fffffffffffd32919bcdc94000 */
++ L(-8.79390484115892344533724650295100871E-32), /* bf97c89b0b89cc19c3ab2b60da9bbbc3 */
++ L(-2.69531250000000002434203866460082225E-01), /* bffd14000000000000b39ccf9e130000 */
++  L(9.44060754687026590886751809927191596E-32), /* 3f97ea2f32cfecca5c64a26137a9210f */
++ L(-2.65624999999999997296320716986257179E-01), /* bffd0fffffffffffff3880f13a2bc000 */
++  L(2.07142664067265697791007875348396921E-32), /* 3f95ae37ee685b9122fbe377bd205ee4 */
++ L(-2.61718750000000010237478733739017956E-01), /* bffd0c000000000002f3648179d40000 */
++ L(-6.10552936159265665298996309192680256E-32), /* bf973d0467d31e407515a3cca0f3b4e2 */
++ L(-2.57812500000000011948220522778370303E-01), /* bffd08000000000003719f81275bd000 */
++  L(6.72477169058908902499239631466443836E-32), /* 3f975d2b8c475d3160cf72d227d8e6f9 */
++ L(-2.53906249999999991822993360536596860E-01), /* bffd03fffffffffffda4a4b62f818000 */
++ L(-2.44868296623215865054704392917190994E-32), /* bf95fc92516c6d057d29fc2528855976 */
++ L(-2.49999999999999986862019457428548084E-01), /* bffcfffffffffffff86d2d20d5ff4000 */
++ L(-3.85302898949105073614122724961613078E-32), /* bf96901f147cb7d643af71b6129ce929 */
++ L(-2.46093750000000000237554160737318435E-01), /* bffcf8000000000000230e8ade26b000 */
++ L(-1.52823675242678363494345369284988589E-32), /* bf953d6700c5f3fc303f79d0ec8c680a */
++ L(-2.42187500000000003023380963205457065E-01), /* bffcf0000000000001be2c1a78bb0000 */
++ L(-7.78402037952209709489481182714311699E-34), /* bf9102ab1f3998e887f0ee4cf940faa5 */
++ L(-2.38281249999999995309623303145485725E-01), /* bffce7fffffffffffd4bd2940f43f000 */
++ L(-3.54307216794236899443913216397197696E-32), /* bf966fef03ab69c3f289436205b21d02 */
++ L(-2.34374999999999998425804947623207526E-01), /* bffcdfffffffffffff17b097a6092000 */
++ L(-2.86038428948386602859761879407549696E-32), /* bf96290a0eba0131efe3a05fe188f2e3 */
++ L(-2.30468749999999993822207406785200832E-01), /* bffcd7fffffffffffc70519834eae000 */
++ L(-2.54339521031747516806893838749365762E-32), /* bf96081f0ad7f9107ae6cddb32c178ab */
++ L(-2.26562499999999997823524030344489884E-01), /* bffccffffffffffffebecf10093df000 */
++  L(4.31904611473158635644635628922959401E-32), /* 3f96c083f0b1faa7c4c686193e38d67c */
++ L(-2.22656250000000004835132405125162742E-01), /* bffcc8000000000002c98a233f19f000 */
++  L(2.54709791629335691650310168420597566E-33), /* 3f92a735903f5eed07a716ab931e20d9 */
++ L(-2.18749999999999988969454021829236626E-01), /* bffcbffffffffffff9a42dc14ce36000 */
++ L(-3.77236096429336082213752014054909454E-32), /* bf9687be8e5b2fca54d3e81157eac660 */
++ L(-2.14843750000000010613256919115758495E-01), /* bffcb80000000000061e3d828ecac000 */
++ L(-4.55194148712216691177097854305964738E-32), /* bf96d8b35c776aa3e1a4768271380503 */
++ L(-2.10937499999999993204656148110447201E-01), /* bffcaffffffffffffc152f2aea118000 */
++ L(-2.95044199165561453749332254271716417E-32), /* bf96326433b00b2439094d9bef22ddd1 */
++ L(-2.07031250000000012233944895423355677E-01), /* bffca80000000000070d695ee0e94000 */
++  L(1.93146788688385419095981415411012357E-32), /* 3f959126729135a5e390d4bb802a0bde */
++ L(-2.03125000000000008030983633336321863E-01), /* bffca0000000000004a129fbc51af000 */
++  L(2.37361904671826193563212931215900137E-32), /* 3f95ecfb3c4ba1b97ea3ad45cbb1e68a */
++ L(-1.99218750000000001763815712796132779E-01), /* bffc98000000000001044b12d9950000 */
++ L(-3.63171243370923753295192486732883239E-33), /* bf932db5fb3f27c38e0fa7bbcfc64f55 */
++ L(-1.95312500000000004883660234506677272E-01), /* bffc90000000000002d0b3779d1f9000 */
++ L(-3.19989507343607877747980892249711601E-33), /* bf9309d63de96bb3ef744c865f22f1bd */
++ L(-1.91406250000000013720152363227519348E-01), /* bffc88000000000007e8bcb387121000 */
++ L(-1.89295754093147174148371614722178860E-32), /* bf958926e2e67dfe812c508290add2e7 */
++ L(-1.87500000000000000182342082774432620E-01), /* bffc800000000000001ae8b06a39f000 */
++ L(-2.96812835183184815200854214892983927E-32), /* bf96343a62d156bbe71f55d14ca4b6e5 */
++ L(-1.83593750000000012410147185883290345E-01), /* bffc78000000000007276a1adda8d000 */
++ L(-2.02191931237489669058466239995304587E-32), /* bf95a3efab92d26ec2df90df036a117f */
++ L(-1.79687499999999997439177363346082917E-01), /* bffc6ffffffffffffe8616db2927d000 */
++ L(-9.92752326937775530007399526834009465E-33), /* bf949c5f88ed17041e1a3f1829d543cd */
++ L(-1.75781249999999995824373974504785174E-01), /* bffc67fffffffffffd97c94f13ea3000 */
++  L(1.44184772065335613487885714828816178E-32), /* 3f952b75c63476e7fcc2f5841c27bcce */
++ L(-1.71874999999999986685050259043077809E-01), /* bffc5ffffffffffff8530f6bc531a000 */
++ L(-3.49007014971241147689894940544402482E-32), /* bf966a6dfaa012aea8ffe6d90b02330f */
++ L(-1.67968749999999997316058782350439701E-01), /* bffc57fffffffffffe73eb914f2aa000 */
++  L(3.34025733574205019081305778794376391E-32), /* 3f965adf4572561fd5456a6c13d8babf */
++ L(-1.64062499999999993322730602128318480E-01), /* bffc4ffffffffffffc269be4f68f3000 */
++ L(-1.83345916769684984022099095506340635E-32), /* bf957ccb69026cb2f6024c211576d5f4 */
++ L(-1.60156249999999992419000744447607979E-01), /* bffc47fffffffffffba13df21784a000 */
++  L(2.73442789798110494773517431626534726E-32), /* 3f961bf58ff22c9b30f1e2b39f26d7d5 */
++ L(-1.56249999999999987665010524130393080E-01), /* bffc3ffffffffffff8e3ad45e7508000 */
++  L(2.02695576464836145806428118889332191E-32), /* 3f95a4fb7435a4a2f71de81eb8ae75d1 */
++ L(-1.52343749999999989905291167951491803E-01), /* bffc37fffffffffffa2e48aecfc24000 */
++ L(-3.61436631548815190395331054871041524E-32), /* bf967756567ebd108075ae527cc2e7f0 */
++ L(-1.48437500000000006686107754967759751E-01), /* bffc30000000000003dab20261b3c000 */
++ L(-2.15524270159131591469319477922198390E-32), /* bf95bfa05b82ef3a708c4f0395e9fcf6 */
++ L(-1.44531250000000005132889939177166485E-01), /* bffc28000000000002f57b1969e7b000 */
++  L(2.74741116529653547935086189244019604E-32), /* 3f961d4eb77c1185d34fe1b04a3f3cf5 */
++ L(-1.40625000000000000707469094533647325E-01), /* bffc2000000000000068676d3d5c4000 */
++  L(4.40607097220049957013547629906723266E-33), /* 3f936e0ac425daf795b42913cf0ef881 */
++ L(-1.36718749999999995713752139187543306E-01), /* bffc17fffffffffffd87762255991000 */
++ L(-3.73751317180116492404578048203389108E-32), /* bf9684202491e9cbb7ceb67d9ff7e0c9 */
++ L(-1.32812500000000007198453630478482191E-01), /* bffc10000000000004264de3a4379000 */
++ L(-3.97050085179660203884930593717220728E-32), /* bf969c52048de14be3c9c1971e50869c */
++ L(-1.28906250000000006070486371645733082E-01), /* bffc080000000000037fd87db2cb0000 */
++  L(3.59610068058504988294019521946586131E-32), /* 3f967570c10687cb8e9ebd0b280abf5a */
++ L(-1.25000000000000003700729208608337966E-01), /* bffc00000000000002222198bbc74000 */
++  L(3.23464851393124362331846965931995969E-33), /* 3f930cb95da3bfc847e593716c91d57a */
++ L(-1.21093750000000013729038501177102555E-01), /* bffbf000000000000fd418d1f5fda000 */
++  L(2.45242487730722066611358741283977619E-32), /* 3f95fd5945ad86a464292e26ac192a84 */
++ L(-1.17187499999999999765305306880205578E-01), /* bffbdfffffffffffffbabaf869845000 */
++ L(-1.14557520298960389903199646350205537E-32), /* bf94dbda735322179d9bcf392e1dd06d */
++ L(-1.13281250000000009579647893740755690E-01), /* bffbd000000000000b0b69bae7ab9000 */
++  L(2.37873962873837390105423621772752350E-32), /* 3f95ee0b7e0bd5ac1f6fab1e2a71abc3 */
++ L(-1.09375000000000008981153004560108539E-01), /* bffbc000000000000a5ac4bc1d2c3000 */
++  L(1.53152444860014076105003555837231015E-32), /* 3f953e15ce931e12ef9a152522e32bdd */
++ L(-1.05468749999999992399063850363228723E-01), /* bffbaffffffffffff73c998091408000 */
++ L(-8.75920903597804862471749360196688834E-33), /* bf946bd7e310a01bae5687ebdc47fcc5 */
++ L(-1.01562500000000007685885179918350550E-01), /* bffba0000000000008dc7910a648c000 */
++ L(-4.63820993797174451904075397785059501E-33), /* bf938153d0e54001a472da180fb5e8aa */
++ L(-9.76562499999999887262211517861331814E-02), /* bffb8ffffffffffff300915aa6fd6000 */
++ L(-2.63767025974952608658936466715705903E-33), /* bf92b64215bb8d520be5404620d38088 */
++ L(-9.37499999999999939650246024457439795E-02), /* bffb7ffffffffffff90aca26bd0fc000 */
++ L(-1.72047822349322956713582039121348377E-32), /* bf9565545015c5b9b56d02cfefca2c7d */
++ L(-8.98437500000000033088896383977486369E-02), /* bffb70000000000003d09ca1e3cbe000 */
++  L(3.04831994420989436248526129869697270E-33), /* 3f92fa7d30d2ed90e7ebbd6231fd08b1 */
++ L(-8.59374999999999947312400115121319225E-02), /* bffb5ffffffffffff9ecefc03376e000 */
++  L(1.50416954438393392150792422537312281E-32), /* 3f9538675ee99bd722fad0023c09c915 */
++ L(-8.20312500000000054182280847004695514E-02), /* bffb500000000000063f2dbd40200000 */
++  L(2.68399664523430004488075638997207289E-33), /* 3f92bdf49766629882c49a3da88928ed */
++ L(-7.81250000000000114767533968079748798E-02), /* bffb4000000000000d3b56f81ba70000 */
++  L(1.72318124201659121296305402819694281E-32), /* 3f9565e407aaabfb359e8a567d760de3 */
++ L(-7.42187500000000035531829472486812869E-02), /* bffb3000000000000418b6e9b5388000 */
++  L(2.09401756478514117051383998628099655E-32), /* 3f95b2e91221fcd74be0a86d8ad658d2 */
++ L(-7.03124999999999987474933134860732535E-02), /* bffb1ffffffffffffe8e53453d2ac000 */
++  L(2.28515798224350800271565551341211666E-32), /* 3f95da9bd6adf00894f05b5cc5530125 */
++ L(-6.64062500000000042267533361089054159E-02), /* bffb10000000000004df8473dbcf2000 */
++  L(1.97576478800281368377376002585430031E-32), /* 3f959a59acbddb2f53bd3096b66370e9 */
++ L(-6.25000000000000066329769382774201686E-02), /* bffb00000000000007a5b5914e336000 */
++ L(-1.46422615813786836245343723048221678E-33), /* bf91e69295f069fc0c4a9db181ea25a3 */
++ L(-5.85937500000000002823707957982406053E-02), /* bffae0000000000000a6aeab10592000 */
++  L(9.25637741701318872896718218457555829E-33), /* 3f94807eb021f1f40a37d4015b1eb76b */
++ L(-5.46875000000000081586888005226044448E-02), /* bffac0000000000012d00a3171e3a000 */
++ L(-4.87144542459404765480424673678105050E-33), /* bf9394b42faba6b7036fe7b36269daf3 */
++ L(-5.07812499999999927720348253140567013E-02), /* bffa9fffffffffffef555cc8dd914000 */
++ L(-3.01901021987395945826043649523451725E-33), /* bf92f59e7e3025691f290f8f67277faf */
++ L(-4.68749999999999935349476738962633103E-02), /* bffa7ffffffffffff117b4ea2b876000 */
++  L(1.21521638219189777347767475937119750E-32), /* 3f94f8c7f88c5b56674b94d984ac8ecb */
++ L(-4.29687500000000056305562847814228219E-02), /* bffa6000000000000cfbb19be30c0000 */
++ L(-1.18643699217679276275559592978275214E-32), /* bf94ecd39f0833a876550e83eb012b99 */
++ L(-3.90624999999999962692914526031373542E-02), /* bffa3ffffffffffff765c743922f9000 */
++ L(-4.91277156857520035712509544689973679E-33), /* bf939823189996193872e58ac0dececb */
++ L(-3.51562500000000108152468207687602886E-02), /* bffa20000000000018f031e41177f000 */
++  L(1.18599806302656253755207072755609820E-32), /* 3f94eca4f23e787fab73ce8f6b9b8d64 */
++ L(-3.12500000000000077376981036742289578E-02), /* bffa00000000000011d787e0b386f000 */
++  L(9.97730386477005171963635210799577079E-33), /* 3f949e70e498c46a0173ac0d46c699fc */
++ L(-2.73437500000000139436129596418623235E-02), /* bff9c00000000000404db66e70a08000 */
++  L(2.25755321633070123579875157841633859E-33), /* 3f927719b1a93074bdf9f3c2cb784785 */
++ L(-2.34375000000000088003629211828324876E-02), /* bff98000000000002895a27d45feb000 */
++  L(2.84374279216848803102126617873942975E-33), /* 3f92d87f70e749d6da6c260b68dc210b */
++ L(-1.95312500000000107408831063404855424E-02), /* bff9400000000000318898ba69f71000 */
++  L(2.47348089686935458989103979140011912E-33), /* 3f929afa3de45086fe909fdddb41edce */
++ L(-1.56250000000000081443917555362290635E-02), /* bff9000000000000258f335e9cdd6000 */
++ L(-2.43379314483517422161458863218426254E-33), /* bf9294621c8a9ccacf2b020ec19cad27 */
++ L(-1.17187500000000051490597418161403184E-02), /* bff88000000000002f7ddfa26221f000 */
++  L(1.83405297208145390679150568810924707E-33), /* 3f9230bbfc5d5fe1b534fbcda0465bb9 */
++ L(-7.81249999999999715861805208310174953E-03), /* bff7ffffffffffffcb95f3fff157d000 */
++  L(3.51548384878710915171654413641872451E-34), /* 3f8fd349b76c22966f77a39fc37ed704 */
++ L(-3.90625000000000309326013918295097128E-03), /* bff7000000000000390f820c8e153000 */
++  L(6.38058004651791109324060099097251911E-36), /* 3f8a0f665d3ac25a1ac94d688273dbcd */
++#define T_EXPL_ARG1 (2*89)
++  L(0.00000000000000000000000000000000000E+00), /* 00000000000000000000000000000000 */
++  L(0.00000000000000000000000000000000000E+00), /* 00000000000000000000000000000000 */
++  L(3.90625000000000245479958859972588985E-03), /* 3ff70000000000002d48769ac9874000 */
++ L(-6.58439598384342854976169982902779828E-36), /* bf8a1811b923e6c626b07ef29761482a */
++  L(7.81250000000001311374391093664996358E-03), /* 3ff800000000000078f3f3cd89111000 */
++  L(2.60265650555493781464273319671555602E-33), /* 3f92b070c3b635b87af426735a71fc87 */
++  L(1.17187500000000269581156218247101912E-02), /* 3ff8800000000000f8a50d02fe20d000 */
++  L(1.00961747974945520631836275894919326E-33), /* 3f914f80c1a4f8042044fe3b757b030b */
++  L(1.56249999999999797878275270751825475E-02), /* 3ff8ffffffffffff45935b69da62e000 */
++  L(2.03174577741375590087897353146748580E-33), /* 3f925194e863496e0f6e91cbf6b22e26 */
++  L(1.95312499999999760319884511789111533E-02), /* 3ff93fffffffffff917790ff9a8f4000 */
++  L(4.62788519658803722282100289809515007E-33), /* 3f9380783ba81295feeb3e4879d7d52d */
++  L(2.34374999999999822953909016349145918E-02), /* 3ff97fffffffffffae5a163bd3cd5000 */
++ L(-3.19499956304699705390404384504876533E-33), /* bf93096e2037ced8194cf344c692f8d6 */
++  L(2.73437500000000137220327275871555682E-02), /* 3ff9c000000000003f481dea5dd51000 */
++ L(-2.25757776523031994464630107442723424E-33), /* bf92771abcf988a02b414bf2614e3734 */
++  L(3.12499999999999790857640618332718621E-02), /* 3ff9ffffffffffff9f8cd40b51509000 */
++ L(-4.22479470489989916319395454536511458E-33), /* bf935efb7245612f371deca17cb7b30c */
++  L(3.51562499999999840753382405747597346E-02), /* 3ffa1fffffffffffdb47bd275f722000 */
++  L(1.08459658374118041980976756063083500E-34), /* 3f8e2055d18b7117c9db1c318b1e889b */
++  L(3.90624999999999989384433621470426757E-02), /* 3ffa3ffffffffffffd8d5e18b042e000 */
++ L(-7.41674226146122000759491297811091830E-33), /* bf94341454e48029e5b0205d91baffdc */
++  L(4.29687500000000107505739500500200462E-02), /* 3ffa60000000000018ca04cd9085c000 */
++ L(-4.74689012756713017494437969420919847E-34), /* bf903b7c268103c6f7fbaaa24142e287 */
++  L(4.68749999999999978700749928325717352E-02), /* 3ffa7ffffffffffffb16b6d5479e3000 */
++ L(-1.06208165308448830117773486334902917E-32), /* bf94b92be4b3b5b5a596a0a5187cc955 */
++  L(5.07812499999999815072625435955786253E-02), /* 3ffa9fffffffffffd55bd086d5cbc000 */
++ L(-9.37038897148383660401929567549111394E-33), /* bf94853b111b0175b491c80d00419416 */
++  L(5.46874999999999809511553152189867394E-02), /* 3ffabfffffffffffd4138bfa74a61000 */
++  L(1.06642963074562437340498606682822123E-32), /* 3f94bafa3fe991b39255d563dfa05d89 */
++  L(5.85937500000000184331996330905145551E-02), /* 3ffae000000000002a810a5f2f8bf000 */
++ L(-1.76639977694797200820296641773791945E-34), /* bf8ed596f07ce4408f1705c8ec16864c */
++  L(6.25000000000000021544696744852045001E-02), /* 3ffb000000000000027be32045e2b000 */
++  L(1.68616371995798354366633034788947149E-32), /* 3f955e33d7440794d8a1b25233d086ab */
++  L(6.64062499999999965563110718495802889E-02), /* 3ffb0ffffffffffffc079a38a3fed000 */
++ L(-1.82463217667830160048872113565316215E-32), /* bf957af6163bcdb97cefab44a942482a */
++  L(7.03124999999999759989183341261898222E-02), /* 3ffb1fffffffffffe454218acea05000 */
++ L(-1.07843770101525495515646940862541503E-32), /* bf94bff72aada26d94e76e71c07e0580 */
++  L(7.42187499999999898968873730710101412E-02), /* 3ffb2ffffffffffff45a166496dc1000 */
++  L(1.28629441689592874462780757154138223E-32), /* 3f950b2724597b8b93ce1e9d1cf4d035 */
++  L(7.81249999999999957198938523510804668E-02), /* 3ffb3ffffffffffffb10bc52adbc5000 */
++  L(1.13297573459968118467100063135856856E-33), /* 3f91787eea895b3c245899cf34ad0abd */
++  L(8.20312500000000199911640621145851159E-02), /* 3ffb500000000000170c59a661a89000 */
++ L(-1.51161335208135146756554123073528707E-32), /* bf9539f326c5ca84e7db5401566f3775 */
++  L(8.59375000000000134175373433347670743E-02), /* 3ffb6000000000000f78287547af0000 */
++  L(1.09763629458404270323909815379924900E-32), /* 3f94c7f0b61b6e3e27d44b9f5bbc7e9d */
++  L(8.98437500000000036533922600308306335E-02), /* 3ffb70000000000004364a83b7a14000 */
++  L(3.11459653680110433194288029777718358E-33), /* 3f9302c0248136d65cebeab69488d949 */
++  L(9.37500000000000184977946245216914691E-02), /* 3ffb800000000000155395d870b17000 */
++ L(-4.66656154468277949130395786965043927E-33), /* bf9383aec9b993b6db492b1ede786d8a */
++  L(9.76562500000000237839723100419376084E-02), /* 3ffb9000000000001b6bca237f6c4000 */
++ L(-1.03028043424658760249140747856831301E-32), /* bf94abf6352e3d2bb398e47919a343fb */
++  L(1.01562500000000012345545575236836572E-01), /* 3ffba000000000000e3bc30cd9a1f000 */
++  L(2.15755372310795701322789783729456319E-32), /* 3f95c01b3b819edd9d07548fafd61550 */
++  L(1.05468749999999976493840484471911438E-01), /* 3ffbafffffffffffe4e634cd77985000 */
++  L(1.78771847038773333029677216592309083E-32), /* 3f95734b6ae650f33dd43c49a1df9fc0 */
++  L(1.09375000000000002267015055992785402E-01), /* 3ffbc00000000000029d1ad08de7b000 */
++  L(6.23263106693943817730045115112427717E-33), /* 3f9402e4b39ce2198a45e1d045868cd6 */
++  L(1.13281250000000022354208618429577398E-01), /* 3ffbd0000000000019c5cc3f9d2b5000 */
++  L(5.40514416644786448581426756221178868E-33), /* 3f93c10ab4021472c662f69435de9269 */
++  L(1.17187500000000013252367133076817603E-01), /* 3ffbe000000000000f47688cc561b000 */
++ L(-7.12412585457324989451327215568641325E-33), /* bf9427ecb343a8d1758990565fcfbf45 */
++  L(1.21093750000000020759863992944300792E-01), /* 3ffbf0000000000017ef3af97bf04000 */
++  L(6.26591408357572503875647872077266444E-33), /* 3f940446a09a2da771b45fc075514d12 */
++  L(1.25000000000000004739659392396765618E-01), /* 3ffc00000000000002bb7344ecd89000 */
++ L(-1.55611398459729463981000080101758830E-32), /* bf95433135febefa9e6aa4db39e263d2 */
++  L(1.28906249999999982360888081057894783E-01), /* 3ffc07fffffffffff5d4ed3154361000 */
++ L(-1.77531518652835570781208599686606474E-32), /* bf9570b7f225ea076f97f418d11359c1 */
++  L(1.32812500000000010568583998727400436E-01), /* 3ffc1000000000000617a5d09526a000 */
++  L(2.12104021624990594668286391598300893E-32), /* 3f95b885d767a1048d93055927a27adc */
++  L(1.36718749999999998434125157367005292E-01), /* 3ffc17ffffffffffff18eaebc7970000 */
++  L(2.50454798592543203967309921276955297E-32), /* 3f9604164e5598528a76faff26cd1c97 */
++  L(1.40625000000000015550032422969330356E-01), /* 3ffc20000000000008f6c79d8928c000 */
++  L(7.80972982879849783680252962992639832E-33), /* 3f9444674acf2b3225c7647e0d95edf3 */
++  L(1.44531250000000012402535562111122522E-01), /* 3ffc28000000000007264a8bc1ff1000 */
++  L(2.79662468716455159585514763921671876E-32), /* 3f96226b095bd78aa650faf95a221993 */
++  L(1.48437500000000007761020440087419948E-01), /* 3ffc3000000000000479530ff8fe3000 */
++  L(2.15518492972728435680556239996258527E-32), /* 3f95bf9d49295e73a957906a029768cb */
++  L(1.52343750000000001733189947520484032E-01), /* 3ffc38000000000000ffc6109f71f000 */
++  L(8.34032236093545825619420380704500188E-33), /* 3f945a71851226a1d0ce5e656693153e */
++  L(1.56249999999999988073295321246958484E-01), /* 3ffc3ffffffffffff91fedd62ae0f000 */
++  L(2.44119337150624789345260194989620908E-32), /* 3f95fb041a57bc1c1280680ac1620bea */
++  L(1.60156250000000002076894210913572460E-01), /* 3ffc48000000000001327ed84a199000 */
++ L(-7.36124501128859978061216696286151753E-33), /* bf9431c62f01e59d2c1e00f195a0037f */
++  L(1.64062500000000000950861276373482172E-01), /* 3ffc500000000000008c5285fba85000 */
++ L(-4.80566184447001164583855800470217373E-33), /* bf938f3d1fcafd390f22f80e6c19421f */
++  L(1.67968749999999989878071706155265999E-01), /* 3ffc57fffffffffffa2a445c548c5000 */
++ L(-4.42154428718618459799673088733365064E-32), /* bf96cb28cf1c1b28006d53ffe633b22a */
++  L(1.71874999999999999459734108403218175E-01), /* 3ffc5fffffffffffffb04554e9dd4000 */
++ L(-3.29736288190321377985697972236270628E-32), /* bf96566af0ebc852e84be12859b24a31 */
++  L(1.75781249999999997987525759778901845E-01), /* 3ffc67fffffffffffed702df6ffff000 */
++ L(-1.28800728638468399687523924685844352E-32), /* bf950b8236b88ca0c1b739dc91a7e3fc */
++  L(1.79687500000000004929565820437175783E-01), /* 3ffc70000000000002d779bb32d2e000 */
++  L(1.60624461317978482424582320675174225E-32), /* 3f954d9a9cc0c963fd081f3dc922d04e */
++  L(1.83593750000000016873727045739708856E-01), /* 3ffc78000000000009ba1f6263c9a000 */
++ L(-3.83390389582056606880506003118452558E-32), /* bf968e22a5d826f77f19ee788474df22 */
++  L(1.87500000000000013443068740761666872E-01), /* 3ffc80000000000007bfd8c72a1bf000 */
++ L(-2.74141662712926256150154726565203091E-32), /* bf961caf5ac59c7f941f928e324c2cc1 */
++  L(1.91406249999999981494101786848611970E-01), /* 3ffc87fffffffffff55502eeae001000 */
++  L(3.68992437075565165346469517256118001E-32), /* 3f967f2f03f9096793372a27b92ad79d */
++  L(1.95312499999999989069921848800501648E-01), /* 3ffc8ffffffffffff9b3015280394000 */
++  L(3.69712249337856518452988332367785220E-32), /* 3f967fee5fdb5bd501ff93516999faa0 */
++  L(1.99218750000000021148042946919300804E-01), /* 3ffc9800000000000c30e67939095000 */
++  L(2.50142536781142175091322844848566649E-32), /* 3f9603c34ae58e10b300b07137ee618a */
++  L(2.03124999999999977732559198825437141E-01), /* 3ffc9ffffffffffff329e7df079e4000 */
++ L(-2.41951877287895024779300892731537816E-32), /* bf95f683aefe6965f080df8f59dd34a1 */
++  L(2.07031249999999996744030653771913124E-01), /* 3ffca7fffffffffffe1f80f4b73ca000 */
++ L(-1.94346475904454000031592792989765585E-32), /* bf9593a44f87870a3d100d498501ecc7 */
++  L(2.10937500000000000251399259834392298E-01), /* 3ffcb000000000000025199873310000 */
++ L(-1.33528748788094249098998693871759411E-33), /* bf91bbb9b25c813668d6103d08acac35 */
++  L(2.14843749999999993936323609611875097E-01), /* 3ffcb7fffffffffffc8128c866236000 */
++  L(1.14839877977014974625242788556545292E-32), /* 3f94dd06b4655c9b83a1305b240e7a42 */
++  L(2.18750000000000015181732784749663837E-01), /* 3ffcc0000000000008c06da5fff24000 */
++  L(1.42689085313142539755499441881408391E-32), /* 3f95285a87dfa7ea7dad5b3be8c669f4 */
++  L(2.22656249999999992172647770539596569E-01), /* 3ffcc7fffffffffffb7ce2fe531f6000 */
++ L(-3.34421462850496887359128610229650547E-32), /* bf965b487962b5c2d9056ca6ac0c2e5c */
++  L(2.26562499999999989595607223847082419E-01), /* 3ffccffffffffffffa0095277be5c000 */
++ L(-3.08983588107248752517344356508205569E-32), /* bf9640dded57157f8eded311213bdbcd */
++  L(2.30468749999999979130462438434567117E-01), /* 3ffcd7fffffffffff3f8332996560000 */
++ L(-3.01407539802851697849105682795217019E-32), /* bf9638ffde35dbdfe1a1ffe45185de5d */
++  L(2.34375000000000012194252337217891971E-01), /* 3ffce0000000000007078dd402c86000 */
++ L(-8.46879710915628592284714319904522657E-33), /* bf945fc7b29a2ac6c9eff9eb258a510f */
++  L(2.38281249999999982991877076137149870E-01), /* 3ffce7fffffffffff6320b486eece000 */
++ L(-2.93563878880439245627127095245798544E-32), /* bf9630daaa4f40ff05caf29ace2ea7d4 */
++  L(2.42187499999999981447559841442773990E-01), /* 3ffceffffffffffff54e24a09a8d5000 */
++ L(-4.56766746558806021264215486909850481E-32), /* bf96da556dee11f3113e5a3467b908e6 */
++  L(2.46093749999999991067720539980207318E-01), /* 3ffcf7fffffffffffad9d405dcb5d000 */
++  L(2.14033004219908074003010247652128251E-32), /* 3f95bc8776e8f9ae098884aa664cc3df */
++  L(2.50000000000000016613825838126835953E-01), /* 3ffd00000000000004c9e24c12bb3000 */
++  L(2.57617532593749185996714235009382870E-32), /* 3f960b867cc01178c0ec68226c6cb47d */
++  L(2.53906250000000013372004437827044321E-01), /* 3ffd04000000000003daae05b3168000 */
++  L(7.20177123439204414298152646284640101E-32), /* 3f9775eff59ddad7e7530b83934af87f */
++  L(2.57812499999999995765234725413886085E-01), /* 3ffd07fffffffffffec7878bad9d5000 */
++  L(6.51253187532920882777046064603770602E-32), /* 3f975226659ca241402e71c2011583b0 */
++  L(2.61718750000000007647689994011222248E-01), /* 3ffd0c000000000002344cc793a0f000 */
++  L(3.02370610028725823590045201871491395E-32), /* 3f9639ffe55fa2fa011674448b4e5b96 */
++  L(2.65624999999999986893899042596554269E-01), /* 3ffd0ffffffffffffc38f0c0a1e9f000 */
++ L(-2.07683715950724761146070082510569258E-32), /* bf95af579a92e872fef81abfdf06bae8 */
++  L(2.69531249999999979842788204900639327E-01), /* 3ffd13fffffffffffa30a908d67db000 */
++  L(8.71465252506557329027658736641075706E-32), /* 3f97c47d99e19830447a42b1c0ffac61 */
++  L(2.73437500000000006712165837793818271E-01), /* 3ffd18000000000001ef453a58edb000 */
++ L(-6.62704045767568912140550474455810301E-32), /* bf9758187a204dcb06ece46588aeeaba */
++  L(2.77343749999999994411329302988535617E-01), /* 3ffd1bfffffffffffe63a0fec9c9e000 */
++ L(-4.87273466291944117406493607771338767E-32), /* bf96fa0381b0844a0be46bac2d673f0c */
++  L(2.81250000000000012677892447379453135E-01), /* 3ffd20000000000003a7769e125d6000 */
++ L(-8.55871796664700790726282049552906783E-32), /* bf97bc64e01332cf7616b0091b8dff2c */
++  L(2.85156249999999998558643013736363981E-01), /* 3ffd23ffffffffffff95a5894bccf000 */
++ L(-1.33068334720606220176455289635046875E-32), /* bf95145f43290ecf5b7adcb24697bc73 */
++  L(2.89062500000000008831431235621753924E-01), /* 3ffd280000000000028ba504fac59000 */
++ L(-9.34157398616814623985483776710704237E-32), /* bf97e50ad1115b941fcb5f0c88a428f7 */
++  L(2.92968750000000019840235286110877063E-01), /* 3ffd2c000000000005b7f372d184f000 */
++  L(4.99302093775173155906059132992249671E-33), /* 3f939ecdcfb97bad3f8dbec5df5ec67d */
++  L(2.96875000000000015867911730971630513E-01), /* 3ffd3000000000000492d860c79db000 */
++  L(7.86107787827057767235127454590866211E-33), /* 3f944689517ee8f16cdb97d6a6938f32 */
++  L(3.00781250000000015814100002286124758E-01), /* 3ffd340000000000048edfe73a17d000 */
++ L(-1.65419431293024229981937172317171504E-32), /* bf9557900e3efca16c89646b57f68dc0 */
++  L(3.04687499999999985213157159965287195E-01), /* 3ffd37fffffffffffbbcec6f99b36000 */
++  L(9.68753602893894024018934325652944198E-32), /* 3f97f70170e5458660c33a7e8d43d049 */
++  L(3.08593749999999989969324338045156215E-01), /* 3ffd3bfffffffffffd1bdde4d0fb1000 */
++  L(7.10268609610294706092252562643261106E-32), /* 3f9770cae45cdf615010401a4b37d8d4 */
++  L(3.12500000000000002971606591018488854E-01), /* 3ffd40000000000000db440fbc06b000 */
++  L(6.38924218802905979887732294952782964E-32), /* 3f974bbf988bb5622bd8fbaa46e8b811 */
++  L(3.16406250000000006594921047402056305E-01), /* 3ffd44000000000001e69e8954814000 */
++  L(3.96079878754651470094149874444850097E-32), /* 3f969b5017b9fa7a1e86975258c73d3d */
++  L(3.20312500000000006713799366908329147E-01), /* 3ffd48000000000001ef64159c065000 */
++ L(-1.86401314975634286055150437995880517E-32), /* bf958323f0434911794e5fb8bfe136ba */
++  L(3.24218749999999987061246567584951210E-01), /* 3ffd4bfffffffffffc4549db9b928000 */
++ L(-3.18643523744758601387071062700407431E-32), /* bf964ae5fa7e26c2c3981bed12e14372 */
++  L(3.28124999999999991782776266707412953E-01), /* 3ffd4ffffffffffffda1ad0840ca8000 */
++ L(-4.46964199751314296839915534813144652E-32), /* bf96d0277729ffd74727150df6d15547 */
++  L(3.32031250000000000393816557756032682E-01), /* 3ffd540000000000001d0efc04fad000 */
++ L(-9.03246333902065439930373230002688649E-33), /* bf947731a008748cc6dee948839ef7ae */
++  L(3.35937499999999983810482995064392173E-01), /* 3ffd57fffffffffffb556cab8ae61000 */
++  L(5.27742727066129518825981597650621794E-32), /* 3f9712050a6ddbf1cabf1b971f4b5d0b */
++  L(3.39843750000000004310441349760912471E-01), /* 3ffd5c0000000000013e0def5ddc4000 */
++ L(-3.85927263474732591932884416445586106E-32), /* bf9690c51088ef3db9ca000829c450c2 */
++  L(3.43749999999999990248130003997484364E-01), /* 3ffd5ffffffffffffd3070624a0af000 */
++  L(9.62005170171527308106468341512327487E-34), /* 3f913fae595cea84432eb01430817fca */
++  L(3.47656250000000004085726414568625697E-01), /* 3ffd640000000000012d79309e291000 */
++ L(-6.59664093705705297250259434519072507E-32), /* bf97568465eafb0e662e64a5dbfaf35f */
++
++ L(-1.98364257812501251077851763965418372E-03), /* bff6040000000001cd90f658cf0b1000 */
++ L(-3.71984513103117734260309047540278737E-34), /* bf8fee73c54483194782aac4a6154d11 */
++ L(-1.95312500000000378520649630233891879E-03), /* bff60000000000008ba643bb5e2e8000 */
++ L(-1.12194202736719050440745599339855038E-34), /* bf8e2a436aeff7bc529873354f47a3f5 */
++ L(-1.92260742187499397430259771221991482E-03), /* bff5f7fffffffffe4361cb51170da000 */
++ L(-2.30068299876822157331268484824540848E-34), /* bf8f31d02f85cfe8c0cc02276ce0f437 */
++ L(-1.89208984375001137424603270262074989E-03), /* bff5f0000000000347456ed490c23000 */
++ L(-1.15012507244426243338260435466985403E-34), /* bf8e31c174d5677a937a34ad8d2a70b4 */
++ L(-1.86157226562500172319250342061336738E-03), /* bff5e800000000007f262fa3617b4000 */
++ L(-3.12438344643346437509767736937785561E-34), /* bf8f9f4d426a2457c273d34ef7d9bde9 */
++ L(-1.83105468749999505256246872355430379E-03), /* bff5dffffffffffe92f18c1c2b6fa000 */
++ L(-5.91130415288336591179087455220308942E-35), /* bf8d3a4c80b42dc036bae446c9807f78 */
++ L(-1.80053710937499445182387245573120522E-03), /* bff5d7fffffffffe669dea82b4a4c000 */
++ L(-1.92396289352411531324908916321392100E-34), /* bf8eff7a2123fb573ba9778550d669bd */
++ L(-1.77001953125000387737631542516323906E-03), /* bff5d000000000011e19915c3ddb7000 */
++  L(7.91101758977203355387806553469731354E-36), /* 3f8a507f5a70faaccf469e3461873dea */
++ L(-1.73950195312500034854670281415554486E-03), /* bff5c8000000000019b7dc6ef97bd000 */
++  L(1.55906551582436824067407021178835755E-34), /* 3f8e9e7880333e34955aebcde3cfb053 */
++ L(-1.70898437499998955782591472611429852E-03), /* bff5bffffffffffcfd80e88aa6b96000 */
++  L(8.22951661962611381718215899498500357E-35), /* 3f8db58e6031a779b59f6ece191de7cc */
++ L(-1.67846679687500586652037711131708544E-03), /* bff5b80000000001b0df6fd21c133000 */
++ L(-8.96642618848426299713145894522897419E-35), /* bf8ddcbcab46d531801bfae4121f2f8a */
++ L(-1.64794921875000109499161354039904782E-03), /* bff5b0000000000050cbce8915575000 */
++ L(-2.88077905394253859590587789680486639E-34), /* bf8f7eebd4dd860ef73b674d5e707959 */
++ L(-1.61743164062501133830507079150388351E-03), /* bff5a80000000003449e8700c3e82000 */
++ L(-3.68271725851639066312899986829350273E-34), /* bf8fe9845fe20a5fe74059e0cae185d6 */
++ L(-1.58691406249999015546015764131101956E-03), /* bff59ffffffffffd2999e668cdd28000 */
++  L(8.48197657099957029953716507898788812E-35), /* 3f8dc2faaebb97392e451b07b28c4b12 */
++ L(-1.55639648437500317366570219290722587E-03), /* bff5980000000000ea2cd9a40d256000 */
++ L(-3.45156704719737676412949957712570373E-36), /* bf8925a079505516c8e317ac1ff53255 */
++ L(-1.52587890625000568759013197767046039E-03), /* bff5900000000001a3ab8a3f6b698000 */
++ L(-1.01902948542497496574967177677556729E-34), /* bf8e0ee78d94d9b5ad3d63ae35c9b554 */
++ L(-1.49536132812500945889014955936485340E-03), /* bff5880000000002b9f1621b57743000 */
++ L(-3.32264697086631598830366079048117140E-34), /* bf8fb9a7d14c32289204fbb0c9eb20e0 */
++ L(-1.46484374999999931883259902869504725E-03), /* bff57fffffffffffcdbd1c90e1b4a000 */
++ L(-1.76487524793892929381101031660811433E-34), /* bf8ed52f2f724bc1ae870b18356337b4 */
++ L(-1.43432617187498876325946983333888768E-03), /* bff577fffffffffcc2dff8faa5570000 */
++ L(-3.54550084538495708816233114576143814E-34), /* bf8fd74724576915868c1e8ce9f430f1 */
++ L(-1.40380859374999215367421282192718062E-03), /* bff56ffffffffffdbd0b18aac65ed000 */
++ L(-1.90585907028351204486765167064669639E-34), /* bf8efaaa0c0e23e50c11b2120348054f */
++ L(-1.37329101562499692341771212945644892E-03), /* bff567ffffffffff1cfd00f1b0577000 */
++ L(-3.59631150411372589637918252836880320E-34), /* bf8fde08239ac74942a46298ea4fb715 */
++ L(-1.34277343749999137467356674296739172E-03), /* bff55ffffffffffd839030b05d53d000 */
++ L(-1.49571076125940368185068762485268117E-35), /* bf8b3e1a3d5c684b27a9f835b1d8d3c9 */
++ L(-1.31225585937499247038404301859788734E-03), /* bff557fffffffffdd469936e691e3000 */
++  L(3.10375845385355395586146533282311300E-34), /* 3f8f9c8f6d63b7a4145716ffd92491fb */
++ L(-1.28173828124999024755581675764821898E-03), /* bff54ffffffffffd306589b0ab21d000 */
++ L(-1.98541096105909793397376077900810019E-34), /* bf8f07e808bbb1e35106c294ffbb9687 */
++ L(-1.25122070312500340204619591143332523E-03), /* bff5480000000000fb06d5f16ad2c000 */
++  L(3.62884195935761446237911443317457521E-34), /* 3f8fe25b17d623178a386a6fa6c5afb2 */
++ L(-1.22070312499999591578388993012071279E-03), /* bff53ffffffffffed2a356c440074000 */
++ L(-2.96756662615653130862526710937493307E-35), /* bf8c3b90d8ff2a991e5bd16718fb0645 */
++ L(-1.19018554687498821966212632349422735E-03), /* bff537fffffffffc9ac3b585dda89000 */
++  L(1.44659971891167323357060028901142644E-34), /* 3f8e809279ab249edf1dad9fe13fb0bf */
++ L(-1.15966796875000160938908064907298384E-03), /* bff530000000000076c0800db9639000 */
++  L(2.50088010538742402346270685365928513E-34), /* 3f8f4c6c8a483b60201d30c1a83c3cb7 */
++ L(-1.12915039062500267151512523291939657E-03), /* bff5280000000000c51f7e7315137000 */
++  L(7.56402096465615210500092443924888831E-35), /* 3f8d922c1e485d99aea2668ed32b55a6 */
++ L(-1.09863281249998665006360103291051571E-03), /* bff51ffffffffffc26f2d4c9ce2ba000 */
++  L(1.43982174467233642713619821353592061E-34), /* 3f8e7ec530b3d92b6303bec1c81214d1 */
++ L(-1.06811523437500522742248711752028025E-03), /* bff518000000000181b7380f10446000 */
++  L(5.41265133745862349181293024531133174E-35), /* 3f8d1fc9313d018b30e790e06b6be723 */
++ L(-1.03759765624999980942114138999770552E-03), /* bff50ffffffffffff1f01130490e1000 */
++  L(1.21525139612685854366189534669623436E-34), /* 3f8e4311b96b6fcde412caf3f0d86fb9 */
++ L(-1.00708007812499602697537601515759439E-03), /* bff507fffffffffedad7afcce7051000 */
++  L(1.00020246351201558505328236381833392E-34), /* 3f8e09e640992512b1300744a7e984ed */
++ L(-9.76562499999992592487302113340463694E-04), /* bff4fffffffffffbbad8151f8adf6000 */
++ L(-1.64984406575162932060422892046851002E-34), /* bf8eb69a919986e8054b86fc34300f24 */
++ L(-9.46044921874989085824996924138179594E-04), /* bff4effffffffff9b55a204fd9792000 */
++ L(-9.29539174108308550334255350011347171E-35), /* bf8dee3a50ed896b4656fa577a1df3d7 */
++ L(-9.15527343750013735214860599791540029E-04), /* bff4e00000000007eaf5bf103f82d000 */
++  L(3.07557018309280519949818825519490586E-35), /* 3f8c470cfbef77d32c74cb8042f6ee81 */
++ L(-8.85009765625012292294986105781516428E-04), /* bff4d000000000071605c65403b97000 */
++  L(4.77499983783821950338363358545463558E-35), /* 3f8cfbc3dc18884c4c4f9e07d90d7bd3 */
++ L(-8.54492187499986941239470706817188192E-04), /* bff4bffffffffff878ddf9cab264a000 */
++ L(-1.60128240346239526958630011447901568E-34), /* bf8ea9b1a21e19e2d5bd84b0fbffcf95 */
++ L(-8.23974609374996290174598690241743810E-04), /* bff4affffffffffddc86c249ebe06000 */
++  L(1.61677540391961912631535763471935882E-34), /* 3f8eadd00841366b0dc2bc262c2c8c36 */
++ L(-7.93457031249988696952538334288757473E-04), /* bff49ffffffffff97bf6f0aa85a5f000 */
++  L(1.22318577008381887076634753347515709E-34), /* 3f8e452db5b5d250878f71040da06d14 */
++ L(-7.62939453124996723316499040007097041E-04), /* bff48ffffffffffe1c7265b431108000 */
++ L(-1.03845161748762410745671891558398468E-34), /* bf8e14115ad884c96d1a820c73647220 */
++ L(-7.32421874999998242520117923997325794E-04), /* bff47ffffffffffefca4498b7aa8a000 */
++  L(5.64005211953031009549514026639438083E-35), /* 3f8d2be06950f68f1a6d8ff829a6928e */
++ L(-7.01904296874999772890934814265622012E-04), /* bff46fffffffffffde7c0fe5d8041000 */
++  L(5.90245467325173644235991233229525762E-35), /* 3f8d39d40cc49002189243c194b1db0e */
++ L(-6.71386718750008699269643939210658742E-04), /* bff460000000000503c91d798b60c000 */
++ L(-5.20515801723324452151498579012322191E-35), /* bf8d14c0f08a6a9285b32b8bda003eb5 */
++ L(-6.40869140625005499535275057463709988E-04), /* bff45000000000032b969184e9751000 */
++ L(-6.69469163285461870099846471658294534E-35), /* bf8d63f36bab7b24d936c9380e3d3fa6 */
++ L(-6.10351562499999293780097329596079841E-04), /* bff43fffffffffff97c7c433e35ed000 */
++ L(-1.16941808547394177991845382085515086E-34), /* bf8e36e27886f10b234a7dd8fc588bf0 */
++ L(-5.79833984375000068291972326409994795E-04), /* bff43000000000000a13ff6dcf2bf000 */
++  L(1.17885044988246219185041488459766001E-34), /* 3f8e3964677e001a00412aab52790842 */
++ L(-5.49316406249990904622170867910987793E-04), /* bff41ffffffffffac1c25739c716b000 */
++ L(-3.31875702128137033065075734368960972E-35), /* bf8c60e928d8982c3c99aef4f885a121 */
++ L(-5.18798828125011293653756992177727236E-04), /* bff410000000000682a62cff36775000 */
++ L(-5.69971237642088463334239430962628187E-35), /* bf8d2f0c76f8757d61cd1abc7ea7d066 */
++ L(-4.88281249999990512232251384917893121E-04), /* bff3fffffffffff50fb48992320df000 */
++  L(1.02144616714408655325510171265051108E-35), /* 3f8ab279a3626612710b9b3ac71734ac */
++ L(-4.57763671874997554564967307956493434E-04), /* bff3dffffffffffd2e3c272e3cca9000 */
++ L(-8.25484058867957231164162481843653503E-35), /* bf8db6e71158e7bf93e2e683f07aa841 */
++ L(-4.27246093749991203999790346349633286E-04), /* bff3bffffffffff5dbe103cba0eb2000 */
++ L(-3.51191203319375193921924105905691755E-35), /* bf8c757356d0f3dd7fbefc0dd419ab50 */
++ L(-3.96728515624986649402960638705483281E-04), /* bff39ffffffffff09b996882706ec000 */
++ L(-5.51925962073095883016589497244931171E-36), /* bf89d586d49f22289cfc860bebb99056 */
++ L(-3.66210937499999945095511981300980754E-04), /* bff37fffffffffffefcb88bfc7df6000 */
++ L(-2.11696465278144529364423332249588595E-35), /* bf8bc23a84d28e5496c874ef9833be25 */
++ L(-3.35693359374992480958458008559640163E-04), /* bff35ffffffffff754c548a8798f2000 */
++ L(-8.58941791799705081104736787493668352E-35), /* bf8dc8b1192fb7c3662826d43acb7c68 */
++ L(-3.05175781250009811036303273640122156E-04), /* bff340000000000b4fb4f1aad1c76000 */
++ L(-8.61173897858769926480551302277426632E-35), /* bf8dc9e0eabb1c0b33051011b64769fa */
++ L(-2.74658203124987298321920308390303850E-04), /* bff31ffffffffff15b2056ac252fd000 */
++  L(3.35152809454778381053519808988046631E-37), /* 3f85c82fb59ff8d7c80d44e635420ab1 */
++ L(-2.44140624999999992770514819575735516E-04), /* bff2fffffffffffffbbb82d6a7636000 */
++  L(3.54445837111124472730013879165516908E-35), /* 3f8c78e955b01378be647b1c92aa9a77 */
++ L(-2.13623046875012756463165168672749438E-04), /* bff2c0000000001d6a1635fea6bbf000 */
++  L(1.50050816288650121729916777279129473E-35), /* 3f8b3f1f6f616a61129a58e131cbd31d */
++ L(-1.83105468749991323078784464300306893E-04), /* bff27fffffffffebfe0cbd0c82399000 */
++ L(-9.14919506501448661140572099029756008E-37), /* bf873754bacaa9d9513b6127e791eb47 */
++ L(-1.52587890625013337032336300236461546E-04), /* bff240000000001ec0cb57f2cc995000 */
++  L(2.84906084373176180870418394956384516E-35), /* 3f8c2ef6d03a7e6ab087c4f099e4de89 */
++ L(-1.22070312499990746786116828458007518E-04), /* bff1ffffffffffd553bbb49f35a34000 */
++  L(6.71618008964968339584520728412444537E-36), /* 3f8a1dacb99c60071fc9cd2349495bf0 */
++ L(-9.15527343750029275602791047595142231E-05), /* bff180000000000d8040cd6ecde28000 */
++ L(-1.95753652091078750312541716951402172E-35), /* bf8ba0526cfb24d8d59122f1c7a09a14 */
++ L(-6.10351562499913258461494008080572701E-05), /* bff0ffffffffffaffebbb92d7f6a9000 */
++  L(5.69868489273961111703398456218119973E-36), /* 3f89e4ca5df09ef4a4386dd5b3bf0331 */
++ L(-3.05175781250092882818419203884960853E-05), /* bff0000000000055ab55de88fac1d000 */
++  L(9.03341100018476837609128961872915953E-36), /* 3f8a803d229fa3a0e834a63abb06662b */
++#define T_EXPL_ARG2 (2*T_EXPL_ARG1 + 2 + 2*65)
++  L(0.00000000000000000000000000000000000E+00), /* 00000000000000000000000000000000 */
++  L(0.00000000000000000000000000000000000E+00), /* 00000000000000000000000000000000 */
++  L(3.05175781249814607084128277672749162E-05), /* 3feffffffffffeaa02abb9102f499000 */
++  L(1.00271855391179733380665816525889949E-36), /* 3f8755351afa042ac3f58114824d4c10 */
++  L(6.10351562500179243748093427073421439E-05), /* 3ff1000000000052a95de07a4c26d000 */
++  L(1.67231624299180373502350811501181670E-36), /* 3f881c87a53691cae9d77f4e40d66616 */
++  L(9.15527343749970728685313252158399200E-05), /* 3ff17ffffffffff28040cc2acde28000 */
++  L(2.43665747834893104318707597514407880E-36), /* 3f889e9366c7c6c6a2ecb78dc9b0509e */
++  L(1.22070312500027751961838150070880064E-04), /* 3ff200000000003ffddde6c153b53000 */
++ L(-1.73322146370624186623546452226755405E-35), /* bf8b709d8d658ed5dbbe943de56ee84e */
++  L(1.52587890624995916105682628143179430E-04), /* 3ff23ffffffffff6954b56e285d23000 */
++  L(1.23580432650945898349135528000443828E-35), /* 3f8b06d396601dde16de7d7bc27346e6 */
++  L(1.83105468750008670314358488289621794E-04), /* 3ff2800000000013fe0cdc8c823b7000 */
++  L(4.30446229148833293310207915930740796E-35), /* 3f8cc9ba9bfe554a4f7f2fece291eb23 */
++  L(2.13623046875005741337455947623248132E-04), /* 3ff2c0000000000d3d1662de21a3f000 */
++ L(-3.96110759869520786681660669615255057E-35), /* bf8ca5379b04ff4a31aab0ceacc917e6 */
++  L(2.44140624999981493573336463433440506E-04), /* 3ff2ffffffffffd553bbdf48e0534000 */
++ L(-1.39617373942387888957350179316792928E-35), /* bf8b28eeedc286015802b63f96b8c5cd */
++  L(2.74658203124984920706309918754626834E-04), /* 3ff31fffffffffee9d60c8439ec1d000 */
++ L(-3.16168080483901830349738314447356223E-36), /* bf890cf74f81c77a611abc1243812444 */
++  L(3.05175781250008648918265055410966055E-04), /* 3ff3400000000009f8b5c9a346636000 */
++  L(8.54421306185008998867856704677221443E-35), /* 3f8dc649cd40922fc08adc6b6b20ead0 */
++  L(3.35693359374988945462612499316774515E-04), /* 3ff35ffffffffff34146c540f15b2000 */
++  L(7.96443137431639500475160850431097078E-35), /* 3f8da77638ed3148fc4d99d1c9e13446 */
++  L(3.66210937500027690542093987739604535E-04), /* 3ff380000000001fecce34bea89c4000 */
++  L(2.14507323877752361258862577769090367E-35), /* 3f8bc834e554d38894cf91957b0253d3 */
++  L(3.96728515625003928083564943615052121E-04), /* 3ff3a00000000004875d9a4acf6ab000 */
++  L(4.88358523466632050664019922448605508E-35), /* 3f8d03a7eaeef1a9f78c71a12c44dd28 */
++  L(4.27246093750017799227172345607351585E-04), /* 3ff3c00000000014856794c3ee850000 */
++  L(6.66520494592631402182216588784828935E-35), /* 3f8d6262118fcdb59b8f16108f5f1a6c */
++  L(4.57763671875002108342364320152138181E-04), /* 3ff3e000000000026e45d855410b9000 */
++  L(7.21799615960261390920033272189522298E-35), /* 3f8d7fc645cff8879462296af975c9fd */
++  L(4.88281249999999768797631616370963356E-04), /* 3ff3ffffffffffffbbc2d7cc004df000 */
++ L(-5.30564629906905979452258114088325361E-35), /* bf8d1a18b71929a30d67a217a27ae851 */
++  L(5.18798828124997339054881383202487041E-04), /* 3ff40ffffffffffe775055eea5851000 */
++ L(-4.03682911253647925867848180522846377E-35), /* bf8cad44f0f3e5199d8a589d9332acad */
++  L(5.49316406249980511907933706754958501E-04), /* 3ff41ffffffffff4c410b29bb62fb000 */
++ L(-2.08166843948323917121806956728438051E-35), /* bf8bbab8cf691403249fe5b699e25143 */
++  L(5.79833984374989593561576568548497165E-04), /* 3ff42ffffffffffa0047df328d817000 */
++ L(-1.72745033420153042445343706432627539E-34), /* bf8ecb3c2d7d3a9e6e960576be901fdf */
++  L(6.10351562500008540711511259540838154E-04), /* 3ff4400000000004ec62f54f8c271000 */
++  L(7.41889382604319545724663095428976499E-35), /* 3f8d8a74c002c81a47c93b8e05d15f8e */
++  L(6.40869140625020444702875407535884986E-04), /* 3ff450000000000bc91b09718515d000 */
++ L(-4.47321009727305792048065440180490107E-35), /* bf8cdbac5c8fe70822081d8993eb5cb6 */
++  L(6.71386718750007531635964622352684074E-04), /* 3ff460000000000457792973db05c000 */
++  L(5.13698959677949336513874456684462092E-35), /* 3f8d112114436949c5ef38d8049004ab */
++  L(7.01904296875006634673332887754430334E-04), /* 3ff4700000000003d31adf2cb8b1d000 */
++ L(-8.25665755717729437292989870760751482E-35), /* bf8db6ffcc8ef71f8e648e3a8b160f5a */
++  L(7.32421874999998244664170215504673504E-04), /* 3ff47ffffffffffefcf5498bd5c8a000 */
++ L(-5.64005234937832153139057628112753364E-35), /* bf8d2be06a1dfe90e7bf90fba7c12a98 */
++  L(7.62939453125017456345986752604096408E-04), /* 3ff490000000000a101a1b093d4a8000 */
++ L(-1.11084094120417622468550608896588329E-34), /* bf8e274feabd2d94f6694507a46accb1 */
++  L(7.93457031249987558617598988993908016E-04), /* 3ff49ffffffffff8d3f9dcab74bbf000 */
++ L(-1.22966480225449015129079129940978828E-34), /* bf8e46e6a65eef8fa9e42eddf3da305e */
++  L(8.23974609374997378723747633335135819E-04), /* 3ff4affffffffffe7d2afbaa55b26000 */
++ L(-1.62270010016794279091906973366704963E-34), /* bf8eaf633f057ebdb664a34566401c4e */
++  L(8.54492187500023938282350821569920958E-04), /* 3ff4c0000000000dccaabce399e59000 */
++ L(-1.39076361712838158775374263169606160E-34), /* bf8e71ba779364b3bbdba7841f2c4ca1 */
++  L(8.85009765624987932362186815286691297E-04), /* 3ff4cffffffffff90b218886edc2a000 */
++  L(4.07328275060905585228261577392403980E-35), /* 3f8cb1254dbb6ea4b8cfa5ed4cf28d24 */
++  L(9.15527343749975579461305518559161974E-04), /* 3ff4dffffffffff1ec2a21f25df33000 */
++  L(1.16855112459192484947855553716334015E-35), /* 3f8af10bf319e9f5270cf249eeffbe5c */
++  L(9.46044921875016761584725882821122521E-04), /* 3ff4f00000000009a992c46c16d71000 */
++  L(9.51660680007524262741115611071680436E-35), /* 3f8df9fd56e81f8edf133843910ee831 */
++  L(9.76562499999974118878133088548272636E-04), /* 3ff4fffffffffff1149edc46a6df6000 */
++ L(-5.65271128977550656964071208289181661E-36), /* bf89e0e12689dd721aa2314c81eb6429 */
++  L(1.00708007812498671732140389760347830E-03), /* 3ff507fffffffffc2be94b90ed091000 */
++ L(-1.43355074891483635310132767255371379E-34), /* bf8e7d1a688c247b16022daab1316d55 */
++  L(1.03759765625002637786192745235343007E-03), /* 3ff51000000000079a57b966bc158000 */
++  L(2.95905815240957629366749917020106928E-34), /* 3f8f895387fc73bb38f8a1b254c01a60 */
++  L(1.06811523437500860568717813047520763E-03), /* 3ff51800000000027afcd5b35f5e6000 */
++ L(-5.98328495358586628195372356742878314E-35), /* bf8d3e204130013bf6328f1b70ff8c76 */
++  L(1.09863281250001439958487251556220070E-03), /* 3ff5200000000004268077c6c66bd000 */
++  L(2.41371837889426603334113000868144760E-34), /* 3f8f40d6948edf864054ccf151f9815e */
++  L(1.12915039062501298413451613770002366E-03), /* 3ff5280000000003be0f5dd8fe81b000 */
++ L(-1.28815268997394164973472617519705703E-34), /* bf8e567321172ea089dce4bc8354ecb7 */
++  L(1.15966796874997272036339054191407232E-03), /* 3ff52ffffffffff8231e3bcfff1e8000 */
++  L(1.02996064554316248496839462594377804E-34), /* 3f8e11cf7d402789244f68e2d4f985b1 */
++  L(1.19018554687502744121802585360546796E-03), /* 3ff5380000000007e8cdf3f8f6c20000 */
++ L(-1.43453217726255628994625761307322163E-34), /* bf8e7d5d3370d85a374f5f4802fc517a */
++  L(1.22070312499997743541996266398850614E-03), /* 3ff53ffffffffff97f0722561f454000 */
++ L(-1.41086259180534339713692694428211646E-34), /* bf8e77125519ff76244dfec5fbd58402 */
++  L(1.25122070312501024092560690174507039E-03), /* 3ff5480000000002f3a59d8820691000 */
++  L(3.84102646020099293168698506729765213E-34), /* 3f8ffe8f5b86f9c3569c8f26e19b1f50 */
++  L(1.28173828124997986521442660131425390E-03), /* 3ff54ffffffffffa3250a764439d9000 */
++  L(1.44644589735033114377952806106652650E-34), /* 3f8e808801b80dcf38323cdbfdca2549 */
++  L(1.31225585937501665804856968749058137E-03), /* 3ff5580000000004cd25a414c6d62000 */
++  L(1.67474574742200577294563576414361377E-34), /* 3f8ebd394a151dbda4f81d5d83c0f1e9 */
++  L(1.34277343749997290265837386401818888E-03), /* 3ff55ffffffffff83091b042cfd59000 */
++ L(-1.55650565030381326742591837551559103E-34), /* bf8e9dca490d7fecfadba9625ffb91c5 */
++  L(1.37329101562497720784949380297774268E-03), /* 3ff567fffffffff96e3c7312f5ccf000 */
++  L(1.65279335325630026116581677369221748E-34), /* 3f8eb763496f5bd7404f2298b402074f */
++  L(1.40380859374999099958354100336136647E-03), /* 3ff56ffffffffffd67e2f09f2a381000 */
++  L(1.89919944388961890195706641264717076E-34), /* 3f8ef8e4d0ffdfeba982aa8829501389 */
++  L(1.43432617187497484122173130998160625E-03), /* 3ff577fffffffff8bf9c1d71af8a8000 */
++  L(2.57638517142061429772064578590009568E-34), /* 3f8f5675d82c1cc4ada70fd3a957b89a */
++  L(1.46484374999999929342158925502052945E-03), /* 3ff57fffffffffffcbdd1c7671b46000 */
++  L(1.76487201934184070490166772482073801E-34), /* 3f8ed52ef732458f6e4c5c07504f33cc */
++  L(1.49536132812502318451070466256902933E-03), /* 3ff5880000000006aeb7066c8ad43000 */
++  L(2.38068367275295804321313550609246656E-34), /* 3f8f3c7277ae6fc390ace5e06c0b025b */
++  L(1.52587890625000448053340248672949543E-03), /* 3ff59000000000014a9ae2104b3bc000 */
++  L(1.01174455568392813258454590274740959E-34), /* 3f8e0cf7c434762991bb38e12acee215 */
++  L(1.55639648437501113499837053523090913E-03), /* 3ff5980000000003359e2c204355e000 */
++ L(-2.82398418808099749023517211651363693E-35), /* bf8c2c4c2971d88caa95e15fb1ccb1a1 */
++  L(1.58691406249999937955142588308171026E-03), /* 3ff59fffffffffffd2380ecbc87c2000 */
++ L(-1.27361695572422741562701199136538047E-34), /* bf8e5295e0e206dfb0f0266c07225448 */
++  L(1.61743164062498000531048954475329309E-03), /* 3ff5a7fffffffffa3ca6fe61ed94c000 */
++ L(-1.22606548862580061633942923016222044E-34), /* bf8e45f1b17bb61039d21a351bb207b8 */
++  L(1.64794921875001835451453858682255576E-03), /* 3ff5b000000000054a52fa20f6565000 */
++  L(1.39132339594152335892305491425264583E-34), /* 3f8e71e0904c5449b414ee49b191cef2 */
++  L(1.67846679687501263995029340691547953E-03), /* 3ff5b80000000003a4a9e912c910b000 */
++  L(6.67245854693585315412242764786197029E-35), /* 3f8d62c4ccac1e7511a617d469468ccd */
++  L(1.70898437500002646861403514115369655E-03), /* 3ff5c00000000007a109fbaa7e015000 */
++  L(6.87367172354719289559624829652240928E-36), /* 3f8a245fa835eceb42bae8128d9336db */
++  L(1.73950195312501174308226096992992128E-03), /* 3ff5c80000000003627c8d637a005000 */
++ L(-2.20824271875474985927385878948759352E-34), /* bf8f25869b1cbefb25e735992f232f57 */
++  L(1.77001953124997491747605207736194513E-03), /* 3ff5cffffffffff8c53c84b6883b8000 */
++  L(3.43123048533596296514343180408963705E-34), /* 3f8fc816b91d173ddadbbf09b1287906 */
++  L(1.80053710937497698911127570705069398E-03), /* 3ff5d7fffffffff95e1899f4a8430000 */
++  L(3.99231237340890073475077494556136100E-35), /* 3f8ca889148f62fa854da5674df41279 */
++  L(1.83105468750002267094899598630423914E-03), /* 3ff5e0000000000688d21e62ba674000 */
++ L(-3.22274595655810623999007524769365273E-34), /* bf8fac605cb9ae01eb719675ced25560 */
++  L(1.86157226562500499224728040579690330E-03), /* 3ff5e80000000001705ce28a6d89e000 */
++  L(3.07094985075881613489605622068441083E-34), /* 3f8f98330225ec7e2c8f3c0d1c432b91 */
++  L(1.89208984374998234666824993196980949E-03), /* 3ff5effffffffffae969fdc7cd8cf000 */
++ L(-3.06287628722973914692165056776495733E-34), /* bf8f9720477d9cfa10e464df7f91020c */
++  L(1.92260742187501225343755557292811682E-03), /* 3ff5f800000000038824e428ed49a000 */
++  L(6.30049124729794620592961282769623368E-35), /* 3f8d4efdd7cd4336d88a6aa49e1e96bc */
++  L(1.95312499999998514894032051116231258E-03), /* 3ff5fffffffffffbb82f6a04f1ae0000 */
++ L(-6.14610057507500948543216998736262902E-35), /* bf8d46c862d39255370e7974d48daa7e */
++  L(1.98364257812501222021119324146882732E-03), /* 3ff6040000000001c2d8a1aa5188d000 */
++  L(3.71942298418113774118754986159801984E-34), /* 3f8fee6567d9940495519ffe62cbc9a4 */
++
++  L(7.06341639425619532977052017486130353E-01), /* 3ffe69a59c8245a9ac00000000000000 */
++  L(7.09106182437398424589503065362805501E-01), /* 3ffe6b0ff72deb89d000000000000000 */
++  L(7.11881545564596485142772053222870454E-01), /* 3ffe6c7bbce9a6d93000000000000000 */
++  L(7.14667771155948150507697391731198877E-01), /* 3ffe6de8ef213d71e000000000000000 */
++  L(7.17464901725936049503573599395167548E-01), /* 3ffe6f578f41e1a9e400000000000000 */
++  L(7.20272979955439790478166628417966422E-01), /* 3ffe70c79eba33c06c00000000000000 */
++  L(7.23092048692387218133958981525211129E-01), /* 3ffe72391efa434c7400000000000000 */
++  L(7.25922150952408251622927082280511968E-01), /* 3ffe73ac117390acd800000000000000 */
++  L(7.28763329919491220643124052003258839E-01), /* 3ffe752077990e79d000000000000000 */
++  L(7.31615628946641782803794740175362676E-01), /* 3ffe769652df22f7e000000000000000 */
++  L(7.34479091556544505525749855223693885E-01), /* 3ffe780da4bba98c4800000000000000 */
++  L(7.37353761442226890432394270646909717E-01), /* 3ffe79866ea5f432d400000000000000 */
++  L(7.40239682467726090031590047146892175E-01), /* 3ffe7b00b216ccf53000000000000000 */
++  L(7.43136898668758316688354170764796436E-01), /* 3ffe7c7c70887763c000000000000000 */
++  L(7.46045454253390638577059235103661194E-01), /* 3ffe7df9ab76b20fd000000000000000 */
++  L(7.48965393602715662213498148958024103E-01), /* 3ffe7f78645eb8076400000000000000 */
++  L(7.51896761271528629722027403659012634E-01), /* 3ffe80f89cbf42526400000000000000 */
++  L(7.54839601989007347171423134568613023E-01), /* 3ffe827a561889716000000000000000 */
++  L(7.57793960659394638668118204805068672E-01), /* 3ffe83fd91ec46ddc000000000000000 */
++  L(7.60759882362683631518152083117456641E-01), /* 3ffe858251bdb68b8c00000000000000 */
++  L(7.63737412355305483879774897104653064E-01), /* 3ffe87089711986c9400000000000000 */
++  L(7.66726596070820082262642358728044201E-01), /* 3ffe8890636e31f54400000000000000 */
++  L(7.69727479120609181517664865168626420E-01), /* 3ffe8a19b85b4fa2d800000000000000 */
++  L(7.72740107294572486917871856348938309E-01), /* 3ffe8ba4976246833800000000000000 */
++  L(7.75764526561826289752232810315035749E-01), /* 3ffe8d31020df5be4400000000000000 */
++  L(7.78800783071404878477039801509818062E-01), /* 3ffe8ebef9eac820b000000000000000 */
++  L(7.81848923152964780936002853195532225E-01), /* 3ffe904e8086b5a87800000000000000 */
++  L(7.84908993317491698871180005880887620E-01), /* 3ffe91df97714512d800000000000000 */
++  L(7.87981040258010162480317717381694820E-01), /* 3ffe9372403b8d6bcc00000000000000 */
++  L(7.91065110850296016042904057030682452E-01), /* 3ffe95067c78379f2800000000000000 */
++  L(7.94161252153591734614934694036492147E-01), /* 3ffe969c4dbb800b4800000000000000 */
++  L(7.97269511411324433014513601847284008E-01), /* 3ffe9833b59b38154400000000000000 */
++  L(8.00389936051826789142893403550260700E-01), /* 3ffe99ccb5aec7bec800000000000000 */
++  L(8.03522573689060742863077280162542593E-01), /* 3ffe9b674f8f2f3d7c00000000000000 */
++  L(8.06667472123343942680406826184480451E-01), /* 3ffe9d0384d70893f800000000000000 */
++  L(8.09824679342079301047618855591281317E-01), /* 3ffe9ea15722892c7800000000000000 */
++  L(8.12994243520486992160556383169023320E-01), /* 3ffea040c80f8374f000000000000000 */
++  L(8.16176213022339780422953481320291758E-01), /* 3ffea1e1d93d687d0000000000000000 */
++  L(8.19370636400700819157449927843117621E-01), /* 3ffea3848c4d49954c00000000000000 */
++  L(8.22577562398664585696650419777142815E-01), /* 3ffea528e2e1d9f09800000000000000 */
++  L(8.25797039950100647542896581398963463E-01), /* 3ffea6cede9f70467c00000000000000 */
++  L(8.29029118180400342863478613253391813E-01), /* 3ffea876812c0877bc00000000000000 */
++  L(8.32273846407226292054559735333896242E-01), /* 3ffeaa1fcc2f45343800000000000000 */
++  L(8.35531274141265073440720811959181447E-01), /* 3ffeabcac15271a2a400000000000000 */
++  L(8.38801451086982535754188461396552157E-01), /* 3ffead7762408309bc00000000000000 */
++  L(8.42084427143382358016410194068157580E-01), /* 3ffeaf25b0a61a7b4c00000000000000 */
++  L(8.45380252404767357221615498019673396E-01), /* 3ffeb0d5ae318680c400000000000000 */
++  L(8.48688977161503960155997106085123960E-01), /* 3ffeb2875c92c4c99400000000000000 */
++  L(8.52010651900789478530029441571969073E-01), /* 3ffeb43abd7b83db1c00000000000000 */
++  L(8.55345327307422548246407245642330963E-01), /* 3ffeb5efd29f24c26400000000000000 */
++  L(8.58693054264576483003423845730139874E-01), /* 3ffeb7a69db2bcc77800000000000000 */
++  L(8.62053883854575708767242758767679334E-01), /* 3ffeb95f206d17228000000000000000 */
++  L(8.65427867359675251357487013592617586E-01), /* 3ffebb195c86b6b29000000000000000 */
++  L(8.68815056262843166123843730019871145E-01), /* 3ffebcd553b9d7b62000000000000000 */
++  L(8.72215502248546159513864495238522068E-01), /* 3ffebe9307c271855000000000000000 */
++  L(8.75629257203538208242932228131394368E-01), /* 3ffec0527a5e384ddc00000000000000 */
++  L(8.79056373217652342599848225290770642E-01), /* 3ffec213ad4c9ed0d800000000000000 */
++  L(8.82496902584595399599010079327854328E-01), /* 3ffec3d6a24ed8221800000000000000 */
++  L(8.85950897802745995779361010136199184E-01), /* 3ffec59b5b27d9696800000000000000 */
++  L(8.89418411575955636383383762222365476E-01), /* 3ffec761d99c5ba58800000000000000 */
++  L(8.92899496814352794382685374330321793E-01), /* 3ffec92a1f72dd70d400000000000000 */
++  L(8.96394206635150403439382671422208659E-01), /* 3ffecaf42e73a4c7d800000000000000 */
++  L(8.99902594363456265202927397695020773E-01), /* 3ffeccc00868c0d18800000000000000 */
++  L(9.03424713533086704009278378180169966E-01), /* 3ffece8daf1e0ba94c00000000000000 */
++  L(9.06960617887383580004723171441582963E-01), /* 3ffed05d24612c2af000000000000000 */
++  L(9.10510361380034133338412516422977205E-01), /* 3ffed22e6a0197c02c00000000000000 */
++  L(9.14073998175894436579724811053893063E-01), /* 3ffed40181d094303400000000000000 */
++  L(9.17651582651815816982221463149471674E-01), /* 3ffed5d66da13970f400000000000000 */
++  L(9.21243169397474526149949269893113524E-01), /* 3ffed7ad2f48737a2000000000000000 */
++  L(9.24848813216204823639543519675498828E-01), /* 3ffed985c89d041a3000000000000000 */
++  L(9.28468569125835141431224428743007593E-01), /* 3ffedb603b7784cd1800000000000000 */
++  L(9.32102492359527579068867453315760940E-01), /* 3ffedd3c89b26894e000000000000000 */
++  L(9.35750638366620729469147477175283711E-01), /* 3ffedf1ab529fdd41c00000000000000 */
++  L(9.39413062813475779888605643463961314E-01), /* 3ffee0fabfbc702a3c00000000000000 */
++  L(9.43089821584325888048638830696290825E-01), /* 3ffee2dcab49ca51b400000000000000 */
++  L(9.46780970782128888929563004239753354E-01), /* 3ffee4c079b3f8000400000000000000 */
++  L(9.50486566729423443256052905780961737E-01), /* 3ffee6a62cdec7c7b000000000000000 */
++  L(9.54206665969188322362626308859034907E-01), /* 3ffee88dc6afecfbfc00000000000000 */
++  L(9.57941325265705301283958306157728657E-01), /* 3ffeea77490f0196b000000000000000 */
++  L(9.61690601605425299247542625380447134E-01), /* 3ffeec62b5e5881fb000000000000000 */
++  L(9.65454552197837823079851204965962097E-01), /* 3ffeee500f1eed967000000000000000 */
++  L(9.69233234476344074348475032820715569E-01), /* 3ffef03f56a88b5d7800000000000000 */
++  L(9.73026706099133165128733935489435680E-01), /* 3ffef2308e71a927a800000000000000 */
++  L(9.76835024950062025261843245971249416E-01), /* 3ffef423b86b7ee79000000000000000 */
++  L(9.80658249139538557015427500118676107E-01), /* 3ffef618d68936c09c00000000000000 */
++  L(9.84496437005408397968864164795377292E-01), /* 3ffef80feabfeefa4800000000000000 */
++  L(9.88349647113845042323276857132441364E-01), /* 3ffefa08f706bbf53800000000000000 */
++  L(9.92217938260243514925207364285597578E-01), /* 3ffefc03fd56aa225000000000000000 */
++  L(9.96101369470117486981664001177705359E-01), /* 3ffefe00ffaabffbbc00000000000000 */
++#define T_EXPL_RES1 (T_EXPL_ARG2 + 2 + 2*65 + 89)
++  L(1.00000000000000000000000000000000000E+00), /* 3fff0000000000000000000000000000 */
++  L(1.00391388933834757590801700644078664E+00), /* 3fff0100802ab5577800000000000000 */
++  L(1.00784309720644799091004983893071767E+00), /* 3fff0202015600445c00000000000000 */
++  L(1.01178768355933151879000320150225889E+00), /* 3fff0304848362076c00000000000000 */
++  L(1.01574770858668572692806719715008512E+00), /* 3fff04080ab55de39000000000000000 */
++  L(1.01972323271377413034244341361045372E+00), /* 3fff050c94ef7a206c00000000000000 */
++  L(1.02371431660235789884438872832106426E+00), /* 3fff06122436410dd000000000000000 */
++  L(1.02772102115162167201845022646011785E+00), /* 3fff0718b98f42085000000000000000 */
++  L(1.03174340749910264936062276319717057E+00), /* 3fff08205601127ec800000000000000 */
++  L(1.03578153702162378824169763902318664E+00), /* 3fff0928fa934ef90800000000000000 */
++  L(1.03983547133622999947277776300325058E+00), /* 3fff0a32a84e9c1f5800000000000000 */
++  L(1.04390527230112850620713516036630608E+00), /* 3fff0b3d603ca7c32800000000000000 */
++  L(1.04799100201663270004459604933799710E+00), /* 3fff0c49236829e8bc00000000000000 */
++  L(1.05209272282610977189420964350574650E+00), /* 3fff0d55f2dce5d1e800000000000000 */
++  L(1.05621049731693195106174698594259098E+00), /* 3fff0e63cfa7ab09d000000000000000 */
++  L(1.06034438832143151909548350886325352E+00), /* 3fff0f72bad65671b800000000000000 */
++  L(1.06449445891785943185681162503897212E+00), /* 3fff1082b577d34ed800000000000000 */
++  L(1.06866077243134810492719566354935523E+00), /* 3fff1193c09c1c595c00000000000000 */
++  L(1.07284339243487741866189821848820429E+00), /* 3fff12a5dd543ccc4c00000000000000 */
++  L(1.07704238275024494209120007326419000E+00), /* 3fff13b90cb25176a400000000000000 */
++  L(1.08125780744903959851299646288680378E+00), /* 3fff14cd4fc989cd6400000000000000 */
++  L(1.08548973085361949442173568058933597E+00), /* 3fff15e2a7ae28fecc00000000000000 */
++  L(1.08973821753809324563988525369495619E+00), /* 3fff16f9157587069400000000000000 */
++  L(1.09400333232930546678574046381982043E+00), /* 3fff18109a3611c35000000000000000 */
++  L(1.09828514030782586896606289883493446E+00), /* 3fff192937074e0cd800000000000000 */
++  L(1.10258370680894224324930519287590869E+00), /* 3fff1a42ed01d8cbc800000000000000 */
++  L(1.10689909742365749645287564817408565E+00), /* 3fff1b5dbd3f68122400000000000000 */
++  L(1.11123137799969046168868658241990488E+00), /* 3fff1c79a8dacc350c00000000000000 */
++  L(1.11558061464248076122274255794764031E+00), /* 3fff1d96b0eff0e79400000000000000 */
++  L(1.11994687371619722204840741142106708E+00), /* 3fff1eb4d69bde569c00000000000000 */
++  L(1.12433022184475073235176978414529003E+00), /* 3fff1fd41afcba45e800000000000000 */
++  L(1.12873072591281087273529237791080959E+00), /* 3fff20f47f31c92e4800000000000000 */
++  L(1.13314845306682632219974493636982515E+00), /* 3fff2216045b6f5cd000000000000000 */
++  L(1.13758347071604959399593326452304609E+00), /* 3fff2338ab9b32134800000000000000 */
++  L(1.14203584653356560174586320499656722E+00), /* 3fff245c7613b8a9b000000000000000 */
++  L(1.14650564845732405583333957110880874E+00), /* 3fff258164e8cdb0d800000000000000 */
++  L(1.15099294469117646722011727433709893E+00), /* 3fff26a7793f60164400000000000000 */
++  L(1.15549780370591653744227755851170514E+00), /* 3fff27ceb43d84490400000000000000 */
++  L(1.16002029424032515603215642840950750E+00), /* 3fff28f7170a755fd800000000000000 */
++  L(1.16456048530221917269855680387991015E+00), /* 3fff2a20a2ce96406400000000000000 */
++  L(1.16911844616950438835445424956560601E+00), /* 3fff2b4b58b372c79400000000000000 */
++  L(1.17369424639123270948104504896036815E+00), /* 3fff2c7739e3c0f32c00000000000000 */
++  L(1.17828795578866324378353169777255971E+00), /* 3fff2da4478b620c7400000000000000 */
++  L(1.18289964445632783673900689791480545E+00), /* 3fff2ed282d763d42400000000000000 */
++  L(1.18752938276310060494722620205720887E+00), /* 3fff3001ecf601af7000000000000000 */
++  L(1.19217724135327157730657177125976887E+00), /* 3fff31328716a5d63c00000000000000 */
++  L(1.19684329114762477708211463323095813E+00), /* 3fff32645269ea829000000000000000 */
++  L(1.20152760334452030077656559114984702E+00), /* 3fff339750219b212c00000000000000 */
++  L(1.20623024942098072687102217059873510E+00), /* 3fff34cb8170b5835400000000000000 */
++  L(1.21095130113378179892436037334846333E+00), /* 3fff3600e78b6b11d000000000000000 */
++  L(1.21569083052054743854242246925423387E+00), /* 3fff373783a722012400000000000000 */
++  L(1.22044890990084875515009343871497549E+00), /* 3fff386f56fa7686e800000000000000 */
++  L(1.22522561187730755216662714701669756E+00), /* 3fff39a862bd3c106400000000000000 */
++  L(1.23002100933670455162882717559114099E+00), /* 3fff3ae2a8287e7a8000000000000000 */
++  L(1.23483517545109100499445276000187732E+00), /* 3fff3c1e2876834aa800000000000000 */
++  L(1.23966818367890557750499169742397498E+00), /* 3fff3d5ae4e2cae92c00000000000000 */
++  L(1.24452010776609517384017067342938390E+00), /* 3fff3e98deaa11dcbc00000000000000 */
++  L(1.24939102174724003813111039562500082E+00), /* 3fff3fd8170a52071800000000000000 */
++  L(1.25428099994668373895478907797951251E+00), /* 3fff41188f42c3e32000000000000000 */
++  L(1.25919011697966698459794088194030337E+00), /* 3fff425a4893dfc3f800000000000000 */
++  L(1.26411844775346637881341393949696794E+00), /* 3fff439d443f5f159000000000000000 */
++  L(1.26906606746853711786826579555054195E+00), /* 3fff44e183883d9e4800000000000000 */
++  L(1.27403305161966090564007458851847332E+00), /* 3fff462707b2bac20c00000000000000 */
++  L(1.27901947599709753244923149395617656E+00), /* 3fff476dd2045ac67800000000000000 */
++  L(1.28402541668774150540599521264084615E+00), /* 3fff48b5e3c3e8186800000000000000 */
++  L(1.28905095007628295311619126550795045E+00), /* 3fff49ff3e397492bc00000000000000 */
++  L(1.29409615284637330434591717676084954E+00), /* 3fff4b49e2ae5ac67400000000000000 */
++  L(1.29916110198179535206719492634874769E+00), /* 3fff4c95d26d3f440800000000000000 */
++  L(1.30424587476763775839572190307080746E+00), /* 3fff4de30ec211e60000000000000000 */
++  L(1.30935054879147461104338390214252286E+00), /* 3fff4f3198fa0f1cf800000000000000 */
++  L(1.31447520194454914310711046709911898E+00), /* 3fff50817263c13cd000000000000000 */
++  L(1.31961991242296217130558488861424848E+00), /* 3fff51d29c4f01cb3000000000000000 */
++  L(1.32478475872886558573071624778094701E+00), /* 3fff5325180cfacf7800000000000000 */
++  L(1.32996981967165983640200010995613411E+00), /* 3fff5478e6f02823d000000000000000 */
++  L(1.33517517436919680440254865061433520E+00), /* 3fff55ce0a4c58c7bc00000000000000 */
++  L(1.34040090224898678084031189428060316E+00), /* 3fff57248376b033d800000000000000 */
++  L(1.34564708304941055283521222918352578E+00), /* 3fff587c53c5a7af0400000000000000 */
++  L(1.35091379682093615244298234756570309E+00), /* 3fff59d57c910fa4e000000000000000 */
++  L(1.35620112392734021300455538039386738E+00), /* 3fff5b2fff3210fd9400000000000000 */
++  L(1.36150914504693443252136830778908916E+00), /* 3fff5c8bdd032e770800000000000000 */
++  L(1.36683794117379636690046140756749082E+00), /* 3fff5de9176045ff5400000000000000 */
++  L(1.37218759361900544124779344201670028E+00), /* 3fff5f47afa69210a800000000000000 */
++  L(1.37755818401188367960941150158760138E+00), /* 3fff60a7a734ab0e8800000000000000 */
++  L(1.38294979430124120867162673675920814E+00), /* 3fff6208ff6a88a46000000000000000 */
++  L(1.38836250675662681297595213436579797E+00), /* 3fff636bb9a983258400000000000000 */
++  L(1.39379640396958309755959248832368758E+00), /* 3fff64cfd75454ee7c00000000000000 */
++  L(1.39925156885490681313299887733592186E+00), /* 3fff663559cf1bc7c400000000000000 */
++  L(1.40472808465191417726103395580139477E+00), /* 3fff679c427f5a49f400000000000000 */
++  L(1.41022603492571069194738697660795879E+00), /* 3fff690492cbf9432c00000000000000 */
++  L(1.41574550356846662335641440222389065E+00), /* 3fff6a6e4c1d491e1800000000000000 */
++
++  L(9.98018323540573404351050612604012713E-01), /* 3ffefefc41f8d4bdb000000000000000 */
++  L(9.98048781107475468932221929208026268E-01), /* 3ffeff003ff556aa8800000000000000 */
++  L(9.98079239603882895082165305211674422E-01), /* 3ffeff043df9d4986000000000000000 */
++  L(9.98109699029824021243584297735651489E-01), /* 3ffeff083c064e972c00000000000000 */
++  L(9.98140159385327269125909310787392315E-01), /* 3ffeff0c3a1ac4b6ec00000000000000 */
++  L(9.98170620670420977171843901487591211E-01), /* 3ffeff10383737079400000000000000 */
++  L(9.98201082885133511579667242585856002E-01), /* 3ffeff14365ba5991c00000000000000 */
++  L(9.98231546029493238547658506831794512E-01), /* 3ffeff183488107b7c00000000000000 */
++  L(9.98262010103528552029672482603928074E-01), /* 3ffeff1c32bc77beb000000000000000 */
++  L(9.98292475107267818223988342651864514E-01), /* 3ffeff2030f8db72b000000000000000 */
++  L(9.98322941040739375573309644096298143E-01), /* 3ffeff242f3d3ba77000000000000000 */
++  L(9.98353407903971645787066790944663808E-01), /* 3ffeff282d89986cf000000000000000 */
++  L(9.98383875696992967307963340317655820E-01), /* 3ffeff2c2bddf1d32400000000000000 */
++  L(9.98414344419831761845429696222709026E-01), /* 3ffeff302a3a47ea0c00000000000000 */
++  L(9.98444814072516340086593800151604228E-01), /* 3ffeff34289e9ac19800000000000000 */
++  L(9.98475284655075123740886056111776270E-01), /* 3ffeff38270aea69c800000000000000 */
++  L(9.98505756167536479006585636852832977E-01), /* 3ffeff3c257f36f29400000000000000 */
++  L(9.98536228609928799837547330753295682E-01), /* 3ffeff4023fb806bf800000000000000 */
++  L(9.98566701982280452432050310562772211E-01), /* 3ffeff44227fc6e5ec00000000000000 */
++  L(9.98597176284619802988373749030870385E-01), /* 3ffeff48210c0a706800000000000000 */
++  L(9.98627651516975245460372434536111541E-01), /* 3ffeff4c1fa04b1b6800000000000000 */
++  L(9.98658127679375173801901155457017012E-01), /* 3ffeff501e3c88f6e800000000000000 */
++  L(9.98688604771847954211239084543194622E-01), /* 3ffeff541ce0c412e000000000000000 */
++  L(9.98719082794421980642241010173165705E-01), /* 3ffeff581b8cfc7f4c00000000000000 */
++  L(9.98749561747125619293186105096538085E-01), /* 3ffeff5c1a41324c2400000000000000 */
++  L(9.98780041629987291873504773320746608E-01), /* 3ffeff6018fd65896800000000000000 */
++  L(9.98810522443035364581476187595399097E-01), /* 3ffeff6417c196471000000000000000 */
++  L(9.98841004186298203615379520670103375E-01), /* 3ffeff68168dc4951400000000000000 */
++  L(9.98871486859804230684645176552294288E-01), /* 3ffeff6c1561f0837400000000000000 */
++  L(9.98901970463581839743127943620493170E-01), /* 3ffeff70143e1a222c00000000000000 */
++  L(9.98932454997659369233531378995394334E-01), /* 3ffeff74132241813000000000000000 */
++  L(9.98962940462065268620861502313346136E-01), /* 3ffeff78120e66b08400000000000000 */
++  L(9.98993426856827904103397486323956400E-01), /* 3ffeff7c110289c02000000000000000 */
++  L(9.99023914181975669634994119405746460E-01), /* 3ffeff800ffeaac00000000000000000 */
++  L(9.99054402437536959169506189937237650E-01), /* 3ffeff840f02c9c02000000000000000 */
++  L(9.99084891623540138905212870668037795E-01), /* 3ffeff880e0ee6d07800000000000000 */
++  L(9.99115381740013658307120181234495249E-01), /* 3ffeff8c0d2302010c00000000000000 */
++  L(9.99145872786985911329082910015131347E-01), /* 3ffeff900c3f1b61d800000000000000 */
++  L(9.99176364764485236413804614130640402E-01), /* 3ffeff940b633302d000000000000000 */
++  L(9.99206857672540083026291313217370771E-01), /* 3ffeff980a8f48f3f800000000000000 */
++  L(9.99237351511178817364822180024930276E-01), /* 3ffeff9c09c35d454800000000000000 */
++  L(9.99267846280429861138827618560753763E-01), /* 3ffeffa008ff7006c000000000000000 */
++  L(9.99298341980321608302162417203362565E-01), /* 3ffeffa4084381485c00000000000000 */
++  L(9.99328838610882452808681364331278019E-01), /* 3ffeffa8078f911a1800000000000000 */
++  L(9.99359336172140816367814863951934967E-01), /* 3ffeffac06e39f8bf400000000000000 */
++  L(9.99389834664125092933417704443854745E-01), /* 3ffeffb0063facadec00000000000000 */
++  L(9.99420334086863676459344674185558688E-01), /* 3ffeffb405a3b88ffc00000000000000 */
++  L(9.99450834440384988655026177184481639E-01), /* 3ffeffb8050fc3422400000000000000 */
++  L(9.99481335724717395718741386190231424E-01), /* 3ffeffbc0483ccd45c00000000000000 */
++  L(9.99511837939889374871071936468069907E-01), /* 3ffeffc003ffd556ac00000000000000 */
++  L(9.99542341085929264554721385138691403E-01), /* 3ffeffc40383dcd90800000000000000 */
++  L(9.99572845162865514234695751838444266E-01), /* 3ffeffc8030fe36b7400000000000000 */
++  L(9.99603350170726517864849824945849832E-01), /* 3ffeffcc02a3e91dec00000000000000 */
++  L(9.99633856109540669399038392839429434E-01), /* 3ffeffd0023fee006c00000000000000 */
++  L(9.99664362979336418302267475155531429E-01), /* 3ffeffd401e3f222f800000000000000 */
++  L(9.99694870780142130772816244643763639E-01), /* 3ffeffd8018ff5958800000000000000 */
++  L(9.99725379511986284031266336569387931E-01), /* 3ffeffdc0143f8682400000000000000 */
++  L(9.99755889174897216520321308053098619E-01), /* 3ffeffe000fffaaac000000000000000 */
++  L(9.99786399768903377704987178731244057E-01), /* 3ffeffe400c3fc6d6000000000000000 */
++  L(9.99816911294033217050269968240172602E-01), /* 3ffeffe8008ffdc00800000000000000 */
++  L(9.99847423750315072998873233700578567E-01), /* 3ffeffec0063feb2ac00000000000000 */
++  L(9.99877937137777450526954226006637327E-01), /* 3ffefff0003fff555800000000000000 */
++  L(9.99908451456448688077216502279043198E-01), /* 3ffefff40023ffb80000000000000000 */
++  L(9.99938966706357262870241697783058044E-01), /* 3ffefff8000fffeaac00000000000000 */
++  L(9.99969482887531541104308985268289689E-01), /* 3ffefffc0003fffd5400000000000000 */
++#define T_EXPL_RES2 (T_EXPL_RES1 + 1 + 89 + 65)
++  L(1.00000000000000000000000000000000000E+00), /* 3fff0000000000000000000000000000 */
++  L(1.00003051804379100575559391472779680E+00), /* 3fff0002000200015400000000000000 */
++  L(1.00006103701893306334724798034585547E+00), /* 3fff00040008000aac00000000000000 */
++  L(1.00009155692545448346209013834595680E+00), /* 3fff0006001200240000000000000000 */
++  L(1.00012207776338379883185325525118969E+00), /* 3fff0008002000555800000000000000 */
++  L(1.00015259953274932014366527255333494E+00), /* 3fff000a003200a6ac00000000000000 */
++  L(1.00018312223357958012925905677548144E+00), /* 3fff000c004801200400000000000000 */
++  L(1.00021364586590294498691378066723701E+00), /* 3fff000e006201c95c00000000000000 */
++  L(1.00024417042974783642605984823603649E+00), /* 3fff0010008002aab400000000000000 */
++  L(1.00027469592514273166727889474714175E+00), /* 3fff001200a203cc1000000000000000 */
++  L(1.00030522235211605242000132420798764E+00), /* 3fff001400c805357000000000000000 */
++  L(1.00033574971069616488250630936818197E+00), /* 3fff001600f206eed000000000000000 */
++  L(1.00036627800091160178652671675081365E+00), /* 3fff0018012009003800000000000000 */
++  L(1.00039680722279067381919048784766346E+00), /* 3fff001a01520b71a000000000000000 */
++  L(1.00042733737636191371223048918182030E+00), /* 3fff001c01880e4b1000000000000000 */
++  L(1.00045786846165368766392589350289200E+00), /* 3fff001e01c211948400000000000000 */
++  L(1.00048840047869447289485833607614040E+00), /* 3fff0020020015560000000000000000 */
++  L(1.00051893342751269111445822090900037E+00), /* 3fff0022024219978400000000000000 */
++  L(1.00054946730813676403215595200890675E+00), /* 3fff002402881e611000000000000000 */
++  L(1.00058000212059516886853316464112140E+00), /* 3fff002602d223baa800000000000000 */
++  L(1.00061053786491632733302026281307917E+00), /* 3fff0028032029ac4c00000000000000 */
++  L(1.00064107454112866113504765053221490E+00), /* 3fff002a0372303dfc00000000000000 */
++  L(1.00067161214926059198404573180596344E+00), /* 3fff002c03c83777b800000000000000 */
++  L(1.00070215068934059710059614189958666E+00), /* 3fff002e04223f618400000000000000 */
++  L(1.00073269016139709819412928482051939E+00), /* 3fff0030048048036000000000000000 */
++  L(1.00076323056545857248522679583402351E+00), /* 3fff003204e251655000000000000000 */
++  L(1.00079377190155338617216784768970683E+00), /* 3fff003405485b8f5000000000000000 */
++  L(1.00082431416971007198668530691065826E+00), /* 3fff003605b266896800000000000000 */
++  L(1.00085485736995705163820957750431262E+00), /* 3fff00380620725b9800000000000000 */
++  L(1.00088540150232269132501983222027775E+00), /* 3fff003a06927f0ddc00000000000000 */
++  L(1.00091594656683552377884893758164253E+00), /* 3fff003c07088ca83c00000000000000 */
++  L(1.00094649256352402622027852885366883E+00), /* 3fff003e07829b32bc00000000000000 */
++  L(1.00097703949241650933643654752813745E+00), /* 3fff00400800aab55400000000000000 */
++  L(1.00100758735354156137020709138596430E+00), /* 3fff00420882bb381000000000000000 */
++  L(1.00103813614692760403102056443458423E+00), /* 3fff00440908ccc2f000000000000000 */
++  L(1.00106868587260300351715613942360505E+00), /* 3fff00460992df5df000000000000000 */
++  L(1.00109923653059629256034668287611566E+00), /* 3fff00480a20f3111800000000000000 */
++  L(1.00112978812093589287002259879955091E+00), /* 3fff004a0ab307e46800000000000000 */
++  L(1.00116034064365022615561429120134562E+00), /* 3fff004c0b491ddfe000000000000000 */
++  L(1.00119089409876788066000585786241572E+00), /* 3fff004e0be3350b8c00000000000000 */
++  L(1.00122144848631711155917400901671499E+00), /* 3fff00500c814d6f6000000000000000 */
++  L(1.00125200380632656260715407370298635E+00), /* 3fff00520d2367136c00000000000000 */
++  L(1.00128256005882454449107399341301061E+00), /* 3fff00540dc981ffa800000000000000 */
++  L(1.00131311724383964545381786592770368E+00), /* 3fff00560e739e3c2000000000000000 */
++  L(1.00134367536140017618251363273884635E+00), /* 3fff00580f21bbd0cc00000000000000 */
++  L(1.00137423441153472492004539162735455E+00), /* 3fff005a0fd3dac5b800000000000000 */
++  L(1.00140479439427171337584354660066310E+00), /* 3fff005c1089fb22e400000000000000 */
++  L(1.00143535530963956325933850166620687E+00), /* 3fff005e11441cf05000000000000000 */
++  L(1.00146591715766680730226312334707472E+00), /* 3fff0060120240360400000000000000 */
++  L(1.00149647993838186721404781565070152E+00), /* 3fff006212c464fc0000000000000000 */
++  L(1.00152704365181316470412298258452211E+00), /* 3fff0064138a8b4a4400000000000000 */
++  L(1.00155760829798923250422149067162536E+00), /* 3fff00661454b328d800000000000000 */
++  L(1.00158817387693849232377374391944613E+00), /* 3fff00681522dc9fbc00000000000000 */
++  L(1.00161874038868942138336137759324629E+00), /* 3fff006a15f507b6f400000000000000 */
++  L(1.00164930783327055241471725821611471E+00), /* 3fff006c16cb34768800000000000000 */
++  L(1.00167987621071025161612055853765924E+00), /* 3fff006e17a562e67400000000000000 */
++  L(1.00171044552103705171930414508096874E+00), /* 3fff00701883930ec000000000000000 */
++  L(1.00174101576427937443369842185347807E+00), /* 3fff00721965c4f76c00000000000000 */
++  L(1.00177158694046569697988502412044909E+00), /* 3fff00741a4bf8a87c00000000000000 */
++  L(1.00180215904962455208959681840497069E+00), /* 3fff00761b362e29f800000000000000 */
++  L(1.00183273209178441698341543997230474E+00), /* 3fff00781c246583e400000000000000 */
++  L(1.00186330606697365785962006157205906E+00), /* 3fff007a1d169ebe3c00000000000000 */
++  L(1.00189388097522080744994354972732253E+00), /* 3fff007c1e0cd9e10800000000000000 */
++  L(1.00192445681655439848611877096118405E+00), /* 3fff007e1f0716f45000000000000000 */
++  L(1.00195503359100279716642489802325144E+00), /* 3fff0080200556001000000000000000 */
++  L(1.00198561129859459173374602869444061E+00), /* 3fff00822107970c5400000000000000 */
++};
diff --git a/gnu/packages/patches/glibc-2-26-0057.patch b/gnu/packages/patches/glibc-2-26-0057.patch
new file mode 100644
index 000000000..0a6c90892
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0057.patch
@@ -0,0 +1,5465 @@
+From d50b9bf1cc842bfac6de12a1e2c7d202fb71879f Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gabriel@inconstante.eti.br>
+Date: Sat, 9 Sep 2017 19:37:11 -0300
+Subject: [PATCH 57/90] ldbl-128ibm: Automatic replacing of _Float128 and L()
+
+The ldbl-128ibm implementation of j0l, j1l, lgammal_r, and cbrtl, as
+well as the tables used by expl were copied from ldbl-128.  However, the
+original files used _Float128 for the type and L() for the literal
+suffix.  This patch uses the following sed command to rewrite _Float128
+as long double and L(x) as xL (for e_expl.c, e_j0l.c, e_j1l.c,
+e_lgammal_r.c, and t_expl.h):
+
+  sed -i <filename> \
+    -e "/^#define _Float128 long double/d" \
+    -e "/^#define L(x) x ## L/d" \
+    -e "/L(/s/)/L/" \
+    -e "/L(/s/L(//" \
+    -e "s/_Float128/long double/g"
+
+For sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c, this sed command incorrectly
+replaces a few occurrences of L(), so the following command is used
+instead:
+
+  sed -i sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c \
+    -e "/^#define _Float128 long double/d" \
+    -e "/^#define L(x) x ## L/d" \
+    -e "s/L(0\.3\{40\})/0.3333333333333333333333333333333333333333L/" \
+    -e "s/L(3\.7568280825958912391243e-1)/3.7568280825958912391243e-1L/" \
+    -e "/L(/s/)/L/" \
+    -e "/L(/s/L(//" \
+    -e "s/_Float128/long double/g"
+
+Tested for powerpc64le with patched [1] and unpatched gcc.
+
+[1] https://gcc.gnu.org/ml/gcc-patches/2017-08/msg01028.html
+
+	* sysdeps/ieee754/ldbl-128ibm/e_expl.c: Remove definitions of
+	_Float128 and L().
+	* sysdeps/ieee754/ldbl-128ibm/e_j0l.c: Remove definitions of
+	_Float128 and L(). Replace _Float128 with long double and L(x)
+	with xL, throughout the file.
+	* sysdeps/ieee754/ldbl-128ibm/e_j1l.c: Likewise.
+	* sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c: Likewise.
+	* sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c: Likewise.
+	* sysdeps/ieee754/ldbl-128ibm/t_expl.h: Likewise.
+
+(cherry picked from commit d2f0ed09f88195dbeaa8a667b2d3ffa5423562a1)
+
+diff --git a/ChangeLog b/ChangeLog
+index 9713fd8e21..21e923c2f7 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,15 @@
++2017-09-21  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
++
++	* sysdeps/ieee754/ldbl-128ibm/e_expl.c: Remove definitions of
++	_Float128 and L().
++	* sysdeps/ieee754/ldbl-128ibm/e_j0l.c: Remove definitions of
++	_Float128 and L(). Replace _Float128 with long double and L(x)
++	with xL, throughout the file.
++	* sysdeps/ieee754/ldbl-128ibm/e_j1l.c: Likewise.
++	* sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c: Likewise.
++	* sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c: Likewise.
++	* sysdeps/ieee754/ldbl-128ibm/t_expl.h: Likewise.
++
+ 2017-09-21  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
+ 
+ 	* sysdeps/ieee754/ldbl-128ibm/e_expl.c: Include tables from
+diff --git a/sysdeps/ieee754/ldbl-128ibm/e_expl.c b/sysdeps/ieee754/ldbl-128ibm/e_expl.c
+index db812e9b82..9185e7cb5c 100644
+--- a/sysdeps/ieee754/ldbl-128ibm/e_expl.c
++++ b/sysdeps/ieee754/ldbl-128ibm/e_expl.c
+@@ -66,8 +66,6 @@
+ #include <inttypes.h>
+ #include <math_private.h>
+ 
+-#define _Float128 long double
+-#define L(x) x ## L
+ 
+ #include "t_expl.h"
+ 
+diff --git a/sysdeps/ieee754/ldbl-128ibm/e_j0l.c b/sysdeps/ieee754/ldbl-128ibm/e_j0l.c
+index d437926bb1..0a7fe32354 100644
+--- a/sysdeps/ieee754/ldbl-128ibm/e_j0l.c
++++ b/sysdeps/ieee754/ldbl-128ibm/e_j0l.c
+@@ -17,41 +17,39 @@
+ 
+ /* This file was copied from sysdeps/ieee754/ldbl-128/e_j0l.c.  */
+ 
+-#define _Float128 long double
+-#define L(x) x ## L
+ 
+ #include <math.h>
+ #include <math_private.h>
+ #include <float.h>
+ 
+ /* 1 / sqrt(pi) */
+-static const _Float128 ONEOSQPI = L(5.6418958354775628694807945156077258584405E-1);
++static const long double ONEOSQPI = 5.6418958354775628694807945156077258584405E-1L;
+ /* 2 / pi */
+-static const _Float128 TWOOPI = L(6.3661977236758134307553505349005744813784E-1);
+-static const _Float128 zero = 0;
++static const long double TWOOPI = 6.3661977236758134307553505349005744813784E-1L;
++static const long double zero = 0;
+ 
+ /* J0(x) = 1 - x^2/4 + x^2 x^2 R(x^2)
+    Peak relative error 3.4e-37
+    0 <= x <= 2  */
+ #define NJ0_2N 6
+-static const _Float128 J0_2N[NJ0_2N + 1] = {
+-  L(3.133239376997663645548490085151484674892E16),
+- L(-5.479944965767990821079467311839107722107E14),
+-  L(6.290828903904724265980249871997551894090E12),
+- L(-3.633750176832769659849028554429106299915E10),
+-  L(1.207743757532429576399485415069244807022E8),
+- L(-2.107485999925074577174305650549367415465E5),
+-  L(1.562826808020631846245296572935547005859E2),
++static const long double J0_2N[NJ0_2N + 1] = {
++  3.133239376997663645548490085151484674892E16L,
++ -5.479944965767990821079467311839107722107E14L,
++  6.290828903904724265980249871997551894090E12L,
++ -3.633750176832769659849028554429106299915E10L,
++  1.207743757532429576399485415069244807022E8L,
++ -2.107485999925074577174305650549367415465E5L,
++  1.562826808020631846245296572935547005859E2L,
+ };
+ #define NJ0_2D 6
+-static const _Float128 J0_2D[NJ0_2D + 1] = {
+-  L(2.005273201278504733151033654496928968261E18),
+-  L(2.063038558793221244373123294054149790864E16),
+-  L(1.053350447931127971406896594022010524994E14),
+-  L(3.496556557558702583143527876385508882310E11),
+-  L(8.249114511878616075860654484367133976306E8),
+-  L(1.402965782449571800199759247964242790589E6),
+-  L(1.619910762853439600957801751815074787351E3),
++static const long double J0_2D[NJ0_2D + 1] = {
++  2.005273201278504733151033654496928968261E18L,
++  2.063038558793221244373123294054149790864E16L,
++  1.053350447931127971406896594022010524994E14L,
++  3.496556557558702583143527876385508882310E11L,
++  8.249114511878616075860654484367133976306E8L,
++  1.402965782449571800199759247964242790589E6L,
++  1.619910762853439600957801751815074787351E3L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -59,30 +57,30 @@ static const _Float128 J0_2D[NJ0_2D + 1] = {
+    0 <= 1/x <= .0625
+    Peak relative error 3.3e-36  */
+ #define NP16_IN 9
+-static const _Float128 P16_IN[NP16_IN + 1] = {
+-  L(-1.901689868258117463979611259731176301065E-16),
+-  L(-1.798743043824071514483008340803573980931E-13),
+-  L(-6.481746687115262291873324132944647438959E-11),
+-  L(-1.150651553745409037257197798528294248012E-8),
+-  L(-1.088408467297401082271185599507222695995E-6),
+-  L(-5.551996725183495852661022587879817546508E-5),
+-  L(-1.477286941214245433866838787454880214736E-3),
+-  L(-1.882877976157714592017345347609200402472E-2),
+-  L(-9.620983176855405325086530374317855880515E-2),
+-  L(-1.271468546258855781530458854476627766233E-1),
++static const long double P16_IN[NP16_IN + 1] = {
++  -1.901689868258117463979611259731176301065E-16L,
++  -1.798743043824071514483008340803573980931E-13L,
++  -6.481746687115262291873324132944647438959E-11L,
++  -1.150651553745409037257197798528294248012E-8L,
++  -1.088408467297401082271185599507222695995E-6L,
++  -5.551996725183495852661022587879817546508E-5L,
++  -1.477286941214245433866838787454880214736E-3L,
++  -1.882877976157714592017345347609200402472E-2L,
++  -9.620983176855405325086530374317855880515E-2L,
++  -1.271468546258855781530458854476627766233E-1L,
+ };
+ #define NP16_ID 9
+-static const _Float128 P16_ID[NP16_ID + 1] = {
+-  L(2.704625590411544837659891569420764475007E-15),
+-  L(2.562526347676857624104306349421985403573E-12),
+-  L(9.259137589952741054108665570122085036246E-10),
+-  L(1.651044705794378365237454962653430805272E-7),
+-  L(1.573561544138733044977714063100859136660E-5),
+-  L(8.134482112334882274688298469629884804056E-4),
+-  L(2.219259239404080863919375103673593571689E-2),
+-  L(2.976990606226596289580242451096393862792E-1),
+-  L(1.713895630454693931742734911930937246254E0),
+-  L(3.231552290717904041465898249160757368855E0),
++static const long double P16_ID[NP16_ID + 1] = {
++  2.704625590411544837659891569420764475007E-15L,
++  2.562526347676857624104306349421985403573E-12L,
++  9.259137589952741054108665570122085036246E-10L,
++  1.651044705794378365237454962653430805272E-7L,
++  1.573561544138733044977714063100859136660E-5L,
++  8.134482112334882274688298469629884804056E-4L,
++  2.219259239404080863919375103673593571689E-2L,
++  2.976990606226596289580242451096393862792E-1L,
++  1.713895630454693931742734911930937246254E0L,
++  3.231552290717904041465898249160757368855E0L,
+   /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -90,32 +88,32 @@ static const _Float128 P16_ID[NP16_ID + 1] = {
+     0.0625 <= 1/x <= 0.125
+     Peak relative error 2.4e-35  */
+ #define NP8_16N 10
+-static const _Float128 P8_16N[NP8_16N + 1] = {
+-  L(-2.335166846111159458466553806683579003632E-15),
+-  L(-1.382763674252402720401020004169367089975E-12),
+-  L(-3.192160804534716696058987967592784857907E-10),
+-  L(-3.744199606283752333686144670572632116899E-8),
+-  L(-2.439161236879511162078619292571922772224E-6),
+-  L(-9.068436986859420951664151060267045346549E-5),
+-  L(-1.905407090637058116299757292660002697359E-3),
+-  L(-2.164456143936718388053842376884252978872E-2),
+-  L(-1.212178415116411222341491717748696499966E-1),
+-  L(-2.782433626588541494473277445959593334494E-1),
+-  L(-1.670703190068873186016102289227646035035E-1),
++static const long double P8_16N[NP8_16N + 1] = {
++  -2.335166846111159458466553806683579003632E-15L,
++  -1.382763674252402720401020004169367089975E-12L,
++  -3.192160804534716696058987967592784857907E-10L,
++  -3.744199606283752333686144670572632116899E-8L,
++  -2.439161236879511162078619292571922772224E-6L,
++  -9.068436986859420951664151060267045346549E-5L,
++  -1.905407090637058116299757292660002697359E-3L,
++  -2.164456143936718388053842376884252978872E-2L,
++  -1.212178415116411222341491717748696499966E-1L,
++  -2.782433626588541494473277445959593334494E-1L,
++  -1.670703190068873186016102289227646035035E-1L,
+ };
+ #define NP8_16D 10
+-static const _Float128 P8_16D[NP8_16D + 1] = {
+-  L(3.321126181135871232648331450082662856743E-14),
+-  L(1.971894594837650840586859228510007703641E-11),
+-  L(4.571144364787008285981633719513897281690E-9),
+-  L(5.396419143536287457142904742849052402103E-7),
+-  L(3.551548222385845912370226756036899901549E-5),
+-  L(1.342353874566932014705609788054598013516E-3),
+-  L(2.899133293006771317589357444614157734385E-2),
+-  L(3.455374978185770197704507681491574261545E-1),
+-  L(2.116616964297512311314454834712634820514E0),
+-  L(5.850768316827915470087758636881584174432E0),
+-  L(5.655273858938766830855753983631132928968E0),
++static const long double P8_16D[NP8_16D + 1] = {
++  3.321126181135871232648331450082662856743E-14L,
++  1.971894594837650840586859228510007703641E-11L,
++  4.571144364787008285981633719513897281690E-9L,
++  5.396419143536287457142904742849052402103E-7L,
++  3.551548222385845912370226756036899901549E-5L,
++  1.342353874566932014705609788054598013516E-3L,
++  2.899133293006771317589357444614157734385E-2L,
++  3.455374978185770197704507681491574261545E-1L,
++  2.116616964297512311314454834712634820514E0L,
++  5.850768316827915470087758636881584174432E0L,
++  5.655273858938766830855753983631132928968E0L,
+   /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -123,31 +121,31 @@ static const _Float128 P8_16D[NP8_16D + 1] = {
+   0.125 <= 1/x <= 0.1875
+   Peak relative error 2.7e-35  */
+ #define NP5_8N 10
+-static const _Float128 P5_8N[NP5_8N + 1] = {
+-  L(-1.270478335089770355749591358934012019596E-12),
+-  L(-4.007588712145412921057254992155810347245E-10),
+-  L(-4.815187822989597568124520080486652009281E-8),
+-  L(-2.867070063972764880024598300408284868021E-6),
+-  L(-9.218742195161302204046454768106063638006E-5),
+-  L(-1.635746821447052827526320629828043529997E-3),
+-  L(-1.570376886640308408247709616497261011707E-2),
+-  L(-7.656484795303305596941813361786219477807E-2),
+-  L(-1.659371030767513274944805479908858628053E-1),
+-  L(-1.185340550030955660015841796219919804915E-1),
+-  L(-8.920026499909994671248893388013790366712E-3),
++static const long double P5_8N[NP5_8N + 1] = {
++  -1.270478335089770355749591358934012019596E-12L,
++  -4.007588712145412921057254992155810347245E-10L,
++  -4.815187822989597568124520080486652009281E-8L,
++  -2.867070063972764880024598300408284868021E-6L,
++  -9.218742195161302204046454768106063638006E-5L,
++  -1.635746821447052827526320629828043529997E-3L,
++  -1.570376886640308408247709616497261011707E-2L,
++  -7.656484795303305596941813361786219477807E-2L,
++  -1.659371030767513274944805479908858628053E-1L,
++  -1.185340550030955660015841796219919804915E-1L,
++  -8.920026499909994671248893388013790366712E-3L,
+ };
+ #define NP5_8D 9
+-static const _Float128 P5_8D[NP5_8D + 1] = {
+-  L(1.806902521016705225778045904631543990314E-11),
+-  L(5.728502760243502431663549179135868966031E-9),
+-  L(6.938168504826004255287618819550667978450E-7),
+-  L(4.183769964807453250763325026573037785902E-5),
+-  L(1.372660678476925468014882230851637878587E-3),
+-  L(2.516452105242920335873286419212708961771E-2),
+-  L(2.550502712902647803796267951846557316182E-1),
+-  L(1.365861559418983216913629123778747617072E0),
+-  L(3.523825618308783966723472468855042541407E0),
+-  L(3.656365803506136165615111349150536282434E0),
++static const long double P5_8D[NP5_8D + 1] = {
++  1.806902521016705225778045904631543990314E-11L,
++  5.728502760243502431663549179135868966031E-9L,
++  6.938168504826004255287618819550667978450E-7L,
++  4.183769964807453250763325026573037785902E-5L,
++  1.372660678476925468014882230851637878587E-3L,
++  2.516452105242920335873286419212708961771E-2L,
++  2.550502712902647803796267951846557316182E-1L,
++  1.365861559418983216913629123778747617072E0L,
++  3.523825618308783966723472468855042541407E0L,
++  3.656365803506136165615111349150536282434E0L,
+   /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -155,30 +153,30 @@ static const _Float128 P5_8D[NP5_8D + 1] = {
+    Peak relative error 3.5e-35
+    0.1875 <= 1/x <= 0.25  */
+ #define NP4_5N 9
+-static const _Float128 P4_5N[NP4_5N + 1] = {
+-  L(-9.791405771694098960254468859195175708252E-10),
+-  L(-1.917193059944531970421626610188102836352E-7),
+-  L(-1.393597539508855262243816152893982002084E-5),
+-  L(-4.881863490846771259880606911667479860077E-4),
+-  L(-8.946571245022470127331892085881699269853E-3),
+-  L(-8.707474232568097513415336886103899434251E-2),
+-  L(-4.362042697474650737898551272505525973766E-1),
+-  L(-1.032712171267523975431451359962375617386E0),
+-  L(-9.630502683169895107062182070514713702346E-1),
+-  L(-2.251804386252969656586810309252357233320E-1),
++static const long double P4_5N[NP4_5N + 1] = {
++  -9.791405771694098960254468859195175708252E-10L,
++  -1.917193059944531970421626610188102836352E-7L,
++  -1.393597539508855262243816152893982002084E-5L,
++  -4.881863490846771259880606911667479860077E-4L,
++  -8.946571245022470127331892085881699269853E-3L,
++  -8.707474232568097513415336886103899434251E-2L,
++  -4.362042697474650737898551272505525973766E-1L,
++  -1.032712171267523975431451359962375617386E0L,
++  -9.630502683169895107062182070514713702346E-1L,
++  -2.251804386252969656586810309252357233320E-1L,
+ };
+ #define NP4_5D 9
+-static const _Float128 P4_5D[NP4_5D + 1] = {
+-  L(1.392555487577717669739688337895791213139E-8),
+-  L(2.748886559120659027172816051276451376854E-6),
+-  L(2.024717710644378047477189849678576659290E-4),
+-  L(7.244868609350416002930624752604670292469E-3),
+-  L(1.373631762292244371102989739300382152416E-1),
+-  L(1.412298581400224267910294815260613240668E0),
+-  L(7.742495637843445079276397723849017617210E0),
+-  L(2.138429269198406512028307045259503811861E1),
+-  L(2.651547684548423476506826951831712762610E1),
+-  L(1.167499382465291931571685222882909166935E1),
++static const long double P4_5D[NP4_5D + 1] = {
++  1.392555487577717669739688337895791213139E-8L,
++  2.748886559120659027172816051276451376854E-6L,
++  2.024717710644378047477189849678576659290E-4L,
++  7.244868609350416002930624752604670292469E-3L,
++  1.373631762292244371102989739300382152416E-1L,
++  1.412298581400224267910294815260613240668E0L,
++  7.742495637843445079276397723849017617210E0L,
++  2.138429269198406512028307045259503811861E1L,
++  2.651547684548423476506826951831712762610E1L,
++  1.167499382465291931571685222882909166935E1L,
+   /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -186,30 +184,30 @@ static const _Float128 P4_5D[NP4_5D + 1] = {
+    Peak relative error 2.3e-36
+    0.25 <= 1/x <= 0.3125  */
+ #define NP3r2_4N 9
+-static const _Float128 P3r2_4N[NP3r2_4N + 1] = {
+-  L(-2.589155123706348361249809342508270121788E-8),
+-  L(-3.746254369796115441118148490849195516593E-6),
+-  L(-1.985595497390808544622893738135529701062E-4),
+-  L(-5.008253705202932091290132760394976551426E-3),
+-  L(-6.529469780539591572179155511840853077232E-2),
+-  L(-4.468736064761814602927408833818990271514E-1),
+-  L(-1.556391252586395038089729428444444823380E0),
+-  L(-2.533135309840530224072920725976994981638E0),
+-  L(-1.605509621731068453869408718565392869560E0),
+-  L(-2.518966692256192789269859830255724429375E-1),
++static const long double P3r2_4N[NP3r2_4N + 1] = {
++  -2.589155123706348361249809342508270121788E-8L,
++  -3.746254369796115441118148490849195516593E-6L,
++  -1.985595497390808544622893738135529701062E-4L,
++  -5.008253705202932091290132760394976551426E-3L,
++  -6.529469780539591572179155511840853077232E-2L,
++  -4.468736064761814602927408833818990271514E-1L,
++  -1.556391252586395038089729428444444823380E0L,
++  -2.533135309840530224072920725976994981638E0L,
++  -1.605509621731068453869408718565392869560E0L,
++  -2.518966692256192789269859830255724429375E-1L,
+ };
+ #define NP3r2_4D 9
+-static const _Float128 P3r2_4D[NP3r2_4D + 1] = {
+-  L(3.682353957237979993646169732962573930237E-7),
+-  L(5.386741661883067824698973455566332102029E-5),
+-  L(2.906881154171822780345134853794241037053E-3),
+-  L(7.545832595801289519475806339863492074126E-2),
+-  L(1.029405357245594877344360389469584526654E0),
+-  L(7.565706120589873131187989560509757626725E0),
+-  L(2.951172890699569545357692207898667665796E1),
+-  L(5.785723537170311456298467310529815457536E1),
+-  L(5.095621464598267889126015412522773474467E1),
+-  L(1.602958484169953109437547474953308401442E1),
++static const long double P3r2_4D[NP3r2_4D + 1] = {
++  3.682353957237979993646169732962573930237E-7L,
++  5.386741661883067824698973455566332102029E-5L,
++  2.906881154171822780345134853794241037053E-3L,
++  7.545832595801289519475806339863492074126E-2L,
++  1.029405357245594877344360389469584526654E0L,
++  7.565706120589873131187989560509757626725E0L,
++  2.951172890699569545357692207898667665796E1L,
++  5.785723537170311456298467310529815457536E1L,
++  5.095621464598267889126015412522773474467E1L,
++  1.602958484169953109437547474953308401442E1L,
+   /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -217,29 +215,29 @@ static const _Float128 P3r2_4D[NP3r2_4D + 1] = {
+    Peak relative error 1.0e-35
+    0.3125 <= 1/x <= 0.375  */
+ #define NP2r7_3r2N 9
+-static const _Float128 P2r7_3r2N[NP2r7_3r2N + 1] = {
+-  L(-1.917322340814391131073820537027234322550E-7),
+-  L(-1.966595744473227183846019639723259011906E-5),
+-  L(-7.177081163619679403212623526632690465290E-4),
+-  L(-1.206467373860974695661544653741899755695E-2),
+-  L(-1.008656452188539812154551482286328107316E-1),
+-  L(-4.216016116408810856620947307438823892707E-1),
+-  L(-8.378631013025721741744285026537009814161E-1),
+-  L(-6.973895635309960850033762745957946272579E-1),
+-  L(-1.797864718878320770670740413285763554812E-1),
+-  L(-4.098025357743657347681137871388402849581E-3),
++static const long double P2r7_3r2N[NP2r7_3r2N + 1] = {
++  -1.917322340814391131073820537027234322550E-7L,
++  -1.966595744473227183846019639723259011906E-5L,
++  -7.177081163619679403212623526632690465290E-4L,
++  -1.206467373860974695661544653741899755695E-2L,
++  -1.008656452188539812154551482286328107316E-1L,
++  -4.216016116408810856620947307438823892707E-1L,
++  -8.378631013025721741744285026537009814161E-1L,
++  -6.973895635309960850033762745957946272579E-1L,
++  -1.797864718878320770670740413285763554812E-1L,
++  -4.098025357743657347681137871388402849581E-3L,
+ };
+ #define NP2r7_3r2D 8
+-static const _Float128 P2r7_3r2D[NP2r7_3r2D + 1] = {
+-  L(2.726858489303036441686496086962545034018E-6),
+-  L(2.840430827557109238386808968234848081424E-4),
+-  L(1.063826772041781947891481054529454088832E-2),
+-  L(1.864775537138364773178044431045514405468E-1),
+-  L(1.665660052857205170440952607701728254211E0),
+-  L(7.723745889544331153080842168958348568395E0),
+-  L(1.810726427571829798856428548102077799835E1),
+-  L(1.986460672157794440666187503833545388527E1),
+-  L(8.645503204552282306364296517220055815488E0),
++static const long double P2r7_3r2D[NP2r7_3r2D + 1] = {
++  2.726858489303036441686496086962545034018E-6L,
++  2.840430827557109238386808968234848081424E-4L,
++  1.063826772041781947891481054529454088832E-2L,
++  1.864775537138364773178044431045514405468E-1L,
++  1.665660052857205170440952607701728254211E0L,
++  7.723745889544331153080842168958348568395E0L,
++  1.810726427571829798856428548102077799835E1L,
++  1.986460672157794440666187503833545388527E1L,
++  8.645503204552282306364296517220055815488E0L,
+   /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -247,29 +245,29 @@ static const _Float128 P2r7_3r2D[NP2r7_3r2D + 1] = {
+    Peak relative error 1.3e-36
+    0.3125 <= 1/x <= 0.4375  */
+ #define NP2r3_2r7N 9
+-static const _Float128 P2r3_2r7N[NP2r3_2r7N + 1] = {
+-  L(-1.594642785584856746358609622003310312622E-6),
+-  L(-1.323238196302221554194031733595194539794E-4),
+-  L(-3.856087818696874802689922536987100372345E-3),
+-  L(-5.113241710697777193011470733601522047399E-2),
+-  L(-3.334229537209911914449990372942022350558E-1),
+-  L(-1.075703518198127096179198549659283422832E0),
+-  L(-1.634174803414062725476343124267110981807E0),
+-  L(-1.030133247434119595616826842367268304880E0),
+-  L(-1.989811539080358501229347481000707289391E-1),
+-  L(-3.246859189246653459359775001466924610236E-3),
++static const long double P2r3_2r7N[NP2r3_2r7N + 1] = {
++  -1.594642785584856746358609622003310312622E-6L,
++  -1.323238196302221554194031733595194539794E-4L,
++  -3.856087818696874802689922536987100372345E-3L,
++  -5.113241710697777193011470733601522047399E-2L,
++  -3.334229537209911914449990372942022350558E-1L,
++  -1.075703518198127096179198549659283422832E0L,
++  -1.634174803414062725476343124267110981807E0L,
++  -1.030133247434119595616826842367268304880E0L,
++  -1.989811539080358501229347481000707289391E-1L,
++  -3.246859189246653459359775001466924610236E-3L,
+ };
+ #define NP2r3_2r7D 8
+-static const _Float128 P2r3_2r7D[NP2r3_2r7D + 1] = {
+-  L(2.267936634217251403663034189684284173018E-5),
+-  L(1.918112982168673386858072491437971732237E-3),
+-  L(5.771704085468423159125856786653868219522E-2),
+-  L(8.056124451167969333717642810661498890507E-1),
+-  L(5.687897967531010276788680634413789328776E0),
+-  L(2.072596760717695491085444438270778394421E1),
+-  L(3.801722099819929988585197088613160496684E1),
+-  L(3.254620235902912339534998592085115836829E1),
+-  L(1.104847772130720331801884344645060675036E1),
++static const long double P2r3_2r7D[NP2r3_2r7D + 1] = {
++  2.267936634217251403663034189684284173018E-5L,
++  1.918112982168673386858072491437971732237E-3L,
++  5.771704085468423159125856786653868219522E-2L,
++  8.056124451167969333717642810661498890507E-1L,
++  5.687897967531010276788680634413789328776E0L,
++  2.072596760717695491085444438270778394421E1L,
++  3.801722099819929988585197088613160496684E1L,
++  3.254620235902912339534998592085115836829E1L,
++  1.104847772130720331801884344645060675036E1L,
+   /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -277,28 +275,28 @@ static const _Float128 P2r3_2r7D[NP2r3_2r7D + 1] = {
+    Peak relative error 1.2e-35
+    0.4375 <= 1/x <= 0.5  */
+ #define NP2_2r3N 8
+-static const _Float128 P2_2r3N[NP2_2r3N + 1] = {
+-  L(-1.001042324337684297465071506097365389123E-4),
+-  L(-6.289034524673365824853547252689991418981E-3),
+-  L(-1.346527918018624234373664526930736205806E-1),
+-  L(-1.268808313614288355444506172560463315102E0),
+-  L(-5.654126123607146048354132115649177406163E0),
+-  L(-1.186649511267312652171775803270911971693E1),
+-  L(-1.094032424931998612551588246779200724257E1),
+-  L(-3.728792136814520055025256353193674625267E0),
+-  L(-3.000348318524471807839934764596331810608E-1),
++static const long double P2_2r3N[NP2_2r3N + 1] = {
++  -1.001042324337684297465071506097365389123E-4L,
++  -6.289034524673365824853547252689991418981E-3L,
++  -1.346527918018624234373664526930736205806E-1L,
++  -1.268808313614288355444506172560463315102E0L,
++  -5.654126123607146048354132115649177406163E0L,
++  -1.186649511267312652171775803270911971693E1L,
++  -1.094032424931998612551588246779200724257E1L,
++  -3.728792136814520055025256353193674625267E0L,
++  -3.000348318524471807839934764596331810608E-1L,
+ };
+ #define NP2_2r3D 8
+-static const _Float128 P2_2r3D[NP2_2r3D + 1] = {
+-  L(1.423705538269770974803901422532055612980E-3),
+-  L(9.171476630091439978533535167485230575894E-2),
+-  L(2.049776318166637248868444600215942828537E0),
+-  L(2.068970329743769804547326701946144899583E1),
+-  L(1.025103500560831035592731539565060347709E2),
+-  L(2.528088049697570728252145557167066708284E2),
+-  L(2.992160327587558573740271294804830114205E2),
+-  L(1.540193761146551025832707739468679973036E2),
+-  L(2.779516701986912132637672140709452502650E1),
++static const long double P2_2r3D[NP2_2r3D + 1] = {
++  1.423705538269770974803901422532055612980E-3L,
++  9.171476630091439978533535167485230575894E-2L,
++  2.049776318166637248868444600215942828537E0L,
++  2.068970329743769804547326701946144899583E1L,
++  1.025103500560831035592731539565060347709E2L,
++  2.528088049697570728252145557167066708284E2L,
++  2.992160327587558573740271294804830114205E2L,
++  1.540193761146551025832707739468679973036E2L,
++  2.779516701986912132637672140709452502650E1L,
+   /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -307,31 +305,31 @@ static const _Float128 P2_2r3D[NP2_2r3D + 1] = {
+    Peak relative error 2.2e-35
+    0 <= 1/x <= .0625  */
+ #define NQ16_IN 10
+-static const _Float128 Q16_IN[NQ16_IN + 1] = {
+-  L(2.343640834407975740545326632205999437469E-18),
+-  L(2.667978112927811452221176781536278257448E-15),
+-  L(1.178415018484555397390098879501969116536E-12),
+-  L(2.622049767502719728905924701288614016597E-10),
+-  L(3.196908059607618864801313380896308968673E-8),
+-  L(2.179466154171673958770030655199434798494E-6),
+-  L(8.139959091628545225221976413795645177291E-5),
+-  L(1.563900725721039825236927137885747138654E-3),
+-  L(1.355172364265825167113562519307194840307E-2),
+-  L(3.928058355906967977269780046844768588532E-2),
+-  L(1.107891967702173292405380993183694932208E-2),
++static const long double Q16_IN[NQ16_IN + 1] = {
++  2.343640834407975740545326632205999437469E-18L,
++  2.667978112927811452221176781536278257448E-15L,
++  1.178415018484555397390098879501969116536E-12L,
++  2.622049767502719728905924701288614016597E-10L,
++  3.196908059607618864801313380896308968673E-8L,
++  2.179466154171673958770030655199434798494E-6L,
++  8.139959091628545225221976413795645177291E-5L,
++  1.563900725721039825236927137885747138654E-3L,
++  1.355172364265825167113562519307194840307E-2L,
++  3.928058355906967977269780046844768588532E-2L,
++  1.107891967702173292405380993183694932208E-2L,
+ };
+ #define NQ16_ID 9
+-static const _Float128 Q16_ID[NQ16_ID + 1] = {
+-  L(3.199850952578356211091219295199301766718E-17),
+-  L(3.652601488020654842194486058637953363918E-14),
+-  L(1.620179741394865258354608590461839031281E-11),
+-  L(3.629359209474609630056463248923684371426E-9),
+-  L(4.473680923894354600193264347733477363305E-7),
+-  L(3.106368086644715743265603656011050476736E-5),
+-  L(1.198239259946770604954664925153424252622E-3),
+-  L(2.446041004004283102372887804475767568272E-2),
+-  L(2.403235525011860603014707768815113698768E-1),
+-  L(9.491006790682158612266270665136910927149E-1),
++static const long double Q16_ID[NQ16_ID + 1] = {
++  3.199850952578356211091219295199301766718E-17L,
++  3.652601488020654842194486058637953363918E-14L,
++  1.620179741394865258354608590461839031281E-11L,
++  3.629359209474609630056463248923684371426E-9L,
++  4.473680923894354600193264347733477363305E-7L,
++  3.106368086644715743265603656011050476736E-5L,
++  1.198239259946770604954664925153424252622E-3L,
++  2.446041004004283102372887804475767568272E-2L,
++  2.403235525011860603014707768815113698768E-1L,
++  9.491006790682158612266270665136910927149E-1L,
+  /* 1.000000000000000000000000000000000000000E0 */
+  };
+ 
+@@ -340,34 +338,34 @@ static const _Float128 Q16_ID[NQ16_ID + 1] = {
+    Peak relative error 5.1e-36
+    0.0625 <= 1/x <= 0.125  */
+ #define NQ8_16N 11
+-static const _Float128 Q8_16N[NQ8_16N + 1] = {
+-  L(1.001954266485599464105669390693597125904E-17),
+-  L(7.545499865295034556206475956620160007849E-15),
+-  L(2.267838684785673931024792538193202559922E-12),
+-  L(3.561909705814420373609574999542459912419E-10),
+-  L(3.216201422768092505214730633842924944671E-8),
+-  L(1.731194793857907454569364622452058554314E-6),
+-  L(5.576944613034537050396518509871004586039E-5),
+-  L(1.051787760316848982655967052985391418146E-3),
+-  L(1.102852974036687441600678598019883746959E-2),
+-  L(5.834647019292460494254225988766702933571E-2),
+-  L(1.290281921604364618912425380717127576529E-1),
+-  L(7.598886310387075708640370806458926458301E-2),
++static const long double Q8_16N[NQ8_16N + 1] = {
++  1.001954266485599464105669390693597125904E-17L,
++  7.545499865295034556206475956620160007849E-15L,
++  2.267838684785673931024792538193202559922E-12L,
++  3.561909705814420373609574999542459912419E-10L,
++  3.216201422768092505214730633842924944671E-8L,
++  1.731194793857907454569364622452058554314E-6L,
++  5.576944613034537050396518509871004586039E-5L,
++  1.051787760316848982655967052985391418146E-3L,
++  1.102852974036687441600678598019883746959E-2L,
++  5.834647019292460494254225988766702933571E-2L,
++  1.290281921604364618912425380717127576529E-1L,
++  7.598886310387075708640370806458926458301E-2L,
+ };
+ #define NQ8_16D 11
+-static const _Float128 Q8_16D[NQ8_16D + 1] = {
+-  L(1.368001558508338469503329967729951830843E-16),
+-  L(1.034454121857542147020549303317348297289E-13),
+-  L(3.128109209247090744354764050629381674436E-11),
+-  L(4.957795214328501986562102573522064468671E-9),
+-  L(4.537872468606711261992676606899273588899E-7),
+-  L(2.493639207101727713192687060517509774182E-5),
+-  L(8.294957278145328349785532236663051405805E-4),
+-  L(1.646471258966713577374948205279380115839E-2),
+-  L(1.878910092770966718491814497982191447073E-1),
+-  L(1.152641605706170353727903052525652504075E0),
+-  L(3.383550240669773485412333679367792932235E0),
+-  L(3.823875252882035706910024716609908473970E0),
++static const long double Q8_16D[NQ8_16D + 1] = {
++  1.368001558508338469503329967729951830843E-16L,
++  1.034454121857542147020549303317348297289E-13L,
++  3.128109209247090744354764050629381674436E-11L,
++  4.957795214328501986562102573522064468671E-9L,
++  4.537872468606711261992676606899273588899E-7L,
++  2.493639207101727713192687060517509774182E-5L,
++  8.294957278145328349785532236663051405805E-4L,
++  1.646471258966713577374948205279380115839E-2L,
++  1.878910092770966718491814497982191447073E-1L,
++  1.152641605706170353727903052525652504075E0L,
++  3.383550240669773485412333679367792932235E0L,
++  3.823875252882035706910024716609908473970E0L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -376,32 +374,32 @@ static const _Float128 Q8_16D[NQ8_16D + 1] = {
+    Peak relative error 3.9e-35
+    0.125 <= 1/x <= 0.1875  */
+ #define NQ5_8N 10
+-static const _Float128 Q5_8N[NQ5_8N + 1] = {
+-  L(1.750399094021293722243426623211733898747E-13),
+-  L(6.483426211748008735242909236490115050294E-11),
+-  L(9.279430665656575457141747875716899958373E-9),
+-  L(6.696634968526907231258534757736576340266E-7),
+-  L(2.666560823798895649685231292142838188061E-5),
+-  L(6.025087697259436271271562769707550594540E-4),
+-  L(7.652807734168613251901945778921336353485E-3),
+-  L(5.226269002589406461622551452343519078905E-2),
+-  L(1.748390159751117658969324896330142895079E-1),
+-  L(2.378188719097006494782174902213083589660E-1),
+-  L(8.383984859679804095463699702165659216831E-2),
++static const long double Q5_8N[NQ5_8N + 1] = {
++  1.750399094021293722243426623211733898747E-13L,
++  6.483426211748008735242909236490115050294E-11L,
++  9.279430665656575457141747875716899958373E-9L,
++  6.696634968526907231258534757736576340266E-7L,
++  2.666560823798895649685231292142838188061E-5L,
++  6.025087697259436271271562769707550594540E-4L,
++  7.652807734168613251901945778921336353485E-3L,
++  5.226269002589406461622551452343519078905E-2L,
++  1.748390159751117658969324896330142895079E-1L,
++  2.378188719097006494782174902213083589660E-1L,
++  8.383984859679804095463699702165659216831E-2L,
+ };
+ #define NQ5_8D 10
+-static const _Float128 Q5_8D[NQ5_8D + 1] = {
+-  L(2.389878229704327939008104855942987615715E-12),
+-  L(8.926142817142546018703814194987786425099E-10),
+-  L(1.294065862406745901206588525833274399038E-7),
+-  L(9.524139899457666250828752185212769682191E-6),
+-  L(3.908332488377770886091936221573123353489E-4),
+-  L(9.250427033957236609624199884089916836748E-3),
+-  L(1.263420066165922645975830877751588421451E-1),
+-  L(9.692527053860420229711317379861733180654E-1),
+-  L(3.937813834630430172221329298841520707954E0),
+-  L(7.603126427436356534498908111445191312181E0),
+-  L(5.670677653334105479259958485084550934305E0),
++static const long double Q5_8D[NQ5_8D + 1] = {
++  2.389878229704327939008104855942987615715E-12L,
++  8.926142817142546018703814194987786425099E-10L,
++  1.294065862406745901206588525833274399038E-7L,
++  9.524139899457666250828752185212769682191E-6L,
++  3.908332488377770886091936221573123353489E-4L,
++  9.250427033957236609624199884089916836748E-3L,
++  1.263420066165922645975830877751588421451E-1L,
++  9.692527053860420229711317379861733180654E-1L,
++  3.937813834630430172221329298841520707954E0L,
++  7.603126427436356534498908111445191312181E0L,
++  5.670677653334105479259958485084550934305E0L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -410,31 +408,31 @@ static const _Float128 Q5_8D[NQ5_8D + 1] = {
+    Peak relative error 3.2e-35
+    0.1875 <= 1/x <= 0.25  */
+ #define NQ4_5N 10
+-static const _Float128 Q4_5N[NQ4_5N + 1] = {
+-  L(2.233870042925895644234072357400122854086E-11),
+-  L(5.146223225761993222808463878999151699792E-9),
+-  L(4.459114531468296461688753521109797474523E-7),
+-  L(1.891397692931537975547242165291668056276E-5),
+-  L(4.279519145911541776938964806470674565504E-4),
+-  L(5.275239415656560634702073291768904783989E-3),
+-  L(3.468698403240744801278238473898432608887E-2),
+-  L(1.138773146337708415188856882915457888274E-1),
+-  L(1.622717518946443013587108598334636458955E-1),
+-  L(7.249040006390586123760992346453034628227E-2),
+-  L(1.941595365256460232175236758506411486667E-3),
++static const long double Q4_5N[NQ4_5N + 1] = {
++  2.233870042925895644234072357400122854086E-11L,
++  5.146223225761993222808463878999151699792E-9L,
++  4.459114531468296461688753521109797474523E-7L,
++  1.891397692931537975547242165291668056276E-5L,
++  4.279519145911541776938964806470674565504E-4L,
++  5.275239415656560634702073291768904783989E-3L,
++  3.468698403240744801278238473898432608887E-2L,
++  1.138773146337708415188856882915457888274E-1L,
++  1.622717518946443013587108598334636458955E-1L,
++  7.249040006390586123760992346453034628227E-2L,
++  1.941595365256460232175236758506411486667E-3L,
+ };
+ #define NQ4_5D 9
+-static const _Float128 Q4_5D[NQ4_5D + 1] = {
+-  L(3.049977232266999249626430127217988047453E-10),
+-  L(7.120883230531035857746096928889676144099E-8),
+-  L(6.301786064753734446784637919554359588859E-6),
+-  L(2.762010530095069598480766869426308077192E-4),
+-  L(6.572163250572867859316828886203406361251E-3),
+-  L(8.752566114841221958200215255461843397776E-2),
+-  L(6.487654992874805093499285311075289932664E-1),
+-  L(2.576550017826654579451615283022812801435E0),
+-  L(5.056392229924022835364779562707348096036E0),
+-  L(4.179770081068251464907531367859072157773E0),
++static const long double Q4_5D[NQ4_5D + 1] = {
++  3.049977232266999249626430127217988047453E-10L,
++  7.120883230531035857746096928889676144099E-8L,
++  6.301786064753734446784637919554359588859E-6L,
++  2.762010530095069598480766869426308077192E-4L,
++  6.572163250572867859316828886203406361251E-3L,
++  8.752566114841221958200215255461843397776E-2L,
++  6.487654992874805093499285311075289932664E-1L,
++  2.576550017826654579451615283022812801435E0L,
++  5.056392229924022835364779562707348096036E0L,
++  4.179770081068251464907531367859072157773E0L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -443,31 +441,31 @@ static const _Float128 Q4_5D[NQ4_5D + 1] = {
+    Peak relative error 1.4e-36
+    0.25 <= 1/x <= 0.3125  */
+ #define NQ3r2_4N 10
+-static const _Float128 Q3r2_4N[NQ3r2_4N + 1] = {
+-  L(6.126167301024815034423262653066023684411E-10),
+-  L(1.043969327113173261820028225053598975128E-7),
+-  L(6.592927270288697027757438170153763220190E-6),
+-  L(2.009103660938497963095652951912071336730E-4),
+-  L(3.220543385492643525985862356352195896964E-3),
+-  L(2.774405975730545157543417650436941650990E-2),
+-  L(1.258114008023826384487378016636555041129E-1),
+-  L(2.811724258266902502344701449984698323860E-1),
+-  L(2.691837665193548059322831687432415014067E-1),
+-  L(7.949087384900985370683770525312735605034E-2),
+-  L(1.229509543620976530030153018986910810747E-3),
++static const long double Q3r2_4N[NQ3r2_4N + 1] = {
++  6.126167301024815034423262653066023684411E-10L,
++  1.043969327113173261820028225053598975128E-7L,
++  6.592927270288697027757438170153763220190E-6L,
++  2.009103660938497963095652951912071336730E-4L,
++  3.220543385492643525985862356352195896964E-3L,
++  2.774405975730545157543417650436941650990E-2L,
++  1.258114008023826384487378016636555041129E-1L,
++  2.811724258266902502344701449984698323860E-1L,
++  2.691837665193548059322831687432415014067E-1L,
++  7.949087384900985370683770525312735605034E-2L,
++  1.229509543620976530030153018986910810747E-3L,
+ };
+ #define NQ3r2_4D 9
+-static const _Float128 Q3r2_4D[NQ3r2_4D + 1] = {
+-  L(8.364260446128475461539941389210166156568E-9),
+-  L(1.451301850638956578622154585560759862764E-6),
+-  L(9.431830010924603664244578867057141839463E-5),
+-  L(3.004105101667433434196388593004526182741E-3),
+-  L(5.148157397848271739710011717102773780221E-2),
+-  L(4.901089301726939576055285374953887874895E-1),
+-  L(2.581760991981709901216967665934142240346E0),
+-  L(7.257105880775059281391729708630912791847E0),
+-  L(1.006014717326362868007913423810737369312E1),
+-  L(5.879416600465399514404064187445293212470E0),
++static const long double Q3r2_4D[NQ3r2_4D + 1] = {
++  8.364260446128475461539941389210166156568E-9L,
++  1.451301850638956578622154585560759862764E-6L,
++  9.431830010924603664244578867057141839463E-5L,
++  3.004105101667433434196388593004526182741E-3L,
++  5.148157397848271739710011717102773780221E-2L,
++  4.901089301726939576055285374953887874895E-1L,
++  2.581760991981709901216967665934142240346E0L,
++  7.257105880775059281391729708630912791847E0L,
++  1.006014717326362868007913423810737369312E1L,
++  5.879416600465399514404064187445293212470E0L,
+  /* 1.000000000000000000000000000000000000000E0*/
+ };
+ 
+@@ -476,30 +474,30 @@ static const _Float128 Q3r2_4D[NQ3r2_4D + 1] = {
+    Peak relative error 3.8e-36
+    0.3125 <= 1/x <= 0.375  */
+ #define NQ2r7_3r2N 9
+-static const _Float128 Q2r7_3r2N[NQ2r7_3r2N + 1] = {
+-  L(7.584861620402450302063691901886141875454E-8),
+-  L(9.300939338814216296064659459966041794591E-6),
+-  L(4.112108906197521696032158235392604947895E-4),
+-  L(8.515168851578898791897038357239630654431E-3),
+-  L(8.971286321017307400142720556749573229058E-2),
+-  L(4.885856732902956303343015636331874194498E-1),
+-  L(1.334506268733103291656253500506406045846E0),
+-  L(1.681207956863028164179042145803851824654E0),
+-  L(8.165042692571721959157677701625853772271E-1),
+-  L(9.805848115375053300608712721986235900715E-2),
++static const long double Q2r7_3r2N[NQ2r7_3r2N + 1] = {
++  7.584861620402450302063691901886141875454E-8L,
++  9.300939338814216296064659459966041794591E-6L,
++  4.112108906197521696032158235392604947895E-4L,
++  8.515168851578898791897038357239630654431E-3L,
++  8.971286321017307400142720556749573229058E-2L,
++  4.885856732902956303343015636331874194498E-1L,
++  1.334506268733103291656253500506406045846E0L,
++  1.681207956863028164179042145803851824654E0L,
++  8.165042692571721959157677701625853772271E-1L,
++  9.805848115375053300608712721986235900715E-2L,
+ };
+ #define NQ2r7_3r2D 9
+-static const _Float128 Q2r7_3r2D[NQ2r7_3r2D + 1] = {
+-  L(1.035586492113036586458163971239438078160E-6),
+-  L(1.301999337731768381683593636500979713689E-4),
+-  L(5.993695702564527062553071126719088859654E-3),
+-  L(1.321184892887881883489141186815457808785E-1),
+-  L(1.528766555485015021144963194165165083312E0),
+-  L(9.561463309176490874525827051566494939295E0),
+-  L(3.203719484883967351729513662089163356911E1),
+-  L(5.497294687660930446641539152123568668447E1),
+-  L(4.391158169390578768508675452986948391118E1),
+-  L(1.347836630730048077907818943625789418378E1),
++static const long double Q2r7_3r2D[NQ2r7_3r2D + 1] = {
++  1.035586492113036586458163971239438078160E-6L,
++  1.301999337731768381683593636500979713689E-4L,
++  5.993695702564527062553071126719088859654E-3L,
++  1.321184892887881883489141186815457808785E-1L,
++  1.528766555485015021144963194165165083312E0L,
++  9.561463309176490874525827051566494939295E0L,
++  3.203719484883967351729513662089163356911E1L,
++  5.497294687660930446641539152123568668447E1L,
++  4.391158169390578768508675452986948391118E1L,
++  1.347836630730048077907818943625789418378E1L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -508,29 +506,29 @@ static const _Float128 Q2r7_3r2D[NQ2r7_3r2D + 1] = {
+    Peak relative error 2.2e-35
+    0.375 <= 1/x <= 0.4375  */
+ #define NQ2r3_2r7N 9
+-static const _Float128 Q2r3_2r7N[NQ2r3_2r7N + 1] = {
+-  L(4.455027774980750211349941766420190722088E-7),
+-  L(4.031998274578520170631601850866780366466E-5),
+-  L(1.273987274325947007856695677491340636339E-3),
+-  L(1.818754543377448509897226554179659122873E-2),
+-  L(1.266748858326568264126353051352269875352E-1),
+-  L(4.327578594728723821137731555139472880414E-1),
+-  L(6.892532471436503074928194969154192615359E-1),
+-  L(4.490775818438716873422163588640262036506E-1),
+-  L(8.649615949297322440032000346117031581572E-2),
+-  L(7.261345286655345047417257611469066147561E-4),
++static const long double Q2r3_2r7N[NQ2r3_2r7N + 1] = {
++  4.455027774980750211349941766420190722088E-7L,
++  4.031998274578520170631601850866780366466E-5L,
++  1.273987274325947007856695677491340636339E-3L,
++  1.818754543377448509897226554179659122873E-2L,
++  1.266748858326568264126353051352269875352E-1L,
++  4.327578594728723821137731555139472880414E-1L,
++  6.892532471436503074928194969154192615359E-1L,
++  4.490775818438716873422163588640262036506E-1L,
++  8.649615949297322440032000346117031581572E-2L,
++  7.261345286655345047417257611469066147561E-4L,
+ };
+ #define NQ2r3_2r7D 8
+-static const _Float128 Q2r3_2r7D[NQ2r3_2r7D + 1] = {
+-  L(6.082600739680555266312417978064954793142E-6),
+-  L(5.693622538165494742945717226571441747567E-4),
+-  L(1.901625907009092204458328768129666975975E-2),
+-  L(2.958689532697857335456896889409923371570E-1),
+-  L(2.343124711045660081603809437993368799568E0),
+-  L(9.665894032187458293568704885528192804376E0),
+-  L(2.035273104990617136065743426322454881353E1),
+-  L(2.044102010478792896815088858740075165531E1),
+-  L(8.445937177863155827844146643468706599304E0),
++static const long double Q2r3_2r7D[NQ2r3_2r7D + 1] = {
++  6.082600739680555266312417978064954793142E-6L,
++  5.693622538165494742945717226571441747567E-4L,
++  1.901625907009092204458328768129666975975E-2L,
++  2.958689532697857335456896889409923371570E-1L,
++  2.343124711045660081603809437993368799568E0L,
++  9.665894032187458293568704885528192804376E0L,
++  2.035273104990617136065743426322454881353E1L,
++  2.044102010478792896815088858740075165531E1L,
++  8.445937177863155827844146643468706599304E0L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -539,39 +537,39 @@ static const _Float128 Q2r3_2r7D[NQ2r3_2r7D + 1] = {
+    Peak relative error 3.1e-36
+    0.4375 <= 1/x <= 0.5  */
+ #define NQ2_2r3N 9
+-static const _Float128 Q2_2r3N[NQ2_2r3N + 1] = {
+-  L(2.817566786579768804844367382809101929314E-6),
+-  L(2.122772176396691634147024348373539744935E-4),
+-  L(5.501378031780457828919593905395747517585E-3),
+-  L(6.355374424341762686099147452020466524659E-2),
+-  L(3.539652320122661637429658698954748337223E-1),
+-  L(9.571721066119617436343740541777014319695E-1),
+-  L(1.196258777828426399432550698612171955305E0),
+-  L(6.069388659458926158392384709893753793967E-1),
+-  L(9.026746127269713176512359976978248763621E-2),
+-  L(5.317668723070450235320878117210807236375E-4),
++static const long double Q2_2r3N[NQ2_2r3N + 1] = {
++  2.817566786579768804844367382809101929314E-6L,
++  2.122772176396691634147024348373539744935E-4L,
++  5.501378031780457828919593905395747517585E-3L,
++  6.355374424341762686099147452020466524659E-2L,
++  3.539652320122661637429658698954748337223E-1L,
++  9.571721066119617436343740541777014319695E-1L,
++  1.196258777828426399432550698612171955305E0L,
++  6.069388659458926158392384709893753793967E-1L,
++  9.026746127269713176512359976978248763621E-2L,
++  5.317668723070450235320878117210807236375E-4L,
+ };
+ #define NQ2_2r3D 8
+-static const _Float128 Q2_2r3D[NQ2_2r3D + 1] = {
+-  L(3.846924354014260866793741072933159380158E-5),
+-  L(3.017562820057704325510067178327449946763E-3),
+-  L(8.356305620686867949798885808540444210935E-2),
+-  L(1.068314930499906838814019619594424586273E0),
+-  L(6.900279623894821067017966573640732685233E0),
+-  L(2.307667390886377924509090271780839563141E1),
+-  L(3.921043465412723970791036825401273528513E1),
+-  L(3.167569478939719383241775717095729233436E1),
+-  L(1.051023841699200920276198346301543665909E1),
++static const long double Q2_2r3D[NQ2_2r3D + 1] = {
++  3.846924354014260866793741072933159380158E-5L,
++  3.017562820057704325510067178327449946763E-3L,
++  8.356305620686867949798885808540444210935E-2L,
++  1.068314930499906838814019619594424586273E0L,
++  6.900279623894821067017966573640732685233E0L,
++  2.307667390886377924509090271780839563141E1L,
++  3.921043465412723970791036825401273528513E1L,
++  3.167569478939719383241775717095729233436E1L,
++  1.051023841699200920276198346301543665909E1L,
+  /* 1.000000000000000000000000000000000000000E0*/
+ };
+ 
+ 
+ /* Evaluate P[n] x^n  +  P[n-1] x^(n-1)  +  ...  +  P[0] */
+ 
+-static _Float128
+-neval (_Float128 x, const _Float128 *p, int n)
++static long double
++neval (long double x, const long double *p, int n)
+ {
+-  _Float128 y;
++  long double y;
+ 
+   p += n;
+   y = *p--;
+@@ -586,10 +584,10 @@ neval (_Float128 x, const _Float128 *p, int n)
+ 
+ /* Evaluate x^n+1  +  P[n] x^(n)  +  P[n-1] x^(n-1)  +  ...  +  P[0] */
+ 
+-static _Float128
+-deval (_Float128 x, const _Float128 *p, int n)
++static long double
++deval (long double x, const long double *p, int n)
+ {
+-  _Float128 y;
++  long double y;
+ 
+   p += n;
+   y = x + *p--;
+@@ -604,10 +602,10 @@ deval (_Float128 x, const _Float128 *p, int n)
+ 
+ /* Bessel function of the first kind, order zero.  */
+ 
+-_Float128
+-__ieee754_j0l (_Float128 x)
++long double
++__ieee754_j0l (long double x)
+ {
+-  _Float128 xx, xinv, z, p, q, c, s, cc, ss;
++  long double xx, xinv, z, p, q, c, s, cc, ss;
+ 
+   if (! isfinite (x))
+     {
+@@ -622,12 +620,12 @@ __ieee754_j0l (_Float128 x)
+   xx = fabsl (x);
+   if (xx <= 2)
+     {
+-      if (xx < L(0x1p-57))
++      if (xx < 0x1p-57L)
+ 	return 1;
+       /* 0 <= x <= 2 */
+       z = xx * xx;
+       p = z * z * neval (z, J0_2N, NJ0_2N) / deval (z, J0_2D, NJ0_2D);
+-      p -= L(0.25) * z;
++      p -= 0.25L * z;
+       p += 1;
+       return p;
+     }
+@@ -651,7 +649,7 @@ __ieee754_j0l (_Float128 x)
+ 	ss = z / cc;
+     }
+ 
+-  if (xx > L(0x1p256))
++  if (xx > 0x1p256L)
+     return ONEOSQPI * cc / __ieee754_sqrtl (xx);
+ 
+   xinv = 1 / xx;
+@@ -714,7 +712,7 @@ __ieee754_j0l (_Float128 x)
+     }
+   p = 1 + z * p;
+   q = z * xinv * q;
+-  q = q - L(0.125) * xinv;
++  q = q - 0.125L * xinv;
+   z = ONEOSQPI * (p * cc - q * ss) / __ieee754_sqrtl (xx);
+   return z;
+ }
+@@ -725,37 +723,37 @@ strong_alias (__ieee754_j0l, __j0l_finite)
+    Peak absolute error 1.7e-36 (relative where Y0 > 1)
+    0 <= x <= 2   */
+ #define NY0_2N 7
+-static _Float128 Y0_2N[NY0_2N + 1] = {
+- L(-1.062023609591350692692296993537002558155E19),
+-  L(2.542000883190248639104127452714966858866E19),
+- L(-1.984190771278515324281415820316054696545E18),
+-  L(4.982586044371592942465373274440222033891E16),
+- L(-5.529326354780295177243773419090123407550E14),
+-  L(3.013431465522152289279088265336861140391E12),
+- L(-7.959436160727126750732203098982718347785E9),
+-  L(8.230845651379566339707130644134372793322E6),
++static long double Y0_2N[NY0_2N + 1] = {
++ -1.062023609591350692692296993537002558155E19L,
++  2.542000883190248639104127452714966858866E19L,
++ -1.984190771278515324281415820316054696545E18L,
++  4.982586044371592942465373274440222033891E16L,
++ -5.529326354780295177243773419090123407550E14L,
++  3.013431465522152289279088265336861140391E12L,
++ -7.959436160727126750732203098982718347785E9L,
++  8.230845651379566339707130644134372793322E6L,
+ };
+ #define NY0_2D 7
+-static _Float128 Y0_2D[NY0_2D + 1] = {
+-  L(1.438972634353286978700329883122253752192E20),
+-  L(1.856409101981569254247700169486907405500E18),
+-  L(1.219693352678218589553725579802986255614E16),
+-  L(5.389428943282838648918475915779958097958E13),
+-  L(1.774125762108874864433872173544743051653E11),
+-  L(4.522104832545149534808218252434693007036E8),
+-  L(8.872187401232943927082914504125234454930E5),
+-  L(1.251945613186787532055610876304669413955E3),
++static long double Y0_2D[NY0_2D + 1] = {
++  1.438972634353286978700329883122253752192E20L,
++  1.856409101981569254247700169486907405500E18L,
++  1.219693352678218589553725579802986255614E16L,
++  5.389428943282838648918475915779958097958E13L,
++  1.774125762108874864433872173544743051653E11L,
++  4.522104832545149534808218252434693007036E8L,
++  8.872187401232943927082914504125234454930E5L,
++  1.251945613186787532055610876304669413955E3L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+-static const _Float128 U0 = L(-7.3804295108687225274343927948483016310862e-02);
++static const long double U0 = -7.3804295108687225274343927948483016310862e-02L;
+ 
+ /* Bessel function of the second kind, order zero.  */
+ 
+-_Float128
+- __ieee754_y0l(_Float128 x)
++long double
++ __ieee754_y0l(long double x)
+ {
+-  _Float128 xx, xinv, z, p, q, c, s, cc, ss;
++  long double xx, xinv, z, p, q, c, s, cc, ss;
+ 
+   if (! isfinite (x))
+     return 1 / (x + x * x);
+@@ -796,7 +794,7 @@ _Float128
+ 	ss = z / cc;
+     }
+ 
+-  if (xx > L(0x1p256))
++  if (xx > 0x1p256L)
+     return ONEOSQPI * ss / __ieee754_sqrtl (x);
+ 
+   xinv = 1 / xx;
+@@ -859,7 +857,7 @@ _Float128
+     }
+   p = 1 + z * p;
+   q = z * xinv * q;
+-  q = q - L(0.125) * xinv;
++  q = q - 0.125L * xinv;
+   z = ONEOSQPI * (p * ss + q * cc) / __ieee754_sqrtl (x);
+   return z;
+ }
+diff --git a/sysdeps/ieee754/ldbl-128ibm/e_j1l.c b/sysdeps/ieee754/ldbl-128ibm/e_j1l.c
+index 3cedeec438..5956c97b82 100644
+--- a/sysdeps/ieee754/ldbl-128ibm/e_j1l.c
++++ b/sysdeps/ieee754/ldbl-128ibm/e_j1l.c
+@@ -17,8 +17,6 @@
+ 
+ /* This file was copied from sysdeps/ieee754/ldbl-128/e_j0l.c.  */
+ 
+-#define _Float128 long double
+-#define L(x) x ## L
+ 
+ #include <errno.h>
+ #include <math.h>
+@@ -26,33 +24,33 @@
+ #include <float.h>
+ 
+ /* 1 / sqrt(pi) */
+-static const _Float128 ONEOSQPI = L(5.6418958354775628694807945156077258584405E-1);
++static const long double ONEOSQPI = 5.6418958354775628694807945156077258584405E-1L;
+ /* 2 / pi */
+-static const _Float128 TWOOPI = L(6.3661977236758134307553505349005744813784E-1);
+-static const _Float128 zero = 0;
++static const long double TWOOPI = 6.3661977236758134307553505349005744813784E-1L;
++static const long double zero = 0;
+ 
+ /* J1(x) = .5x + x x^2 R(x^2)
+    Peak relative error 1.9e-35
+    0 <= x <= 2  */
+ #define NJ0_2N 6
+-static const _Float128 J0_2N[NJ0_2N + 1] = {
+- L(-5.943799577386942855938508697619735179660E16),
+-  L(1.812087021305009192259946997014044074711E15),
+- L(-2.761698314264509665075127515729146460895E13),
+-  L(2.091089497823600978949389109350658815972E11),
+- L(-8.546413231387036372945453565654130054307E8),
+-  L(1.797229225249742247475464052741320612261E6),
+- L(-1.559552840946694171346552770008812083969E3)
++static const long double J0_2N[NJ0_2N + 1] = {
++ -5.943799577386942855938508697619735179660E16L,
++  1.812087021305009192259946997014044074711E15L,
++ -2.761698314264509665075127515729146460895E13L,
++  2.091089497823600978949389109350658815972E11L,
++ -8.546413231387036372945453565654130054307E8L,
++  1.797229225249742247475464052741320612261E6L,
++ -1.559552840946694171346552770008812083969E3L
+ };
+ #define NJ0_2D 6
+-static const _Float128 J0_2D[NJ0_2D + 1] = {
+-  L(9.510079323819108569501613916191477479397E17),
+-  L(1.063193817503280529676423936545854693915E16),
+-  L(5.934143516050192600795972192791775226920E13),
+-  L(2.168000911950620999091479265214368352883E11),
+-  L(5.673775894803172808323058205986256928794E8),
+-  L(1.080329960080981204840966206372671147224E6),
+-  L(1.411951256636576283942477881535283304912E3),
++static const long double J0_2D[NJ0_2D + 1] = {
++  9.510079323819108569501613916191477479397E17L,
++  1.063193817503280529676423936545854693915E16L,
++  5.934143516050192600795972192791775226920E13L,
++  2.168000911950620999091479265214368352883E11L,
++  5.673775894803172808323058205986256928794E8L,
++  1.080329960080981204840966206372671147224E6L,
++  1.411951256636576283942477881535283304912E3L,
+  /* 1.000000000000000000000000000000000000000E0L */
+ };
+ 
+@@ -60,30 +58,30 @@ static const _Float128 J0_2D[NJ0_2D + 1] = {
+    0 <= 1/x <= .0625
+    Peak relative error 3.6e-36  */
+ #define NP16_IN 9
+-static const _Float128 P16_IN[NP16_IN + 1] = {
+-  L(5.143674369359646114999545149085139822905E-16),
+-  L(4.836645664124562546056389268546233577376E-13),
+-  L(1.730945562285804805325011561498453013673E-10),
+-  L(3.047976856147077889834905908605310585810E-8),
+-  L(2.855227609107969710407464739188141162386E-6),
+-  L(1.439362407936705484122143713643023998457E-4),
+-  L(3.774489768532936551500999699815873422073E-3),
+-  L(4.723962172984642566142399678920790598426E-2),
+-  L(2.359289678988743939925017240478818248735E-1),
+-  L(3.032580002220628812728954785118117124520E-1),
++static const long double P16_IN[NP16_IN + 1] = {
++  5.143674369359646114999545149085139822905E-16L,
++  4.836645664124562546056389268546233577376E-13L,
++  1.730945562285804805325011561498453013673E-10L,
++  3.047976856147077889834905908605310585810E-8L,
++  2.855227609107969710407464739188141162386E-6L,
++  1.439362407936705484122143713643023998457E-4L,
++  3.774489768532936551500999699815873422073E-3L,
++  4.723962172984642566142399678920790598426E-2L,
++  2.359289678988743939925017240478818248735E-1L,
++  3.032580002220628812728954785118117124520E-1L,
+ };
+ #define NP16_ID 9
+-static const _Float128 P16_ID[NP16_ID + 1] = {
+-  L(4.389268795186898018132945193912677177553E-15),
+-  L(4.132671824807454334388868363256830961655E-12),
+-  L(1.482133328179508835835963635130894413136E-9),
+-  L(2.618941412861122118906353737117067376236E-7),
+-  L(2.467854246740858470815714426201888034270E-5),
+-  L(1.257192927368839847825938545925340230490E-3),
+-  L(3.362739031941574274949719324644120720341E-2),
+-  L(4.384458231338934105875343439265370178858E-1),
+-  L(2.412830809841095249170909628197264854651E0),
+-  L(4.176078204111348059102962617368214856874E0),
++static const long double P16_ID[NP16_ID + 1] = {
++  4.389268795186898018132945193912677177553E-15L,
++  4.132671824807454334388868363256830961655E-12L,
++  1.482133328179508835835963635130894413136E-9L,
++  2.618941412861122118906353737117067376236E-7L,
++  2.467854246740858470815714426201888034270E-5L,
++  1.257192927368839847825938545925340230490E-3L,
++  3.362739031941574274949719324644120720341E-2L,
++  4.384458231338934105875343439265370178858E-1L,
++  2.412830809841095249170909628197264854651E0L,
++  4.176078204111348059102962617368214856874E0L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -91,33 +89,33 @@ static const _Float128 P16_ID[NP16_ID + 1] = {
+     0.0625 <= 1/x <= 0.125
+     Peak relative error 1.9e-36  */
+ #define NP8_16N 11
+-static const _Float128 P8_16N[NP8_16N + 1] = {
+-  L(2.984612480763362345647303274082071598135E-16),
+-  L(1.923651877544126103941232173085475682334E-13),
+-  L(4.881258879388869396043760693256024307743E-11),
+-  L(6.368866572475045408480898921866869811889E-9),
+-  L(4.684818344104910450523906967821090796737E-7),
+-  L(2.005177298271593587095982211091300382796E-5),
+-  L(4.979808067163957634120681477207147536182E-4),
+-  L(6.946005761642579085284689047091173581127E-3),
+-  L(5.074601112955765012750207555985299026204E-2),
+-  L(1.698599455896180893191766195194231825379E-1),
+-  L(1.957536905259237627737222775573623779638E-1),
+-  L(2.991314703282528370270179989044994319374E-2),
++static const long double P8_16N[NP8_16N + 1] = {
++  2.984612480763362345647303274082071598135E-16L,
++  1.923651877544126103941232173085475682334E-13L,
++  4.881258879388869396043760693256024307743E-11L,
++  6.368866572475045408480898921866869811889E-9L,
++  4.684818344104910450523906967821090796737E-7L,
++  2.005177298271593587095982211091300382796E-5L,
++  4.979808067163957634120681477207147536182E-4L,
++  6.946005761642579085284689047091173581127E-3L,
++  5.074601112955765012750207555985299026204E-2L,
++  1.698599455896180893191766195194231825379E-1L,
++  1.957536905259237627737222775573623779638E-1L,
++  2.991314703282528370270179989044994319374E-2L,
+ };
+ #define NP8_16D 10
+-static const _Float128 P8_16D[NP8_16D + 1] = {
+-  L(2.546869316918069202079580939942463010937E-15),
+-  L(1.644650111942455804019788382157745229955E-12),
+-  L(4.185430770291694079925607420808011147173E-10),
+-  L(5.485331966975218025368698195861074143153E-8),
+-  L(4.062884421686912042335466327098932678905E-6),
+-  L(1.758139661060905948870523641319556816772E-4),
+-  L(4.445143889306356207566032244985607493096E-3),
+-  L(6.391901016293512632765621532571159071158E-2),
+-  L(4.933040207519900471177016015718145795434E-1),
+-  L(1.839144086168947712971630337250761842976E0),
+-  L(2.715120873995490920415616716916149586579E0),
++static const long double P8_16D[NP8_16D + 1] = {
++  2.546869316918069202079580939942463010937E-15L,
++  1.644650111942455804019788382157745229955E-12L,
++  4.185430770291694079925607420808011147173E-10L,
++  5.485331966975218025368698195861074143153E-8L,
++  4.062884421686912042335466327098932678905E-6L,
++  1.758139661060905948870523641319556816772E-4L,
++  4.445143889306356207566032244985607493096E-3L,
++  6.391901016293512632765621532571159071158E-2L,
++  4.933040207519900471177016015718145795434E-1L,
++  1.839144086168947712971630337250761842976E0L,
++  2.715120873995490920415616716916149586579E0L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -125,32 +123,32 @@ static const _Float128 P8_16D[NP8_16D + 1] = {
+   0.125 <= 1/x <= 0.1875
+   Peak relative error 1.3e-36  */
+ #define NP5_8N 10
+-static const _Float128 P5_8N[NP5_8N + 1] = {
+-  L(2.837678373978003452653763806968237227234E-12),
+-  L(9.726641165590364928442128579282742354806E-10),
+-  L(1.284408003604131382028112171490633956539E-7),
+-  L(8.524624695868291291250573339272194285008E-6),
+-  L(3.111516908953172249853673787748841282846E-4),
+-  L(6.423175156126364104172801983096596409176E-3),
+-  L(7.430220589989104581004416356260692450652E-2),
+-  L(4.608315409833682489016656279567605536619E-1),
+-  L(1.396870223510964882676225042258855977512E0),
+-  L(1.718500293904122365894630460672081526236E0),
+-  L(5.465927698800862172307352821870223855365E-1)
++static const long double P5_8N[NP5_8N + 1] = {
++  2.837678373978003452653763806968237227234E-12L,
++  9.726641165590364928442128579282742354806E-10L,
++  1.284408003604131382028112171490633956539E-7L,
++  8.524624695868291291250573339272194285008E-6L,
++  3.111516908953172249853673787748841282846E-4L,
++  6.423175156126364104172801983096596409176E-3L,
++  7.430220589989104581004416356260692450652E-2L,
++  4.608315409833682489016656279567605536619E-1L,
++  1.396870223510964882676225042258855977512E0L,
++  1.718500293904122365894630460672081526236E0L,
++  5.465927698800862172307352821870223855365E-1L
+ };
+ #define NP5_8D 10
+-static const _Float128 P5_8D[NP5_8D + 1] = {
+-  L(2.421485545794616609951168511612060482715E-11),
+-  L(8.329862750896452929030058039752327232310E-9),
+-  L(1.106137992233383429630592081375289010720E-6),
+-  L(7.405786153760681090127497796448503306939E-5),
+-  L(2.740364785433195322492093333127633465227E-3),
+-  L(5.781246470403095224872243564165254652198E-2),
+-  L(6.927711353039742469918754111511109983546E-1),
+-  L(4.558679283460430281188304515922826156690E0),
+-  L(1.534468499844879487013168065728837900009E1),
+-  L(2.313927430889218597919624843161569422745E1),
+-  L(1.194506341319498844336768473218382828637E1),
++static const long double P5_8D[NP5_8D + 1] = {
++  2.421485545794616609951168511612060482715E-11L,
++  8.329862750896452929030058039752327232310E-9L,
++  1.106137992233383429630592081375289010720E-6L,
++  7.405786153760681090127497796448503306939E-5L,
++  2.740364785433195322492093333127633465227E-3L,
++  5.781246470403095224872243564165254652198E-2L,
++  6.927711353039742469918754111511109983546E-1L,
++  4.558679283460430281188304515922826156690E0L,
++  1.534468499844879487013168065728837900009E1L,
++  2.313927430889218597919624843161569422745E1L,
++  1.194506341319498844336768473218382828637E1L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -158,31 +156,31 @@ static const _Float128 P5_8D[NP5_8D + 1] = {
+    Peak relative error 1.4e-36
+    0.1875 <= 1/x <= 0.25  */
+ #define NP4_5N 10
+-static const _Float128 P4_5N[NP4_5N + 1] = {
+-  L(1.846029078268368685834261260420933914621E-10),
+-  L(3.916295939611376119377869680335444207768E-8),
+-  L(3.122158792018920627984597530935323997312E-6),
+-  L(1.218073444893078303994045653603392272450E-4),
+-  L(2.536420827983485448140477159977981844883E-3),
+-  L(2.883011322006690823959367922241169171315E-2),
+-  L(1.755255190734902907438042414495469810830E-1),
+-  L(5.379317079922628599870898285488723736599E-1),
+-  L(7.284904050194300773890303361501726561938E-1),
+-  L(3.270110346613085348094396323925000362813E-1),
+-  L(1.804473805689725610052078464951722064757E-2),
++static const long double P4_5N[NP4_5N + 1] = {
++  1.846029078268368685834261260420933914621E-10L,
++  3.916295939611376119377869680335444207768E-8L,
++  3.122158792018920627984597530935323997312E-6L,
++  1.218073444893078303994045653603392272450E-4L,
++  2.536420827983485448140477159977981844883E-3L,
++  2.883011322006690823959367922241169171315E-2L,
++  1.755255190734902907438042414495469810830E-1L,
++  5.379317079922628599870898285488723736599E-1L,
++  7.284904050194300773890303361501726561938E-1L,
++  3.270110346613085348094396323925000362813E-1L,
++  1.804473805689725610052078464951722064757E-2L,
+ };
+ #define NP4_5D 9
+-static const _Float128 P4_5D[NP4_5D + 1] = {
+-  L(1.575278146806816970152174364308980863569E-9),
+-  L(3.361289173657099516191331123405675054321E-7),
+-  L(2.704692281550877810424745289838790693708E-5),
+-  L(1.070854930483999749316546199273521063543E-3),
+-  L(2.282373093495295842598097265627962125411E-2),
+-  L(2.692025460665354148328762368240343249830E-1),
+-  L(1.739892942593664447220951225734811133759E0),
+-  L(5.890727576752230385342377570386657229324E0),
+-  L(9.517442287057841500750256954117735128153E0),
+-  L(6.100616353935338240775363403030137736013E0),
++static const long double P4_5D[NP4_5D + 1] = {
++  1.575278146806816970152174364308980863569E-9L,
++  3.361289173657099516191331123405675054321E-7L,
++  2.704692281550877810424745289838790693708E-5L,
++  1.070854930483999749316546199273521063543E-3L,
++  2.282373093495295842598097265627962125411E-2L,
++  2.692025460665354148328762368240343249830E-1L,
++  1.739892942593664447220951225734811133759E0L,
++  5.890727576752230385342377570386657229324E0L,
++  9.517442287057841500750256954117735128153E0L,
++  6.100616353935338240775363403030137736013E0L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -190,30 +188,30 @@ static const _Float128 P4_5D[NP4_5D + 1] = {
+    Peak relative error 3.0e-36
+    0.25 <= 1/x <= 0.3125  */
+ #define NP3r2_4N 9
+-static const _Float128 P3r2_4N[NP3r2_4N + 1] = {
+-  L(8.240803130988044478595580300846665863782E-8),
+-  L(1.179418958381961224222969866406483744580E-5),
+-  L(6.179787320956386624336959112503824397755E-4),
+-  L(1.540270833608687596420595830747166658383E-2),
+-  L(1.983904219491512618376375619598837355076E-1),
+-  L(1.341465722692038870390470651608301155565E0),
+-  L(4.617865326696612898792238245990854646057E0),
+-  L(7.435574801812346424460233180412308000587E0),
+-  L(4.671327027414635292514599201278557680420E0),
+-  L(7.299530852495776936690976966995187714739E-1),
++static const long double P3r2_4N[NP3r2_4N + 1] = {
++  8.240803130988044478595580300846665863782E-8L,
++  1.179418958381961224222969866406483744580E-5L,
++  6.179787320956386624336959112503824397755E-4L,
++  1.540270833608687596420595830747166658383E-2L,
++  1.983904219491512618376375619598837355076E-1L,
++  1.341465722692038870390470651608301155565E0L,
++  4.617865326696612898792238245990854646057E0L,
++  7.435574801812346424460233180412308000587E0L,
++  4.671327027414635292514599201278557680420E0L,
++  7.299530852495776936690976966995187714739E-1L,
+ };
+ #define NP3r2_4D 9
+-static const _Float128 P3r2_4D[NP3r2_4D + 1] = {
+-  L(7.032152009675729604487575753279187576521E-7),
+-  L(1.015090352324577615777511269928856742848E-4),
+-  L(5.394262184808448484302067955186308730620E-3),
+-  L(1.375291438480256110455809354836988584325E-1),
+-  L(1.836247144461106304788160919310404376670E0),
+-  L(1.314378564254376655001094503090935880349E1),
+-  L(4.957184590465712006934452500894672343488E1),
+-  L(9.287394244300647738855415178790263465398E1),
+-  L(7.652563275535900609085229286020552768399E1),
+-  L(2.147042473003074533150718117770093209096E1),
++static const long double P3r2_4D[NP3r2_4D + 1] = {
++  7.032152009675729604487575753279187576521E-7L,
++  1.015090352324577615777511269928856742848E-4L,
++  5.394262184808448484302067955186308730620E-3L,
++  1.375291438480256110455809354836988584325E-1L,
++  1.836247144461106304788160919310404376670E0L,
++  1.314378564254376655001094503090935880349E1L,
++  4.957184590465712006934452500894672343488E1L,
++  9.287394244300647738855415178790263465398E1L,
++  7.652563275535900609085229286020552768399E1L,
++  2.147042473003074533150718117770093209096E1L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -221,29 +219,29 @@ static const _Float128 P3r2_4D[NP3r2_4D + 1] = {
+    Peak relative error 1.0e-35
+    0.3125 <= 1/x <= 0.375  */
+ #define NP2r7_3r2N 9
+-static const _Float128 P2r7_3r2N[NP2r7_3r2N + 1] = {
+-  L(4.599033469240421554219816935160627085991E-7),
+-  L(4.665724440345003914596647144630893997284E-5),
+-  L(1.684348845667764271596142716944374892756E-3),
+-  L(2.802446446884455707845985913454440176223E-2),
+-  L(2.321937586453963310008279956042545173930E-1),
+-  L(9.640277413988055668692438709376437553804E-1),
+-  L(1.911021064710270904508663334033003246028E0),
+-  L(1.600811610164341450262992138893970224971E0),
+-  L(4.266299218652587901171386591543457861138E-1),
+-  L(1.316470424456061252962568223251247207325E-2),
++static const long double P2r7_3r2N[NP2r7_3r2N + 1] = {
++  4.599033469240421554219816935160627085991E-7L,
++  4.665724440345003914596647144630893997284E-5L,
++  1.684348845667764271596142716944374892756E-3L,
++  2.802446446884455707845985913454440176223E-2L,
++  2.321937586453963310008279956042545173930E-1L,
++  9.640277413988055668692438709376437553804E-1L,
++  1.911021064710270904508663334033003246028E0L,
++  1.600811610164341450262992138893970224971E0L,
++  4.266299218652587901171386591543457861138E-1L,
++  1.316470424456061252962568223251247207325E-2L,
+ };
+ #define NP2r7_3r2D 8
+-static const _Float128 P2r7_3r2D[NP2r7_3r2D + 1] = {
+-  L(3.924508608545520758883457108453520099610E-6),
+-  L(4.029707889408829273226495756222078039823E-4),
+-  L(1.484629715787703260797886463307469600219E-2),
+-  L(2.553136379967180865331706538897231588685E-1),
+-  L(2.229457223891676394409880026887106228740E0),
+-  L(1.005708903856384091956550845198392117318E1),
+-  L(2.277082659664386953166629360352385889558E1),
+-  L(2.384726835193630788249826630376533988245E1),
+-  L(9.700989749041320895890113781610939632410E0),
++static const long double P2r7_3r2D[NP2r7_3r2D + 1] = {
++  3.924508608545520758883457108453520099610E-6L,
++  4.029707889408829273226495756222078039823E-4L,
++  1.484629715787703260797886463307469600219E-2L,
++  2.553136379967180865331706538897231588685E-1L,
++  2.229457223891676394409880026887106228740E0L,
++  1.005708903856384091956550845198392117318E1L,
++  2.277082659664386953166629360352385889558E1L,
++  2.384726835193630788249826630376533988245E1L,
++  9.700989749041320895890113781610939632410E0L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -251,29 +249,29 @@ static const _Float128 P2r7_3r2D[NP2r7_3r2D + 1] = {
+    Peak relative error 1.7e-36
+    0.3125 <= 1/x <= 0.4375  */
+ #define NP2r3_2r7N 9
+-static const _Float128 P2r3_2r7N[NP2r3_2r7N + 1] = {
+-  L(3.916766777108274628543759603786857387402E-6),
+-  L(3.212176636756546217390661984304645137013E-4),
+-  L(9.255768488524816445220126081207248947118E-3),
+-  L(1.214853146369078277453080641911700735354E-1),
+-  L(7.855163309847214136198449861311404633665E-1),
+-  L(2.520058073282978403655488662066019816540E0),
+-  L(3.825136484837545257209234285382183711466E0),
+-  L(2.432569427554248006229715163865569506873E0),
+-  L(4.877934835018231178495030117729800489743E-1),
+-  L(1.109902737860249670981355149101343427885E-2),
++static const long double P2r3_2r7N[NP2r3_2r7N + 1] = {
++  3.916766777108274628543759603786857387402E-6L,
++  3.212176636756546217390661984304645137013E-4L,
++  9.255768488524816445220126081207248947118E-3L,
++  1.214853146369078277453080641911700735354E-1L,
++  7.855163309847214136198449861311404633665E-1L,
++  2.520058073282978403655488662066019816540E0L,
++  3.825136484837545257209234285382183711466E0L,
++  2.432569427554248006229715163865569506873E0L,
++  4.877934835018231178495030117729800489743E-1L,
++  1.109902737860249670981355149101343427885E-2L,
+ };
+ #define NP2r3_2r7D 8
+-static const _Float128 P2r3_2r7D[NP2r3_2r7D + 1] = {
+-  L(3.342307880794065640312646341190547184461E-5),
+-  L(2.782182891138893201544978009012096558265E-3),
+-  L(8.221304931614200702142049236141249929207E-2),
+-  L(1.123728246291165812392918571987858010949E0),
+-  L(7.740482453652715577233858317133423434590E0),
+-  L(2.737624677567945952953322566311201919139E1),
+-  L(4.837181477096062403118304137851260715475E1),
+-  L(3.941098643468580791437772701093795299274E1),
+-  L(1.245821247166544627558323920382547533630E1),
++static const long double P2r3_2r7D[NP2r3_2r7D + 1] = {
++  3.342307880794065640312646341190547184461E-5L,
++  2.782182891138893201544978009012096558265E-3L,
++  8.221304931614200702142049236141249929207E-2L,
++  1.123728246291165812392918571987858010949E0L,
++  7.740482453652715577233858317133423434590E0L,
++  2.737624677567945952953322566311201919139E1L,
++  4.837181477096062403118304137851260715475E1L,
++  3.941098643468580791437772701093795299274E1L,
++  1.245821247166544627558323920382547533630E1L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -281,28 +279,28 @@ static const _Float128 P2r3_2r7D[NP2r3_2r7D + 1] = {
+    Peak relative error 1.7e-35
+    0.4375 <= 1/x <= 0.5  */
+ #define NP2_2r3N 8
+-static const _Float128 P2_2r3N[NP2_2r3N + 1] = {
+-  L(3.397930802851248553545191160608731940751E-4),
+-  L(2.104020902735482418784312825637833698217E-2),
+-  L(4.442291771608095963935342749477836181939E-1),
+-  L(4.131797328716583282869183304291833754967E0),
+-  L(1.819920169779026500146134832455189917589E1),
+-  L(3.781779616522937565300309684282401791291E1),
+-  L(3.459605449728864218972931220783543410347E1),
+-  L(1.173594248397603882049066603238568316561E1),
+-  L(9.455702270242780642835086549285560316461E-1),
++static const long double P2_2r3N[NP2_2r3N + 1] = {
++  3.397930802851248553545191160608731940751E-4L,
++  2.104020902735482418784312825637833698217E-2L,
++  4.442291771608095963935342749477836181939E-1L,
++  4.131797328716583282869183304291833754967E0L,
++  1.819920169779026500146134832455189917589E1L,
++  3.781779616522937565300309684282401791291E1L,
++  3.459605449728864218972931220783543410347E1L,
++  1.173594248397603882049066603238568316561E1L,
++  9.455702270242780642835086549285560316461E-1L,
+ };
+ #define NP2_2r3D 8
+-static const _Float128 P2_2r3D[NP2_2r3D + 1] = {
+-  L(2.899568897241432883079888249845707400614E-3),
+-  L(1.831107138190848460767699919531132426356E-1),
+-  L(3.999350044057883839080258832758908825165E0),
+-  L(3.929041535867957938340569419874195303712E1),
+-  L(1.884245613422523323068802689915538908291E2),
+-  L(4.461469948819229734353852978424629815929E2),
+-  L(5.004998753999796821224085972610636347903E2),
+-  L(2.386342520092608513170837883757163414100E2),
+-  L(3.791322528149347975999851588922424189957E1),
++static const long double P2_2r3D[NP2_2r3D + 1] = {
++  2.899568897241432883079888249845707400614E-3L,
++  1.831107138190848460767699919531132426356E-1L,
++  3.999350044057883839080258832758908825165E0L,
++  3.929041535867957938340569419874195303712E1L,
++  1.884245613422523323068802689915538908291E2L,
++  4.461469948819229734353852978424629815929E2L,
++  5.004998753999796821224085972610636347903E2L,
++  2.386342520092608513170837883757163414100E2L,
++  3.791322528149347975999851588922424189957E1L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -311,31 +309,31 @@ static const _Float128 P2_2r3D[NP2_2r3D + 1] = {
+    Peak relative error 8.0e-36
+    0 <= 1/x <= .0625  */
+ #define NQ16_IN 10
+-static const _Float128 Q16_IN[NQ16_IN + 1] = {
+-  L(-3.917420835712508001321875734030357393421E-18),
+-  L(-4.440311387483014485304387406538069930457E-15),
+-  L(-1.951635424076926487780929645954007139616E-12),
+-  L(-4.318256438421012555040546775651612810513E-10),
+-  L(-5.231244131926180765270446557146989238020E-8),
+-  L(-3.540072702902043752460711989234732357653E-6),
+-  L(-1.311017536555269966928228052917534882984E-4),
+-  L(-2.495184669674631806622008769674827575088E-3),
+-  L(-2.141868222987209028118086708697998506716E-2),
+-  L(-6.184031415202148901863605871197272650090E-2),
+-  L(-1.922298704033332356899546792898156493887E-2),
++static const long double Q16_IN[NQ16_IN + 1] = {
++  -3.917420835712508001321875734030357393421E-18L,
++  -4.440311387483014485304387406538069930457E-15L,
++  -1.951635424076926487780929645954007139616E-12L,
++  -4.318256438421012555040546775651612810513E-10L,
++  -5.231244131926180765270446557146989238020E-8L,
++  -3.540072702902043752460711989234732357653E-6L,
++  -1.311017536555269966928228052917534882984E-4L,
++  -2.495184669674631806622008769674827575088E-3L,
++  -2.141868222987209028118086708697998506716E-2L,
++  -6.184031415202148901863605871197272650090E-2L,
++  -1.922298704033332356899546792898156493887E-2L,
+ };
+ #define NQ16_ID 9
+-static const _Float128 Q16_ID[NQ16_ID + 1] = {
+-  L(3.820418034066293517479619763498400162314E-17),
+-  L(4.340702810799239909648911373329149354911E-14),
+-  L(1.914985356383416140706179933075303538524E-11),
+-  L(4.262333682610888819476498617261895474330E-9),
+-  L(5.213481314722233980346462747902942182792E-7),
+-  L(3.585741697694069399299005316809954590558E-5),
+-  L(1.366513429642842006385029778105539457546E-3),
+-  L(2.745282599850704662726337474371355160594E-2),
+-  L(2.637644521611867647651200098449903330074E-1),
+-  L(1.006953426110765984590782655598680488746E0),
++static const long double Q16_ID[NQ16_ID + 1] = {
++  3.820418034066293517479619763498400162314E-17L,
++  4.340702810799239909648911373329149354911E-14L,
++  1.914985356383416140706179933075303538524E-11L,
++  4.262333682610888819476498617261895474330E-9L,
++  5.213481314722233980346462747902942182792E-7L,
++  3.585741697694069399299005316809954590558E-5L,
++  1.366513429642842006385029778105539457546E-3L,
++  2.745282599850704662726337474371355160594E-2L,
++  2.637644521611867647651200098449903330074E-1L,
++  1.006953426110765984590782655598680488746E0L,
+  /* 1.000000000000000000000000000000000000000E0 */
+  };
+ 
+@@ -344,34 +342,34 @@ static const _Float128 Q16_ID[NQ16_ID + 1] = {
+    Peak relative error 1.9e-36
+    0.0625 <= 1/x <= 0.125  */
+ #define NQ8_16N 11
+-static const _Float128 Q8_16N[NQ8_16N + 1] = {
+-  L(-2.028630366670228670781362543615221542291E-17),
+-  L(-1.519634620380959966438130374006858864624E-14),
+-  L(-4.540596528116104986388796594639405114524E-12),
+-  L(-7.085151756671466559280490913558388648274E-10),
+-  L(-6.351062671323970823761883833531546885452E-8),
+-  L(-3.390817171111032905297982523519503522491E-6),
+-  L(-1.082340897018886970282138836861233213972E-4),
+-  L(-2.020120801187226444822977006648252379508E-3),
+-  L(-2.093169910981725694937457070649605557555E-2),
+-  L(-1.092176538874275712359269481414448063393E-1),
+-  L(-2.374790947854765809203590474789108718733E-1),
+-  L(-1.365364204556573800719985118029601401323E-1),
++static const long double Q8_16N[NQ8_16N + 1] = {
++  -2.028630366670228670781362543615221542291E-17L,
++  -1.519634620380959966438130374006858864624E-14L,
++  -4.540596528116104986388796594639405114524E-12L,
++  -7.085151756671466559280490913558388648274E-10L,
++  -6.351062671323970823761883833531546885452E-8L,
++  -3.390817171111032905297982523519503522491E-6L,
++  -1.082340897018886970282138836861233213972E-4L,
++  -2.020120801187226444822977006648252379508E-3L,
++  -2.093169910981725694937457070649605557555E-2L,
++  -1.092176538874275712359269481414448063393E-1L,
++  -2.374790947854765809203590474789108718733E-1L,
++  -1.365364204556573800719985118029601401323E-1L,
+ };
+ #define NQ8_16D 11
+-static const _Float128 Q8_16D[NQ8_16D + 1] = {
+-  L(1.978397614733632533581207058069628242280E-16),
+-  L(1.487361156806202736877009608336766720560E-13),
+-  L(4.468041406888412086042576067133365913456E-11),
+-  L(7.027822074821007443672290507210594648877E-9),
+-  L(6.375740580686101224127290062867976007374E-7),
+-  L(3.466887658320002225888644977076410421940E-5),
+-  L(1.138625640905289601186353909213719596986E-3),
+-  L(2.224470799470414663443449818235008486439E-2),
+-  L(2.487052928527244907490589787691478482358E-1),
+-  L(1.483927406564349124649083853892380899217E0),
+-  L(4.182773513276056975777258788903489507705E0),
+-  L(4.419665392573449746043880892524360870944E0),
++static const long double Q8_16D[NQ8_16D + 1] = {
++  1.978397614733632533581207058069628242280E-16L,
++  1.487361156806202736877009608336766720560E-13L,
++  4.468041406888412086042576067133365913456E-11L,
++  7.027822074821007443672290507210594648877E-9L,
++  6.375740580686101224127290062867976007374E-7L,
++  3.466887658320002225888644977076410421940E-5L,
++  1.138625640905289601186353909213719596986E-3L,
++  2.224470799470414663443449818235008486439E-2L,
++  2.487052928527244907490589787691478482358E-1L,
++  1.483927406564349124649083853892380899217E0L,
++  4.182773513276056975777258788903489507705E0L,
++  4.419665392573449746043880892524360870944E0L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -380,32 +378,32 @@ static const _Float128 Q8_16D[NQ8_16D + 1] = {
+    Peak relative error 1.5e-35
+    0.125 <= 1/x <= 0.1875  */
+ #define NQ5_8N 10
+-static const _Float128 Q5_8N[NQ5_8N + 1] = {
+-  L(-3.656082407740970534915918390488336879763E-13),
+-  L(-1.344660308497244804752334556734121771023E-10),
+-  L(-1.909765035234071738548629788698150760791E-8),
+-  L(-1.366668038160120210269389551283666716453E-6),
+-  L(-5.392327355984269366895210704976314135683E-5),
+-  L(-1.206268245713024564674432357634540343884E-3),
+-  L(-1.515456784370354374066417703736088291287E-2),
+-  L(-1.022454301137286306933217746545237098518E-1),
+-  L(-3.373438906472495080504907858424251082240E-1),
+-  L(-4.510782522110845697262323973549178453405E-1),
+-  L(-1.549000892545288676809660828213589804884E-1),
++static const long double Q5_8N[NQ5_8N + 1] = {
++  -3.656082407740970534915918390488336879763E-13L,
++  -1.344660308497244804752334556734121771023E-10L,
++  -1.909765035234071738548629788698150760791E-8L,
++  -1.366668038160120210269389551283666716453E-6L,
++  -5.392327355984269366895210704976314135683E-5L,
++  -1.206268245713024564674432357634540343884E-3L,
++  -1.515456784370354374066417703736088291287E-2L,
++  -1.022454301137286306933217746545237098518E-1L,
++  -3.373438906472495080504907858424251082240E-1L,
++  -4.510782522110845697262323973549178453405E-1L,
++  -1.549000892545288676809660828213589804884E-1L,
+ };
+ #define NQ5_8D 10
+-static const _Float128 Q5_8D[NQ5_8D + 1] = {
+-  L(3.565550843359501079050699598913828460036E-12),
+-  L(1.321016015556560621591847454285330528045E-9),
+-  L(1.897542728662346479999969679234270605975E-7),
+-  L(1.381720283068706710298734234287456219474E-5),
+-  L(5.599248147286524662305325795203422873725E-4),
+-  L(1.305442352653121436697064782499122164843E-2),
+-  L(1.750234079626943298160445750078631894985E-1),
+-  L(1.311420542073436520965439883806946678491E0),
+-  L(5.162757689856842406744504211089724926650E0),
+-  L(9.527760296384704425618556332087850581308E0),
+-  L(6.604648207463236667912921642545100248584E0),
++static const long double Q5_8D[NQ5_8D + 1] = {
++  3.565550843359501079050699598913828460036E-12L,
++  1.321016015556560621591847454285330528045E-9L,
++  1.897542728662346479999969679234270605975E-7L,
++  1.381720283068706710298734234287456219474E-5L,
++  5.599248147286524662305325795203422873725E-4L,
++  1.305442352653121436697064782499122164843E-2L,
++  1.750234079626943298160445750078631894985E-1L,
++  1.311420542073436520965439883806946678491E0L,
++  5.162757689856842406744504211089724926650E0L,
++  9.527760296384704425618556332087850581308E0L,
++  6.604648207463236667912921642545100248584E0L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -414,31 +412,31 @@ static const _Float128 Q5_8D[NQ5_8D + 1] = {
+    Peak relative error 1.3e-35
+    0.1875 <= 1/x <= 0.25  */
+ #define NQ4_5N 10
+-static const _Float128 Q4_5N[NQ4_5N + 1] = {
+-  L(-4.079513568708891749424783046520200903755E-11),
+-  L(-9.326548104106791766891812583019664893311E-9),
+-  L(-8.016795121318423066292906123815687003356E-7),
+-  L(-3.372350544043594415609295225664186750995E-5),
+-  L(-7.566238665947967882207277686375417983917E-4),
+-  L(-9.248861580055565402130441618521591282617E-3),
+-  L(-6.033106131055851432267702948850231270338E-2),
+-  L(-1.966908754799996793730369265431584303447E-1),
+-  L(-2.791062741179964150755788226623462207560E-1),
+-  L(-1.255478605849190549914610121863534191666E-1),
+-  L(-4.320429862021265463213168186061696944062E-3),
++static const long double Q4_5N[NQ4_5N + 1] = {
++  -4.079513568708891749424783046520200903755E-11L,
++  -9.326548104106791766891812583019664893311E-9L,
++  -8.016795121318423066292906123815687003356E-7L,
++  -3.372350544043594415609295225664186750995E-5L,
++  -7.566238665947967882207277686375417983917E-4L,
++  -9.248861580055565402130441618521591282617E-3L,
++  -6.033106131055851432267702948850231270338E-2L,
++  -1.966908754799996793730369265431584303447E-1L,
++  -2.791062741179964150755788226623462207560E-1L,
++  -1.255478605849190549914610121863534191666E-1L,
++  -4.320429862021265463213168186061696944062E-3L,
+ };
+ #define NQ4_5D 9
+-static const _Float128 Q4_5D[NQ4_5D + 1] = {
+-  L(3.978497042580921479003851216297330701056E-10),
+-  L(9.203304163828145809278568906420772246666E-8),
+-  L(8.059685467088175644915010485174545743798E-6),
+-  L(3.490187375993956409171098277561669167446E-4),
+-  L(8.189109654456872150100501732073810028829E-3),
+-  L(1.072572867311023640958725265762483033769E-1),
+-  L(7.790606862409960053675717185714576937994E-1),
+-  L(3.016049768232011196434185423512777656328E0),
+-  L(5.722963851442769787733717162314477949360E0),
+-  L(4.510527838428473279647251350931380867663E0),
++static const long double Q4_5D[NQ4_5D + 1] = {
++  3.978497042580921479003851216297330701056E-10L,
++  9.203304163828145809278568906420772246666E-8L,
++  8.059685467088175644915010485174545743798E-6L,
++  3.490187375993956409171098277561669167446E-4L,
++  8.189109654456872150100501732073810028829E-3L,
++  1.072572867311023640958725265762483033769E-1L,
++  7.790606862409960053675717185714576937994E-1L,
++  3.016049768232011196434185423512777656328E0L,
++  5.722963851442769787733717162314477949360E0L,
++  4.510527838428473279647251350931380867663E0L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -447,30 +445,30 @@ static const _Float128 Q4_5D[NQ4_5D + 1] = {
+    Peak relative error 2.1e-35
+    0.25 <= 1/x <= 0.3125  */
+ #define NQ3r2_4N 9
+-static const _Float128 Q3r2_4N[NQ3r2_4N + 1] = {
+-  L(-1.087480809271383885936921889040388133627E-8),
+-  L(-1.690067828697463740906962973479310170932E-6),
+-  L(-9.608064416995105532790745641974762550982E-5),
+-  L(-2.594198839156517191858208513873961837410E-3),
+-  L(-3.610954144421543968160459863048062977822E-2),
+-  L(-2.629866798251843212210482269563961685666E-1),
+-  L(-9.709186825881775885917984975685752956660E-1),
+-  L(-1.667521829918185121727268867619982417317E0),
+-  L(-1.109255082925540057138766105229900943501E0),
+-  L(-1.812932453006641348145049323713469043328E-1),
++static const long double Q3r2_4N[NQ3r2_4N + 1] = {
++  -1.087480809271383885936921889040388133627E-8L,
++  -1.690067828697463740906962973479310170932E-6L,
++  -9.608064416995105532790745641974762550982E-5L,
++  -2.594198839156517191858208513873961837410E-3L,
++  -3.610954144421543968160459863048062977822E-2L,
++  -2.629866798251843212210482269563961685666E-1L,
++  -9.709186825881775885917984975685752956660E-1L,
++  -1.667521829918185121727268867619982417317E0L,
++  -1.109255082925540057138766105229900943501E0L,
++  -1.812932453006641348145049323713469043328E-1L,
+ };
+ #define NQ3r2_4D 9
+-static const _Float128 Q3r2_4D[NQ3r2_4D + 1] = {
+-  L(1.060552717496912381388763753841473407026E-7),
+-  L(1.676928002024920520786883649102388708024E-5),
+-  L(9.803481712245420839301400601140812255737E-4),
+-  L(2.765559874262309494758505158089249012930E-2),
+-  L(4.117921827792571791298862613287549140706E-1),
+-  L(3.323769515244751267093378361930279161413E0),
+-  L(1.436602494405814164724810151689705353670E1),
+-  L(3.163087869617098638064881410646782408297E1),
+-  L(3.198181264977021649489103980298349589419E1),
+-  L(1.203649258862068431199471076202897823272E1),
++static const long double Q3r2_4D[NQ3r2_4D + 1] = {
++  1.060552717496912381388763753841473407026E-7L,
++  1.676928002024920520786883649102388708024E-5L,
++  9.803481712245420839301400601140812255737E-4L,
++  2.765559874262309494758505158089249012930E-2L,
++  4.117921827792571791298862613287549140706E-1L,
++  3.323769515244751267093378361930279161413E0L,
++  1.436602494405814164724810151689705353670E1L,
++  3.163087869617098638064881410646782408297E1L,
++  3.198181264977021649489103980298349589419E1L,
++  1.203649258862068431199471076202897823272E1L,
+  /* 1.000000000000000000000000000000000000000E0  */
+ };
+ 
+@@ -479,30 +477,30 @@ static const _Float128 Q3r2_4D[NQ3r2_4D + 1] = {
+    Peak relative error 1.6e-36
+    0.3125 <= 1/x <= 0.375  */
+ #define NQ2r7_3r2N 9
+-static const _Float128 Q2r7_3r2N[NQ2r7_3r2N + 1] = {
+-  L(-1.723405393982209853244278760171643219530E-7),
+-  L(-2.090508758514655456365709712333460087442E-5),
+-  L(-9.140104013370974823232873472192719263019E-4),
+-  L(-1.871349499990714843332742160292474780128E-2),
+-  L(-1.948930738119938669637865956162512983416E-1),
+-  L(-1.048764684978978127908439526343174139788E0),
+-  L(-2.827714929925679500237476105843643064698E0),
+-  L(-3.508761569156476114276988181329773987314E0),
+-  L(-1.669332202790211090973255098624488308989E0),
+-  L(-1.930796319299022954013840684651016077770E-1),
++static const long double Q2r7_3r2N[NQ2r7_3r2N + 1] = {
++  -1.723405393982209853244278760171643219530E-7L,
++  -2.090508758514655456365709712333460087442E-5L,
++  -9.140104013370974823232873472192719263019E-4L,
++  -1.871349499990714843332742160292474780128E-2L,
++  -1.948930738119938669637865956162512983416E-1L,
++  -1.048764684978978127908439526343174139788E0L,
++  -2.827714929925679500237476105843643064698E0L,
++  -3.508761569156476114276988181329773987314E0L,
++  -1.669332202790211090973255098624488308989E0L,
++  -1.930796319299022954013840684651016077770E-1L,
+ };
+ #define NQ2r7_3r2D 9
+-static const _Float128 Q2r7_3r2D[NQ2r7_3r2D + 1] = {
+-  L(1.680730662300831976234547482334347983474E-6),
+-  L(2.084241442440551016475972218719621841120E-4),
+-  L(9.445316642108367479043541702688736295579E-3),
+-  L(2.044637889456631896650179477133252184672E-1),
+-  L(2.316091982244297350829522534435350078205E0),
+-  L(1.412031891783015085196708811890448488865E1),
+-  L(4.583830154673223384837091077279595496149E1),
+-  L(7.549520609270909439885998474045974122261E1),
+-  L(5.697605832808113367197494052388203310638E1),
+-  L(1.601496240876192444526383314589371686234E1),
++static const long double Q2r7_3r2D[NQ2r7_3r2D + 1] = {
++  1.680730662300831976234547482334347983474E-6L,
++  2.084241442440551016475972218719621841120E-4L,
++  9.445316642108367479043541702688736295579E-3L,
++  2.044637889456631896650179477133252184672E-1L,
++  2.316091982244297350829522534435350078205E0L,
++  1.412031891783015085196708811890448488865E1L,
++  4.583830154673223384837091077279595496149E1L,
++  7.549520609270909439885998474045974122261E1L,
++  5.697605832808113367197494052388203310638E1L,
++  1.601496240876192444526383314589371686234E1L,
+   /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -511,29 +509,29 @@ static const _Float128 Q2r7_3r2D[NQ2r7_3r2D + 1] = {
+    Peak relative error 9.5e-36
+    0.375 <= 1/x <= 0.4375  */
+ #define NQ2r3_2r7N 9
+-static const _Float128 Q2r3_2r7N[NQ2r3_2r7N + 1] = {
+-  L(-8.603042076329122085722385914954878953775E-7),
+-  L(-7.701746260451647874214968882605186675720E-5),
+-  L(-2.407932004380727587382493696877569654271E-3),
+-  L(-3.403434217607634279028110636919987224188E-2),
+-  L(-2.348707332185238159192422084985713102877E-1),
+-  L(-7.957498841538254916147095255700637463207E-1),
+-  L(-1.258469078442635106431098063707934348577E0),
+-  L(-8.162415474676345812459353639449971369890E-1),
+-  L(-1.581783890269379690141513949609572806898E-1),
+-  L(-1.890595651683552228232308756569450822905E-3),
++static const long double Q2r3_2r7N[NQ2r3_2r7N + 1] = {
++  -8.603042076329122085722385914954878953775E-7L,
++  -7.701746260451647874214968882605186675720E-5L,
++  -2.407932004380727587382493696877569654271E-3L,
++  -3.403434217607634279028110636919987224188E-2L,
++  -2.348707332185238159192422084985713102877E-1L,
++  -7.957498841538254916147095255700637463207E-1L,
++  -1.258469078442635106431098063707934348577E0L,
++  -8.162415474676345812459353639449971369890E-1L,
++  -1.581783890269379690141513949609572806898E-1L,
++  -1.890595651683552228232308756569450822905E-3L,
+ };
+ #define NQ2r3_2r7D 8
+-static const _Float128 Q2r3_2r7D[NQ2r3_2r7D + 1] = {
+-  L(8.390017524798316921170710533381568175665E-6),
+-  L(7.738148683730826286477254659973968763659E-4),
+-  L(2.541480810958665794368759558791634341779E-2),
+-  L(3.878879789711276799058486068562386244873E-1),
+-  L(3.003783779325811292142957336802456109333E0),
+-  L(1.206480374773322029883039064575464497400E1),
+-  L(2.458414064785315978408974662900438351782E1),
+-  L(2.367237826273668567199042088835448715228E1),
+-  L(9.231451197519171090875569102116321676763E0),
++static const long double Q2r3_2r7D[NQ2r3_2r7D + 1] = {
++  8.390017524798316921170710533381568175665E-6L,
++  7.738148683730826286477254659973968763659E-4L,
++  2.541480810958665794368759558791634341779E-2L,
++  3.878879789711276799058486068562386244873E-1L,
++  3.003783779325811292142957336802456109333E0L,
++  1.206480374773322029883039064575464497400E1L,
++  2.458414064785315978408974662900438351782E1L,
++  2.367237826273668567199042088835448715228E1L,
++  9.231451197519171090875569102116321676763E0L,
+  /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+@@ -542,39 +540,39 @@ static const _Float128 Q2r3_2r7D[NQ2r3_2r7D + 1] = {
+    Peak relative error 1.4e-36
+    0.4375 <= 1/x <= 0.5  */
+ #define NQ2_2r3N 9
+-static const _Float128 Q2_2r3N[NQ2_2r3N + 1] = {
+-  L(-5.552507516089087822166822364590806076174E-6),
+-  L(-4.135067659799500521040944087433752970297E-4),
+-  L(-1.059928728869218962607068840646564457980E-2),
+-  L(-1.212070036005832342565792241385459023801E-1),
+-  L(-6.688350110633603958684302153362735625156E-1),
+-  L(-1.793587878197360221340277951304429821582E0),
+-  L(-2.225407682237197485644647380483725045326E0),
+-  L(-1.123402135458940189438898496348239744403E0),
+-  L(-1.679187241566347077204805190763597299805E-1),
+-  L(-1.458550613639093752909985189067233504148E-3),
++static const long double Q2_2r3N[NQ2_2r3N + 1] = {
++  -5.552507516089087822166822364590806076174E-6L,
++  -4.135067659799500521040944087433752970297E-4L,
++  -1.059928728869218962607068840646564457980E-2L,
++  -1.212070036005832342565792241385459023801E-1L,
++  -6.688350110633603958684302153362735625156E-1L,
++  -1.793587878197360221340277951304429821582E0L,
++  -2.225407682237197485644647380483725045326E0L,
++  -1.123402135458940189438898496348239744403E0L,
++  -1.679187241566347077204805190763597299805E-1L,
++  -1.458550613639093752909985189067233504148E-3L,
+ };
+ #define NQ2_2r3D 8
+-static const _Float128 Q2_2r3D[NQ2_2r3D + 1] = {
+-  L(5.415024336507980465169023996403597916115E-5),
+-  L(4.179246497380453022046357404266022870788E-3),
+-  L(1.136306384261959483095442402929502368598E-1),
+-  L(1.422640343719842213484515445393284072830E0),
+-  L(8.968786703393158374728850922289204805764E0),
+-  L(2.914542473339246127533384118781216495934E1),
+-  L(4.781605421020380669870197378210457054685E1),
+-  L(3.693865837171883152382820584714795072937E1),
+-  L(1.153220502744204904763115556224395893076E1),
++static const long double Q2_2r3D[NQ2_2r3D + 1] = {
++  5.415024336507980465169023996403597916115E-5L,
++  4.179246497380453022046357404266022870788E-3L,
++  1.136306384261959483095442402929502368598E-1L,
++  1.422640343719842213484515445393284072830E0L,
++  8.968786703393158374728850922289204805764E0L,
++  2.914542473339246127533384118781216495934E1L,
++  4.781605421020380669870197378210457054685E1L,
++  3.693865837171883152382820584714795072937E1L,
++  1.153220502744204904763115556224395893076E1L,
+   /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+ 
+ /* Evaluate P[n] x^n  +  P[n-1] x^(n-1)  +  ...  +  P[0] */
+ 
+-static _Float128
+-neval (_Float128 x, const _Float128 *p, int n)
++static long double
++neval (long double x, const long double *p, int n)
+ {
+-  _Float128 y;
++  long double y;
+ 
+   p += n;
+   y = *p--;
+@@ -589,10 +587,10 @@ neval (_Float128 x, const _Float128 *p, int n)
+ 
+ /* Evaluate x^n+1  +  P[n] x^(n)  +  P[n-1] x^(n-1)  +  ...  +  P[0] */
+ 
+-static _Float128
+-deval (_Float128 x, const _Float128 *p, int n)
++static long double
++deval (long double x, const long double *p, int n)
+ {
+-  _Float128 y;
++  long double y;
+ 
+   p += n;
+   y = x + *p--;
+@@ -607,10 +605,10 @@ deval (_Float128 x, const _Float128 *p, int n)
+ 
+ /* Bessel function of the first kind, order one.  */
+ 
+-_Float128
+-__ieee754_j1l (_Float128 x)
++long double
++__ieee754_j1l (long double x)
+ {
+-  _Float128 xx, xinv, z, p, q, c, s, cc, ss;
++  long double xx, xinv, z, p, q, c, s, cc, ss;
+ 
+   if (! isfinite (x))
+     {
+@@ -622,9 +620,9 @@ __ieee754_j1l (_Float128 x)
+   if (x == 0)
+     return x;
+   xx = fabsl (x);
+-  if (xx <= L(0x1p-58))
++  if (xx <= 0x1p-58L)
+     {
+-      _Float128 ret = x * L(0.5);
++      long double ret = x * 0.5L;
+       math_check_force_underflow (ret);
+       if (ret == 0)
+ 	__set_errno (ERANGE);
+@@ -635,7 +633,7 @@ __ieee754_j1l (_Float128 x)
+       /* 0 <= x <= 2 */
+       z = xx * xx;
+       p = xx * z * neval (z, J0_2N, NJ0_2N) / deval (z, J0_2D, NJ0_2D);
+-      p += L(0.5) * xx;
++      p += 0.5L * xx;
+       if (x < 0)
+ 	p = -p;
+       return p;
+@@ -659,7 +657,7 @@ __ieee754_j1l (_Float128 x)
+ 	ss = z / cc;
+     }
+ 
+-  if (xx > L(0x1p256))
++  if (xx > 0x1p256L)
+     {
+       z = ONEOSQPI * cc / __ieee754_sqrtl (xx);
+       if (x < 0)
+@@ -727,7 +725,7 @@ __ieee754_j1l (_Float128 x)
+     }
+   p = 1 + z * p;
+   q = z * q;
+-  q = q * xinv + L(0.375) * xinv;
++  q = q * xinv + 0.375L * xinv;
+   z = ONEOSQPI * (p * cc - q * ss) / __ieee754_sqrtl (xx);
+   if (x < 0)
+     z = -z;
+@@ -740,36 +738,36 @@ strong_alias (__ieee754_j1l, __j1l_finite)
+    Peak relative error 6.2e-38
+    0 <= x <= 2   */
+ #define NY0_2N 7
+-static _Float128 Y0_2N[NY0_2N + 1] = {
+-  L(-6.804415404830253804408698161694720833249E19),
+-  L(1.805450517967019908027153056150465849237E19),
+-  L(-8.065747497063694098810419456383006737312E17),
+-  L(1.401336667383028259295830955439028236299E16),
+-  L(-1.171654432898137585000399489686629680230E14),
+-  L(5.061267920943853732895341125243428129150E11),
+-  L(-1.096677850566094204586208610960870217970E9),
+-  L(9.541172044989995856117187515882879304461E5),
++static long double Y0_2N[NY0_2N + 1] = {
++  -6.804415404830253804408698161694720833249E19L,
++  1.805450517967019908027153056150465849237E19L,
++  -8.065747497063694098810419456383006737312E17L,
++  1.401336667383028259295830955439028236299E16L,
++  -1.171654432898137585000399489686629680230E14L,
++  5.061267920943853732895341125243428129150E11L,
++  -1.096677850566094204586208610960870217970E9L,
++  9.541172044989995856117187515882879304461E5L,
+ };
+ #define NY0_2D 7
+-static _Float128 Y0_2D[NY0_2D + 1] = {
+-  L(3.470629591820267059538637461549677594549E20),
+-  L(4.120796439009916326855848107545425217219E18),
+-  L(2.477653371652018249749350657387030814542E16),
+-  L(9.954678543353888958177169349272167762797E13),
+-  L(2.957927997613630118216218290262851197754E11),
+-  L(6.748421382188864486018861197614025972118E8),
+-  L(1.173453425218010888004562071020305709319E6),
+-  L(1.450335662961034949894009554536003377187E3),
++static long double Y0_2D[NY0_2D + 1] = {
++  3.470629591820267059538637461549677594549E20L,
++  4.120796439009916326855848107545425217219E18L,
++  2.477653371652018249749350657387030814542E16L,
++  9.954678543353888958177169349272167762797E13L,
++  2.957927997613630118216218290262851197754E11L,
++  6.748421382188864486018861197614025972118E8L,
++  1.173453425218010888004562071020305709319E6L,
++  1.450335662961034949894009554536003377187E3L,
+   /* 1.000000000000000000000000000000000000000E0 */
+ };
+ 
+ 
+ /* Bessel function of the second kind, order one.  */
+ 
+-_Float128
+-__ieee754_y1l (_Float128 x)
++long double
++__ieee754_y1l (long double x)
+ {
+-  _Float128 xx, xinv, z, p, q, c, s, cc, ss;
++  long double xx, xinv, z, p, q, c, s, cc, ss;
+ 
+   if (! isfinite (x))
+     return 1 / (x + x * x);
+@@ -816,7 +814,7 @@ __ieee754_y1l (_Float128 x)
+ 	ss = z / cc;
+     }
+ 
+-  if (xx > L(0x1p256))
++  if (xx > 0x1p256L)
+     return ONEOSQPI * ss / __ieee754_sqrtl (xx);
+ 
+   xinv = 1 / xx;
+@@ -879,7 +877,7 @@ __ieee754_y1l (_Float128 x)
+     }
+   p = 1 + z * p;
+   q = z * q;
+-  q = q * xinv + L(0.375) * xinv;
++  q = q * xinv + 0.375L * xinv;
+   z = ONEOSQPI * (p * ss + q * cc) / __ieee754_sqrtl (xx);
+   return z;
+ }
+diff --git a/sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c b/sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c
+index f3e184c622..474773e81d 100644
+--- a/sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c
++++ b/sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c
+@@ -17,42 +17,40 @@
+ 
+ /* This file was copied from sysdeps/ieee754/ldbl-128/e_lgammal_r.c.  */
+ 
+-#define _Float128 long double
+-#define L(x) x ## L
+ 
+ #include <math.h>
+ #include <math_private.h>
+ #include <float.h>
+ 
+-static const _Float128 PIL = L(3.1415926535897932384626433832795028841972E0);
++static const long double PIL = 3.1415926535897932384626433832795028841972E0L;
+ #if LDBL_MANT_DIG == 106
+-static const _Float128 MAXLGM = L(0x5.d53649e2d469dbc1f01e99fd66p+1012);
++static const long double MAXLGM = 0x5.d53649e2d469dbc1f01e99fd66p+1012L;
+ #else
+-static const _Float128 MAXLGM = L(1.0485738685148938358098967157129705071571E4928);
++static const long double MAXLGM = 1.0485738685148938358098967157129705071571E4928L;
+ #endif
+-static const _Float128 one = 1;
+-static const _Float128 huge = LDBL_MAX;
++static const long double one = 1;
++static const long double huge = LDBL_MAX;
+ 
+ /* log gamma(x) = ( x - 0.5 ) * log(x) - x + LS2PI + 1/x P(1/x^2)
+    1/x <= 0.0741 (x >= 13.495...)
+    Peak relative error 1.5e-36  */
+-static const _Float128 ls2pi = L(9.1893853320467274178032973640561763986140E-1);
++static const long double ls2pi = 9.1893853320467274178032973640561763986140E-1L;
+ #define NRASY 12
+-static const _Float128 RASY[NRASY + 1] =
++static const long double RASY[NRASY + 1] =
+ {
+-  L(8.333333333333333333333333333310437112111E-2),
+- L(-2.777777777777777777777774789556228296902E-3),
+-  L(7.936507936507936507795933938448586499183E-4),
+- L(-5.952380952380952041799269756378148574045E-4),
+-  L(8.417508417507928904209891117498524452523E-4),
+- L(-1.917526917481263997778542329739806086290E-3),
+-  L(6.410256381217852504446848671499409919280E-3),
+- L(-2.955064066900961649768101034477363301626E-2),
+-  L(1.796402955865634243663453415388336954675E-1),
+- L(-1.391522089007758553455753477688592767741E0),
+-  L(1.326130089598399157988112385013829305510E1),
+- L(-1.420412699593782497803472576479997819149E2),
+-  L(1.218058922427762808938869872528846787020E3)
++  8.333333333333333333333333333310437112111E-2L,
++ -2.777777777777777777777774789556228296902E-3L,
++  7.936507936507936507795933938448586499183E-4L,
++ -5.952380952380952041799269756378148574045E-4L,
++  8.417508417507928904209891117498524452523E-4L,
++ -1.917526917481263997778542329739806086290E-3L,
++  6.410256381217852504446848671499409919280E-3L,
++ -2.955064066900961649768101034477363301626E-2L,
++  1.796402955865634243663453415388336954675E-1L,
++ -1.391522089007758553455753477688592767741E0L,
++  1.326130089598399157988112385013829305510E1L,
++ -1.420412699593782497803472576479997819149E2L,
++  1.218058922427762808938869872528846787020E3L
+ };
+ 
+ 
+@@ -60,30 +58,30 @@ static const _Float128 RASY[NRASY + 1] =
+    -0.5 <= x <= 0.5
+    12.5 <= x+13 <= 13.5
+    Peak relative error 1.1e-36  */
+-static const _Float128 lgam13a = L(1.9987213134765625E1);
+-static const _Float128 lgam13b = L(1.3608962611495173623870550785125024484248E-6);
++static const long double lgam13a = 1.9987213134765625E1L;
++static const long double lgam13b = 1.3608962611495173623870550785125024484248E-6L;
+ #define NRN13 7
+-static const _Float128 RN13[NRN13 + 1] =
++static const long double RN13[NRN13 + 1] =
+ {
+-  L(8.591478354823578150238226576156275285700E11),
+-  L(2.347931159756482741018258864137297157668E11),
+-  L(2.555408396679352028680662433943000804616E10),
+-  L(1.408581709264464345480765758902967123937E9),
+-  L(4.126759849752613822953004114044451046321E7),
+-  L(6.133298899622688505854211579222889943778E5),
+-  L(3.929248056293651597987893340755876578072E3),
+-  L(6.850783280018706668924952057996075215223E0)
++  8.591478354823578150238226576156275285700E11L,
++  2.347931159756482741018258864137297157668E11L,
++  2.555408396679352028680662433943000804616E10L,
++  1.408581709264464345480765758902967123937E9L,
++  4.126759849752613822953004114044451046321E7L,
++  6.133298899622688505854211579222889943778E5L,
++  3.929248056293651597987893340755876578072E3L,
++  6.850783280018706668924952057996075215223E0L
+ };
+ #define NRD13 6
+-static const _Float128 RD13[NRD13 + 1] =
+-{
+-  L(3.401225382297342302296607039352935541669E11),
+-  L(8.756765276918037910363513243563234551784E10),
+-  L(8.873913342866613213078554180987647243903E9),
+-  L(4.483797255342763263361893016049310017973E8),
+-  L(1.178186288833066430952276702931512870676E7),
+-  L(1.519928623743264797939103740132278337476E5),
+-  L(7.989298844938119228411117593338850892311E2)
++static const long double RD13[NRD13 + 1] =
++{
++  3.401225382297342302296607039352935541669E11L,
++  8.756765276918037910363513243563234551784E10L,
++  8.873913342866613213078554180987647243903E9L,
++  4.483797255342763263361893016049310017973E8L,
++  1.178186288833066430952276702931512870676E7L,
++  1.519928623743264797939103740132278337476E5L,
++  7.989298844938119228411117593338850892311E2L
+  /* 1.0E0L */
+ };
+ 
+@@ -92,30 +90,30 @@ static const _Float128 RD13[NRD13 + 1] =
+    -0.5 <= x <= 0.5
+    11.5 <= x+12 <= 12.5
+    Peak relative error 4.1e-36  */
+-static const _Float128 lgam12a = L(1.75023040771484375E1);
+-static const _Float128 lgam12b = L(3.7687254483392876529072161996717039575982E-6);
++static const long double lgam12a = 1.75023040771484375E1L;
++static const long double lgam12b = 3.7687254483392876529072161996717039575982E-6L;
+ #define NRN12 7
+-static const _Float128 RN12[NRN12 + 1] =
++static const long double RN12[NRN12 + 1] =
+ {
+-  L(4.709859662695606986110997348630997559137E11),
+-  L(1.398713878079497115037857470168777995230E11),
+-  L(1.654654931821564315970930093932954900867E10),
+-  L(9.916279414876676861193649489207282144036E8),
+-  L(3.159604070526036074112008954113411389879E7),
+-  L(5.109099197547205212294747623977502492861E5),
+-  L(3.563054878276102790183396740969279826988E3),
+-  L(6.769610657004672719224614163196946862747E0)
++  4.709859662695606986110997348630997559137E11L,
++  1.398713878079497115037857470168777995230E11L,
++  1.654654931821564315970930093932954900867E10L,
++  9.916279414876676861193649489207282144036E8L,
++  3.159604070526036074112008954113411389879E7L,
++  5.109099197547205212294747623977502492861E5L,
++  3.563054878276102790183396740969279826988E3L,
++  6.769610657004672719224614163196946862747E0L
+ };
+ #define NRD12 6
+-static const _Float128 RD12[NRD12 + 1] =
+-{
+-  L(1.928167007860968063912467318985802726613E11),
+-  L(5.383198282277806237247492369072266389233E10),
+-  L(5.915693215338294477444809323037871058363E9),
+-  L(3.241438287570196713148310560147925781342E8),
+-  L(9.236680081763754597872713592701048455890E6),
+-  L(1.292246897881650919242713651166596478850E5),
+-  L(7.366532445427159272584194816076600211171E2)
++static const long double RD12[NRD12 + 1] =
++{
++  1.928167007860968063912467318985802726613E11L,
++  5.383198282277806237247492369072266389233E10L,
++  5.915693215338294477444809323037871058363E9L,
++  3.241438287570196713148310560147925781342E8L,
++  9.236680081763754597872713592701048455890E6L,
++  1.292246897881650919242713651166596478850E5L,
++  7.366532445427159272584194816076600211171E2L
+  /* 1.0E0L */
+ };
+ 
+@@ -124,30 +122,30 @@ static const _Float128 RD12[NRD12 + 1] =
+    -0.5 <= x <= 0.5
+    10.5 <= x+11 <= 11.5
+    Peak relative error 1.8e-35  */
+-static const _Float128 lgam11a = L(1.5104400634765625E1);
+-static const _Float128 lgam11b = L(1.1938309890295225709329251070371882250744E-5);
++static const long double lgam11a = 1.5104400634765625E1L;
++static const long double lgam11b = 1.1938309890295225709329251070371882250744E-5L;
+ #define NRN11 7
+-static const _Float128 RN11[NRN11 + 1] =
++static const long double RN11[NRN11 + 1] =
+ {
+-  L(2.446960438029415837384622675816736622795E11),
+-  L(7.955444974446413315803799763901729640350E10),
+-  L(1.030555327949159293591618473447420338444E10),
+-  L(6.765022131195302709153994345470493334946E8),
+-  L(2.361892792609204855279723576041468347494E7),
+-  L(4.186623629779479136428005806072176490125E5),
+-  L(3.202506022088912768601325534149383594049E3),
+-  L(6.681356101133728289358838690666225691363E0)
++  2.446960438029415837384622675816736622795E11L,
++  7.955444974446413315803799763901729640350E10L,
++  1.030555327949159293591618473447420338444E10L,
++  6.765022131195302709153994345470493334946E8L,
++  2.361892792609204855279723576041468347494E7L,
++  4.186623629779479136428005806072176490125E5L,
++  3.202506022088912768601325534149383594049E3L,
++  6.681356101133728289358838690666225691363E0L
+ };
+ #define NRD11 6
+-static const _Float128 RD11[NRD11 + 1] =
+-{
+-  L(1.040483786179428590683912396379079477432E11),
+-  L(3.172251138489229497223696648369823779729E10),
+-  L(3.806961885984850433709295832245848084614E9),
+-  L(2.278070344022934913730015420611609620171E8),
+-  L(7.089478198662651683977290023829391596481E6),
+-  L(1.083246385105903533237139380509590158658E5),
+-  L(6.744420991491385145885727942219463243597E2)
++static const long double RD11[NRD11 + 1] =
++{
++  1.040483786179428590683912396379079477432E11L,
++  3.172251138489229497223696648369823779729E10L,
++  3.806961885984850433709295832245848084614E9L,
++  2.278070344022934913730015420611609620171E8L,
++  7.089478198662651683977290023829391596481E6L,
++  1.083246385105903533237139380509590158658E5L,
++  6.744420991491385145885727942219463243597E2L
+  /* 1.0E0L */
+ };
+ 
+@@ -156,31 +154,31 @@ static const _Float128 RD11[NRD11 + 1] =
+    -0.5 <= x <= 0.5
+    9.5 <= x+10 <= 10.5
+    Peak relative error 5.4e-37  */
+-static const _Float128 lgam10a = L(1.280181884765625E1);
+-static const _Float128 lgam10b = L(8.6324252196112077178745667061642811492557E-6);
++static const long double lgam10a = 1.280181884765625E1L;
++static const long double lgam10b = 8.6324252196112077178745667061642811492557E-6L;
+ #define NRN10 7
+-static const _Float128 RN10[NRN10 + 1] =
++static const long double RN10[NRN10 + 1] =
+ {
+-  L(-1.239059737177249934158597996648808363783E14),
+-  L(-4.725899566371458992365624673357356908719E13),
+-  L(-7.283906268647083312042059082837754850808E12),
+-  L(-5.802855515464011422171165179767478794637E11),
+-  L(-2.532349691157548788382820303182745897298E10),
+-  L(-5.884260178023777312587193693477072061820E8),
+-  L(-6.437774864512125749845840472131829114906E6),
+-  L(-2.350975266781548931856017239843273049384E4)
++  -1.239059737177249934158597996648808363783E14L,
++  -4.725899566371458992365624673357356908719E13L,
++  -7.283906268647083312042059082837754850808E12L,
++  -5.802855515464011422171165179767478794637E11L,
++  -2.532349691157548788382820303182745897298E10L,
++  -5.884260178023777312587193693477072061820E8L,
++  -6.437774864512125749845840472131829114906E6L,
++  -2.350975266781548931856017239843273049384E4L
+ };
+ #define NRD10 7
+-static const _Float128 RD10[NRD10 + 1] =
+-{
+-  L(-5.502645997581822567468347817182347679552E13),
+-  L(-1.970266640239849804162284805400136473801E13),
+-  L(-2.819677689615038489384974042561531409392E12),
+-  L(-2.056105863694742752589691183194061265094E11),
+-  L(-8.053670086493258693186307810815819662078E9),
+-  L(-1.632090155573373286153427982504851867131E8),
+-  L(-1.483575879240631280658077826889223634921E6),
+-  L(-4.002806669713232271615885826373550502510E3)
++static const long double RD10[NRD10 + 1] =
++{
++  -5.502645997581822567468347817182347679552E13L,
++  -1.970266640239849804162284805400136473801E13L,
++  -2.819677689615038489384974042561531409392E12L,
++  -2.056105863694742752589691183194061265094E11L,
++  -8.053670086493258693186307810815819662078E9L,
++  -1.632090155573373286153427982504851867131E8L,
++  -1.483575879240631280658077826889223634921E6L,
++  -4.002806669713232271615885826373550502510E3L
+  /* 1.0E0L */
+ };
+ 
+@@ -189,31 +187,31 @@ static const _Float128 RD10[NRD10 + 1] =
+    -0.5 <= x <= 0.5
+    8.5 <= x+9 <= 9.5
+    Peak relative error 3.6e-36  */
+-static const _Float128 lgam9a = L(1.06045989990234375E1);
+-static const _Float128 lgam9b = L(3.9037218127284172274007216547549861681400E-6);
++static const long double lgam9a = 1.06045989990234375E1L;
++static const long double lgam9b = 3.9037218127284172274007216547549861681400E-6L;
+ #define NRN9 7
+-static const _Float128 RN9[NRN9 + 1] =
++static const long double RN9[NRN9 + 1] =
+ {
+-  L(-4.936332264202687973364500998984608306189E13),
+-  L(-2.101372682623700967335206138517766274855E13),
+-  L(-3.615893404644823888655732817505129444195E12),
+-  L(-3.217104993800878891194322691860075472926E11),
+-  L(-1.568465330337375725685439173603032921399E10),
+-  L(-4.073317518162025744377629219101510217761E8),
+-  L(-4.983232096406156139324846656819246974500E6),
+-  L(-2.036280038903695980912289722995505277253E4)
++  -4.936332264202687973364500998984608306189E13L,
++  -2.101372682623700967335206138517766274855E13L,
++  -3.615893404644823888655732817505129444195E12L,
++  -3.217104993800878891194322691860075472926E11L,
++  -1.568465330337375725685439173603032921399E10L,
++  -4.073317518162025744377629219101510217761E8L,
++  -4.983232096406156139324846656819246974500E6L,
++  -2.036280038903695980912289722995505277253E4L
+ };
+ #define NRD9 7
+-static const _Float128 RD9[NRD9 + 1] =
+-{
+-  L(-2.306006080437656357167128541231915480393E13),
+-  L(-9.183606842453274924895648863832233799950E12),
+-  L(-1.461857965935942962087907301194381010380E12),
+-  L(-1.185728254682789754150068652663124298303E11),
+-  L(-5.166285094703468567389566085480783070037E9),
+-  L(-1.164573656694603024184768200787835094317E8),
+-  L(-1.177343939483908678474886454113163527909E6),
+-  L(-3.529391059783109732159524500029157638736E3)
++static const long double RD9[NRD9 + 1] =
++{
++  -2.306006080437656357167128541231915480393E13L,
++  -9.183606842453274924895648863832233799950E12L,
++  -1.461857965935942962087907301194381010380E12L,
++  -1.185728254682789754150068652663124298303E11L,
++  -5.166285094703468567389566085480783070037E9L,
++  -1.164573656694603024184768200787835094317E8L,
++  -1.177343939483908678474886454113163527909E6L,
++  -3.529391059783109732159524500029157638736E3L
+   /* 1.0E0L */
+ };
+ 
+@@ -222,32 +220,32 @@ static const _Float128 RD9[NRD9 + 1] =
+    -0.5 <= x <= 0.5
+    7.5 <= x+8 <= 8.5
+    Peak relative error 2.4e-37  */
+-static const _Float128 lgam8a = L(8.525146484375E0);
+-static const _Float128 lgam8b = L(1.4876690414300165531036347125050759667737E-5);
++static const long double lgam8a = 8.525146484375E0L;
++static const long double lgam8b = 1.4876690414300165531036347125050759667737E-5L;
+ #define NRN8 8
+-static const _Float128 RN8[NRN8 + 1] =
+-{
+-  L(6.600775438203423546565361176829139703289E11),
+-  L(3.406361267593790705240802723914281025800E11),
+-  L(7.222460928505293914746983300555538432830E10),
+-  L(8.102984106025088123058747466840656458342E9),
+-  L(5.157620015986282905232150979772409345927E8),
+-  L(1.851445288272645829028129389609068641517E7),
+-  L(3.489261702223124354745894067468953756656E5),
+-  L(2.892095396706665774434217489775617756014E3),
+-  L(6.596977510622195827183948478627058738034E0)
++static const long double RN8[NRN8 + 1] =
++{
++  6.600775438203423546565361176829139703289E11L,
++  3.406361267593790705240802723914281025800E11L,
++  7.222460928505293914746983300555538432830E10L,
++  8.102984106025088123058747466840656458342E9L,
++  5.157620015986282905232150979772409345927E8L,
++  1.851445288272645829028129389609068641517E7L,
++  3.489261702223124354745894067468953756656E5L,
++  2.892095396706665774434217489775617756014E3L,
++  6.596977510622195827183948478627058738034E0L
+ };
+ #define NRD8 7
+-static const _Float128 RD8[NRD8 + 1] =
+-{
+-  L(3.274776546520735414638114828622673016920E11),
+-  L(1.581811207929065544043963828487733970107E11),
+-  L(3.108725655667825188135393076860104546416E10),
+-  L(3.193055010502912617128480163681842165730E9),
+-  L(1.830871482669835106357529710116211541839E8),
+-  L(5.790862854275238129848491555068073485086E6),
+-  L(9.305213264307921522842678835618803553589E4),
+-  L(6.216974105861848386918949336819572333622E2)
++static const long double RD8[NRD8 + 1] =
++{
++  3.274776546520735414638114828622673016920E11L,
++  1.581811207929065544043963828487733970107E11L,
++  3.108725655667825188135393076860104546416E10L,
++  3.193055010502912617128480163681842165730E9L,
++  1.830871482669835106357529710116211541839E8L,
++  5.790862854275238129848491555068073485086E6L,
++  9.305213264307921522842678835618803553589E4L,
++  6.216974105861848386918949336819572333622E2L
+   /* 1.0E0L */
+ };
+ 
+@@ -256,32 +254,32 @@ static const _Float128 RD8[NRD8 + 1] =
+    -0.5 <= x <= 0.5
+    6.5 <= x+7 <= 7.5
+    Peak relative error 3.2e-36  */
+-static const _Float128 lgam7a = L(6.5792388916015625E0);
+-static const _Float128 lgam7b = L(1.2320408538495060178292903945321122583007E-5);
++static const long double lgam7a = 6.5792388916015625E0L;
++static const long double lgam7b = 1.2320408538495060178292903945321122583007E-5L;
+ #define NRN7 8
+-static const _Float128 RN7[NRN7 + 1] =
+-{
+-  L(2.065019306969459407636744543358209942213E11),
+-  L(1.226919919023736909889724951708796532847E11),
+-  L(2.996157990374348596472241776917953749106E10),
+-  L(3.873001919306801037344727168434909521030E9),
+-  L(2.841575255593761593270885753992732145094E8),
+-  L(1.176342515359431913664715324652399565551E7),
+-  L(2.558097039684188723597519300356028511547E5),
+-  L(2.448525238332609439023786244782810774702E3),
+-  L(6.460280377802030953041566617300902020435E0)
++static const long double RN7[NRN7 + 1] =
++{
++  2.065019306969459407636744543358209942213E11L,
++  1.226919919023736909889724951708796532847E11L,
++  2.996157990374348596472241776917953749106E10L,
++  3.873001919306801037344727168434909521030E9L,
++  2.841575255593761593270885753992732145094E8L,
++  1.176342515359431913664715324652399565551E7L,
++  2.558097039684188723597519300356028511547E5L,
++  2.448525238332609439023786244782810774702E3L,
++  6.460280377802030953041566617300902020435E0L
+ };
+ #define NRD7 7
+-static const _Float128 RD7[NRD7 + 1] =
+-{
+-  L(1.102646614598516998880874785339049304483E11),
+-  L(6.099297512712715445879759589407189290040E10),
+-  L(1.372898136289611312713283201112060238351E10),
+-  L(1.615306270420293159907951633566635172343E9),
+-  L(1.061114435798489135996614242842561967459E8),
+-  L(3.845638971184305248268608902030718674691E6),
+-  L(7.081730675423444975703917836972720495507E4),
+-  L(5.423122582741398226693137276201344096370E2)
++static const long double RD7[NRD7 + 1] =
++{
++  1.102646614598516998880874785339049304483E11L,
++  6.099297512712715445879759589407189290040E10L,
++  1.372898136289611312713283201112060238351E10L,
++  1.615306270420293159907951633566635172343E9L,
++  1.061114435798489135996614242842561967459E8L,
++  3.845638971184305248268608902030718674691E6L,
++  7.081730675423444975703917836972720495507E4L,
++  5.423122582741398226693137276201344096370E2L
+   /* 1.0E0L */
+ };
+ 
+@@ -290,33 +288,33 @@ static const _Float128 RD7[NRD7 + 1] =
+    -0.5 <= x <= 0.5
+    5.5 <= x+6 <= 6.5
+    Peak relative error 6.2e-37  */
+-static const _Float128 lgam6a = L(4.7874908447265625E0);
+-static const _Float128 lgam6b = L(8.9805548349424770093452324304839959231517E-7);
++static const long double lgam6a = 4.7874908447265625E0L;
++static const long double lgam6b = 8.9805548349424770093452324304839959231517E-7L;
+ #define NRN6 8
+-static const _Float128 RN6[NRN6 + 1] =
+-{
+-  L(-3.538412754670746879119162116819571823643E13),
+-  L(-2.613432593406849155765698121483394257148E13),
+-  L(-8.020670732770461579558867891923784753062E12),
+-  L(-1.322227822931250045347591780332435433420E12),
+-  L(-1.262809382777272476572558806855377129513E11),
+-  L(-7.015006277027660872284922325741197022467E9),
+-  L(-2.149320689089020841076532186783055727299E8),
+-  L(-3.167210585700002703820077565539658995316E6),
+-  L(-1.576834867378554185210279285358586385266E4)
++static const long double RN6[NRN6 + 1] =
++{
++  -3.538412754670746879119162116819571823643E13L,
++  -2.613432593406849155765698121483394257148E13L,
++  -8.020670732770461579558867891923784753062E12L,
++  -1.322227822931250045347591780332435433420E12L,
++  -1.262809382777272476572558806855377129513E11L,
++  -7.015006277027660872284922325741197022467E9L,
++  -2.149320689089020841076532186783055727299E8L,
++  -3.167210585700002703820077565539658995316E6L,
++  -1.576834867378554185210279285358586385266E4L
+ };
+ #define NRD6 8
+-static const _Float128 RD6[NRD6 + 1] =
+-{
+-  L(-2.073955870771283609792355579558899389085E13),
+-  L(-1.421592856111673959642750863283919318175E13),
+-  L(-4.012134994918353924219048850264207074949E12),
+-  L(-6.013361045800992316498238470888523722431E11),
+-  L(-5.145382510136622274784240527039643430628E10),
+-  L(-2.510575820013409711678540476918249524123E9),
+-  L(-6.564058379709759600836745035871373240904E7),
+-  L(-7.861511116647120540275354855221373571536E5),
+-  L(-2.821943442729620524365661338459579270561E3)
++static const long double RD6[NRD6 + 1] =
++{
++  -2.073955870771283609792355579558899389085E13L,
++  -1.421592856111673959642750863283919318175E13L,
++  -4.012134994918353924219048850264207074949E12L,
++  -6.013361045800992316498238470888523722431E11L,
++  -5.145382510136622274784240527039643430628E10L,
++  -2.510575820013409711678540476918249524123E9L,
++  -6.564058379709759600836745035871373240904E7L,
++  -7.861511116647120540275354855221373571536E5L,
++  -2.821943442729620524365661338459579270561E3L
+   /* 1.0E0L */
+ };
+ 
+@@ -325,34 +323,34 @@ static const _Float128 RD6[NRD6 + 1] =
+    -0.5 <= x <= 0.5
+    4.5 <= x+5 <= 5.5
+    Peak relative error 3.4e-37  */
+-static const _Float128 lgam5a = L(3.17803955078125E0);
+-static const _Float128 lgam5b = L(1.4279566695619646941601297055408873990961E-5);
++static const long double lgam5a = 3.17803955078125E0L;
++static const long double lgam5b = 1.4279566695619646941601297055408873990961E-5L;
+ #define NRN5 9
+-static const _Float128 RN5[NRN5 + 1] =
+-{
+-  L(2.010952885441805899580403215533972172098E11),
+-  L(1.916132681242540921354921906708215338584E11),
+-  L(7.679102403710581712903937970163206882492E10),
+-  L(1.680514903671382470108010973615268125169E10),
+-  L(2.181011222911537259440775283277711588410E9),
+-  L(1.705361119398837808244780667539728356096E8),
+-  L(7.792391565652481864976147945997033946360E6),
+-  L(1.910741381027985291688667214472560023819E5),
+-  L(2.088138241893612679762260077783794329559E3),
+-  L(6.330318119566998299106803922739066556550E0)
++static const long double RN5[NRN5 + 1] =
++{
++  2.010952885441805899580403215533972172098E11L,
++  1.916132681242540921354921906708215338584E11L,
++  7.679102403710581712903937970163206882492E10L,
++  1.680514903671382470108010973615268125169E10L,
++  2.181011222911537259440775283277711588410E9L,
++  1.705361119398837808244780667539728356096E8L,
++  7.792391565652481864976147945997033946360E6L,
++  1.910741381027985291688667214472560023819E5L,
++  2.088138241893612679762260077783794329559E3L,
++  6.330318119566998299106803922739066556550E0L
+ };
+ #define NRD5 8
+-static const _Float128 RD5[NRD5 + 1] =
+-{
+-  L(1.335189758138651840605141370223112376176E11),
+-  L(1.174130445739492885895466097516530211283E11),
+-  L(4.308006619274572338118732154886328519910E10),
+-  L(8.547402888692578655814445003283720677468E9),
+-  L(9.934628078575618309542580800421370730906E8),
+-  L(6.847107420092173812998096295422311820672E7),
+-  L(2.698552646016599923609773122139463150403E6),
+-  L(5.526516251532464176412113632726150253215E4),
+-  L(4.772343321713697385780533022595450486932E2)
++static const long double RD5[NRD5 + 1] =
++{
++  1.335189758138651840605141370223112376176E11L,
++  1.174130445739492885895466097516530211283E11L,
++  4.308006619274572338118732154886328519910E10L,
++  8.547402888692578655814445003283720677468E9L,
++  9.934628078575618309542580800421370730906E8L,
++  6.847107420092173812998096295422311820672E7L,
++  2.698552646016599923609773122139463150403E6L,
++  5.526516251532464176412113632726150253215E4L,
++  4.772343321713697385780533022595450486932E2L
+   /* 1.0E0L */
+ };
+ 
+@@ -361,35 +359,35 @@ static const _Float128 RD5[NRD5 + 1] =
+    -0.5 <= x <= 0.5
+    3.5 <= x+4 <= 4.5
+    Peak relative error 6.7e-37  */
+-static const _Float128 lgam4a = L(1.791748046875E0);
+-static const _Float128 lgam4b = L(1.1422353055000812477358380702272722990692E-5);
++static const long double lgam4a = 1.791748046875E0L;
++static const long double lgam4b = 1.1422353055000812477358380702272722990692E-5L;
+ #define NRN4 9
+-static const _Float128 RN4[NRN4 + 1] =
+-{
+-  L(-1.026583408246155508572442242188887829208E13),
+-  L(-1.306476685384622809290193031208776258809E13),
+-  L(-7.051088602207062164232806511992978915508E12),
+-  L(-2.100849457735620004967624442027793656108E12),
+-  L(-3.767473790774546963588549871673843260569E11),
+-  L(-4.156387497364909963498394522336575984206E10),
+-  L(-2.764021460668011732047778992419118757746E9),
+-  L(-1.036617204107109779944986471142938641399E8),
+-  L(-1.895730886640349026257780896972598305443E6),
+-  L(-1.180509051468390914200720003907727988201E4)
++static const long double RN4[NRN4 + 1] =
++{
++  -1.026583408246155508572442242188887829208E13L,
++  -1.306476685384622809290193031208776258809E13L,
++  -7.051088602207062164232806511992978915508E12L,
++  -2.100849457735620004967624442027793656108E12L,
++  -3.767473790774546963588549871673843260569E11L,
++  -4.156387497364909963498394522336575984206E10L,
++  -2.764021460668011732047778992419118757746E9L,
++  -1.036617204107109779944986471142938641399E8L,
++  -1.895730886640349026257780896972598305443E6L,
++  -1.180509051468390914200720003907727988201E4L
+ };
+ #define NRD4 9
+-static const _Float128 RD4[NRD4 + 1] =
+-{
+-  L(-8.172669122056002077809119378047536240889E12),
+-  L(-9.477592426087986751343695251801814226960E12),
+-  L(-4.629448850139318158743900253637212801682E12),
+-  L(-1.237965465892012573255370078308035272942E12),
+-  L(-1.971624313506929845158062177061297598956E11),
+-  L(-1.905434843346570533229942397763361493610E10),
+-  L(-1.089409357680461419743730978512856675984E9),
+-  L(-3.416703082301143192939774401370222822430E7),
+-  L(-4.981791914177103793218433195857635265295E5),
+-  L(-2.192507743896742751483055798411231453733E3)
++static const long double RD4[NRD4 + 1] =
++{
++  -8.172669122056002077809119378047536240889E12L,
++  -9.477592426087986751343695251801814226960E12L,
++  -4.629448850139318158743900253637212801682E12L,
++  -1.237965465892012573255370078308035272942E12L,
++  -1.971624313506929845158062177061297598956E11L,
++  -1.905434843346570533229942397763361493610E10L,
++  -1.089409357680461419743730978512856675984E9L,
++  -3.416703082301143192939774401370222822430E7L,
++  -4.981791914177103793218433195857635265295E5L,
++  -2.192507743896742751483055798411231453733E3L
+   /* 1.0E0L */
+ };
+ 
+@@ -398,36 +396,36 @@ static const _Float128 RD4[NRD4 + 1] =
+    -0.25 <= x <= 0.5
+    2.75 <= x+3 <= 3.5
+    Peak relative error 6.0e-37  */
+-static const _Float128 lgam3a = L(6.93145751953125E-1);
+-static const _Float128 lgam3b = L(1.4286068203094172321214581765680755001344E-6);
++static const long double lgam3a = 6.93145751953125E-1L;
++static const long double lgam3b = 1.4286068203094172321214581765680755001344E-6L;
+ 
+ #define NRN3 9
+-static const _Float128 RN3[NRN3 + 1] =
+-{
+-  L(-4.813901815114776281494823863935820876670E11),
+-  L(-8.425592975288250400493910291066881992620E11),
+-  L(-6.228685507402467503655405482985516909157E11),
+-  L(-2.531972054436786351403749276956707260499E11),
+-  L(-6.170200796658926701311867484296426831687E10),
+-  L(-9.211477458528156048231908798456365081135E9),
+-  L(-8.251806236175037114064561038908691305583E8),
+-  L(-4.147886355917831049939930101151160447495E7),
+-  L(-1.010851868928346082547075956946476932162E6),
+-  L(-8.333374463411801009783402800801201603736E3)
++static const long double RN3[NRN3 + 1] =
++{
++  -4.813901815114776281494823863935820876670E11L,
++  -8.425592975288250400493910291066881992620E11L,
++  -6.228685507402467503655405482985516909157E11L,
++  -2.531972054436786351403749276956707260499E11L,
++  -6.170200796658926701311867484296426831687E10L,
++  -9.211477458528156048231908798456365081135E9L,
++  -8.251806236175037114064561038908691305583E8L,
++  -4.147886355917831049939930101151160447495E7L,
++  -1.010851868928346082547075956946476932162E6L,
++  -8.333374463411801009783402800801201603736E3L
+ };
+ #define NRD3 9
+-static const _Float128 RD3[NRD3 + 1] =
+-{
+-  L(-5.216713843111675050627304523368029262450E11),
+-  L(-8.014292925418308759369583419234079164391E11),
+-  L(-5.180106858220030014546267824392678611990E11),
+-  L(-1.830406975497439003897734969120997840011E11),
+-  L(-3.845274631904879621945745960119924118925E10),
+-  L(-4.891033385370523863288908070309417710903E9),
+-  L(-3.670172254411328640353855768698287474282E8),
+-  L(-1.505316381525727713026364396635522516989E7),
+-  L(-2.856327162923716881454613540575964890347E5),
+-  L(-1.622140448015769906847567212766206894547E3)
++static const long double RD3[NRD3 + 1] =
++{
++  -5.216713843111675050627304523368029262450E11L,
++  -8.014292925418308759369583419234079164391E11L,
++  -5.180106858220030014546267824392678611990E11L,
++  -1.830406975497439003897734969120997840011E11L,
++  -3.845274631904879621945745960119924118925E10L,
++  -4.891033385370523863288908070309417710903E9L,
++  -3.670172254411328640353855768698287474282E8L,
++  -1.505316381525727713026364396635522516989E7L,
++  -2.856327162923716881454613540575964890347E5L,
++  -1.622140448015769906847567212766206894547E3L
+   /* 1.0E0L */
+ };
+ 
+@@ -435,33 +433,33 @@ static const _Float128 RD3[NRD3 + 1] =
+ /* log gamma(x+2.5) = log gamma(2.5) +  x P(x)/Q(x)
+    -0.125 <= x <= 0.25
+    2.375 <= x+2.5 <= 2.75  */
+-static const _Float128 lgam2r5a = L(2.8466796875E-1);
+-static const _Float128 lgam2r5b = L(1.4901722919159632494669682701924320137696E-5);
++static const long double lgam2r5a = 2.8466796875E-1L;
++static const long double lgam2r5b = 1.4901722919159632494669682701924320137696E-5L;
+ #define NRN2r5 8
+-static const _Float128 RN2r5[NRN2r5 + 1] =
+-{
+-  L(-4.676454313888335499356699817678862233205E9),
+-  L(-9.361888347911187924389905984624216340639E9),
+-  L(-7.695353600835685037920815799526540237703E9),
+-  L(-3.364370100981509060441853085968900734521E9),
+-  L(-8.449902011848163568670361316804900559863E8),
+-  L(-1.225249050950801905108001246436783022179E8),
+-  L(-9.732972931077110161639900388121650470926E6),
+-  L(-3.695711763932153505623248207576425983573E5),
+-  L(-4.717341584067827676530426007495274711306E3)
++static const long double RN2r5[NRN2r5 + 1] =
++{
++  -4.676454313888335499356699817678862233205E9L,
++  -9.361888347911187924389905984624216340639E9L,
++  -7.695353600835685037920815799526540237703E9L,
++  -3.364370100981509060441853085968900734521E9L,
++  -8.449902011848163568670361316804900559863E8L,
++  -1.225249050950801905108001246436783022179E8L,
++  -9.732972931077110161639900388121650470926E6L,
++  -3.695711763932153505623248207576425983573E5L,
++  -4.717341584067827676530426007495274711306E3L
+ };
+ #define NRD2r5 8
+-static const _Float128 RD2r5[NRD2r5 + 1] =
+-{
+-  L(-6.650657966618993679456019224416926875619E9),
+-  L(-1.099511409330635807899718829033488771623E10),
+-  L(-7.482546968307837168164311101447116903148E9),
+-  L(-2.702967190056506495988922973755870557217E9),
+-  L(-5.570008176482922704972943389590409280950E8),
+-  L(-6.536934032192792470926310043166993233231E7),
+-  L(-4.101991193844953082400035444146067511725E6),
+-  L(-1.174082735875715802334430481065526664020E5),
+-  L(-9.932840389994157592102947657277692978511E2)
++static const long double RD2r5[NRD2r5 + 1] =
++{
++  -6.650657966618993679456019224416926875619E9L,
++  -1.099511409330635807899718829033488771623E10L,
++  -7.482546968307837168164311101447116903148E9L,
++  -2.702967190056506495988922973755870557217E9L,
++  -5.570008176482922704972943389590409280950E8L,
++  -6.536934032192792470926310043166993233231E7L,
++  -4.101991193844953082400035444146067511725E6L,
++  -1.174082735875715802334430481065526664020E5L,
++  -9.932840389994157592102947657277692978511E2L
+   /* 1.0E0L */
+ };
+ 
+@@ -471,32 +469,32 @@ static const _Float128 RD2r5[NRD2r5 + 1] =
+    1.875 <= x+2 <= 2.375
+    Peak relative error 4.6e-36  */
+ #define NRN2 9
+-static const _Float128 RN2[NRN2 + 1] =
+-{
+-  L(-3.716661929737318153526921358113793421524E9),
+-  L(-1.138816715030710406922819131397532331321E10),
+-  L(-1.421017419363526524544402598734013569950E10),
+-  L(-9.510432842542519665483662502132010331451E9),
+-  L(-3.747528562099410197957514973274474767329E9),
+-  L(-8.923565763363912474488712255317033616626E8),
+-  L(-1.261396653700237624185350402781338231697E8),
+-  L(-9.918402520255661797735331317081425749014E6),
+-  L(-3.753996255897143855113273724233104768831E5),
+-  L(-4.778761333044147141559311805999540765612E3)
++static const long double RN2[NRN2 + 1] =
++{
++  -3.716661929737318153526921358113793421524E9L,
++  -1.138816715030710406922819131397532331321E10L,
++  -1.421017419363526524544402598734013569950E10L,
++  -9.510432842542519665483662502132010331451E9L,
++  -3.747528562099410197957514973274474767329E9L,
++  -8.923565763363912474488712255317033616626E8L,
++  -1.261396653700237624185350402781338231697E8L,
++  -9.918402520255661797735331317081425749014E6L,
++  -3.753996255897143855113273724233104768831E5L,
++  -4.778761333044147141559311805999540765612E3L
+ };
+ #define NRD2 9
+-static const _Float128 RD2[NRD2 + 1] =
+-{
+-  L(-8.790916836764308497770359421351673950111E9),
+-  L(-2.023108608053212516399197678553737477486E10),
+-  L(-1.958067901852022239294231785363504458367E10),
+-  L(-1.035515043621003101254252481625188704529E10),
+-  L(-3.253884432621336737640841276619272224476E9),
+-  L(-6.186383531162456814954947669274235815544E8),
+-  L(-6.932557847749518463038934953605969951466E7),
+-  L(-4.240731768287359608773351626528479703758E6),
+-  L(-1.197343995089189188078944689846348116630E5),
+-  L(-1.004622911670588064824904487064114090920E3)
++static const long double RD2[NRD2 + 1] =
++{
++  -8.790916836764308497770359421351673950111E9L,
++  -2.023108608053212516399197678553737477486E10L,
++  -1.958067901852022239294231785363504458367E10L,
++  -1.035515043621003101254252481625188704529E10L,
++  -3.253884432621336737640841276619272224476E9L,
++  -6.186383531162456814954947669274235815544E8L,
++  -6.932557847749518463038934953605969951466E7L,
++  -4.240731768287359608773351626528479703758E6L,
++  -1.197343995089189188078944689846348116630E5L,
++  -1.004622911670588064824904487064114090920E3L
+ /* 1.0E0 */
+ };
+ 
+@@ -505,33 +503,33 @@ static const _Float128 RD2[NRD2 + 1] =
+    -0.125 <= x <= +0.125
+    1.625 <= x+1.75 <= 1.875
+    Peak relative error 9.2e-37 */
+-static const _Float128 lgam1r75a = L(-8.441162109375E-2);
+-static const _Float128 lgam1r75b = L(1.0500073264444042213965868602268256157604E-5);
++static const long double lgam1r75a = -8.441162109375E-2L;
++static const long double lgam1r75b = 1.0500073264444042213965868602268256157604E-5L;
+ #define NRN1r75 8
+-static const _Float128 RN1r75[NRN1r75 + 1] =
+-{
+-  L(-5.221061693929833937710891646275798251513E7),
+-  L(-2.052466337474314812817883030472496436993E8),
+-  L(-2.952718275974940270675670705084125640069E8),
+-  L(-2.132294039648116684922965964126389017840E8),
+-  L(-8.554103077186505960591321962207519908489E7),
+-  L(-1.940250901348870867323943119132071960050E7),
+-  L(-2.379394147112756860769336400290402208435E6),
+-  L(-1.384060879999526222029386539622255797389E5),
+-  L(-2.698453601378319296159355612094598695530E3)
++static const long double RN1r75[NRN1r75 + 1] =
++{
++  -5.221061693929833937710891646275798251513E7L,
++  -2.052466337474314812817883030472496436993E8L,
++  -2.952718275974940270675670705084125640069E8L,
++  -2.132294039648116684922965964126389017840E8L,
++  -8.554103077186505960591321962207519908489E7L,
++  -1.940250901348870867323943119132071960050E7L,
++  -2.379394147112756860769336400290402208435E6L,
++  -1.384060879999526222029386539622255797389E5L,
++  -2.698453601378319296159355612094598695530E3L
+ };
+ #define NRD1r75 8
+-static const _Float128 RD1r75[NRD1r75 + 1] =
+-{
+-  L(-2.109754689501705828789976311354395393605E8),
+-  L(-5.036651829232895725959911504899241062286E8),
+-  L(-4.954234699418689764943486770327295098084E8),
+-  L(-2.589558042412676610775157783898195339410E8),
+-  L(-7.731476117252958268044969614034776883031E7),
+-  L(-1.316721702252481296030801191240867486965E7),
+-  L(-1.201296501404876774861190604303728810836E6),
+-  L(-5.007966406976106636109459072523610273928E4),
+-  L(-6.155817990560743422008969155276229018209E2)
++static const long double RD1r75[NRD1r75 + 1] =
++{
++  -2.109754689501705828789976311354395393605E8L,
++  -5.036651829232895725959911504899241062286E8L,
++  -4.954234699418689764943486770327295098084E8L,
++  -2.589558042412676610775157783898195339410E8L,
++  -7.731476117252958268044969614034776883031E7L,
++  -1.316721702252481296030801191240867486965E7L,
++  -1.201296501404876774861190604303728810836E6L,
++  -5.007966406976106636109459072523610273928E4L,
++  -6.155817990560743422008969155276229018209E2L
+   /* 1.0E0L */
+ };
+ 
+@@ -540,35 +538,35 @@ static const _Float128 RD1r75[NRD1r75 + 1] =
+    -0.0867 <= x <= +0.1634
+    1.374932... <= x+x0 <= 1.625032...
+    Peak relative error 4.0e-36  */
+-static const _Float128 x0a = L(1.4616241455078125);
+-static const _Float128 x0b = L(7.9994605498412626595423257213002588621246E-6);
+-static const _Float128 y0a = L(-1.21490478515625E-1);
+-static const _Float128 y0b = L(4.1879797753919044854428223084178486438269E-6);
++static const long double x0a = 1.4616241455078125L;
++static const long double x0b = 7.9994605498412626595423257213002588621246E-6L;
++static const long double y0a = -1.21490478515625E-1L;
++static const long double y0b = 4.1879797753919044854428223084178486438269E-6L;
+ #define NRN1r5 8
+-static const _Float128 RN1r5[NRN1r5 + 1] =
+-{
+-  L(6.827103657233705798067415468881313128066E5),
+-  L(1.910041815932269464714909706705242148108E6),
+-  L(2.194344176925978377083808566251427771951E6),
+-  L(1.332921400100891472195055269688876427962E6),
+-  L(4.589080973377307211815655093824787123508E5),
+-  L(8.900334161263456942727083580232613796141E4),
+-  L(9.053840838306019753209127312097612455236E3),
+-  L(4.053367147553353374151852319743594873771E2),
+-  L(5.040631576303952022968949605613514584950E0)
++static const long double RN1r5[NRN1r5 + 1] =
++{
++  6.827103657233705798067415468881313128066E5L,
++  1.910041815932269464714909706705242148108E6L,
++  2.194344176925978377083808566251427771951E6L,
++  1.332921400100891472195055269688876427962E6L,
++  4.589080973377307211815655093824787123508E5L,
++  8.900334161263456942727083580232613796141E4L,
++  9.053840838306019753209127312097612455236E3L,
++  4.053367147553353374151852319743594873771E2L,
++  5.040631576303952022968949605613514584950E0L
+ };
+ #define NRD1r5 8
+-static const _Float128 RD1r5[NRD1r5 + 1] =
+-{
+-  L(1.411036368843183477558773688484699813355E6),
+-  L(4.378121767236251950226362443134306184849E6),
+-  L(5.682322855631723455425929877581697918168E6),
+-  L(3.999065731556977782435009349967042222375E6),
+-  L(1.653651390456781293163585493620758410333E6),
+-  L(4.067774359067489605179546964969435858311E5),
+-  L(5.741463295366557346748361781768833633256E4),
+-  L(4.226404539738182992856094681115746692030E3),
+-  L(1.316980975410327975566999780608618774469E2),
++static const long double RD1r5[NRD1r5 + 1] =
++{
++  1.411036368843183477558773688484699813355E6L,
++  4.378121767236251950226362443134306184849E6L,
++  5.682322855631723455425929877581697918168E6L,
++  3.999065731556977782435009349967042222375E6L,
++  1.653651390456781293163585493620758410333E6L,
++  4.067774359067489605179546964969435858311E5L,
++  5.741463295366557346748361781768833633256E4L,
++  4.226404539738182992856094681115746692030E3L,
++  1.316980975410327975566999780608618774469E2L,
+   /* 1.0E0L */
+ };
+ 
+@@ -577,34 +575,34 @@ static const _Float128 RD1r5[NRD1r5 + 1] =
+    -.125 <= x <= +.125
+    1.125 <= x+1.25 <= 1.375
+    Peak relative error = 4.9e-36 */
+-static const _Float128 lgam1r25a = L(-9.82818603515625E-2);
+-static const _Float128 lgam1r25b = L(1.0023929749338536146197303364159774377296E-5);
++static const long double lgam1r25a = -9.82818603515625E-2L;
++static const long double lgam1r25b = 1.0023929749338536146197303364159774377296E-5L;
+ #define NRN1r25 9
+-static const _Float128 RN1r25[NRN1r25 + 1] =
+-{
+-  L(-9.054787275312026472896002240379580536760E4),
+-  L(-8.685076892989927640126560802094680794471E4),
+-  L(2.797898965448019916967849727279076547109E5),
+-  L(6.175520827134342734546868356396008898299E5),
+-  L(5.179626599589134831538516906517372619641E5),
+-  L(2.253076616239043944538380039205558242161E5),
+-  L(5.312653119599957228630544772499197307195E4),
+-  L(6.434329437514083776052669599834938898255E3),
+-  L(3.385414416983114598582554037612347549220E2),
+-  L(4.907821957946273805080625052510832015792E0)
++static const long double RN1r25[NRN1r25 + 1] =
++{
++  -9.054787275312026472896002240379580536760E4L,
++  -8.685076892989927640126560802094680794471E4L,
++  2.797898965448019916967849727279076547109E5L,
++  6.175520827134342734546868356396008898299E5L,
++  5.179626599589134831538516906517372619641E5L,
++  2.253076616239043944538380039205558242161E5L,
++  5.312653119599957228630544772499197307195E4L,
++  6.434329437514083776052669599834938898255E3L,
++  3.385414416983114598582554037612347549220E2L,
++  4.907821957946273805080625052510832015792E0L
+ };
+ #define NRD1r25 8
+-static const _Float128 RD1r25[NRD1r25 + 1] =
+-{
+-  L(3.980939377333448005389084785896660309000E5),
+-  L(1.429634893085231519692365775184490465542E6),
+-  L(2.145438946455476062850151428438668234336E6),
+-  L(1.743786661358280837020848127465970357893E6),
+-  L(8.316364251289743923178092656080441655273E5),
+-  L(2.355732939106812496699621491135458324294E5),
+-  L(3.822267399625696880571810137601310855419E4),
+-  L(3.228463206479133236028576845538387620856E3),
+-  L(1.152133170470059555646301189220117965514E2)
++static const long double RD1r25[NRD1r25 + 1] =
++{
++  3.980939377333448005389084785896660309000E5L,
++  1.429634893085231519692365775184490465542E6L,
++  2.145438946455476062850151428438668234336E6L,
++  1.743786661358280837020848127465970357893E6L,
++  8.316364251289743923178092656080441655273E5L,
++  2.355732939106812496699621491135458324294E5L,
++  3.822267399625696880571810137601310855419E4L,
++  3.228463206479133236028576845538387620856E3L,
++  1.152133170470059555646301189220117965514E2L
+   /* 1.0E0L */
+ };
+ 
+@@ -614,29 +612,29 @@ static const _Float128 RD1r25[NRD1r25 + 1] =
+    1.0 <= x+1 <= 1.125
+    Peak relative error 1.1e-35  */
+ #define NRN1 8
+-static const _Float128 RN1[NRN1 + 1] =
+-{
+-  L(-9.987560186094800756471055681088744738818E3),
+-  L(-2.506039379419574361949680225279376329742E4),
+-  L(-1.386770737662176516403363873617457652991E4),
+-  L(1.439445846078103202928677244188837130744E4),
+-  L(2.159612048879650471489449668295139990693E4),
+-  L(1.047439813638144485276023138173676047079E4),
+-  L(2.250316398054332592560412486630769139961E3),
+-  L(1.958510425467720733041971651126443864041E2),
+-  L(4.516830313569454663374271993200291219855E0)
++static const long double RN1[NRN1 + 1] =
++{
++  -9.987560186094800756471055681088744738818E3L,
++  -2.506039379419574361949680225279376329742E4L,
++  -1.386770737662176516403363873617457652991E4L,
++  1.439445846078103202928677244188837130744E4L,
++  2.159612048879650471489449668295139990693E4L,
++  1.047439813638144485276023138173676047079E4L,
++  2.250316398054332592560412486630769139961E3L,
++  1.958510425467720733041971651126443864041E2L,
++  4.516830313569454663374271993200291219855E0L
+ };
+ #define NRD1 7
+-static const _Float128 RD1[NRD1 + 1] =
+-{
+-  L(1.730299573175751778863269333703788214547E4),
+-  L(6.807080914851328611903744668028014678148E4),
+-  L(1.090071629101496938655806063184092302439E5),
+-  L(9.124354356415154289343303999616003884080E4),
+-  L(4.262071638655772404431164427024003253954E4),
+-  L(1.096981664067373953673982635805821283581E4),
+-  L(1.431229503796575892151252708527595787588E3),
+-  L(7.734110684303689320830401788262295992921E1)
++static const long double RD1[NRD1 + 1] =
++{
++  1.730299573175751778863269333703788214547E4L,
++  6.807080914851328611903744668028014678148E4L,
++  1.090071629101496938655806063184092302439E5L,
++  9.124354356415154289343303999616003884080E4L,
++  4.262071638655772404431164427024003253954E4L,
++  1.096981664067373953673982635805821283581E4L,
++  1.431229503796575892151252708527595787588E3L,
++  7.734110684303689320830401788262295992921E1L
+  /* 1.0E0 */
+ };
+ 
+@@ -646,40 +644,40 @@ static const _Float128 RD1[NRD1 + 1] =
+    0.875 <= x+1 <= 1.0
+    Peak relative error 7.0e-37  */
+ #define NRNr9 8
+-static const _Float128 RNr9[NRNr9 + 1] =
+-{
+-  L(4.441379198241760069548832023257571176884E5),
+-  L(1.273072988367176540909122090089580368732E6),
+-  L(9.732422305818501557502584486510048387724E5),
+-  L(-5.040539994443998275271644292272870348684E5),
+-  L(-1.208719055525609446357448132109723786736E6),
+-  L(-7.434275365370936547146540554419058907156E5),
+-  L(-2.075642969983377738209203358199008185741E5),
+-  L(-2.565534860781128618589288075109372218042E4),
+-  L(-1.032901669542994124131223797515913955938E3),
++static const long double RNr9[NRNr9 + 1] =
++{
++  4.441379198241760069548832023257571176884E5L,
++  1.273072988367176540909122090089580368732E6L,
++  9.732422305818501557502584486510048387724E5L,
++  -5.040539994443998275271644292272870348684E5L,
++  -1.208719055525609446357448132109723786736E6L,
++  -7.434275365370936547146540554419058907156E5L,
++  -2.075642969983377738209203358199008185741E5L,
++  -2.565534860781128618589288075109372218042E4L,
++  -1.032901669542994124131223797515913955938E3L,
+ };
+ #define NRDr9 8
+-static const _Float128 RDr9[NRDr9 + 1] =
+-{
+-  L(-7.694488331323118759486182246005193998007E5),
+-  L(-3.301918855321234414232308938454112213751E6),
+-  L(-5.856830900232338906742924836032279404702E6),
+-  L(-5.540672519616151584486240871424021377540E6),
+-  L(-3.006530901041386626148342989181721176919E6),
+-  L(-9.350378280513062139466966374330795935163E5),
+-  L(-1.566179100031063346901755685375732739511E5),
+-  L(-1.205016539620260779274902967231510804992E4),
+-  L(-2.724583156305709733221564484006088794284E2)
++static const long double RDr9[NRDr9 + 1] =
++{
++  -7.694488331323118759486182246005193998007E5L,
++  -3.301918855321234414232308938454112213751E6L,
++  -5.856830900232338906742924836032279404702E6L,
++  -5.540672519616151584486240871424021377540E6L,
++  -3.006530901041386626148342989181721176919E6L,
++  -9.350378280513062139466966374330795935163E5L,
++  -1.566179100031063346901755685375732739511E5L,
++  -1.205016539620260779274902967231510804992E4L,
++  -2.724583156305709733221564484006088794284E2L
+ /* 1.0E0 */
+ };
+ 
+ 
+ /* Evaluate P[n] x^n  +  P[n-1] x^(n-1)  +  ...  +  P[0] */
+ 
+-static _Float128
+-neval (_Float128 x, const _Float128 *p, int n)
++static long double
++neval (long double x, const long double *p, int n)
+ {
+-  _Float128 y;
++  long double y;
+ 
+   p += n;
+   y = *p--;
+@@ -694,10 +692,10 @@ neval (_Float128 x, const _Float128 *p, int n)
+ 
+ /* Evaluate x^n+1  +  P[n] x^(n)  +  P[n-1] x^(n-1)  +  ...  +  P[0] */
+ 
+-static _Float128
+-deval (_Float128 x, const _Float128 *p, int n)
++static long double
++deval (long double x, const long double *p, int n)
+ {
+-  _Float128 y;
++  long double y;
+ 
+   p += n;
+   y = x + *p--;
+@@ -710,10 +708,10 @@ deval (_Float128 x, const _Float128 *p, int n)
+ }
+ 
+ 
+-_Float128
+-__ieee754_lgammal_r (_Float128 x, int *signgamp)
++long double
++__ieee754_lgammal_r (long double x, int *signgamp)
+ {
+-  _Float128 p, q, w, z, nx;
++  long double p, q, w, z, nx;
+   int i, nn;
+ 
+   *signgamp = 1;
+@@ -735,15 +733,15 @@ __ieee754_lgammal_r (_Float128 x, int *signgamp)
+       p = __floorl (q);
+       if (p == q)
+ 	return (one / __fabsl (p - p));
+-      _Float128 halfp = p * L(0.5);
++      long double halfp = p * 0.5L;
+       if (halfp == __floorl (halfp))
+ 	*signgamp = -1;
+       else
+ 	*signgamp = 1;
+-      if (q < L(0x1p-120))
++      if (q < 0x1p-120L)
+ 	return -__logl (q);
+       z = q - p;
+-      if (z > L(0.5))
++      if (z > 0.5L)
+ 	{
+ 	  p += 1;
+ 	  z = p - q;
+@@ -754,16 +752,16 @@ __ieee754_lgammal_r (_Float128 x, int *signgamp)
+       return (z);
+     }
+ 
+-  if (x < L(13.5))
++  if (x < 13.5L)
+     {
+       p = 0;
+-      nx = __floorl (x + L(0.5));
++      nx = __floorl (x + 0.5L);
+       nn = nx;
+       switch (nn)
+ 	{
+ 	case 0:
+ 	  /* log gamma (x + 1) = log(x) + log gamma(x) */
+-	  if (x < L(0x1p-120))
++	  if (x < 0x1p-120L)
+ 	    return -__logl (x);
+ 	  else if (x <= 0.125)
+ 	    {
+@@ -771,7 +769,7 @@ __ieee754_lgammal_r (_Float128 x, int *signgamp)
+ 	    }
+ 	  else if (x <= 0.375)
+ 	    {
+-	      z = x - L(0.25);
++	      z = x - 0.25L;
+ 	      p = z * neval (z, RN1r25, NRN1r25) / deval (z, RD1r25, NRD1r25);
+ 	      p += lgam1r25b;
+ 	      p += lgam1r25a;
+@@ -787,7 +785,7 @@ __ieee754_lgammal_r (_Float128 x, int *signgamp)
+ 	    }
+ 	  else if (x <= 0.875)
+ 	    {
+-	      z = x - L(0.75);
++	      z = x - 0.75L;
+ 	      p = z * neval (z, RN1r75, NRN1r75) / deval (z, RD1r75, NRD1r75);
+ 	      p += lgam1r75b;
+ 	      p += lgam1r75a;
+@@ -801,7 +799,7 @@ __ieee754_lgammal_r (_Float128 x, int *signgamp)
+ 	  break;
+ 
+ 	case 1:
+-	  if (x < L(0.875))
++	  if (x < 0.875L)
+ 	    {
+ 	      if (x <= 0.625)
+ 		{
+@@ -814,7 +812,7 @@ __ieee754_lgammal_r (_Float128 x, int *signgamp)
+ 		}
+ 	      else if (x <= 0.875)
+ 		{
+-		  z = x - L(0.75);
++		  z = x - 0.75L;
+ 		  p = z * neval (z, RN1r75, NRN1r75)
+ 			/ deval (z, RD1r75, NRD1r75);
+ 		  p += lgam1r75b;
+@@ -834,14 +832,14 @@ __ieee754_lgammal_r (_Float128 x, int *signgamp)
+ 	    }
+ 	  else if (x == 1)
+ 	    p = 0;
+-	  else if (x <= L(1.125))
++	  else if (x <= 1.125L)
+ 	    {
+ 	      z = x - 1;
+ 	      p = z * neval (z, RN1, NRN1) / deval (z, RD1, NRD1);
+ 	    }
+ 	  else if (x <= 1.375)
+ 	    {
+-	      z = x - L(1.25);
++	      z = x - 1.25L;
+ 	      p = z * neval (z, RN1r25, NRN1r25) / deval (z, RD1r25, NRD1r25);
+ 	      p += lgam1r25b;
+ 	      p += lgam1r25a;
+@@ -859,7 +857,7 @@ __ieee754_lgammal_r (_Float128 x, int *signgamp)
+ 	  break;
+ 
+ 	case 2:
+-	  if (x < L(1.625))
++	  if (x < 1.625L)
+ 	    {
+ 	      z = x - x0a;
+ 	      z = z - x0b;
+@@ -868,23 +866,23 @@ __ieee754_lgammal_r (_Float128 x, int *signgamp)
+ 	      p = p + y0b;
+ 	      p = p + y0a;
+ 	    }
+-	  else if (x < L(1.875))
++	  else if (x < 1.875L)
+ 	    {
+-	      z = x - L(1.75);
++	      z = x - 1.75L;
+ 	      p = z * neval (z, RN1r75, NRN1r75) / deval (z, RD1r75, NRD1r75);
+ 	      p += lgam1r75b;
+ 	      p += lgam1r75a;
+ 	    }
+ 	  else if (x == 2)
+ 	    p = 0;
+-	  else if (x < L(2.375))
++	  else if (x < 2.375L)
+ 	    {
+ 	      z = x - 2;
+ 	      p = z * neval (z, RN2, NRN2) / deval (z, RD2, NRD2);
+ 	    }
+ 	  else
+ 	    {
+-	      z = x - L(2.5);
++	      z = x - 2.5L;
+ 	      p = z * neval (z, RN2r5, NRN2r5) / deval (z, RD2r5, NRD2r5);
+ 	      p += lgam2r5b;
+ 	      p += lgam2r5a;
+@@ -894,7 +892,7 @@ __ieee754_lgammal_r (_Float128 x, int *signgamp)
+ 	case 3:
+ 	  if (x < 2.75)
+ 	    {
+-	      z = x - L(2.5);
++	      z = x - 2.5L;
+ 	      p = z * neval (z, RN2r5, NRN2r5) / deval (z, RD2r5, NRD2r5);
+ 	      p += lgam2r5b;
+ 	      p += lgam2r5a;
+@@ -984,11 +982,11 @@ __ieee754_lgammal_r (_Float128 x, int *signgamp)
+   if (x > MAXLGM)
+     return (*signgamp * huge * huge);
+ 
+-  if (x > L(0x1p120))
++  if (x > 0x1p120L)
+     return x * (__logl (x) - 1);
+   q = ls2pi - x;
+-  q = (x - L(0.5)) * __logl (x) + q;
+-  if (x > L(1.0e18))
++  q = (x - 0.5L) * __logl (x) + q;
++  if (x > 1.0e18L)
+     return (q);
+ 
+   p = 1 / (x * x);
+diff --git a/sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c b/sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c
+index 615707ca98..317d238057 100644
+--- a/sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c
++++ b/sysdeps/ieee754/ldbl-128ibm/s_cbrtl.c
+@@ -19,24 +19,22 @@
+ 
+ /* This file was copied from sysdeps/ieee754/ldbl-128/e_j0l.c.  */
+ 
+-#define _Float128 long double
+-#define L(x) x ## L
+ 
+ #include <math_ldbl_opt.h>
+ #include <math.h>
+ #include <math_private.h>
+ 
+-static const _Float128 CBRT2 = L(1.259921049894873164767210607278228350570251);
+-static const _Float128 CBRT4 = L(1.587401051968199474751705639272308260391493);
+-static const _Float128 CBRT2I = L(0.7937005259840997373758528196361541301957467);
+-static const _Float128 CBRT4I = L(0.6299605249474365823836053036391141752851257);
++static const long double CBRT2 = 1.259921049894873164767210607278228350570251L;
++static const long double CBRT4 = 1.587401051968199474751705639272308260391493L;
++static const long double CBRT2I = 0.7937005259840997373758528196361541301957467L;
++static const long double CBRT4I = 0.6299605249474365823836053036391141752851257L;
+ 
+ 
+-_Float128
+-__cbrtl (_Float128 x)
++long double
++__cbrtl (long double x)
+ {
+   int e, rem, sign;
+-  _Float128 z;
++  long double z;
+ 
+   if (!isfinite (x))
+     return x + x;
+@@ -58,11 +56,11 @@ __cbrtl (_Float128 x)
+ 
+   /* Approximate cube root of number between .5 and 1,
+      peak relative error = 1.2e-6  */
+-  x = ((((L(1.3584464340920900529734e-1) * x
+-	  - L(6.3986917220457538402318e-1)) * x
+-	 + L(1.2875551670318751538055e0)) * x
+-	- L(1.4897083391357284957891e0)) * x
+-       + L(1.3304961236013647092521e0)) * x + L(3.7568280825958912391243e-1);
++  x = ((((1.3584464340920900529734e-1L * x
++	  - 6.3986917220457538402318e-1L) * x
++	 + 1.2875551670318751538055e0L) * x
++	- 1.4897083391357284957891e0L) * x
++       + 1.3304961236013647092521e0L) * x + 3.7568280825958912391243e-1L;
+ 
+   /* exponent divided by 3 */
+   if (e >= 0)
+@@ -92,9 +90,9 @@ __cbrtl (_Float128 x)
+   x = __ldexpl (x, e);
+ 
+   /* Newton iteration */
+-  x -= (x - (z / (x * x))) * L(0.3333333333333333333333333333333333333333);
+-  x -= (x - (z / (x * x))) * L(0.3333333333333333333333333333333333333333);
+-  x -= (x - (z / (x * x))) * L(0.3333333333333333333333333333333333333333);
++  x -= (x - (z / (x * x))) * 0.3333333333333333333333333333333333333333L;
++  x -= (x - (z / (x * x))) * 0.3333333333333333333333333333333333333333L;
++  x -= (x - (z / (x * x))) * 0.3333333333333333333333333333333333333333L;
+ 
+   if (sign < 0)
+     x = -x;
+diff --git a/sysdeps/ieee754/ldbl-128ibm/t_expl.h b/sysdeps/ieee754/ldbl-128ibm/t_expl.h
+index 0ab0877301..e2fe4dd2ef 100644
+--- a/sysdeps/ieee754/ldbl-128ibm/t_expl.h
++++ b/sysdeps/ieee754/ldbl-128ibm/t_expl.h
+@@ -28,945 +28,943 @@
+    __expl_table[T_EXPL_ARGN+2*i] == i/S+s
+    where absl(s) <= 2^-54 and absl(r) <= 2^-212.  */
+ 
+-#define _Float128 long double
+-#define L(x) x ## L
+ 
+-static const _Float128 __expl_table [] = {
+- L(-3.47656250000000000584188889839535373E-01), /* bffd640000000000002b1b04213cf000 */
+-  L(6.90417668990715641167244540876988960E-32), /* 3f97667c3fdb588a6ae1af8748357a17 */
+- L(-3.43749999999999981853132895957607418E-01), /* bffd5ffffffffffffac4ff5f4050b000 */
+- L(-7.16021898043268093462818380603370350E-33), /* bf94296c8219427edc1431ac2498583e */
+- L(-3.39843750000000013418643523138766329E-01), /* bffd5c000000000003de1f027a30e000 */
+-  L(8.16920774283317801641347327589583265E-32), /* 3f97a82b65774bdca1b4440d749ed8d3 */
+- L(-3.35937500000000014998092453039303051E-01), /* bffd5800000000000452a9f4d8857000 */
+- L(-6.55865578425428447938248396879359670E-32), /* bf97548b7d240f3d034b395e6eecfac8 */
+- L(-3.32031250000000000981984049529998541E-01), /* bffd540000000000004875277cda5000 */
+-  L(6.91213046334032232108944519541512737E-32), /* 3f9766e5f925338a19045c94443b66e1 */
+- L(-3.28124999999999986646017645350399708E-01), /* bffd4ffffffffffffc26a667bf44d000 */
+- L(-6.16281060996110316602421505683742661E-32), /* bf973ffdcdcffb6fbffc86b2b8d42f5d */
+- L(-3.24218749999999991645717430645867963E-01), /* bffd4bfffffffffffd97901063e48000 */
+- L(-7.90797211087760527593856542417304137E-32), /* bf979a9afaaca1ada6a8ed1c80584d60 */
+- L(-3.20312499999999998918211610690789652E-01), /* bffd47ffffffffffffb02d9856d71000 */
+-  L(8.64024799457616856987630373786503376E-32), /* 3f97c0a098623f95579d5d9b2b67342d */
+- L(-3.16406249999999998153974811017181883E-01), /* bffd43ffffffffffff77c991f1076000 */
+- L(-2.73176610180696076418536105483668404E-32), /* bf961baeccb32f9b1fcbb8e60468e95a */
+- L(-3.12500000000000011420976192575972779E-01), /* bffd400000000000034ab8240483d000 */
+-  L(7.16573502812389453744433792609989420E-32), /* 3f977410f4c2cfc4335f28446c0fb363 */
+- L(-3.08593750000000001735496343854851414E-01), /* bffd3c000000000000800e995c176000 */
+- L(-1.56292999645122272621237565671593071E-32), /* bf95449b9cbdaff6ac1246adb2c826ac */
+- L(-3.04687499999999982592401295899221626E-01), /* bffd37fffffffffffafb8bc1e061a000 */
+-  L(6.48993208584888904958594509625158417E-32), /* 3f9750f9fe8366d82d77afa0031a92e1 */
+- L(-3.00781249999999999230616898937763959E-01), /* bffd33ffffffffffffc73ac39da54000 */
+-  L(6.57082437496961397305801409357792029E-32), /* 3f97552d3cb598ea80135cf3feb27ec4 */
+- L(-2.96874999999999998788769281703245722E-01), /* bffd2fffffffffffffa6a07fa5021000 */
+- L(-3.26588297198283968096426564544269170E-32), /* bf9653260fc1802f46b629aee171809b */
+- L(-2.92968750000000015318089182805941695E-01), /* bffd2c0000000000046a468614bd6000 */
+- L(-1.73291974845198589684358727559290718E-32), /* bf9567e9d158f52e483c8d8dcb5961dd */
+- L(-2.89062500000000007736778942676309681E-01), /* bffd280000000000023adf9f4c3d3000 */
+- L(-6.83629745986675744404029225571026236E-32), /* bf9762f5face6281c1daf1c6aedbdb45 */
+- L(-2.85156250000000001367091555763661937E-01), /* bffd2400000000000064dfa11e3fb000 */
+- L(-5.44898442619766878281110054067026237E-32), /* bf971aed6d2db9f542986a785edae072 */
+- L(-2.81249999999999986958718100227029406E-01), /* bffd1ffffffffffffc3db9265ca9d000 */
+-  L(1.13007318374506125723591889451107046E-32), /* 3f94d569fe387f456a97902907ac3856 */
+- L(-2.77343750000000000356078829380495179E-01), /* bffd1c0000000000001a462390083000 */
+- L(-4.98979365468978332358409063436543102E-32), /* bf970315bbf3e0d14b5c94c900702d4c */
+- L(-2.73437499999999990276993957508540484E-01), /* bffd17fffffffffffd32919bcdc94000 */
+- L(-8.79390484115892344533724650295100871E-32), /* bf97c89b0b89cc19c3ab2b60da9bbbc3 */
+- L(-2.69531250000000002434203866460082225E-01), /* bffd14000000000000b39ccf9e130000 */
+-  L(9.44060754687026590886751809927191596E-32), /* 3f97ea2f32cfecca5c64a26137a9210f */
+- L(-2.65624999999999997296320716986257179E-01), /* bffd0fffffffffffff3880f13a2bc000 */
+-  L(2.07142664067265697791007875348396921E-32), /* 3f95ae37ee685b9122fbe377bd205ee4 */
+- L(-2.61718750000000010237478733739017956E-01), /* bffd0c000000000002f3648179d40000 */
+- L(-6.10552936159265665298996309192680256E-32), /* bf973d0467d31e407515a3cca0f3b4e2 */
+- L(-2.57812500000000011948220522778370303E-01), /* bffd08000000000003719f81275bd000 */
+-  L(6.72477169058908902499239631466443836E-32), /* 3f975d2b8c475d3160cf72d227d8e6f9 */
+- L(-2.53906249999999991822993360536596860E-01), /* bffd03fffffffffffda4a4b62f818000 */
+- L(-2.44868296623215865054704392917190994E-32), /* bf95fc92516c6d057d29fc2528855976 */
+- L(-2.49999999999999986862019457428548084E-01), /* bffcfffffffffffff86d2d20d5ff4000 */
+- L(-3.85302898949105073614122724961613078E-32), /* bf96901f147cb7d643af71b6129ce929 */
+- L(-2.46093750000000000237554160737318435E-01), /* bffcf8000000000000230e8ade26b000 */
+- L(-1.52823675242678363494345369284988589E-32), /* bf953d6700c5f3fc303f79d0ec8c680a */
+- L(-2.42187500000000003023380963205457065E-01), /* bffcf0000000000001be2c1a78bb0000 */
+- L(-7.78402037952209709489481182714311699E-34), /* bf9102ab1f3998e887f0ee4cf940faa5 */
+- L(-2.38281249999999995309623303145485725E-01), /* bffce7fffffffffffd4bd2940f43f000 */
+- L(-3.54307216794236899443913216397197696E-32), /* bf966fef03ab69c3f289436205b21d02 */
+- L(-2.34374999999999998425804947623207526E-01), /* bffcdfffffffffffff17b097a6092000 */
+- L(-2.86038428948386602859761879407549696E-32), /* bf96290a0eba0131efe3a05fe188f2e3 */
+- L(-2.30468749999999993822207406785200832E-01), /* bffcd7fffffffffffc70519834eae000 */
+- L(-2.54339521031747516806893838749365762E-32), /* bf96081f0ad7f9107ae6cddb32c178ab */
+- L(-2.26562499999999997823524030344489884E-01), /* bffccffffffffffffebecf10093df000 */
+-  L(4.31904611473158635644635628922959401E-32), /* 3f96c083f0b1faa7c4c686193e38d67c */
+- L(-2.22656250000000004835132405125162742E-01), /* bffcc8000000000002c98a233f19f000 */
+-  L(2.54709791629335691650310168420597566E-33), /* 3f92a735903f5eed07a716ab931e20d9 */
+- L(-2.18749999999999988969454021829236626E-01), /* bffcbffffffffffff9a42dc14ce36000 */
+- L(-3.77236096429336082213752014054909454E-32), /* bf9687be8e5b2fca54d3e81157eac660 */
+- L(-2.14843750000000010613256919115758495E-01), /* bffcb80000000000061e3d828ecac000 */
+- L(-4.55194148712216691177097854305964738E-32), /* bf96d8b35c776aa3e1a4768271380503 */
+- L(-2.10937499999999993204656148110447201E-01), /* bffcaffffffffffffc152f2aea118000 */
+- L(-2.95044199165561453749332254271716417E-32), /* bf96326433b00b2439094d9bef22ddd1 */
+- L(-2.07031250000000012233944895423355677E-01), /* bffca80000000000070d695ee0e94000 */
+-  L(1.93146788688385419095981415411012357E-32), /* 3f959126729135a5e390d4bb802a0bde */
+- L(-2.03125000000000008030983633336321863E-01), /* bffca0000000000004a129fbc51af000 */
+-  L(2.37361904671826193563212931215900137E-32), /* 3f95ecfb3c4ba1b97ea3ad45cbb1e68a */
+- L(-1.99218750000000001763815712796132779E-01), /* bffc98000000000001044b12d9950000 */
+- L(-3.63171243370923753295192486732883239E-33), /* bf932db5fb3f27c38e0fa7bbcfc64f55 */
+- L(-1.95312500000000004883660234506677272E-01), /* bffc90000000000002d0b3779d1f9000 */
+- L(-3.19989507343607877747980892249711601E-33), /* bf9309d63de96bb3ef744c865f22f1bd */
+- L(-1.91406250000000013720152363227519348E-01), /* bffc88000000000007e8bcb387121000 */
+- L(-1.89295754093147174148371614722178860E-32), /* bf958926e2e67dfe812c508290add2e7 */
+- L(-1.87500000000000000182342082774432620E-01), /* bffc800000000000001ae8b06a39f000 */
+- L(-2.96812835183184815200854214892983927E-32), /* bf96343a62d156bbe71f55d14ca4b6e5 */
+- L(-1.83593750000000012410147185883290345E-01), /* bffc78000000000007276a1adda8d000 */
+- L(-2.02191931237489669058466239995304587E-32), /* bf95a3efab92d26ec2df90df036a117f */
+- L(-1.79687499999999997439177363346082917E-01), /* bffc6ffffffffffffe8616db2927d000 */
+- L(-9.92752326937775530007399526834009465E-33), /* bf949c5f88ed17041e1a3f1829d543cd */
+- L(-1.75781249999999995824373974504785174E-01), /* bffc67fffffffffffd97c94f13ea3000 */
+-  L(1.44184772065335613487885714828816178E-32), /* 3f952b75c63476e7fcc2f5841c27bcce */
+- L(-1.71874999999999986685050259043077809E-01), /* bffc5ffffffffffff8530f6bc531a000 */
+- L(-3.49007014971241147689894940544402482E-32), /* bf966a6dfaa012aea8ffe6d90b02330f */
+- L(-1.67968749999999997316058782350439701E-01), /* bffc57fffffffffffe73eb914f2aa000 */
+-  L(3.34025733574205019081305778794376391E-32), /* 3f965adf4572561fd5456a6c13d8babf */
+- L(-1.64062499999999993322730602128318480E-01), /* bffc4ffffffffffffc269be4f68f3000 */
+- L(-1.83345916769684984022099095506340635E-32), /* bf957ccb69026cb2f6024c211576d5f4 */
+- L(-1.60156249999999992419000744447607979E-01), /* bffc47fffffffffffba13df21784a000 */
+-  L(2.73442789798110494773517431626534726E-32), /* 3f961bf58ff22c9b30f1e2b39f26d7d5 */
+- L(-1.56249999999999987665010524130393080E-01), /* bffc3ffffffffffff8e3ad45e7508000 */
+-  L(2.02695576464836145806428118889332191E-32), /* 3f95a4fb7435a4a2f71de81eb8ae75d1 */
+- L(-1.52343749999999989905291167951491803E-01), /* bffc37fffffffffffa2e48aecfc24000 */
+- L(-3.61436631548815190395331054871041524E-32), /* bf967756567ebd108075ae527cc2e7f0 */
+- L(-1.48437500000000006686107754967759751E-01), /* bffc30000000000003dab20261b3c000 */
+- L(-2.15524270159131591469319477922198390E-32), /* bf95bfa05b82ef3a708c4f0395e9fcf6 */
+- L(-1.44531250000000005132889939177166485E-01), /* bffc28000000000002f57b1969e7b000 */
+-  L(2.74741116529653547935086189244019604E-32), /* 3f961d4eb77c1185d34fe1b04a3f3cf5 */
+- L(-1.40625000000000000707469094533647325E-01), /* bffc2000000000000068676d3d5c4000 */
+-  L(4.40607097220049957013547629906723266E-33), /* 3f936e0ac425daf795b42913cf0ef881 */
+- L(-1.36718749999999995713752139187543306E-01), /* bffc17fffffffffffd87762255991000 */
+- L(-3.73751317180116492404578048203389108E-32), /* bf9684202491e9cbb7ceb67d9ff7e0c9 */
+- L(-1.32812500000000007198453630478482191E-01), /* bffc10000000000004264de3a4379000 */
+- L(-3.97050085179660203884930593717220728E-32), /* bf969c52048de14be3c9c1971e50869c */
+- L(-1.28906250000000006070486371645733082E-01), /* bffc080000000000037fd87db2cb0000 */
+-  L(3.59610068058504988294019521946586131E-32), /* 3f967570c10687cb8e9ebd0b280abf5a */
+- L(-1.25000000000000003700729208608337966E-01), /* bffc00000000000002222198bbc74000 */
+-  L(3.23464851393124362331846965931995969E-33), /* 3f930cb95da3bfc847e593716c91d57a */
+- L(-1.21093750000000013729038501177102555E-01), /* bffbf000000000000fd418d1f5fda000 */
+-  L(2.45242487730722066611358741283977619E-32), /* 3f95fd5945ad86a464292e26ac192a84 */
+- L(-1.17187499999999999765305306880205578E-01), /* bffbdfffffffffffffbabaf869845000 */
+- L(-1.14557520298960389903199646350205537E-32), /* bf94dbda735322179d9bcf392e1dd06d */
+- L(-1.13281250000000009579647893740755690E-01), /* bffbd000000000000b0b69bae7ab9000 */
+-  L(2.37873962873837390105423621772752350E-32), /* 3f95ee0b7e0bd5ac1f6fab1e2a71abc3 */
+- L(-1.09375000000000008981153004560108539E-01), /* bffbc000000000000a5ac4bc1d2c3000 */
+-  L(1.53152444860014076105003555837231015E-32), /* 3f953e15ce931e12ef9a152522e32bdd */
+- L(-1.05468749999999992399063850363228723E-01), /* bffbaffffffffffff73c998091408000 */
+- L(-8.75920903597804862471749360196688834E-33), /* bf946bd7e310a01bae5687ebdc47fcc5 */
+- L(-1.01562500000000007685885179918350550E-01), /* bffba0000000000008dc7910a648c000 */
+- L(-4.63820993797174451904075397785059501E-33), /* bf938153d0e54001a472da180fb5e8aa */
+- L(-9.76562499999999887262211517861331814E-02), /* bffb8ffffffffffff300915aa6fd6000 */
+- L(-2.63767025974952608658936466715705903E-33), /* bf92b64215bb8d520be5404620d38088 */
+- L(-9.37499999999999939650246024457439795E-02), /* bffb7ffffffffffff90aca26bd0fc000 */
+- L(-1.72047822349322956713582039121348377E-32), /* bf9565545015c5b9b56d02cfefca2c7d */
+- L(-8.98437500000000033088896383977486369E-02), /* bffb70000000000003d09ca1e3cbe000 */
+-  L(3.04831994420989436248526129869697270E-33), /* 3f92fa7d30d2ed90e7ebbd6231fd08b1 */
+- L(-8.59374999999999947312400115121319225E-02), /* bffb5ffffffffffff9ecefc03376e000 */
+-  L(1.50416954438393392150792422537312281E-32), /* 3f9538675ee99bd722fad0023c09c915 */
+- L(-8.20312500000000054182280847004695514E-02), /* bffb500000000000063f2dbd40200000 */
+-  L(2.68399664523430004488075638997207289E-33), /* 3f92bdf49766629882c49a3da88928ed */
+- L(-7.81250000000000114767533968079748798E-02), /* bffb4000000000000d3b56f81ba70000 */
+-  L(1.72318124201659121296305402819694281E-32), /* 3f9565e407aaabfb359e8a567d760de3 */
+- L(-7.42187500000000035531829472486812869E-02), /* bffb3000000000000418b6e9b5388000 */
+-  L(2.09401756478514117051383998628099655E-32), /* 3f95b2e91221fcd74be0a86d8ad658d2 */
+- L(-7.03124999999999987474933134860732535E-02), /* bffb1ffffffffffffe8e53453d2ac000 */
+-  L(2.28515798224350800271565551341211666E-32), /* 3f95da9bd6adf00894f05b5cc5530125 */
+- L(-6.64062500000000042267533361089054159E-02), /* bffb10000000000004df8473dbcf2000 */
+-  L(1.97576478800281368377376002585430031E-32), /* 3f959a59acbddb2f53bd3096b66370e9 */
+- L(-6.25000000000000066329769382774201686E-02), /* bffb00000000000007a5b5914e336000 */
+- L(-1.46422615813786836245343723048221678E-33), /* bf91e69295f069fc0c4a9db181ea25a3 */
+- L(-5.85937500000000002823707957982406053E-02), /* bffae0000000000000a6aeab10592000 */
+-  L(9.25637741701318872896718218457555829E-33), /* 3f94807eb021f1f40a37d4015b1eb76b */
+- L(-5.46875000000000081586888005226044448E-02), /* bffac0000000000012d00a3171e3a000 */
+- L(-4.87144542459404765480424673678105050E-33), /* bf9394b42faba6b7036fe7b36269daf3 */
+- L(-5.07812499999999927720348253140567013E-02), /* bffa9fffffffffffef555cc8dd914000 */
+- L(-3.01901021987395945826043649523451725E-33), /* bf92f59e7e3025691f290f8f67277faf */
+- L(-4.68749999999999935349476738962633103E-02), /* bffa7ffffffffffff117b4ea2b876000 */
+-  L(1.21521638219189777347767475937119750E-32), /* 3f94f8c7f88c5b56674b94d984ac8ecb */
+- L(-4.29687500000000056305562847814228219E-02), /* bffa6000000000000cfbb19be30c0000 */
+- L(-1.18643699217679276275559592978275214E-32), /* bf94ecd39f0833a876550e83eb012b99 */
+- L(-3.90624999999999962692914526031373542E-02), /* bffa3ffffffffffff765c743922f9000 */
+- L(-4.91277156857520035712509544689973679E-33), /* bf939823189996193872e58ac0dececb */
+- L(-3.51562500000000108152468207687602886E-02), /* bffa20000000000018f031e41177f000 */
+-  L(1.18599806302656253755207072755609820E-32), /* 3f94eca4f23e787fab73ce8f6b9b8d64 */
+- L(-3.12500000000000077376981036742289578E-02), /* bffa00000000000011d787e0b386f000 */
+-  L(9.97730386477005171963635210799577079E-33), /* 3f949e70e498c46a0173ac0d46c699fc */
+- L(-2.73437500000000139436129596418623235E-02), /* bff9c00000000000404db66e70a08000 */
+-  L(2.25755321633070123579875157841633859E-33), /* 3f927719b1a93074bdf9f3c2cb784785 */
+- L(-2.34375000000000088003629211828324876E-02), /* bff98000000000002895a27d45feb000 */
+-  L(2.84374279216848803102126617873942975E-33), /* 3f92d87f70e749d6da6c260b68dc210b */
+- L(-1.95312500000000107408831063404855424E-02), /* bff9400000000000318898ba69f71000 */
+-  L(2.47348089686935458989103979140011912E-33), /* 3f929afa3de45086fe909fdddb41edce */
+- L(-1.56250000000000081443917555362290635E-02), /* bff9000000000000258f335e9cdd6000 */
+- L(-2.43379314483517422161458863218426254E-33), /* bf9294621c8a9ccacf2b020ec19cad27 */
+- L(-1.17187500000000051490597418161403184E-02), /* bff88000000000002f7ddfa26221f000 */
+-  L(1.83405297208145390679150568810924707E-33), /* 3f9230bbfc5d5fe1b534fbcda0465bb9 */
+- L(-7.81249999999999715861805208310174953E-03), /* bff7ffffffffffffcb95f3fff157d000 */
+-  L(3.51548384878710915171654413641872451E-34), /* 3f8fd349b76c22966f77a39fc37ed704 */
+- L(-3.90625000000000309326013918295097128E-03), /* bff7000000000000390f820c8e153000 */
+-  L(6.38058004651791109324060099097251911E-36), /* 3f8a0f665d3ac25a1ac94d688273dbcd */
++static const long double __expl_table [] = {
++ -3.47656250000000000584188889839535373E-01L, /* bffd640000000000002b1b04213cf000 */
++  6.90417668990715641167244540876988960E-32L, /* 3f97667c3fdb588a6ae1af8748357a17 */
++ -3.43749999999999981853132895957607418E-01L, /* bffd5ffffffffffffac4ff5f4050b000 */
++ -7.16021898043268093462818380603370350E-33L, /* bf94296c8219427edc1431ac2498583e */
++ -3.39843750000000013418643523138766329E-01L, /* bffd5c000000000003de1f027a30e000 */
++  8.16920774283317801641347327589583265E-32L, /* 3f97a82b65774bdca1b4440d749ed8d3 */
++ -3.35937500000000014998092453039303051E-01L, /* bffd5800000000000452a9f4d8857000 */
++ -6.55865578425428447938248396879359670E-32L, /* bf97548b7d240f3d034b395e6eecfac8 */
++ -3.32031250000000000981984049529998541E-01L, /* bffd540000000000004875277cda5000 */
++  6.91213046334032232108944519541512737E-32L, /* 3f9766e5f925338a19045c94443b66e1 */
++ -3.28124999999999986646017645350399708E-01L, /* bffd4ffffffffffffc26a667bf44d000 */
++ -6.16281060996110316602421505683742661E-32L, /* bf973ffdcdcffb6fbffc86b2b8d42f5d */
++ -3.24218749999999991645717430645867963E-01L, /* bffd4bfffffffffffd97901063e48000 */
++ -7.90797211087760527593856542417304137E-32L, /* bf979a9afaaca1ada6a8ed1c80584d60 */
++ -3.20312499999999998918211610690789652E-01L, /* bffd47ffffffffffffb02d9856d71000 */
++  8.64024799457616856987630373786503376E-32L, /* 3f97c0a098623f95579d5d9b2b67342d */
++ -3.16406249999999998153974811017181883E-01L, /* bffd43ffffffffffff77c991f1076000 */
++ -2.73176610180696076418536105483668404E-32L, /* bf961baeccb32f9b1fcbb8e60468e95a */
++ -3.12500000000000011420976192575972779E-01L, /* bffd400000000000034ab8240483d000 */
++  7.16573502812389453744433792609989420E-32L, /* 3f977410f4c2cfc4335f28446c0fb363 */
++ -3.08593750000000001735496343854851414E-01L, /* bffd3c000000000000800e995c176000 */
++ -1.56292999645122272621237565671593071E-32L, /* bf95449b9cbdaff6ac1246adb2c826ac */
++ -3.04687499999999982592401295899221626E-01L, /* bffd37fffffffffffafb8bc1e061a000 */
++  6.48993208584888904958594509625158417E-32L, /* 3f9750f9fe8366d82d77afa0031a92e1 */
++ -3.00781249999999999230616898937763959E-01L, /* bffd33ffffffffffffc73ac39da54000 */
++  6.57082437496961397305801409357792029E-32L, /* 3f97552d3cb598ea80135cf3feb27ec4 */
++ -2.96874999999999998788769281703245722E-01L, /* bffd2fffffffffffffa6a07fa5021000 */
++ -3.26588297198283968096426564544269170E-32L, /* bf9653260fc1802f46b629aee171809b */
++ -2.92968750000000015318089182805941695E-01L, /* bffd2c0000000000046a468614bd6000 */
++ -1.73291974845198589684358727559290718E-32L, /* bf9567e9d158f52e483c8d8dcb5961dd */
++ -2.89062500000000007736778942676309681E-01L, /* bffd280000000000023adf9f4c3d3000 */
++ -6.83629745986675744404029225571026236E-32L, /* bf9762f5face6281c1daf1c6aedbdb45 */
++ -2.85156250000000001367091555763661937E-01L, /* bffd2400000000000064dfa11e3fb000 */
++ -5.44898442619766878281110054067026237E-32L, /* bf971aed6d2db9f542986a785edae072 */
++ -2.81249999999999986958718100227029406E-01L, /* bffd1ffffffffffffc3db9265ca9d000 */
++  1.13007318374506125723591889451107046E-32L, /* 3f94d569fe387f456a97902907ac3856 */
++ -2.77343750000000000356078829380495179E-01L, /* bffd1c0000000000001a462390083000 */
++ -4.98979365468978332358409063436543102E-32L, /* bf970315bbf3e0d14b5c94c900702d4c */
++ -2.73437499999999990276993957508540484E-01L, /* bffd17fffffffffffd32919bcdc94000 */
++ -8.79390484115892344533724650295100871E-32L, /* bf97c89b0b89cc19c3ab2b60da9bbbc3 */
++ -2.69531250000000002434203866460082225E-01L, /* bffd14000000000000b39ccf9e130000 */
++  9.44060754687026590886751809927191596E-32L, /* 3f97ea2f32cfecca5c64a26137a9210f */
++ -2.65624999999999997296320716986257179E-01L, /* bffd0fffffffffffff3880f13a2bc000 */
++  2.07142664067265697791007875348396921E-32L, /* 3f95ae37ee685b9122fbe377bd205ee4 */
++ -2.61718750000000010237478733739017956E-01L, /* bffd0c000000000002f3648179d40000 */
++ -6.10552936159265665298996309192680256E-32L, /* bf973d0467d31e407515a3cca0f3b4e2 */
++ -2.57812500000000011948220522778370303E-01L, /* bffd08000000000003719f81275bd000 */
++  6.72477169058908902499239631466443836E-32L, /* 3f975d2b8c475d3160cf72d227d8e6f9 */
++ -2.53906249999999991822993360536596860E-01L, /* bffd03fffffffffffda4a4b62f818000 */
++ -2.44868296623215865054704392917190994E-32L, /* bf95fc92516c6d057d29fc2528855976 */
++ -2.49999999999999986862019457428548084E-01L, /* bffcfffffffffffff86d2d20d5ff4000 */
++ -3.85302898949105073614122724961613078E-32L, /* bf96901f147cb7d643af71b6129ce929 */
++ -2.46093750000000000237554160737318435E-01L, /* bffcf8000000000000230e8ade26b000 */
++ -1.52823675242678363494345369284988589E-32L, /* bf953d6700c5f3fc303f79d0ec8c680a */
++ -2.42187500000000003023380963205457065E-01L, /* bffcf0000000000001be2c1a78bb0000 */
++ -7.78402037952209709489481182714311699E-34L, /* bf9102ab1f3998e887f0ee4cf940faa5 */
++ -2.38281249999999995309623303145485725E-01L, /* bffce7fffffffffffd4bd2940f43f000 */
++ -3.54307216794236899443913216397197696E-32L, /* bf966fef03ab69c3f289436205b21d02 */
++ -2.34374999999999998425804947623207526E-01L, /* bffcdfffffffffffff17b097a6092000 */
++ -2.86038428948386602859761879407549696E-32L, /* bf96290a0eba0131efe3a05fe188f2e3 */
++ -2.30468749999999993822207406785200832E-01L, /* bffcd7fffffffffffc70519834eae000 */
++ -2.54339521031747516806893838749365762E-32L, /* bf96081f0ad7f9107ae6cddb32c178ab */
++ -2.26562499999999997823524030344489884E-01L, /* bffccffffffffffffebecf10093df000 */
++  4.31904611473158635644635628922959401E-32L, /* 3f96c083f0b1faa7c4c686193e38d67c */
++ -2.22656250000000004835132405125162742E-01L, /* bffcc8000000000002c98a233f19f000 */
++  2.54709791629335691650310168420597566E-33L, /* 3f92a735903f5eed07a716ab931e20d9 */
++ -2.18749999999999988969454021829236626E-01L, /* bffcbffffffffffff9a42dc14ce36000 */
++ -3.77236096429336082213752014054909454E-32L, /* bf9687be8e5b2fca54d3e81157eac660 */
++ -2.14843750000000010613256919115758495E-01L, /* bffcb80000000000061e3d828ecac000 */
++ -4.55194148712216691177097854305964738E-32L, /* bf96d8b35c776aa3e1a4768271380503 */
++ -2.10937499999999993204656148110447201E-01L, /* bffcaffffffffffffc152f2aea118000 */
++ -2.95044199165561453749332254271716417E-32L, /* bf96326433b00b2439094d9bef22ddd1 */
++ -2.07031250000000012233944895423355677E-01L, /* bffca80000000000070d695ee0e94000 */
++  1.93146788688385419095981415411012357E-32L, /* 3f959126729135a5e390d4bb802a0bde */
++ -2.03125000000000008030983633336321863E-01L, /* bffca0000000000004a129fbc51af000 */
++  2.37361904671826193563212931215900137E-32L, /* 3f95ecfb3c4ba1b97ea3ad45cbb1e68a */
++ -1.99218750000000001763815712796132779E-01L, /* bffc98000000000001044b12d9950000 */
++ -3.63171243370923753295192486732883239E-33L, /* bf932db5fb3f27c38e0fa7bbcfc64f55 */
++ -1.95312500000000004883660234506677272E-01L, /* bffc90000000000002d0b3779d1f9000 */
++ -3.19989507343607877747980892249711601E-33L, /* bf9309d63de96bb3ef744c865f22f1bd */
++ -1.91406250000000013720152363227519348E-01L, /* bffc88000000000007e8bcb387121000 */
++ -1.89295754093147174148371614722178860E-32L, /* bf958926e2e67dfe812c508290add2e7 */
++ -1.87500000000000000182342082774432620E-01L, /* bffc800000000000001ae8b06a39f000 */
++ -2.96812835183184815200854214892983927E-32L, /* bf96343a62d156bbe71f55d14ca4b6e5 */
++ -1.83593750000000012410147185883290345E-01L, /* bffc78000000000007276a1adda8d000 */
++ -2.02191931237489669058466239995304587E-32L, /* bf95a3efab92d26ec2df90df036a117f */
++ -1.79687499999999997439177363346082917E-01L, /* bffc6ffffffffffffe8616db2927d000 */
++ -9.92752326937775530007399526834009465E-33L, /* bf949c5f88ed17041e1a3f1829d543cd */
++ -1.75781249999999995824373974504785174E-01L, /* bffc67fffffffffffd97c94f13ea3000 */
++  1.44184772065335613487885714828816178E-32L, /* 3f952b75c63476e7fcc2f5841c27bcce */
++ -1.71874999999999986685050259043077809E-01L, /* bffc5ffffffffffff8530f6bc531a000 */
++ -3.49007014971241147689894940544402482E-32L, /* bf966a6dfaa012aea8ffe6d90b02330f */
++ -1.67968749999999997316058782350439701E-01L, /* bffc57fffffffffffe73eb914f2aa000 */
++  3.34025733574205019081305778794376391E-32L, /* 3f965adf4572561fd5456a6c13d8babf */
++ -1.64062499999999993322730602128318480E-01L, /* bffc4ffffffffffffc269be4f68f3000 */
++ -1.83345916769684984022099095506340635E-32L, /* bf957ccb69026cb2f6024c211576d5f4 */
++ -1.60156249999999992419000744447607979E-01L, /* bffc47fffffffffffba13df21784a000 */
++  2.73442789798110494773517431626534726E-32L, /* 3f961bf58ff22c9b30f1e2b39f26d7d5 */
++ -1.56249999999999987665010524130393080E-01L, /* bffc3ffffffffffff8e3ad45e7508000 */
++  2.02695576464836145806428118889332191E-32L, /* 3f95a4fb7435a4a2f71de81eb8ae75d1 */
++ -1.52343749999999989905291167951491803E-01L, /* bffc37fffffffffffa2e48aecfc24000 */
++ -3.61436631548815190395331054871041524E-32L, /* bf967756567ebd108075ae527cc2e7f0 */
++ -1.48437500000000006686107754967759751E-01L, /* bffc30000000000003dab20261b3c000 */
++ -2.15524270159131591469319477922198390E-32L, /* bf95bfa05b82ef3a708c4f0395e9fcf6 */
++ -1.44531250000000005132889939177166485E-01L, /* bffc28000000000002f57b1969e7b000 */
++  2.74741116529653547935086189244019604E-32L, /* 3f961d4eb77c1185d34fe1b04a3f3cf5 */
++ -1.40625000000000000707469094533647325E-01L, /* bffc2000000000000068676d3d5c4000 */
++  4.40607097220049957013547629906723266E-33L, /* 3f936e0ac425daf795b42913cf0ef881 */
++ -1.36718749999999995713752139187543306E-01L, /* bffc17fffffffffffd87762255991000 */
++ -3.73751317180116492404578048203389108E-32L, /* bf9684202491e9cbb7ceb67d9ff7e0c9 */
++ -1.32812500000000007198453630478482191E-01L, /* bffc10000000000004264de3a4379000 */
++ -3.97050085179660203884930593717220728E-32L, /* bf969c52048de14be3c9c1971e50869c */
++ -1.28906250000000006070486371645733082E-01L, /* bffc080000000000037fd87db2cb0000 */
++  3.59610068058504988294019521946586131E-32L, /* 3f967570c10687cb8e9ebd0b280abf5a */
++ -1.25000000000000003700729208608337966E-01L, /* bffc00000000000002222198bbc74000 */
++  3.23464851393124362331846965931995969E-33L, /* 3f930cb95da3bfc847e593716c91d57a */
++ -1.21093750000000013729038501177102555E-01L, /* bffbf000000000000fd418d1f5fda000 */
++  2.45242487730722066611358741283977619E-32L, /* 3f95fd5945ad86a464292e26ac192a84 */
++ -1.17187499999999999765305306880205578E-01L, /* bffbdfffffffffffffbabaf869845000 */
++ -1.14557520298960389903199646350205537E-32L, /* bf94dbda735322179d9bcf392e1dd06d */
++ -1.13281250000000009579647893740755690E-01L, /* bffbd000000000000b0b69bae7ab9000 */
++  2.37873962873837390105423621772752350E-32L, /* 3f95ee0b7e0bd5ac1f6fab1e2a71abc3 */
++ -1.09375000000000008981153004560108539E-01L, /* bffbc000000000000a5ac4bc1d2c3000 */
++  1.53152444860014076105003555837231015E-32L, /* 3f953e15ce931e12ef9a152522e32bdd */
++ -1.05468749999999992399063850363228723E-01L, /* bffbaffffffffffff73c998091408000 */
++ -8.75920903597804862471749360196688834E-33L, /* bf946bd7e310a01bae5687ebdc47fcc5 */
++ -1.01562500000000007685885179918350550E-01L, /* bffba0000000000008dc7910a648c000 */
++ -4.63820993797174451904075397785059501E-33L, /* bf938153d0e54001a472da180fb5e8aa */
++ -9.76562499999999887262211517861331814E-02L, /* bffb8ffffffffffff300915aa6fd6000 */
++ -2.63767025974952608658936466715705903E-33L, /* bf92b64215bb8d520be5404620d38088 */
++ -9.37499999999999939650246024457439795E-02L, /* bffb7ffffffffffff90aca26bd0fc000 */
++ -1.72047822349322956713582039121348377E-32L, /* bf9565545015c5b9b56d02cfefca2c7d */
++ -8.98437500000000033088896383977486369E-02L, /* bffb70000000000003d09ca1e3cbe000 */
++  3.04831994420989436248526129869697270E-33L, /* 3f92fa7d30d2ed90e7ebbd6231fd08b1 */
++ -8.59374999999999947312400115121319225E-02L, /* bffb5ffffffffffff9ecefc03376e000 */
++  1.50416954438393392150792422537312281E-32L, /* 3f9538675ee99bd722fad0023c09c915 */
++ -8.20312500000000054182280847004695514E-02L, /* bffb500000000000063f2dbd40200000 */
++  2.68399664523430004488075638997207289E-33L, /* 3f92bdf49766629882c49a3da88928ed */
++ -7.81250000000000114767533968079748798E-02L, /* bffb4000000000000d3b56f81ba70000 */
++  1.72318124201659121296305402819694281E-32L, /* 3f9565e407aaabfb359e8a567d760de3 */
++ -7.42187500000000035531829472486812869E-02L, /* bffb3000000000000418b6e9b5388000 */
++  2.09401756478514117051383998628099655E-32L, /* 3f95b2e91221fcd74be0a86d8ad658d2 */
++ -7.03124999999999987474933134860732535E-02L, /* bffb1ffffffffffffe8e53453d2ac000 */
++  2.28515798224350800271565551341211666E-32L, /* 3f95da9bd6adf00894f05b5cc5530125 */
++ -6.64062500000000042267533361089054159E-02L, /* bffb10000000000004df8473dbcf2000 */
++  1.97576478800281368377376002585430031E-32L, /* 3f959a59acbddb2f53bd3096b66370e9 */
++ -6.25000000000000066329769382774201686E-02L, /* bffb00000000000007a5b5914e336000 */
++ -1.46422615813786836245343723048221678E-33L, /* bf91e69295f069fc0c4a9db181ea25a3 */
++ -5.85937500000000002823707957982406053E-02L, /* bffae0000000000000a6aeab10592000 */
++  9.25637741701318872896718218457555829E-33L, /* 3f94807eb021f1f40a37d4015b1eb76b */
++ -5.46875000000000081586888005226044448E-02L, /* bffac0000000000012d00a3171e3a000 */
++ -4.87144542459404765480424673678105050E-33L, /* bf9394b42faba6b7036fe7b36269daf3 */
++ -5.07812499999999927720348253140567013E-02L, /* bffa9fffffffffffef555cc8dd914000 */
++ -3.01901021987395945826043649523451725E-33L, /* bf92f59e7e3025691f290f8f67277faf */
++ -4.68749999999999935349476738962633103E-02L, /* bffa7ffffffffffff117b4ea2b876000 */
++  1.21521638219189777347767475937119750E-32L, /* 3f94f8c7f88c5b56674b94d984ac8ecb */
++ -4.29687500000000056305562847814228219E-02L, /* bffa6000000000000cfbb19be30c0000 */
++ -1.18643699217679276275559592978275214E-32L, /* bf94ecd39f0833a876550e83eb012b99 */
++ -3.90624999999999962692914526031373542E-02L, /* bffa3ffffffffffff765c743922f9000 */
++ -4.91277156857520035712509544689973679E-33L, /* bf939823189996193872e58ac0dececb */
++ -3.51562500000000108152468207687602886E-02L, /* bffa20000000000018f031e41177f000 */
++  1.18599806302656253755207072755609820E-32L, /* 3f94eca4f23e787fab73ce8f6b9b8d64 */
++ -3.12500000000000077376981036742289578E-02L, /* bffa00000000000011d787e0b386f000 */
++  9.97730386477005171963635210799577079E-33L, /* 3f949e70e498c46a0173ac0d46c699fc */
++ -2.73437500000000139436129596418623235E-02L, /* bff9c00000000000404db66e70a08000 */
++  2.25755321633070123579875157841633859E-33L, /* 3f927719b1a93074bdf9f3c2cb784785 */
++ -2.34375000000000088003629211828324876E-02L, /* bff98000000000002895a27d45feb000 */
++  2.84374279216848803102126617873942975E-33L, /* 3f92d87f70e749d6da6c260b68dc210b */
++ -1.95312500000000107408831063404855424E-02L, /* bff9400000000000318898ba69f71000 */
++  2.47348089686935458989103979140011912E-33L, /* 3f929afa3de45086fe909fdddb41edce */
++ -1.56250000000000081443917555362290635E-02L, /* bff9000000000000258f335e9cdd6000 */
++ -2.43379314483517422161458863218426254E-33L, /* bf9294621c8a9ccacf2b020ec19cad27 */
++ -1.17187500000000051490597418161403184E-02L, /* bff88000000000002f7ddfa26221f000 */
++  1.83405297208145390679150568810924707E-33L, /* 3f9230bbfc5d5fe1b534fbcda0465bb9 */
++ -7.81249999999999715861805208310174953E-03L, /* bff7ffffffffffffcb95f3fff157d000 */
++  3.51548384878710915171654413641872451E-34L, /* 3f8fd349b76c22966f77a39fc37ed704 */
++ -3.90625000000000309326013918295097128E-03L, /* bff7000000000000390f820c8e153000 */
++  6.38058004651791109324060099097251911E-36L, /* 3f8a0f665d3ac25a1ac94d688273dbcd */
+ #define T_EXPL_ARG1 (2*89)
+-  L(0.00000000000000000000000000000000000E+00), /* 00000000000000000000000000000000 */
+-  L(0.00000000000000000000000000000000000E+00), /* 00000000000000000000000000000000 */
+-  L(3.90625000000000245479958859972588985E-03), /* 3ff70000000000002d48769ac9874000 */
+- L(-6.58439598384342854976169982902779828E-36), /* bf8a1811b923e6c626b07ef29761482a */
+-  L(7.81250000000001311374391093664996358E-03), /* 3ff800000000000078f3f3cd89111000 */
+-  L(2.60265650555493781464273319671555602E-33), /* 3f92b070c3b635b87af426735a71fc87 */
+-  L(1.17187500000000269581156218247101912E-02), /* 3ff8800000000000f8a50d02fe20d000 */
+-  L(1.00961747974945520631836275894919326E-33), /* 3f914f80c1a4f8042044fe3b757b030b */
+-  L(1.56249999999999797878275270751825475E-02), /* 3ff8ffffffffffff45935b69da62e000 */
+-  L(2.03174577741375590087897353146748580E-33), /* 3f925194e863496e0f6e91cbf6b22e26 */
+-  L(1.95312499999999760319884511789111533E-02), /* 3ff93fffffffffff917790ff9a8f4000 */
+-  L(4.62788519658803722282100289809515007E-33), /* 3f9380783ba81295feeb3e4879d7d52d */
+-  L(2.34374999999999822953909016349145918E-02), /* 3ff97fffffffffffae5a163bd3cd5000 */
+- L(-3.19499956304699705390404384504876533E-33), /* bf93096e2037ced8194cf344c692f8d6 */
+-  L(2.73437500000000137220327275871555682E-02), /* 3ff9c000000000003f481dea5dd51000 */
+- L(-2.25757776523031994464630107442723424E-33), /* bf92771abcf988a02b414bf2614e3734 */
+-  L(3.12499999999999790857640618332718621E-02), /* 3ff9ffffffffffff9f8cd40b51509000 */
+- L(-4.22479470489989916319395454536511458E-33), /* bf935efb7245612f371deca17cb7b30c */
+-  L(3.51562499999999840753382405747597346E-02), /* 3ffa1fffffffffffdb47bd275f722000 */
+-  L(1.08459658374118041980976756063083500E-34), /* 3f8e2055d18b7117c9db1c318b1e889b */
+-  L(3.90624999999999989384433621470426757E-02), /* 3ffa3ffffffffffffd8d5e18b042e000 */
+- L(-7.41674226146122000759491297811091830E-33), /* bf94341454e48029e5b0205d91baffdc */
+-  L(4.29687500000000107505739500500200462E-02), /* 3ffa60000000000018ca04cd9085c000 */
+- L(-4.74689012756713017494437969420919847E-34), /* bf903b7c268103c6f7fbaaa24142e287 */
+-  L(4.68749999999999978700749928325717352E-02), /* 3ffa7ffffffffffffb16b6d5479e3000 */
+- L(-1.06208165308448830117773486334902917E-32), /* bf94b92be4b3b5b5a596a0a5187cc955 */
+-  L(5.07812499999999815072625435955786253E-02), /* 3ffa9fffffffffffd55bd086d5cbc000 */
+- L(-9.37038897148383660401929567549111394E-33), /* bf94853b111b0175b491c80d00419416 */
+-  L(5.46874999999999809511553152189867394E-02), /* 3ffabfffffffffffd4138bfa74a61000 */
+-  L(1.06642963074562437340498606682822123E-32), /* 3f94bafa3fe991b39255d563dfa05d89 */
+-  L(5.85937500000000184331996330905145551E-02), /* 3ffae000000000002a810a5f2f8bf000 */
+- L(-1.76639977694797200820296641773791945E-34), /* bf8ed596f07ce4408f1705c8ec16864c */
+-  L(6.25000000000000021544696744852045001E-02), /* 3ffb000000000000027be32045e2b000 */
+-  L(1.68616371995798354366633034788947149E-32), /* 3f955e33d7440794d8a1b25233d086ab */
+-  L(6.64062499999999965563110718495802889E-02), /* 3ffb0ffffffffffffc079a38a3fed000 */
+- L(-1.82463217667830160048872113565316215E-32), /* bf957af6163bcdb97cefab44a942482a */
+-  L(7.03124999999999759989183341261898222E-02), /* 3ffb1fffffffffffe454218acea05000 */
+- L(-1.07843770101525495515646940862541503E-32), /* bf94bff72aada26d94e76e71c07e0580 */
+-  L(7.42187499999999898968873730710101412E-02), /* 3ffb2ffffffffffff45a166496dc1000 */
+-  L(1.28629441689592874462780757154138223E-32), /* 3f950b2724597b8b93ce1e9d1cf4d035 */
+-  L(7.81249999999999957198938523510804668E-02), /* 3ffb3ffffffffffffb10bc52adbc5000 */
+-  L(1.13297573459968118467100063135856856E-33), /* 3f91787eea895b3c245899cf34ad0abd */
+-  L(8.20312500000000199911640621145851159E-02), /* 3ffb500000000000170c59a661a89000 */
+- L(-1.51161335208135146756554123073528707E-32), /* bf9539f326c5ca84e7db5401566f3775 */
+-  L(8.59375000000000134175373433347670743E-02), /* 3ffb6000000000000f78287547af0000 */
+-  L(1.09763629458404270323909815379924900E-32), /* 3f94c7f0b61b6e3e27d44b9f5bbc7e9d */
+-  L(8.98437500000000036533922600308306335E-02), /* 3ffb70000000000004364a83b7a14000 */
+-  L(3.11459653680110433194288029777718358E-33), /* 3f9302c0248136d65cebeab69488d949 */
+-  L(9.37500000000000184977946245216914691E-02), /* 3ffb800000000000155395d870b17000 */
+- L(-4.66656154468277949130395786965043927E-33), /* bf9383aec9b993b6db492b1ede786d8a */
+-  L(9.76562500000000237839723100419376084E-02), /* 3ffb9000000000001b6bca237f6c4000 */
+- L(-1.03028043424658760249140747856831301E-32), /* bf94abf6352e3d2bb398e47919a343fb */
+-  L(1.01562500000000012345545575236836572E-01), /* 3ffba000000000000e3bc30cd9a1f000 */
+-  L(2.15755372310795701322789783729456319E-32), /* 3f95c01b3b819edd9d07548fafd61550 */
+-  L(1.05468749999999976493840484471911438E-01), /* 3ffbafffffffffffe4e634cd77985000 */
+-  L(1.78771847038773333029677216592309083E-32), /* 3f95734b6ae650f33dd43c49a1df9fc0 */
+-  L(1.09375000000000002267015055992785402E-01), /* 3ffbc00000000000029d1ad08de7b000 */
+-  L(6.23263106693943817730045115112427717E-33), /* 3f9402e4b39ce2198a45e1d045868cd6 */
+-  L(1.13281250000000022354208618429577398E-01), /* 3ffbd0000000000019c5cc3f9d2b5000 */
+-  L(5.40514416644786448581426756221178868E-33), /* 3f93c10ab4021472c662f69435de9269 */
+-  L(1.17187500000000013252367133076817603E-01), /* 3ffbe000000000000f47688cc561b000 */
+- L(-7.12412585457324989451327215568641325E-33), /* bf9427ecb343a8d1758990565fcfbf45 */
+-  L(1.21093750000000020759863992944300792E-01), /* 3ffbf0000000000017ef3af97bf04000 */
+-  L(6.26591408357572503875647872077266444E-33), /* 3f940446a09a2da771b45fc075514d12 */
+-  L(1.25000000000000004739659392396765618E-01), /* 3ffc00000000000002bb7344ecd89000 */
+- L(-1.55611398459729463981000080101758830E-32), /* bf95433135febefa9e6aa4db39e263d2 */
+-  L(1.28906249999999982360888081057894783E-01), /* 3ffc07fffffffffff5d4ed3154361000 */
+- L(-1.77531518652835570781208599686606474E-32), /* bf9570b7f225ea076f97f418d11359c1 */
+-  L(1.32812500000000010568583998727400436E-01), /* 3ffc1000000000000617a5d09526a000 */
+-  L(2.12104021624990594668286391598300893E-32), /* 3f95b885d767a1048d93055927a27adc */
+-  L(1.36718749999999998434125157367005292E-01), /* 3ffc17ffffffffffff18eaebc7970000 */
+-  L(2.50454798592543203967309921276955297E-32), /* 3f9604164e5598528a76faff26cd1c97 */
+-  L(1.40625000000000015550032422969330356E-01), /* 3ffc20000000000008f6c79d8928c000 */
+-  L(7.80972982879849783680252962992639832E-33), /* 3f9444674acf2b3225c7647e0d95edf3 */
+-  L(1.44531250000000012402535562111122522E-01), /* 3ffc28000000000007264a8bc1ff1000 */
+-  L(2.79662468716455159585514763921671876E-32), /* 3f96226b095bd78aa650faf95a221993 */
+-  L(1.48437500000000007761020440087419948E-01), /* 3ffc3000000000000479530ff8fe3000 */
+-  L(2.15518492972728435680556239996258527E-32), /* 3f95bf9d49295e73a957906a029768cb */
+-  L(1.52343750000000001733189947520484032E-01), /* 3ffc38000000000000ffc6109f71f000 */
+-  L(8.34032236093545825619420380704500188E-33), /* 3f945a71851226a1d0ce5e656693153e */
+-  L(1.56249999999999988073295321246958484E-01), /* 3ffc3ffffffffffff91fedd62ae0f000 */
+-  L(2.44119337150624789345260194989620908E-32), /* 3f95fb041a57bc1c1280680ac1620bea */
+-  L(1.60156250000000002076894210913572460E-01), /* 3ffc48000000000001327ed84a199000 */
+- L(-7.36124501128859978061216696286151753E-33), /* bf9431c62f01e59d2c1e00f195a0037f */
+-  L(1.64062500000000000950861276373482172E-01), /* 3ffc500000000000008c5285fba85000 */
+- L(-4.80566184447001164583855800470217373E-33), /* bf938f3d1fcafd390f22f80e6c19421f */
+-  L(1.67968749999999989878071706155265999E-01), /* 3ffc57fffffffffffa2a445c548c5000 */
+- L(-4.42154428718618459799673088733365064E-32), /* bf96cb28cf1c1b28006d53ffe633b22a */
+-  L(1.71874999999999999459734108403218175E-01), /* 3ffc5fffffffffffffb04554e9dd4000 */
+- L(-3.29736288190321377985697972236270628E-32), /* bf96566af0ebc852e84be12859b24a31 */
+-  L(1.75781249999999997987525759778901845E-01), /* 3ffc67fffffffffffed702df6ffff000 */
+- L(-1.28800728638468399687523924685844352E-32), /* bf950b8236b88ca0c1b739dc91a7e3fc */
+-  L(1.79687500000000004929565820437175783E-01), /* 3ffc70000000000002d779bb32d2e000 */
+-  L(1.60624461317978482424582320675174225E-32), /* 3f954d9a9cc0c963fd081f3dc922d04e */
+-  L(1.83593750000000016873727045739708856E-01), /* 3ffc78000000000009ba1f6263c9a000 */
+- L(-3.83390389582056606880506003118452558E-32), /* bf968e22a5d826f77f19ee788474df22 */
+-  L(1.87500000000000013443068740761666872E-01), /* 3ffc80000000000007bfd8c72a1bf000 */
+- L(-2.74141662712926256150154726565203091E-32), /* bf961caf5ac59c7f941f928e324c2cc1 */
+-  L(1.91406249999999981494101786848611970E-01), /* 3ffc87fffffffffff55502eeae001000 */
+-  L(3.68992437075565165346469517256118001E-32), /* 3f967f2f03f9096793372a27b92ad79d */
+-  L(1.95312499999999989069921848800501648E-01), /* 3ffc8ffffffffffff9b3015280394000 */
+-  L(3.69712249337856518452988332367785220E-32), /* 3f967fee5fdb5bd501ff93516999faa0 */
+-  L(1.99218750000000021148042946919300804E-01), /* 3ffc9800000000000c30e67939095000 */
+-  L(2.50142536781142175091322844848566649E-32), /* 3f9603c34ae58e10b300b07137ee618a */
+-  L(2.03124999999999977732559198825437141E-01), /* 3ffc9ffffffffffff329e7df079e4000 */
+- L(-2.41951877287895024779300892731537816E-32), /* bf95f683aefe6965f080df8f59dd34a1 */
+-  L(2.07031249999999996744030653771913124E-01), /* 3ffca7fffffffffffe1f80f4b73ca000 */
+- L(-1.94346475904454000031592792989765585E-32), /* bf9593a44f87870a3d100d498501ecc7 */
+-  L(2.10937500000000000251399259834392298E-01), /* 3ffcb000000000000025199873310000 */
+- L(-1.33528748788094249098998693871759411E-33), /* bf91bbb9b25c813668d6103d08acac35 */
+-  L(2.14843749999999993936323609611875097E-01), /* 3ffcb7fffffffffffc8128c866236000 */
+-  L(1.14839877977014974625242788556545292E-32), /* 3f94dd06b4655c9b83a1305b240e7a42 */
+-  L(2.18750000000000015181732784749663837E-01), /* 3ffcc0000000000008c06da5fff24000 */
+-  L(1.42689085313142539755499441881408391E-32), /* 3f95285a87dfa7ea7dad5b3be8c669f4 */
+-  L(2.22656249999999992172647770539596569E-01), /* 3ffcc7fffffffffffb7ce2fe531f6000 */
+- L(-3.34421462850496887359128610229650547E-32), /* bf965b487962b5c2d9056ca6ac0c2e5c */
+-  L(2.26562499999999989595607223847082419E-01), /* 3ffccffffffffffffa0095277be5c000 */
+- L(-3.08983588107248752517344356508205569E-32), /* bf9640dded57157f8eded311213bdbcd */
+-  L(2.30468749999999979130462438434567117E-01), /* 3ffcd7fffffffffff3f8332996560000 */
+- L(-3.01407539802851697849105682795217019E-32), /* bf9638ffde35dbdfe1a1ffe45185de5d */
+-  L(2.34375000000000012194252337217891971E-01), /* 3ffce0000000000007078dd402c86000 */
+- L(-8.46879710915628592284714319904522657E-33), /* bf945fc7b29a2ac6c9eff9eb258a510f */
+-  L(2.38281249999999982991877076137149870E-01), /* 3ffce7fffffffffff6320b486eece000 */
+- L(-2.93563878880439245627127095245798544E-32), /* bf9630daaa4f40ff05caf29ace2ea7d4 */
+-  L(2.42187499999999981447559841442773990E-01), /* 3ffceffffffffffff54e24a09a8d5000 */
+- L(-4.56766746558806021264215486909850481E-32), /* bf96da556dee11f3113e5a3467b908e6 */
+-  L(2.46093749999999991067720539980207318E-01), /* 3ffcf7fffffffffffad9d405dcb5d000 */
+-  L(2.14033004219908074003010247652128251E-32), /* 3f95bc8776e8f9ae098884aa664cc3df */
+-  L(2.50000000000000016613825838126835953E-01), /* 3ffd00000000000004c9e24c12bb3000 */
+-  L(2.57617532593749185996714235009382870E-32), /* 3f960b867cc01178c0ec68226c6cb47d */
+-  L(2.53906250000000013372004437827044321E-01), /* 3ffd04000000000003daae05b3168000 */
+-  L(7.20177123439204414298152646284640101E-32), /* 3f9775eff59ddad7e7530b83934af87f */
+-  L(2.57812499999999995765234725413886085E-01), /* 3ffd07fffffffffffec7878bad9d5000 */
+-  L(6.51253187532920882777046064603770602E-32), /* 3f975226659ca241402e71c2011583b0 */
+-  L(2.61718750000000007647689994011222248E-01), /* 3ffd0c000000000002344cc793a0f000 */
+-  L(3.02370610028725823590045201871491395E-32), /* 3f9639ffe55fa2fa011674448b4e5b96 */
+-  L(2.65624999999999986893899042596554269E-01), /* 3ffd0ffffffffffffc38f0c0a1e9f000 */
+- L(-2.07683715950724761146070082510569258E-32), /* bf95af579a92e872fef81abfdf06bae8 */
+-  L(2.69531249999999979842788204900639327E-01), /* 3ffd13fffffffffffa30a908d67db000 */
+-  L(8.71465252506557329027658736641075706E-32), /* 3f97c47d99e19830447a42b1c0ffac61 */
+-  L(2.73437500000000006712165837793818271E-01), /* 3ffd18000000000001ef453a58edb000 */
+- L(-6.62704045767568912140550474455810301E-32), /* bf9758187a204dcb06ece46588aeeaba */
+-  L(2.77343749999999994411329302988535617E-01), /* 3ffd1bfffffffffffe63a0fec9c9e000 */
+- L(-4.87273466291944117406493607771338767E-32), /* bf96fa0381b0844a0be46bac2d673f0c */
+-  L(2.81250000000000012677892447379453135E-01), /* 3ffd20000000000003a7769e125d6000 */
+- L(-8.55871796664700790726282049552906783E-32), /* bf97bc64e01332cf7616b0091b8dff2c */
+-  L(2.85156249999999998558643013736363981E-01), /* 3ffd23ffffffffffff95a5894bccf000 */
+- L(-1.33068334720606220176455289635046875E-32), /* bf95145f43290ecf5b7adcb24697bc73 */
+-  L(2.89062500000000008831431235621753924E-01), /* 3ffd280000000000028ba504fac59000 */
+- L(-9.34157398616814623985483776710704237E-32), /* bf97e50ad1115b941fcb5f0c88a428f7 */
+-  L(2.92968750000000019840235286110877063E-01), /* 3ffd2c000000000005b7f372d184f000 */
+-  L(4.99302093775173155906059132992249671E-33), /* 3f939ecdcfb97bad3f8dbec5df5ec67d */
+-  L(2.96875000000000015867911730971630513E-01), /* 3ffd3000000000000492d860c79db000 */
+-  L(7.86107787827057767235127454590866211E-33), /* 3f944689517ee8f16cdb97d6a6938f32 */
+-  L(3.00781250000000015814100002286124758E-01), /* 3ffd340000000000048edfe73a17d000 */
+- L(-1.65419431293024229981937172317171504E-32), /* bf9557900e3efca16c89646b57f68dc0 */
+-  L(3.04687499999999985213157159965287195E-01), /* 3ffd37fffffffffffbbcec6f99b36000 */
+-  L(9.68753602893894024018934325652944198E-32), /* 3f97f70170e5458660c33a7e8d43d049 */
+-  L(3.08593749999999989969324338045156215E-01), /* 3ffd3bfffffffffffd1bdde4d0fb1000 */
+-  L(7.10268609610294706092252562643261106E-32), /* 3f9770cae45cdf615010401a4b37d8d4 */
+-  L(3.12500000000000002971606591018488854E-01), /* 3ffd40000000000000db440fbc06b000 */
+-  L(6.38924218802905979887732294952782964E-32), /* 3f974bbf988bb5622bd8fbaa46e8b811 */
+-  L(3.16406250000000006594921047402056305E-01), /* 3ffd44000000000001e69e8954814000 */
+-  L(3.96079878754651470094149874444850097E-32), /* 3f969b5017b9fa7a1e86975258c73d3d */
+-  L(3.20312500000000006713799366908329147E-01), /* 3ffd48000000000001ef64159c065000 */
+- L(-1.86401314975634286055150437995880517E-32), /* bf958323f0434911794e5fb8bfe136ba */
+-  L(3.24218749999999987061246567584951210E-01), /* 3ffd4bfffffffffffc4549db9b928000 */
+- L(-3.18643523744758601387071062700407431E-32), /* bf964ae5fa7e26c2c3981bed12e14372 */
+-  L(3.28124999999999991782776266707412953E-01), /* 3ffd4ffffffffffffda1ad0840ca8000 */
+- L(-4.46964199751314296839915534813144652E-32), /* bf96d0277729ffd74727150df6d15547 */
+-  L(3.32031250000000000393816557756032682E-01), /* 3ffd540000000000001d0efc04fad000 */
+- L(-9.03246333902065439930373230002688649E-33), /* bf947731a008748cc6dee948839ef7ae */
+-  L(3.35937499999999983810482995064392173E-01), /* 3ffd57fffffffffffb556cab8ae61000 */
+-  L(5.27742727066129518825981597650621794E-32), /* 3f9712050a6ddbf1cabf1b971f4b5d0b */
+-  L(3.39843750000000004310441349760912471E-01), /* 3ffd5c0000000000013e0def5ddc4000 */
+- L(-3.85927263474732591932884416445586106E-32), /* bf9690c51088ef3db9ca000829c450c2 */
+-  L(3.43749999999999990248130003997484364E-01), /* 3ffd5ffffffffffffd3070624a0af000 */
+-  L(9.62005170171527308106468341512327487E-34), /* 3f913fae595cea84432eb01430817fca */
+-  L(3.47656250000000004085726414568625697E-01), /* 3ffd640000000000012d79309e291000 */
+- L(-6.59664093705705297250259434519072507E-32), /* bf97568465eafb0e662e64a5dbfaf35f */
++  0.00000000000000000000000000000000000E+00L, /* 00000000000000000000000000000000 */
++  0.00000000000000000000000000000000000E+00L, /* 00000000000000000000000000000000 */
++  3.90625000000000245479958859972588985E-03L, /* 3ff70000000000002d48769ac9874000 */
++ -6.58439598384342854976169982902779828E-36L, /* bf8a1811b923e6c626b07ef29761482a */
++  7.81250000000001311374391093664996358E-03L, /* 3ff800000000000078f3f3cd89111000 */
++  2.60265650555493781464273319671555602E-33L, /* 3f92b070c3b635b87af426735a71fc87 */
++  1.17187500000000269581156218247101912E-02L, /* 3ff8800000000000f8a50d02fe20d000 */
++  1.00961747974945520631836275894919326E-33L, /* 3f914f80c1a4f8042044fe3b757b030b */
++  1.56249999999999797878275270751825475E-02L, /* 3ff8ffffffffffff45935b69da62e000 */
++  2.03174577741375590087897353146748580E-33L, /* 3f925194e863496e0f6e91cbf6b22e26 */
++  1.95312499999999760319884511789111533E-02L, /* 3ff93fffffffffff917790ff9a8f4000 */
++  4.62788519658803722282100289809515007E-33L, /* 3f9380783ba81295feeb3e4879d7d52d */
++  2.34374999999999822953909016349145918E-02L, /* 3ff97fffffffffffae5a163bd3cd5000 */
++ -3.19499956304699705390404384504876533E-33L, /* bf93096e2037ced8194cf344c692f8d6 */
++  2.73437500000000137220327275871555682E-02L, /* 3ff9c000000000003f481dea5dd51000 */
++ -2.25757776523031994464630107442723424E-33L, /* bf92771abcf988a02b414bf2614e3734 */
++  3.12499999999999790857640618332718621E-02L, /* 3ff9ffffffffffff9f8cd40b51509000 */
++ -4.22479470489989916319395454536511458E-33L, /* bf935efb7245612f371deca17cb7b30c */
++  3.51562499999999840753382405747597346E-02L, /* 3ffa1fffffffffffdb47bd275f722000 */
++  1.08459658374118041980976756063083500E-34L, /* 3f8e2055d18b7117c9db1c318b1e889b */
++  3.90624999999999989384433621470426757E-02L, /* 3ffa3ffffffffffffd8d5e18b042e000 */
++ -7.41674226146122000759491297811091830E-33L, /* bf94341454e48029e5b0205d91baffdc */
++  4.29687500000000107505739500500200462E-02L, /* 3ffa60000000000018ca04cd9085c000 */
++ -4.74689012756713017494437969420919847E-34L, /* bf903b7c268103c6f7fbaaa24142e287 */
++  4.68749999999999978700749928325717352E-02L, /* 3ffa7ffffffffffffb16b6d5479e3000 */
++ -1.06208165308448830117773486334902917E-32L, /* bf94b92be4b3b5b5a596a0a5187cc955 */
++  5.07812499999999815072625435955786253E-02L, /* 3ffa9fffffffffffd55bd086d5cbc000 */
++ -9.37038897148383660401929567549111394E-33L, /* bf94853b111b0175b491c80d00419416 */
++  5.46874999999999809511553152189867394E-02L, /* 3ffabfffffffffffd4138bfa74a61000 */
++  1.06642963074562437340498606682822123E-32L, /* 3f94bafa3fe991b39255d563dfa05d89 */
++  5.85937500000000184331996330905145551E-02L, /* 3ffae000000000002a810a5f2f8bf000 */
++ -1.76639977694797200820296641773791945E-34L, /* bf8ed596f07ce4408f1705c8ec16864c */
++  6.25000000000000021544696744852045001E-02L, /* 3ffb000000000000027be32045e2b000 */
++  1.68616371995798354366633034788947149E-32L, /* 3f955e33d7440794d8a1b25233d086ab */
++  6.64062499999999965563110718495802889E-02L, /* 3ffb0ffffffffffffc079a38a3fed000 */
++ -1.82463217667830160048872113565316215E-32L, /* bf957af6163bcdb97cefab44a942482a */
++  7.03124999999999759989183341261898222E-02L, /* 3ffb1fffffffffffe454218acea05000 */
++ -1.07843770101525495515646940862541503E-32L, /* bf94bff72aada26d94e76e71c07e0580 */
++  7.42187499999999898968873730710101412E-02L, /* 3ffb2ffffffffffff45a166496dc1000 */
++  1.28629441689592874462780757154138223E-32L, /* 3f950b2724597b8b93ce1e9d1cf4d035 */
++  7.81249999999999957198938523510804668E-02L, /* 3ffb3ffffffffffffb10bc52adbc5000 */
++  1.13297573459968118467100063135856856E-33L, /* 3f91787eea895b3c245899cf34ad0abd */
++  8.20312500000000199911640621145851159E-02L, /* 3ffb500000000000170c59a661a89000 */
++ -1.51161335208135146756554123073528707E-32L, /* bf9539f326c5ca84e7db5401566f3775 */
++  8.59375000000000134175373433347670743E-02L, /* 3ffb6000000000000f78287547af0000 */
++  1.09763629458404270323909815379924900E-32L, /* 3f94c7f0b61b6e3e27d44b9f5bbc7e9d */
++  8.98437500000000036533922600308306335E-02L, /* 3ffb70000000000004364a83b7a14000 */
++  3.11459653680110433194288029777718358E-33L, /* 3f9302c0248136d65cebeab69488d949 */
++  9.37500000000000184977946245216914691E-02L, /* 3ffb800000000000155395d870b17000 */
++ -4.66656154468277949130395786965043927E-33L, /* bf9383aec9b993b6db492b1ede786d8a */
++  9.76562500000000237839723100419376084E-02L, /* 3ffb9000000000001b6bca237f6c4000 */
++ -1.03028043424658760249140747856831301E-32L, /* bf94abf6352e3d2bb398e47919a343fb */
++  1.01562500000000012345545575236836572E-01L, /* 3ffba000000000000e3bc30cd9a1f000 */
++  2.15755372310795701322789783729456319E-32L, /* 3f95c01b3b819edd9d07548fafd61550 */
++  1.05468749999999976493840484471911438E-01L, /* 3ffbafffffffffffe4e634cd77985000 */
++  1.78771847038773333029677216592309083E-32L, /* 3f95734b6ae650f33dd43c49a1df9fc0 */
++  1.09375000000000002267015055992785402E-01L, /* 3ffbc00000000000029d1ad08de7b000 */
++  6.23263106693943817730045115112427717E-33L, /* 3f9402e4b39ce2198a45e1d045868cd6 */
++  1.13281250000000022354208618429577398E-01L, /* 3ffbd0000000000019c5cc3f9d2b5000 */
++  5.40514416644786448581426756221178868E-33L, /* 3f93c10ab4021472c662f69435de9269 */
++  1.17187500000000013252367133076817603E-01L, /* 3ffbe000000000000f47688cc561b000 */
++ -7.12412585457324989451327215568641325E-33L, /* bf9427ecb343a8d1758990565fcfbf45 */
++  1.21093750000000020759863992944300792E-01L, /* 3ffbf0000000000017ef3af97bf04000 */
++  6.26591408357572503875647872077266444E-33L, /* 3f940446a09a2da771b45fc075514d12 */
++  1.25000000000000004739659392396765618E-01L, /* 3ffc00000000000002bb7344ecd89000 */
++ -1.55611398459729463981000080101758830E-32L, /* bf95433135febefa9e6aa4db39e263d2 */
++  1.28906249999999982360888081057894783E-01L, /* 3ffc07fffffffffff5d4ed3154361000 */
++ -1.77531518652835570781208599686606474E-32L, /* bf9570b7f225ea076f97f418d11359c1 */
++  1.32812500000000010568583998727400436E-01L, /* 3ffc1000000000000617a5d09526a000 */
++  2.12104021624990594668286391598300893E-32L, /* 3f95b885d767a1048d93055927a27adc */
++  1.36718749999999998434125157367005292E-01L, /* 3ffc17ffffffffffff18eaebc7970000 */
++  2.50454798592543203967309921276955297E-32L, /* 3f9604164e5598528a76faff26cd1c97 */
++  1.40625000000000015550032422969330356E-01L, /* 3ffc20000000000008f6c79d8928c000 */
++  7.80972982879849783680252962992639832E-33L, /* 3f9444674acf2b3225c7647e0d95edf3 */
++  1.44531250000000012402535562111122522E-01L, /* 3ffc28000000000007264a8bc1ff1000 */
++  2.79662468716455159585514763921671876E-32L, /* 3f96226b095bd78aa650faf95a221993 */
++  1.48437500000000007761020440087419948E-01L, /* 3ffc3000000000000479530ff8fe3000 */
++  2.15518492972728435680556239996258527E-32L, /* 3f95bf9d49295e73a957906a029768cb */
++  1.52343750000000001733189947520484032E-01L, /* 3ffc38000000000000ffc6109f71f000 */
++  8.34032236093545825619420380704500188E-33L, /* 3f945a71851226a1d0ce5e656693153e */
++  1.56249999999999988073295321246958484E-01L, /* 3ffc3ffffffffffff91fedd62ae0f000 */
++  2.44119337150624789345260194989620908E-32L, /* 3f95fb041a57bc1c1280680ac1620bea */
++  1.60156250000000002076894210913572460E-01L, /* 3ffc48000000000001327ed84a199000 */
++ -7.36124501128859978061216696286151753E-33L, /* bf9431c62f01e59d2c1e00f195a0037f */
++  1.64062500000000000950861276373482172E-01L, /* 3ffc500000000000008c5285fba85000 */
++ -4.80566184447001164583855800470217373E-33L, /* bf938f3d1fcafd390f22f80e6c19421f */
++  1.67968749999999989878071706155265999E-01L, /* 3ffc57fffffffffffa2a445c548c5000 */
++ -4.42154428718618459799673088733365064E-32L, /* bf96cb28cf1c1b28006d53ffe633b22a */
++  1.71874999999999999459734108403218175E-01L, /* 3ffc5fffffffffffffb04554e9dd4000 */
++ -3.29736288190321377985697972236270628E-32L, /* bf96566af0ebc852e84be12859b24a31 */
++  1.75781249999999997987525759778901845E-01L, /* 3ffc67fffffffffffed702df6ffff000 */
++ -1.28800728638468399687523924685844352E-32L, /* bf950b8236b88ca0c1b739dc91a7e3fc */
++  1.79687500000000004929565820437175783E-01L, /* 3ffc70000000000002d779bb32d2e000 */
++  1.60624461317978482424582320675174225E-32L, /* 3f954d9a9cc0c963fd081f3dc922d04e */
++  1.83593750000000016873727045739708856E-01L, /* 3ffc78000000000009ba1f6263c9a000 */
++ -3.83390389582056606880506003118452558E-32L, /* bf968e22a5d826f77f19ee788474df22 */
++  1.87500000000000013443068740761666872E-01L, /* 3ffc80000000000007bfd8c72a1bf000 */
++ -2.74141662712926256150154726565203091E-32L, /* bf961caf5ac59c7f941f928e324c2cc1 */
++  1.91406249999999981494101786848611970E-01L, /* 3ffc87fffffffffff55502eeae001000 */
++  3.68992437075565165346469517256118001E-32L, /* 3f967f2f03f9096793372a27b92ad79d */
++  1.95312499999999989069921848800501648E-01L, /* 3ffc8ffffffffffff9b3015280394000 */
++  3.69712249337856518452988332367785220E-32L, /* 3f967fee5fdb5bd501ff93516999faa0 */
++  1.99218750000000021148042946919300804E-01L, /* 3ffc9800000000000c30e67939095000 */
++  2.50142536781142175091322844848566649E-32L, /* 3f9603c34ae58e10b300b07137ee618a */
++  2.03124999999999977732559198825437141E-01L, /* 3ffc9ffffffffffff329e7df079e4000 */
++ -2.41951877287895024779300892731537816E-32L, /* bf95f683aefe6965f080df8f59dd34a1 */
++  2.07031249999999996744030653771913124E-01L, /* 3ffca7fffffffffffe1f80f4b73ca000 */
++ -1.94346475904454000031592792989765585E-32L, /* bf9593a44f87870a3d100d498501ecc7 */
++  2.10937500000000000251399259834392298E-01L, /* 3ffcb000000000000025199873310000 */
++ -1.33528748788094249098998693871759411E-33L, /* bf91bbb9b25c813668d6103d08acac35 */
++  2.14843749999999993936323609611875097E-01L, /* 3ffcb7fffffffffffc8128c866236000 */
++  1.14839877977014974625242788556545292E-32L, /* 3f94dd06b4655c9b83a1305b240e7a42 */
++  2.18750000000000015181732784749663837E-01L, /* 3ffcc0000000000008c06da5fff24000 */
++  1.42689085313142539755499441881408391E-32L, /* 3f95285a87dfa7ea7dad5b3be8c669f4 */
++  2.22656249999999992172647770539596569E-01L, /* 3ffcc7fffffffffffb7ce2fe531f6000 */
++ -3.34421462850496887359128610229650547E-32L, /* bf965b487962b5c2d9056ca6ac0c2e5c */
++  2.26562499999999989595607223847082419E-01L, /* 3ffccffffffffffffa0095277be5c000 */
++ -3.08983588107248752517344356508205569E-32L, /* bf9640dded57157f8eded311213bdbcd */
++  2.30468749999999979130462438434567117E-01L, /* 3ffcd7fffffffffff3f8332996560000 */
++ -3.01407539802851697849105682795217019E-32L, /* bf9638ffde35dbdfe1a1ffe45185de5d */
++  2.34375000000000012194252337217891971E-01L, /* 3ffce0000000000007078dd402c86000 */
++ -8.46879710915628592284714319904522657E-33L, /* bf945fc7b29a2ac6c9eff9eb258a510f */
++  2.38281249999999982991877076137149870E-01L, /* 3ffce7fffffffffff6320b486eece000 */
++ -2.93563878880439245627127095245798544E-32L, /* bf9630daaa4f40ff05caf29ace2ea7d4 */
++  2.42187499999999981447559841442773990E-01L, /* 3ffceffffffffffff54e24a09a8d5000 */
++ -4.56766746558806021264215486909850481E-32L, /* bf96da556dee11f3113e5a3467b908e6 */
++  2.46093749999999991067720539980207318E-01L, /* 3ffcf7fffffffffffad9d405dcb5d000 */
++  2.14033004219908074003010247652128251E-32L, /* 3f95bc8776e8f9ae098884aa664cc3df */
++  2.50000000000000016613825838126835953E-01L, /* 3ffd00000000000004c9e24c12bb3000 */
++  2.57617532593749185996714235009382870E-32L, /* 3f960b867cc01178c0ec68226c6cb47d */
++  2.53906250000000013372004437827044321E-01L, /* 3ffd04000000000003daae05b3168000 */
++  7.20177123439204414298152646284640101E-32L, /* 3f9775eff59ddad7e7530b83934af87f */
++  2.57812499999999995765234725413886085E-01L, /* 3ffd07fffffffffffec7878bad9d5000 */
++  6.51253187532920882777046064603770602E-32L, /* 3f975226659ca241402e71c2011583b0 */
++  2.61718750000000007647689994011222248E-01L, /* 3ffd0c000000000002344cc793a0f000 */
++  3.02370610028725823590045201871491395E-32L, /* 3f9639ffe55fa2fa011674448b4e5b96 */
++  2.65624999999999986893899042596554269E-01L, /* 3ffd0ffffffffffffc38f0c0a1e9f000 */
++ -2.07683715950724761146070082510569258E-32L, /* bf95af579a92e872fef81abfdf06bae8 */
++  2.69531249999999979842788204900639327E-01L, /* 3ffd13fffffffffffa30a908d67db000 */
++  8.71465252506557329027658736641075706E-32L, /* 3f97c47d99e19830447a42b1c0ffac61 */
++  2.73437500000000006712165837793818271E-01L, /* 3ffd18000000000001ef453a58edb000 */
++ -6.62704045767568912140550474455810301E-32L, /* bf9758187a204dcb06ece46588aeeaba */
++  2.77343749999999994411329302988535617E-01L, /* 3ffd1bfffffffffffe63a0fec9c9e000 */
++ -4.87273466291944117406493607771338767E-32L, /* bf96fa0381b0844a0be46bac2d673f0c */
++  2.81250000000000012677892447379453135E-01L, /* 3ffd20000000000003a7769e125d6000 */
++ -8.55871796664700790726282049552906783E-32L, /* bf97bc64e01332cf7616b0091b8dff2c */
++  2.85156249999999998558643013736363981E-01L, /* 3ffd23ffffffffffff95a5894bccf000 */
++ -1.33068334720606220176455289635046875E-32L, /* bf95145f43290ecf5b7adcb24697bc73 */
++  2.89062500000000008831431235621753924E-01L, /* 3ffd280000000000028ba504fac59000 */
++ -9.34157398616814623985483776710704237E-32L, /* bf97e50ad1115b941fcb5f0c88a428f7 */
++  2.92968750000000019840235286110877063E-01L, /* 3ffd2c000000000005b7f372d184f000 */
++  4.99302093775173155906059132992249671E-33L, /* 3f939ecdcfb97bad3f8dbec5df5ec67d */
++  2.96875000000000015867911730971630513E-01L, /* 3ffd3000000000000492d860c79db000 */
++  7.86107787827057767235127454590866211E-33L, /* 3f944689517ee8f16cdb97d6a6938f32 */
++  3.00781250000000015814100002286124758E-01L, /* 3ffd340000000000048edfe73a17d000 */
++ -1.65419431293024229981937172317171504E-32L, /* bf9557900e3efca16c89646b57f68dc0 */
++  3.04687499999999985213157159965287195E-01L, /* 3ffd37fffffffffffbbcec6f99b36000 */
++  9.68753602893894024018934325652944198E-32L, /* 3f97f70170e5458660c33a7e8d43d049 */
++  3.08593749999999989969324338045156215E-01L, /* 3ffd3bfffffffffffd1bdde4d0fb1000 */
++  7.10268609610294706092252562643261106E-32L, /* 3f9770cae45cdf615010401a4b37d8d4 */
++  3.12500000000000002971606591018488854E-01L, /* 3ffd40000000000000db440fbc06b000 */
++  6.38924218802905979887732294952782964E-32L, /* 3f974bbf988bb5622bd8fbaa46e8b811 */
++  3.16406250000000006594921047402056305E-01L, /* 3ffd44000000000001e69e8954814000 */
++  3.96079878754651470094149874444850097E-32L, /* 3f969b5017b9fa7a1e86975258c73d3d */
++  3.20312500000000006713799366908329147E-01L, /* 3ffd48000000000001ef64159c065000 */
++ -1.86401314975634286055150437995880517E-32L, /* bf958323f0434911794e5fb8bfe136ba */
++  3.24218749999999987061246567584951210E-01L, /* 3ffd4bfffffffffffc4549db9b928000 */
++ -3.18643523744758601387071062700407431E-32L, /* bf964ae5fa7e26c2c3981bed12e14372 */
++  3.28124999999999991782776266707412953E-01L, /* 3ffd4ffffffffffffda1ad0840ca8000 */
++ -4.46964199751314296839915534813144652E-32L, /* bf96d0277729ffd74727150df6d15547 */
++  3.32031250000000000393816557756032682E-01L, /* 3ffd540000000000001d0efc04fad000 */
++ -9.03246333902065439930373230002688649E-33L, /* bf947731a008748cc6dee948839ef7ae */
++  3.35937499999999983810482995064392173E-01L, /* 3ffd57fffffffffffb556cab8ae61000 */
++  5.27742727066129518825981597650621794E-32L, /* 3f9712050a6ddbf1cabf1b971f4b5d0b */
++  3.39843750000000004310441349760912471E-01L, /* 3ffd5c0000000000013e0def5ddc4000 */
++ -3.85927263474732591932884416445586106E-32L, /* bf9690c51088ef3db9ca000829c450c2 */
++  3.43749999999999990248130003997484364E-01L, /* 3ffd5ffffffffffffd3070624a0af000 */
++  9.62005170171527308106468341512327487E-34L, /* 3f913fae595cea84432eb01430817fca */
++  3.47656250000000004085726414568625697E-01L, /* 3ffd640000000000012d79309e291000 */
++ -6.59664093705705297250259434519072507E-32L, /* bf97568465eafb0e662e64a5dbfaf35f */
+ 
+- L(-1.98364257812501251077851763965418372E-03), /* bff6040000000001cd90f658cf0b1000 */
+- L(-3.71984513103117734260309047540278737E-34), /* bf8fee73c54483194782aac4a6154d11 */
+- L(-1.95312500000000378520649630233891879E-03), /* bff60000000000008ba643bb5e2e8000 */
+- L(-1.12194202736719050440745599339855038E-34), /* bf8e2a436aeff7bc529873354f47a3f5 */
+- L(-1.92260742187499397430259771221991482E-03), /* bff5f7fffffffffe4361cb51170da000 */
+- L(-2.30068299876822157331268484824540848E-34), /* bf8f31d02f85cfe8c0cc02276ce0f437 */
+- L(-1.89208984375001137424603270262074989E-03), /* bff5f0000000000347456ed490c23000 */
+- L(-1.15012507244426243338260435466985403E-34), /* bf8e31c174d5677a937a34ad8d2a70b4 */
+- L(-1.86157226562500172319250342061336738E-03), /* bff5e800000000007f262fa3617b4000 */
+- L(-3.12438344643346437509767736937785561E-34), /* bf8f9f4d426a2457c273d34ef7d9bde9 */
+- L(-1.83105468749999505256246872355430379E-03), /* bff5dffffffffffe92f18c1c2b6fa000 */
+- L(-5.91130415288336591179087455220308942E-35), /* bf8d3a4c80b42dc036bae446c9807f78 */
+- L(-1.80053710937499445182387245573120522E-03), /* bff5d7fffffffffe669dea82b4a4c000 */
+- L(-1.92396289352411531324908916321392100E-34), /* bf8eff7a2123fb573ba9778550d669bd */
+- L(-1.77001953125000387737631542516323906E-03), /* bff5d000000000011e19915c3ddb7000 */
+-  L(7.91101758977203355387806553469731354E-36), /* 3f8a507f5a70faaccf469e3461873dea */
+- L(-1.73950195312500034854670281415554486E-03), /* bff5c8000000000019b7dc6ef97bd000 */
+-  L(1.55906551582436824067407021178835755E-34), /* 3f8e9e7880333e34955aebcde3cfb053 */
+- L(-1.70898437499998955782591472611429852E-03), /* bff5bffffffffffcfd80e88aa6b96000 */
+-  L(8.22951661962611381718215899498500357E-35), /* 3f8db58e6031a779b59f6ece191de7cc */
+- L(-1.67846679687500586652037711131708544E-03), /* bff5b80000000001b0df6fd21c133000 */
+- L(-8.96642618848426299713145894522897419E-35), /* bf8ddcbcab46d531801bfae4121f2f8a */
+- L(-1.64794921875000109499161354039904782E-03), /* bff5b0000000000050cbce8915575000 */
+- L(-2.88077905394253859590587789680486639E-34), /* bf8f7eebd4dd860ef73b674d5e707959 */
+- L(-1.61743164062501133830507079150388351E-03), /* bff5a80000000003449e8700c3e82000 */
+- L(-3.68271725851639066312899986829350273E-34), /* bf8fe9845fe20a5fe74059e0cae185d6 */
+- L(-1.58691406249999015546015764131101956E-03), /* bff59ffffffffffd2999e668cdd28000 */
+-  L(8.48197657099957029953716507898788812E-35), /* 3f8dc2faaebb97392e451b07b28c4b12 */
+- L(-1.55639648437500317366570219290722587E-03), /* bff5980000000000ea2cd9a40d256000 */
+- L(-3.45156704719737676412949957712570373E-36), /* bf8925a079505516c8e317ac1ff53255 */
+- L(-1.52587890625000568759013197767046039E-03), /* bff5900000000001a3ab8a3f6b698000 */
+- L(-1.01902948542497496574967177677556729E-34), /* bf8e0ee78d94d9b5ad3d63ae35c9b554 */
+- L(-1.49536132812500945889014955936485340E-03), /* bff5880000000002b9f1621b57743000 */
+- L(-3.32264697086631598830366079048117140E-34), /* bf8fb9a7d14c32289204fbb0c9eb20e0 */
+- L(-1.46484374999999931883259902869504725E-03), /* bff57fffffffffffcdbd1c90e1b4a000 */
+- L(-1.76487524793892929381101031660811433E-34), /* bf8ed52f2f724bc1ae870b18356337b4 */
+- L(-1.43432617187498876325946983333888768E-03), /* bff577fffffffffcc2dff8faa5570000 */
+- L(-3.54550084538495708816233114576143814E-34), /* bf8fd74724576915868c1e8ce9f430f1 */
+- L(-1.40380859374999215367421282192718062E-03), /* bff56ffffffffffdbd0b18aac65ed000 */
+- L(-1.90585907028351204486765167064669639E-34), /* bf8efaaa0c0e23e50c11b2120348054f */
+- L(-1.37329101562499692341771212945644892E-03), /* bff567ffffffffff1cfd00f1b0577000 */
+- L(-3.59631150411372589637918252836880320E-34), /* bf8fde08239ac74942a46298ea4fb715 */
+- L(-1.34277343749999137467356674296739172E-03), /* bff55ffffffffffd839030b05d53d000 */
+- L(-1.49571076125940368185068762485268117E-35), /* bf8b3e1a3d5c684b27a9f835b1d8d3c9 */
+- L(-1.31225585937499247038404301859788734E-03), /* bff557fffffffffdd469936e691e3000 */
+-  L(3.10375845385355395586146533282311300E-34), /* 3f8f9c8f6d63b7a4145716ffd92491fb */
+- L(-1.28173828124999024755581675764821898E-03), /* bff54ffffffffffd306589b0ab21d000 */
+- L(-1.98541096105909793397376077900810019E-34), /* bf8f07e808bbb1e35106c294ffbb9687 */
+- L(-1.25122070312500340204619591143332523E-03), /* bff5480000000000fb06d5f16ad2c000 */
+-  L(3.62884195935761446237911443317457521E-34), /* 3f8fe25b17d623178a386a6fa6c5afb2 */
+- L(-1.22070312499999591578388993012071279E-03), /* bff53ffffffffffed2a356c440074000 */
+- L(-2.96756662615653130862526710937493307E-35), /* bf8c3b90d8ff2a991e5bd16718fb0645 */
+- L(-1.19018554687498821966212632349422735E-03), /* bff537fffffffffc9ac3b585dda89000 */
+-  L(1.44659971891167323357060028901142644E-34), /* 3f8e809279ab249edf1dad9fe13fb0bf */
+- L(-1.15966796875000160938908064907298384E-03), /* bff530000000000076c0800db9639000 */
+-  L(2.50088010538742402346270685365928513E-34), /* 3f8f4c6c8a483b60201d30c1a83c3cb7 */
+- L(-1.12915039062500267151512523291939657E-03), /* bff5280000000000c51f7e7315137000 */
+-  L(7.56402096465615210500092443924888831E-35), /* 3f8d922c1e485d99aea2668ed32b55a6 */
+- L(-1.09863281249998665006360103291051571E-03), /* bff51ffffffffffc26f2d4c9ce2ba000 */
+-  L(1.43982174467233642713619821353592061E-34), /* 3f8e7ec530b3d92b6303bec1c81214d1 */
+- L(-1.06811523437500522742248711752028025E-03), /* bff518000000000181b7380f10446000 */
+-  L(5.41265133745862349181293024531133174E-35), /* 3f8d1fc9313d018b30e790e06b6be723 */
+- L(-1.03759765624999980942114138999770552E-03), /* bff50ffffffffffff1f01130490e1000 */
+-  L(1.21525139612685854366189534669623436E-34), /* 3f8e4311b96b6fcde412caf3f0d86fb9 */
+- L(-1.00708007812499602697537601515759439E-03), /* bff507fffffffffedad7afcce7051000 */
+-  L(1.00020246351201558505328236381833392E-34), /* 3f8e09e640992512b1300744a7e984ed */
+- L(-9.76562499999992592487302113340463694E-04), /* bff4fffffffffffbbad8151f8adf6000 */
+- L(-1.64984406575162932060422892046851002E-34), /* bf8eb69a919986e8054b86fc34300f24 */
+- L(-9.46044921874989085824996924138179594E-04), /* bff4effffffffff9b55a204fd9792000 */
+- L(-9.29539174108308550334255350011347171E-35), /* bf8dee3a50ed896b4656fa577a1df3d7 */
+- L(-9.15527343750013735214860599791540029E-04), /* bff4e00000000007eaf5bf103f82d000 */
+-  L(3.07557018309280519949818825519490586E-35), /* 3f8c470cfbef77d32c74cb8042f6ee81 */
+- L(-8.85009765625012292294986105781516428E-04), /* bff4d000000000071605c65403b97000 */
+-  L(4.77499983783821950338363358545463558E-35), /* 3f8cfbc3dc18884c4c4f9e07d90d7bd3 */
+- L(-8.54492187499986941239470706817188192E-04), /* bff4bffffffffff878ddf9cab264a000 */
+- L(-1.60128240346239526958630011447901568E-34), /* bf8ea9b1a21e19e2d5bd84b0fbffcf95 */
+- L(-8.23974609374996290174598690241743810E-04), /* bff4affffffffffddc86c249ebe06000 */
+-  L(1.61677540391961912631535763471935882E-34), /* 3f8eadd00841366b0dc2bc262c2c8c36 */
+- L(-7.93457031249988696952538334288757473E-04), /* bff49ffffffffff97bf6f0aa85a5f000 */
+-  L(1.22318577008381887076634753347515709E-34), /* 3f8e452db5b5d250878f71040da06d14 */
+- L(-7.62939453124996723316499040007097041E-04), /* bff48ffffffffffe1c7265b431108000 */
+- L(-1.03845161748762410745671891558398468E-34), /* bf8e14115ad884c96d1a820c73647220 */
+- L(-7.32421874999998242520117923997325794E-04), /* bff47ffffffffffefca4498b7aa8a000 */
+-  L(5.64005211953031009549514026639438083E-35), /* 3f8d2be06950f68f1a6d8ff829a6928e */
+- L(-7.01904296874999772890934814265622012E-04), /* bff46fffffffffffde7c0fe5d8041000 */
+-  L(5.90245467325173644235991233229525762E-35), /* 3f8d39d40cc49002189243c194b1db0e */
+- L(-6.71386718750008699269643939210658742E-04), /* bff460000000000503c91d798b60c000 */
+- L(-5.20515801723324452151498579012322191E-35), /* bf8d14c0f08a6a9285b32b8bda003eb5 */
+- L(-6.40869140625005499535275057463709988E-04), /* bff45000000000032b969184e9751000 */
+- L(-6.69469163285461870099846471658294534E-35), /* bf8d63f36bab7b24d936c9380e3d3fa6 */
+- L(-6.10351562499999293780097329596079841E-04), /* bff43fffffffffff97c7c433e35ed000 */
+- L(-1.16941808547394177991845382085515086E-34), /* bf8e36e27886f10b234a7dd8fc588bf0 */
+- L(-5.79833984375000068291972326409994795E-04), /* bff43000000000000a13ff6dcf2bf000 */
+-  L(1.17885044988246219185041488459766001E-34), /* 3f8e3964677e001a00412aab52790842 */
+- L(-5.49316406249990904622170867910987793E-04), /* bff41ffffffffffac1c25739c716b000 */
+- L(-3.31875702128137033065075734368960972E-35), /* bf8c60e928d8982c3c99aef4f885a121 */
+- L(-5.18798828125011293653756992177727236E-04), /* bff410000000000682a62cff36775000 */
+- L(-5.69971237642088463334239430962628187E-35), /* bf8d2f0c76f8757d61cd1abc7ea7d066 */
+- L(-4.88281249999990512232251384917893121E-04), /* bff3fffffffffff50fb48992320df000 */
+-  L(1.02144616714408655325510171265051108E-35), /* 3f8ab279a3626612710b9b3ac71734ac */
+- L(-4.57763671874997554564967307956493434E-04), /* bff3dffffffffffd2e3c272e3cca9000 */
+- L(-8.25484058867957231164162481843653503E-35), /* bf8db6e71158e7bf93e2e683f07aa841 */
+- L(-4.27246093749991203999790346349633286E-04), /* bff3bffffffffff5dbe103cba0eb2000 */
+- L(-3.51191203319375193921924105905691755E-35), /* bf8c757356d0f3dd7fbefc0dd419ab50 */
+- L(-3.96728515624986649402960638705483281E-04), /* bff39ffffffffff09b996882706ec000 */
+- L(-5.51925962073095883016589497244931171E-36), /* bf89d586d49f22289cfc860bebb99056 */
+- L(-3.66210937499999945095511981300980754E-04), /* bff37fffffffffffefcb88bfc7df6000 */
+- L(-2.11696465278144529364423332249588595E-35), /* bf8bc23a84d28e5496c874ef9833be25 */
+- L(-3.35693359374992480958458008559640163E-04), /* bff35ffffffffff754c548a8798f2000 */
+- L(-8.58941791799705081104736787493668352E-35), /* bf8dc8b1192fb7c3662826d43acb7c68 */
+- L(-3.05175781250009811036303273640122156E-04), /* bff340000000000b4fb4f1aad1c76000 */
+- L(-8.61173897858769926480551302277426632E-35), /* bf8dc9e0eabb1c0b33051011b64769fa */
+- L(-2.74658203124987298321920308390303850E-04), /* bff31ffffffffff15b2056ac252fd000 */
+-  L(3.35152809454778381053519808988046631E-37), /* 3f85c82fb59ff8d7c80d44e635420ab1 */
+- L(-2.44140624999999992770514819575735516E-04), /* bff2fffffffffffffbbb82d6a7636000 */
+-  L(3.54445837111124472730013879165516908E-35), /* 3f8c78e955b01378be647b1c92aa9a77 */
+- L(-2.13623046875012756463165168672749438E-04), /* bff2c0000000001d6a1635fea6bbf000 */
+-  L(1.50050816288650121729916777279129473E-35), /* 3f8b3f1f6f616a61129a58e131cbd31d */
+- L(-1.83105468749991323078784464300306893E-04), /* bff27fffffffffebfe0cbd0c82399000 */
+- L(-9.14919506501448661140572099029756008E-37), /* bf873754bacaa9d9513b6127e791eb47 */
+- L(-1.52587890625013337032336300236461546E-04), /* bff240000000001ec0cb57f2cc995000 */
+-  L(2.84906084373176180870418394956384516E-35), /* 3f8c2ef6d03a7e6ab087c4f099e4de89 */
+- L(-1.22070312499990746786116828458007518E-04), /* bff1ffffffffffd553bbb49f35a34000 */
+-  L(6.71618008964968339584520728412444537E-36), /* 3f8a1dacb99c60071fc9cd2349495bf0 */
+- L(-9.15527343750029275602791047595142231E-05), /* bff180000000000d8040cd6ecde28000 */
+- L(-1.95753652091078750312541716951402172E-35), /* bf8ba0526cfb24d8d59122f1c7a09a14 */
+- L(-6.10351562499913258461494008080572701E-05), /* bff0ffffffffffaffebbb92d7f6a9000 */
+-  L(5.69868489273961111703398456218119973E-36), /* 3f89e4ca5df09ef4a4386dd5b3bf0331 */
+- L(-3.05175781250092882818419203884960853E-05), /* bff0000000000055ab55de88fac1d000 */
+-  L(9.03341100018476837609128961872915953E-36), /* 3f8a803d229fa3a0e834a63abb06662b */
++ -1.98364257812501251077851763965418372E-03L, /* bff6040000000001cd90f658cf0b1000 */
++ -3.71984513103117734260309047540278737E-34L, /* bf8fee73c54483194782aac4a6154d11 */
++ -1.95312500000000378520649630233891879E-03L, /* bff60000000000008ba643bb5e2e8000 */
++ -1.12194202736719050440745599339855038E-34L, /* bf8e2a436aeff7bc529873354f47a3f5 */
++ -1.92260742187499397430259771221991482E-03L, /* bff5f7fffffffffe4361cb51170da000 */
++ -2.30068299876822157331268484824540848E-34L, /* bf8f31d02f85cfe8c0cc02276ce0f437 */
++ -1.89208984375001137424603270262074989E-03L, /* bff5f0000000000347456ed490c23000 */
++ -1.15012507244426243338260435466985403E-34L, /* bf8e31c174d5677a937a34ad8d2a70b4 */
++ -1.86157226562500172319250342061336738E-03L, /* bff5e800000000007f262fa3617b4000 */
++ -3.12438344643346437509767736937785561E-34L, /* bf8f9f4d426a2457c273d34ef7d9bde9 */
++ -1.83105468749999505256246872355430379E-03L, /* bff5dffffffffffe92f18c1c2b6fa000 */
++ -5.91130415288336591179087455220308942E-35L, /* bf8d3a4c80b42dc036bae446c9807f78 */
++ -1.80053710937499445182387245573120522E-03L, /* bff5d7fffffffffe669dea82b4a4c000 */
++ -1.92396289352411531324908916321392100E-34L, /* bf8eff7a2123fb573ba9778550d669bd */
++ -1.77001953125000387737631542516323906E-03L, /* bff5d000000000011e19915c3ddb7000 */
++  7.91101758977203355387806553469731354E-36L, /* 3f8a507f5a70faaccf469e3461873dea */
++ -1.73950195312500034854670281415554486E-03L, /* bff5c8000000000019b7dc6ef97bd000 */
++  1.55906551582436824067407021178835755E-34L, /* 3f8e9e7880333e34955aebcde3cfb053 */
++ -1.70898437499998955782591472611429852E-03L, /* bff5bffffffffffcfd80e88aa6b96000 */
++  8.22951661962611381718215899498500357E-35L, /* 3f8db58e6031a779b59f6ece191de7cc */
++ -1.67846679687500586652037711131708544E-03L, /* bff5b80000000001b0df6fd21c133000 */
++ -8.96642618848426299713145894522897419E-35L, /* bf8ddcbcab46d531801bfae4121f2f8a */
++ -1.64794921875000109499161354039904782E-03L, /* bff5b0000000000050cbce8915575000 */
++ -2.88077905394253859590587789680486639E-34L, /* bf8f7eebd4dd860ef73b674d5e707959 */
++ -1.61743164062501133830507079150388351E-03L, /* bff5a80000000003449e8700c3e82000 */
++ -3.68271725851639066312899986829350273E-34L, /* bf8fe9845fe20a5fe74059e0cae185d6 */
++ -1.58691406249999015546015764131101956E-03L, /* bff59ffffffffffd2999e668cdd28000 */
++  8.48197657099957029953716507898788812E-35L, /* 3f8dc2faaebb97392e451b07b28c4b12 */
++ -1.55639648437500317366570219290722587E-03L, /* bff5980000000000ea2cd9a40d256000 */
++ -3.45156704719737676412949957712570373E-36L, /* bf8925a079505516c8e317ac1ff53255 */
++ -1.52587890625000568759013197767046039E-03L, /* bff5900000000001a3ab8a3f6b698000 */
++ -1.01902948542497496574967177677556729E-34L, /* bf8e0ee78d94d9b5ad3d63ae35c9b554 */
++ -1.49536132812500945889014955936485340E-03L, /* bff5880000000002b9f1621b57743000 */
++ -3.32264697086631598830366079048117140E-34L, /* bf8fb9a7d14c32289204fbb0c9eb20e0 */
++ -1.46484374999999931883259902869504725E-03L, /* bff57fffffffffffcdbd1c90e1b4a000 */
++ -1.76487524793892929381101031660811433E-34L, /* bf8ed52f2f724bc1ae870b18356337b4 */
++ -1.43432617187498876325946983333888768E-03L, /* bff577fffffffffcc2dff8faa5570000 */
++ -3.54550084538495708816233114576143814E-34L, /* bf8fd74724576915868c1e8ce9f430f1 */
++ -1.40380859374999215367421282192718062E-03L, /* bff56ffffffffffdbd0b18aac65ed000 */
++ -1.90585907028351204486765167064669639E-34L, /* bf8efaaa0c0e23e50c11b2120348054f */
++ -1.37329101562499692341771212945644892E-03L, /* bff567ffffffffff1cfd00f1b0577000 */
++ -3.59631150411372589637918252836880320E-34L, /* bf8fde08239ac74942a46298ea4fb715 */
++ -1.34277343749999137467356674296739172E-03L, /* bff55ffffffffffd839030b05d53d000 */
++ -1.49571076125940368185068762485268117E-35L, /* bf8b3e1a3d5c684b27a9f835b1d8d3c9 */
++ -1.31225585937499247038404301859788734E-03L, /* bff557fffffffffdd469936e691e3000 */
++  3.10375845385355395586146533282311300E-34L, /* 3f8f9c8f6d63b7a4145716ffd92491fb */
++ -1.28173828124999024755581675764821898E-03L, /* bff54ffffffffffd306589b0ab21d000 */
++ -1.98541096105909793397376077900810019E-34L, /* bf8f07e808bbb1e35106c294ffbb9687 */
++ -1.25122070312500340204619591143332523E-03L, /* bff5480000000000fb06d5f16ad2c000 */
++  3.62884195935761446237911443317457521E-34L, /* 3f8fe25b17d623178a386a6fa6c5afb2 */
++ -1.22070312499999591578388993012071279E-03L, /* bff53ffffffffffed2a356c440074000 */
++ -2.96756662615653130862526710937493307E-35L, /* bf8c3b90d8ff2a991e5bd16718fb0645 */
++ -1.19018554687498821966212632349422735E-03L, /* bff537fffffffffc9ac3b585dda89000 */
++  1.44659971891167323357060028901142644E-34L, /* 3f8e809279ab249edf1dad9fe13fb0bf */
++ -1.15966796875000160938908064907298384E-03L, /* bff530000000000076c0800db9639000 */
++  2.50088010538742402346270685365928513E-34L, /* 3f8f4c6c8a483b60201d30c1a83c3cb7 */
++ -1.12915039062500267151512523291939657E-03L, /* bff5280000000000c51f7e7315137000 */
++  7.56402096465615210500092443924888831E-35L, /* 3f8d922c1e485d99aea2668ed32b55a6 */
++ -1.09863281249998665006360103291051571E-03L, /* bff51ffffffffffc26f2d4c9ce2ba000 */
++  1.43982174467233642713619821353592061E-34L, /* 3f8e7ec530b3d92b6303bec1c81214d1 */
++ -1.06811523437500522742248711752028025E-03L, /* bff518000000000181b7380f10446000 */
++  5.41265133745862349181293024531133174E-35L, /* 3f8d1fc9313d018b30e790e06b6be723 */
++ -1.03759765624999980942114138999770552E-03L, /* bff50ffffffffffff1f01130490e1000 */
++  1.21525139612685854366189534669623436E-34L, /* 3f8e4311b96b6fcde412caf3f0d86fb9 */
++ -1.00708007812499602697537601515759439E-03L, /* bff507fffffffffedad7afcce7051000 */
++  1.00020246351201558505328236381833392E-34L, /* 3f8e09e640992512b1300744a7e984ed */
++ -9.76562499999992592487302113340463694E-04L, /* bff4fffffffffffbbad8151f8adf6000 */
++ -1.64984406575162932060422892046851002E-34L, /* bf8eb69a919986e8054b86fc34300f24 */
++ -9.46044921874989085824996924138179594E-04L, /* bff4effffffffff9b55a204fd9792000 */
++ -9.29539174108308550334255350011347171E-35L, /* bf8dee3a50ed896b4656fa577a1df3d7 */
++ -9.15527343750013735214860599791540029E-04L, /* bff4e00000000007eaf5bf103f82d000 */
++  3.07557018309280519949818825519490586E-35L, /* 3f8c470cfbef77d32c74cb8042f6ee81 */
++ -8.85009765625012292294986105781516428E-04L, /* bff4d000000000071605c65403b97000 */
++  4.77499983783821950338363358545463558E-35L, /* 3f8cfbc3dc18884c4c4f9e07d90d7bd3 */
++ -8.54492187499986941239470706817188192E-04L, /* bff4bffffffffff878ddf9cab264a000 */
++ -1.60128240346239526958630011447901568E-34L, /* bf8ea9b1a21e19e2d5bd84b0fbffcf95 */
++ -8.23974609374996290174598690241743810E-04L, /* bff4affffffffffddc86c249ebe06000 */
++  1.61677540391961912631535763471935882E-34L, /* 3f8eadd00841366b0dc2bc262c2c8c36 */
++ -7.93457031249988696952538334288757473E-04L, /* bff49ffffffffff97bf6f0aa85a5f000 */
++  1.22318577008381887076634753347515709E-34L, /* 3f8e452db5b5d250878f71040da06d14 */
++ -7.62939453124996723316499040007097041E-04L, /* bff48ffffffffffe1c7265b431108000 */
++ -1.03845161748762410745671891558398468E-34L, /* bf8e14115ad884c96d1a820c73647220 */
++ -7.32421874999998242520117923997325794E-04L, /* bff47ffffffffffefca4498b7aa8a000 */
++  5.64005211953031009549514026639438083E-35L, /* 3f8d2be06950f68f1a6d8ff829a6928e */
++ -7.01904296874999772890934814265622012E-04L, /* bff46fffffffffffde7c0fe5d8041000 */
++  5.90245467325173644235991233229525762E-35L, /* 3f8d39d40cc49002189243c194b1db0e */
++ -6.71386718750008699269643939210658742E-04L, /* bff460000000000503c91d798b60c000 */
++ -5.20515801723324452151498579012322191E-35L, /* bf8d14c0f08a6a9285b32b8bda003eb5 */
++ -6.40869140625005499535275057463709988E-04L, /* bff45000000000032b969184e9751000 */
++ -6.69469163285461870099846471658294534E-35L, /* bf8d63f36bab7b24d936c9380e3d3fa6 */
++ -6.10351562499999293780097329596079841E-04L, /* bff43fffffffffff97c7c433e35ed000 */
++ -1.16941808547394177991845382085515086E-34L, /* bf8e36e27886f10b234a7dd8fc588bf0 */
++ -5.79833984375000068291972326409994795E-04L, /* bff43000000000000a13ff6dcf2bf000 */
++  1.17885044988246219185041488459766001E-34L, /* 3f8e3964677e001a00412aab52790842 */
++ -5.49316406249990904622170867910987793E-04L, /* bff41ffffffffffac1c25739c716b000 */
++ -3.31875702128137033065075734368960972E-35L, /* bf8c60e928d8982c3c99aef4f885a121 */
++ -5.18798828125011293653756992177727236E-04L, /* bff410000000000682a62cff36775000 */
++ -5.69971237642088463334239430962628187E-35L, /* bf8d2f0c76f8757d61cd1abc7ea7d066 */
++ -4.88281249999990512232251384917893121E-04L, /* bff3fffffffffff50fb48992320df000 */
++  1.02144616714408655325510171265051108E-35L, /* 3f8ab279a3626612710b9b3ac71734ac */
++ -4.57763671874997554564967307956493434E-04L, /* bff3dffffffffffd2e3c272e3cca9000 */
++ -8.25484058867957231164162481843653503E-35L, /* bf8db6e71158e7bf93e2e683f07aa841 */
++ -4.27246093749991203999790346349633286E-04L, /* bff3bffffffffff5dbe103cba0eb2000 */
++ -3.51191203319375193921924105905691755E-35L, /* bf8c757356d0f3dd7fbefc0dd419ab50 */
++ -3.96728515624986649402960638705483281E-04L, /* bff39ffffffffff09b996882706ec000 */
++ -5.51925962073095883016589497244931171E-36L, /* bf89d586d49f22289cfc860bebb99056 */
++ -3.66210937499999945095511981300980754E-04L, /* bff37fffffffffffefcb88bfc7df6000 */
++ -2.11696465278144529364423332249588595E-35L, /* bf8bc23a84d28e5496c874ef9833be25 */
++ -3.35693359374992480958458008559640163E-04L, /* bff35ffffffffff754c548a8798f2000 */
++ -8.58941791799705081104736787493668352E-35L, /* bf8dc8b1192fb7c3662826d43acb7c68 */
++ -3.05175781250009811036303273640122156E-04L, /* bff340000000000b4fb4f1aad1c76000 */
++ -8.61173897858769926480551302277426632E-35L, /* bf8dc9e0eabb1c0b33051011b64769fa */
++ -2.74658203124987298321920308390303850E-04L, /* bff31ffffffffff15b2056ac252fd000 */
++  3.35152809454778381053519808988046631E-37L, /* 3f85c82fb59ff8d7c80d44e635420ab1 */
++ -2.44140624999999992770514819575735516E-04L, /* bff2fffffffffffffbbb82d6a7636000 */
++  3.54445837111124472730013879165516908E-35L, /* 3f8c78e955b01378be647b1c92aa9a77 */
++ -2.13623046875012756463165168672749438E-04L, /* bff2c0000000001d6a1635fea6bbf000 */
++  1.50050816288650121729916777279129473E-35L, /* 3f8b3f1f6f616a61129a58e131cbd31d */
++ -1.83105468749991323078784464300306893E-04L, /* bff27fffffffffebfe0cbd0c82399000 */
++ -9.14919506501448661140572099029756008E-37L, /* bf873754bacaa9d9513b6127e791eb47 */
++ -1.52587890625013337032336300236461546E-04L, /* bff240000000001ec0cb57f2cc995000 */
++  2.84906084373176180870418394956384516E-35L, /* 3f8c2ef6d03a7e6ab087c4f099e4de89 */
++ -1.22070312499990746786116828458007518E-04L, /* bff1ffffffffffd553bbb49f35a34000 */
++  6.71618008964968339584520728412444537E-36L, /* 3f8a1dacb99c60071fc9cd2349495bf0 */
++ -9.15527343750029275602791047595142231E-05L, /* bff180000000000d8040cd6ecde28000 */
++ -1.95753652091078750312541716951402172E-35L, /* bf8ba0526cfb24d8d59122f1c7a09a14 */
++ -6.10351562499913258461494008080572701E-05L, /* bff0ffffffffffaffebbb92d7f6a9000 */
++  5.69868489273961111703398456218119973E-36L, /* 3f89e4ca5df09ef4a4386dd5b3bf0331 */
++ -3.05175781250092882818419203884960853E-05L, /* bff0000000000055ab55de88fac1d000 */
++  9.03341100018476837609128961872915953E-36L, /* 3f8a803d229fa3a0e834a63abb06662b */
+ #define T_EXPL_ARG2 (2*T_EXPL_ARG1 + 2 + 2*65)
+-  L(0.00000000000000000000000000000000000E+00), /* 00000000000000000000000000000000 */
+-  L(0.00000000000000000000000000000000000E+00), /* 00000000000000000000000000000000 */
+-  L(3.05175781249814607084128277672749162E-05), /* 3feffffffffffeaa02abb9102f499000 */
+-  L(1.00271855391179733380665816525889949E-36), /* 3f8755351afa042ac3f58114824d4c10 */
+-  L(6.10351562500179243748093427073421439E-05), /* 3ff1000000000052a95de07a4c26d000 */
+-  L(1.67231624299180373502350811501181670E-36), /* 3f881c87a53691cae9d77f4e40d66616 */
+-  L(9.15527343749970728685313252158399200E-05), /* 3ff17ffffffffff28040cc2acde28000 */
+-  L(2.43665747834893104318707597514407880E-36), /* 3f889e9366c7c6c6a2ecb78dc9b0509e */
+-  L(1.22070312500027751961838150070880064E-04), /* 3ff200000000003ffddde6c153b53000 */
+- L(-1.73322146370624186623546452226755405E-35), /* bf8b709d8d658ed5dbbe943de56ee84e */
+-  L(1.52587890624995916105682628143179430E-04), /* 3ff23ffffffffff6954b56e285d23000 */
+-  L(1.23580432650945898349135528000443828E-35), /* 3f8b06d396601dde16de7d7bc27346e6 */
+-  L(1.83105468750008670314358488289621794E-04), /* 3ff2800000000013fe0cdc8c823b7000 */
+-  L(4.30446229148833293310207915930740796E-35), /* 3f8cc9ba9bfe554a4f7f2fece291eb23 */
+-  L(2.13623046875005741337455947623248132E-04), /* 3ff2c0000000000d3d1662de21a3f000 */
+- L(-3.96110759869520786681660669615255057E-35), /* bf8ca5379b04ff4a31aab0ceacc917e6 */
+-  L(2.44140624999981493573336463433440506E-04), /* 3ff2ffffffffffd553bbdf48e0534000 */
+- L(-1.39617373942387888957350179316792928E-35), /* bf8b28eeedc286015802b63f96b8c5cd */
+-  L(2.74658203124984920706309918754626834E-04), /* 3ff31fffffffffee9d60c8439ec1d000 */
+- L(-3.16168080483901830349738314447356223E-36), /* bf890cf74f81c77a611abc1243812444 */
+-  L(3.05175781250008648918265055410966055E-04), /* 3ff3400000000009f8b5c9a346636000 */
+-  L(8.54421306185008998867856704677221443E-35), /* 3f8dc649cd40922fc08adc6b6b20ead0 */
+-  L(3.35693359374988945462612499316774515E-04), /* 3ff35ffffffffff34146c540f15b2000 */
+-  L(7.96443137431639500475160850431097078E-35), /* 3f8da77638ed3148fc4d99d1c9e13446 */
+-  L(3.66210937500027690542093987739604535E-04), /* 3ff380000000001fecce34bea89c4000 */
+-  L(2.14507323877752361258862577769090367E-35), /* 3f8bc834e554d38894cf91957b0253d3 */
+-  L(3.96728515625003928083564943615052121E-04), /* 3ff3a00000000004875d9a4acf6ab000 */
+-  L(4.88358523466632050664019922448605508E-35), /* 3f8d03a7eaeef1a9f78c71a12c44dd28 */
+-  L(4.27246093750017799227172345607351585E-04), /* 3ff3c00000000014856794c3ee850000 */
+-  L(6.66520494592631402182216588784828935E-35), /* 3f8d6262118fcdb59b8f16108f5f1a6c */
+-  L(4.57763671875002108342364320152138181E-04), /* 3ff3e000000000026e45d855410b9000 */
+-  L(7.21799615960261390920033272189522298E-35), /* 3f8d7fc645cff8879462296af975c9fd */
+-  L(4.88281249999999768797631616370963356E-04), /* 3ff3ffffffffffffbbc2d7cc004df000 */
+- L(-5.30564629906905979452258114088325361E-35), /* bf8d1a18b71929a30d67a217a27ae851 */
+-  L(5.18798828124997339054881383202487041E-04), /* 3ff40ffffffffffe775055eea5851000 */
+- L(-4.03682911253647925867848180522846377E-35), /* bf8cad44f0f3e5199d8a589d9332acad */
+-  L(5.49316406249980511907933706754958501E-04), /* 3ff41ffffffffff4c410b29bb62fb000 */
+- L(-2.08166843948323917121806956728438051E-35), /* bf8bbab8cf691403249fe5b699e25143 */
+-  L(5.79833984374989593561576568548497165E-04), /* 3ff42ffffffffffa0047df328d817000 */
+- L(-1.72745033420153042445343706432627539E-34), /* bf8ecb3c2d7d3a9e6e960576be901fdf */
+-  L(6.10351562500008540711511259540838154E-04), /* 3ff4400000000004ec62f54f8c271000 */
+-  L(7.41889382604319545724663095428976499E-35), /* 3f8d8a74c002c81a47c93b8e05d15f8e */
+-  L(6.40869140625020444702875407535884986E-04), /* 3ff450000000000bc91b09718515d000 */
+- L(-4.47321009727305792048065440180490107E-35), /* bf8cdbac5c8fe70822081d8993eb5cb6 */
+-  L(6.71386718750007531635964622352684074E-04), /* 3ff460000000000457792973db05c000 */
+-  L(5.13698959677949336513874456684462092E-35), /* 3f8d112114436949c5ef38d8049004ab */
+-  L(7.01904296875006634673332887754430334E-04), /* 3ff4700000000003d31adf2cb8b1d000 */
+- L(-8.25665755717729437292989870760751482E-35), /* bf8db6ffcc8ef71f8e648e3a8b160f5a */
+-  L(7.32421874999998244664170215504673504E-04), /* 3ff47ffffffffffefcf5498bd5c8a000 */
+- L(-5.64005234937832153139057628112753364E-35), /* bf8d2be06a1dfe90e7bf90fba7c12a98 */
+-  L(7.62939453125017456345986752604096408E-04), /* 3ff490000000000a101a1b093d4a8000 */
+- L(-1.11084094120417622468550608896588329E-34), /* bf8e274feabd2d94f6694507a46accb1 */
+-  L(7.93457031249987558617598988993908016E-04), /* 3ff49ffffffffff8d3f9dcab74bbf000 */
+- L(-1.22966480225449015129079129940978828E-34), /* bf8e46e6a65eef8fa9e42eddf3da305e */
+-  L(8.23974609374997378723747633335135819E-04), /* 3ff4affffffffffe7d2afbaa55b26000 */
+- L(-1.62270010016794279091906973366704963E-34), /* bf8eaf633f057ebdb664a34566401c4e */
+-  L(8.54492187500023938282350821569920958E-04), /* 3ff4c0000000000dccaabce399e59000 */
+- L(-1.39076361712838158775374263169606160E-34), /* bf8e71ba779364b3bbdba7841f2c4ca1 */
+-  L(8.85009765624987932362186815286691297E-04), /* 3ff4cffffffffff90b218886edc2a000 */
+-  L(4.07328275060905585228261577392403980E-35), /* 3f8cb1254dbb6ea4b8cfa5ed4cf28d24 */
+-  L(9.15527343749975579461305518559161974E-04), /* 3ff4dffffffffff1ec2a21f25df33000 */
+-  L(1.16855112459192484947855553716334015E-35), /* 3f8af10bf319e9f5270cf249eeffbe5c */
+-  L(9.46044921875016761584725882821122521E-04), /* 3ff4f00000000009a992c46c16d71000 */
+-  L(9.51660680007524262741115611071680436E-35), /* 3f8df9fd56e81f8edf133843910ee831 */
+-  L(9.76562499999974118878133088548272636E-04), /* 3ff4fffffffffff1149edc46a6df6000 */
+- L(-5.65271128977550656964071208289181661E-36), /* bf89e0e12689dd721aa2314c81eb6429 */
+-  L(1.00708007812498671732140389760347830E-03), /* 3ff507fffffffffc2be94b90ed091000 */
+- L(-1.43355074891483635310132767255371379E-34), /* bf8e7d1a688c247b16022daab1316d55 */
+-  L(1.03759765625002637786192745235343007E-03), /* 3ff51000000000079a57b966bc158000 */
+-  L(2.95905815240957629366749917020106928E-34), /* 3f8f895387fc73bb38f8a1b254c01a60 */
+-  L(1.06811523437500860568717813047520763E-03), /* 3ff51800000000027afcd5b35f5e6000 */
+- L(-5.98328495358586628195372356742878314E-35), /* bf8d3e204130013bf6328f1b70ff8c76 */
+-  L(1.09863281250001439958487251556220070E-03), /* 3ff5200000000004268077c6c66bd000 */
+-  L(2.41371837889426603334113000868144760E-34), /* 3f8f40d6948edf864054ccf151f9815e */
+-  L(1.12915039062501298413451613770002366E-03), /* 3ff5280000000003be0f5dd8fe81b000 */
+- L(-1.28815268997394164973472617519705703E-34), /* bf8e567321172ea089dce4bc8354ecb7 */
+-  L(1.15966796874997272036339054191407232E-03), /* 3ff52ffffffffff8231e3bcfff1e8000 */
+-  L(1.02996064554316248496839462594377804E-34), /* 3f8e11cf7d402789244f68e2d4f985b1 */
+-  L(1.19018554687502744121802585360546796E-03), /* 3ff5380000000007e8cdf3f8f6c20000 */
+- L(-1.43453217726255628994625761307322163E-34), /* bf8e7d5d3370d85a374f5f4802fc517a */
+-  L(1.22070312499997743541996266398850614E-03), /* 3ff53ffffffffff97f0722561f454000 */
+- L(-1.41086259180534339713692694428211646E-34), /* bf8e77125519ff76244dfec5fbd58402 */
+-  L(1.25122070312501024092560690174507039E-03), /* 3ff5480000000002f3a59d8820691000 */
+-  L(3.84102646020099293168698506729765213E-34), /* 3f8ffe8f5b86f9c3569c8f26e19b1f50 */
+-  L(1.28173828124997986521442660131425390E-03), /* 3ff54ffffffffffa3250a764439d9000 */
+-  L(1.44644589735033114377952806106652650E-34), /* 3f8e808801b80dcf38323cdbfdca2549 */
+-  L(1.31225585937501665804856968749058137E-03), /* 3ff5580000000004cd25a414c6d62000 */
+-  L(1.67474574742200577294563576414361377E-34), /* 3f8ebd394a151dbda4f81d5d83c0f1e9 */
+-  L(1.34277343749997290265837386401818888E-03), /* 3ff55ffffffffff83091b042cfd59000 */
+- L(-1.55650565030381326742591837551559103E-34), /* bf8e9dca490d7fecfadba9625ffb91c5 */
+-  L(1.37329101562497720784949380297774268E-03), /* 3ff567fffffffff96e3c7312f5ccf000 */
+-  L(1.65279335325630026116581677369221748E-34), /* 3f8eb763496f5bd7404f2298b402074f */
+-  L(1.40380859374999099958354100336136647E-03), /* 3ff56ffffffffffd67e2f09f2a381000 */
+-  L(1.89919944388961890195706641264717076E-34), /* 3f8ef8e4d0ffdfeba982aa8829501389 */
+-  L(1.43432617187497484122173130998160625E-03), /* 3ff577fffffffff8bf9c1d71af8a8000 */
+-  L(2.57638517142061429772064578590009568E-34), /* 3f8f5675d82c1cc4ada70fd3a957b89a */
+-  L(1.46484374999999929342158925502052945E-03), /* 3ff57fffffffffffcbdd1c7671b46000 */
+-  L(1.76487201934184070490166772482073801E-34), /* 3f8ed52ef732458f6e4c5c07504f33cc */
+-  L(1.49536132812502318451070466256902933E-03), /* 3ff5880000000006aeb7066c8ad43000 */
+-  L(2.38068367275295804321313550609246656E-34), /* 3f8f3c7277ae6fc390ace5e06c0b025b */
+-  L(1.52587890625000448053340248672949543E-03), /* 3ff59000000000014a9ae2104b3bc000 */
+-  L(1.01174455568392813258454590274740959E-34), /* 3f8e0cf7c434762991bb38e12acee215 */
+-  L(1.55639648437501113499837053523090913E-03), /* 3ff5980000000003359e2c204355e000 */
+- L(-2.82398418808099749023517211651363693E-35), /* bf8c2c4c2971d88caa95e15fb1ccb1a1 */
+-  L(1.58691406249999937955142588308171026E-03), /* 3ff59fffffffffffd2380ecbc87c2000 */
+- L(-1.27361695572422741562701199136538047E-34), /* bf8e5295e0e206dfb0f0266c07225448 */
+-  L(1.61743164062498000531048954475329309E-03), /* 3ff5a7fffffffffa3ca6fe61ed94c000 */
+- L(-1.22606548862580061633942923016222044E-34), /* bf8e45f1b17bb61039d21a351bb207b8 */
+-  L(1.64794921875001835451453858682255576E-03), /* 3ff5b000000000054a52fa20f6565000 */
+-  L(1.39132339594152335892305491425264583E-34), /* 3f8e71e0904c5449b414ee49b191cef2 */
+-  L(1.67846679687501263995029340691547953E-03), /* 3ff5b80000000003a4a9e912c910b000 */
+-  L(6.67245854693585315412242764786197029E-35), /* 3f8d62c4ccac1e7511a617d469468ccd */
+-  L(1.70898437500002646861403514115369655E-03), /* 3ff5c00000000007a109fbaa7e015000 */
+-  L(6.87367172354719289559624829652240928E-36), /* 3f8a245fa835eceb42bae8128d9336db */
+-  L(1.73950195312501174308226096992992128E-03), /* 3ff5c80000000003627c8d637a005000 */
+- L(-2.20824271875474985927385878948759352E-34), /* bf8f25869b1cbefb25e735992f232f57 */
+-  L(1.77001953124997491747605207736194513E-03), /* 3ff5cffffffffff8c53c84b6883b8000 */
+-  L(3.43123048533596296514343180408963705E-34), /* 3f8fc816b91d173ddadbbf09b1287906 */
+-  L(1.80053710937497698911127570705069398E-03), /* 3ff5d7fffffffff95e1899f4a8430000 */
+-  L(3.99231237340890073475077494556136100E-35), /* 3f8ca889148f62fa854da5674df41279 */
+-  L(1.83105468750002267094899598630423914E-03), /* 3ff5e0000000000688d21e62ba674000 */
+- L(-3.22274595655810623999007524769365273E-34), /* bf8fac605cb9ae01eb719675ced25560 */
+-  L(1.86157226562500499224728040579690330E-03), /* 3ff5e80000000001705ce28a6d89e000 */
+-  L(3.07094985075881613489605622068441083E-34), /* 3f8f98330225ec7e2c8f3c0d1c432b91 */
+-  L(1.89208984374998234666824993196980949E-03), /* 3ff5effffffffffae969fdc7cd8cf000 */
+- L(-3.06287628722973914692165056776495733E-34), /* bf8f9720477d9cfa10e464df7f91020c */
+-  L(1.92260742187501225343755557292811682E-03), /* 3ff5f800000000038824e428ed49a000 */
+-  L(6.30049124729794620592961282769623368E-35), /* 3f8d4efdd7cd4336d88a6aa49e1e96bc */
+-  L(1.95312499999998514894032051116231258E-03), /* 3ff5fffffffffffbb82f6a04f1ae0000 */
+- L(-6.14610057507500948543216998736262902E-35), /* bf8d46c862d39255370e7974d48daa7e */
+-  L(1.98364257812501222021119324146882732E-03), /* 3ff6040000000001c2d8a1aa5188d000 */
+-  L(3.71942298418113774118754986159801984E-34), /* 3f8fee6567d9940495519ffe62cbc9a4 */
++  0.00000000000000000000000000000000000E+00L, /* 00000000000000000000000000000000 */
++  0.00000000000000000000000000000000000E+00L, /* 00000000000000000000000000000000 */
++  3.05175781249814607084128277672749162E-05L, /* 3feffffffffffeaa02abb9102f499000 */
++  1.00271855391179733380665816525889949E-36L, /* 3f8755351afa042ac3f58114824d4c10 */
++  6.10351562500179243748093427073421439E-05L, /* 3ff1000000000052a95de07a4c26d000 */
++  1.67231624299180373502350811501181670E-36L, /* 3f881c87a53691cae9d77f4e40d66616 */
++  9.15527343749970728685313252158399200E-05L, /* 3ff17ffffffffff28040cc2acde28000 */
++  2.43665747834893104318707597514407880E-36L, /* 3f889e9366c7c6c6a2ecb78dc9b0509e */
++  1.22070312500027751961838150070880064E-04L, /* 3ff200000000003ffddde6c153b53000 */
++ -1.73322146370624186623546452226755405E-35L, /* bf8b709d8d658ed5dbbe943de56ee84e */
++  1.52587890624995916105682628143179430E-04L, /* 3ff23ffffffffff6954b56e285d23000 */
++  1.23580432650945898349135528000443828E-35L, /* 3f8b06d396601dde16de7d7bc27346e6 */
++  1.83105468750008670314358488289621794E-04L, /* 3ff2800000000013fe0cdc8c823b7000 */
++  4.30446229148833293310207915930740796E-35L, /* 3f8cc9ba9bfe554a4f7f2fece291eb23 */
++  2.13623046875005741337455947623248132E-04L, /* 3ff2c0000000000d3d1662de21a3f000 */
++ -3.96110759869520786681660669615255057E-35L, /* bf8ca5379b04ff4a31aab0ceacc917e6 */
++  2.44140624999981493573336463433440506E-04L, /* 3ff2ffffffffffd553bbdf48e0534000 */
++ -1.39617373942387888957350179316792928E-35L, /* bf8b28eeedc286015802b63f96b8c5cd */
++  2.74658203124984920706309918754626834E-04L, /* 3ff31fffffffffee9d60c8439ec1d000 */
++ -3.16168080483901830349738314447356223E-36L, /* bf890cf74f81c77a611abc1243812444 */
++  3.05175781250008648918265055410966055E-04L, /* 3ff3400000000009f8b5c9a346636000 */
++  8.54421306185008998867856704677221443E-35L, /* 3f8dc649cd40922fc08adc6b6b20ead0 */
++  3.35693359374988945462612499316774515E-04L, /* 3ff35ffffffffff34146c540f15b2000 */
++  7.96443137431639500475160850431097078E-35L, /* 3f8da77638ed3148fc4d99d1c9e13446 */
++  3.66210937500027690542093987739604535E-04L, /* 3ff380000000001fecce34bea89c4000 */
++  2.14507323877752361258862577769090367E-35L, /* 3f8bc834e554d38894cf91957b0253d3 */
++  3.96728515625003928083564943615052121E-04L, /* 3ff3a00000000004875d9a4acf6ab000 */
++  4.88358523466632050664019922448605508E-35L, /* 3f8d03a7eaeef1a9f78c71a12c44dd28 */
++  4.27246093750017799227172345607351585E-04L, /* 3ff3c00000000014856794c3ee850000 */
++  6.66520494592631402182216588784828935E-35L, /* 3f8d6262118fcdb59b8f16108f5f1a6c */
++  4.57763671875002108342364320152138181E-04L, /* 3ff3e000000000026e45d855410b9000 */
++  7.21799615960261390920033272189522298E-35L, /* 3f8d7fc645cff8879462296af975c9fd */
++  4.88281249999999768797631616370963356E-04L, /* 3ff3ffffffffffffbbc2d7cc004df000 */
++ -5.30564629906905979452258114088325361E-35L, /* bf8d1a18b71929a30d67a217a27ae851 */
++  5.18798828124997339054881383202487041E-04L, /* 3ff40ffffffffffe775055eea5851000 */
++ -4.03682911253647925867848180522846377E-35L, /* bf8cad44f0f3e5199d8a589d9332acad */
++  5.49316406249980511907933706754958501E-04L, /* 3ff41ffffffffff4c410b29bb62fb000 */
++ -2.08166843948323917121806956728438051E-35L, /* bf8bbab8cf691403249fe5b699e25143 */
++  5.79833984374989593561576568548497165E-04L, /* 3ff42ffffffffffa0047df328d817000 */
++ -1.72745033420153042445343706432627539E-34L, /* bf8ecb3c2d7d3a9e6e960576be901fdf */
++  6.10351562500008540711511259540838154E-04L, /* 3ff4400000000004ec62f54f8c271000 */
++  7.41889382604319545724663095428976499E-35L, /* 3f8d8a74c002c81a47c93b8e05d15f8e */
++  6.40869140625020444702875407535884986E-04L, /* 3ff450000000000bc91b09718515d000 */
++ -4.47321009727305792048065440180490107E-35L, /* bf8cdbac5c8fe70822081d8993eb5cb6 */
++  6.71386718750007531635964622352684074E-04L, /* 3ff460000000000457792973db05c000 */
++  5.13698959677949336513874456684462092E-35L, /* 3f8d112114436949c5ef38d8049004ab */
++  7.01904296875006634673332887754430334E-04L, /* 3ff4700000000003d31adf2cb8b1d000 */
++ -8.25665755717729437292989870760751482E-35L, /* bf8db6ffcc8ef71f8e648e3a8b160f5a */
++  7.32421874999998244664170215504673504E-04L, /* 3ff47ffffffffffefcf5498bd5c8a000 */
++ -5.64005234937832153139057628112753364E-35L, /* bf8d2be06a1dfe90e7bf90fba7c12a98 */
++  7.62939453125017456345986752604096408E-04L, /* 3ff490000000000a101a1b093d4a8000 */
++ -1.11084094120417622468550608896588329E-34L, /* bf8e274feabd2d94f6694507a46accb1 */
++  7.93457031249987558617598988993908016E-04L, /* 3ff49ffffffffff8d3f9dcab74bbf000 */
++ -1.22966480225449015129079129940978828E-34L, /* bf8e46e6a65eef8fa9e42eddf3da305e */
++  8.23974609374997378723747633335135819E-04L, /* 3ff4affffffffffe7d2afbaa55b26000 */
++ -1.62270010016794279091906973366704963E-34L, /* bf8eaf633f057ebdb664a34566401c4e */
++  8.54492187500023938282350821569920958E-04L, /* 3ff4c0000000000dccaabce399e59000 */
++ -1.39076361712838158775374263169606160E-34L, /* bf8e71ba779364b3bbdba7841f2c4ca1 */
++  8.85009765624987932362186815286691297E-04L, /* 3ff4cffffffffff90b218886edc2a000 */
++  4.07328275060905585228261577392403980E-35L, /* 3f8cb1254dbb6ea4b8cfa5ed4cf28d24 */
++  9.15527343749975579461305518559161974E-04L, /* 3ff4dffffffffff1ec2a21f25df33000 */
++  1.16855112459192484947855553716334015E-35L, /* 3f8af10bf319e9f5270cf249eeffbe5c */
++  9.46044921875016761584725882821122521E-04L, /* 3ff4f00000000009a992c46c16d71000 */
++  9.51660680007524262741115611071680436E-35L, /* 3f8df9fd56e81f8edf133843910ee831 */
++  9.76562499999974118878133088548272636E-04L, /* 3ff4fffffffffff1149edc46a6df6000 */
++ -5.65271128977550656964071208289181661E-36L, /* bf89e0e12689dd721aa2314c81eb6429 */
++  1.00708007812498671732140389760347830E-03L, /* 3ff507fffffffffc2be94b90ed091000 */
++ -1.43355074891483635310132767255371379E-34L, /* bf8e7d1a688c247b16022daab1316d55 */
++  1.03759765625002637786192745235343007E-03L, /* 3ff51000000000079a57b966bc158000 */
++  2.95905815240957629366749917020106928E-34L, /* 3f8f895387fc73bb38f8a1b254c01a60 */
++  1.06811523437500860568717813047520763E-03L, /* 3ff51800000000027afcd5b35f5e6000 */
++ -5.98328495358586628195372356742878314E-35L, /* bf8d3e204130013bf6328f1b70ff8c76 */
++  1.09863281250001439958487251556220070E-03L, /* 3ff5200000000004268077c6c66bd000 */
++  2.41371837889426603334113000868144760E-34L, /* 3f8f40d6948edf864054ccf151f9815e */
++  1.12915039062501298413451613770002366E-03L, /* 3ff5280000000003be0f5dd8fe81b000 */
++ -1.28815268997394164973472617519705703E-34L, /* bf8e567321172ea089dce4bc8354ecb7 */
++  1.15966796874997272036339054191407232E-03L, /* 3ff52ffffffffff8231e3bcfff1e8000 */
++  1.02996064554316248496839462594377804E-34L, /* 3f8e11cf7d402789244f68e2d4f985b1 */
++  1.19018554687502744121802585360546796E-03L, /* 3ff5380000000007e8cdf3f8f6c20000 */
++ -1.43453217726255628994625761307322163E-34L, /* bf8e7d5d3370d85a374f5f4802fc517a */
++  1.22070312499997743541996266398850614E-03L, /* 3ff53ffffffffff97f0722561f454000 */
++ -1.41086259180534339713692694428211646E-34L, /* bf8e77125519ff76244dfec5fbd58402 */
++  1.25122070312501024092560690174507039E-03L, /* 3ff5480000000002f3a59d8820691000 */
++  3.84102646020099293168698506729765213E-34L, /* 3f8ffe8f5b86f9c3569c8f26e19b1f50 */
++  1.28173828124997986521442660131425390E-03L, /* 3ff54ffffffffffa3250a764439d9000 */
++  1.44644589735033114377952806106652650E-34L, /* 3f8e808801b80dcf38323cdbfdca2549 */
++  1.31225585937501665804856968749058137E-03L, /* 3ff5580000000004cd25a414c6d62000 */
++  1.67474574742200577294563576414361377E-34L, /* 3f8ebd394a151dbda4f81d5d83c0f1e9 */
++  1.34277343749997290265837386401818888E-03L, /* 3ff55ffffffffff83091b042cfd59000 */
++ -1.55650565030381326742591837551559103E-34L, /* bf8e9dca490d7fecfadba9625ffb91c5 */
++  1.37329101562497720784949380297774268E-03L, /* 3ff567fffffffff96e3c7312f5ccf000 */
++  1.65279335325630026116581677369221748E-34L, /* 3f8eb763496f5bd7404f2298b402074f */
++  1.40380859374999099958354100336136647E-03L, /* 3ff56ffffffffffd67e2f09f2a381000 */
++  1.89919944388961890195706641264717076E-34L, /* 3f8ef8e4d0ffdfeba982aa8829501389 */
++  1.43432617187497484122173130998160625E-03L, /* 3ff577fffffffff8bf9c1d71af8a8000 */
++  2.57638517142061429772064578590009568E-34L, /* 3f8f5675d82c1cc4ada70fd3a957b89a */
++  1.46484374999999929342158925502052945E-03L, /* 3ff57fffffffffffcbdd1c7671b46000 */
++  1.76487201934184070490166772482073801E-34L, /* 3f8ed52ef732458f6e4c5c07504f33cc */
++  1.49536132812502318451070466256902933E-03L, /* 3ff5880000000006aeb7066c8ad43000 */
++  2.38068367275295804321313550609246656E-34L, /* 3f8f3c7277ae6fc390ace5e06c0b025b */
++  1.52587890625000448053340248672949543E-03L, /* 3ff59000000000014a9ae2104b3bc000 */
++  1.01174455568392813258454590274740959E-34L, /* 3f8e0cf7c434762991bb38e12acee215 */
++  1.55639648437501113499837053523090913E-03L, /* 3ff5980000000003359e2c204355e000 */
++ -2.82398418808099749023517211651363693E-35L, /* bf8c2c4c2971d88caa95e15fb1ccb1a1 */
++  1.58691406249999937955142588308171026E-03L, /* 3ff59fffffffffffd2380ecbc87c2000 */
++ -1.27361695572422741562701199136538047E-34L, /* bf8e5295e0e206dfb0f0266c07225448 */
++  1.61743164062498000531048954475329309E-03L, /* 3ff5a7fffffffffa3ca6fe61ed94c000 */
++ -1.22606548862580061633942923016222044E-34L, /* bf8e45f1b17bb61039d21a351bb207b8 */
++  1.64794921875001835451453858682255576E-03L, /* 3ff5b000000000054a52fa20f6565000 */
++  1.39132339594152335892305491425264583E-34L, /* 3f8e71e0904c5449b414ee49b191cef2 */
++  1.67846679687501263995029340691547953E-03L, /* 3ff5b80000000003a4a9e912c910b000 */
++  6.67245854693585315412242764786197029E-35L, /* 3f8d62c4ccac1e7511a617d469468ccd */
++  1.70898437500002646861403514115369655E-03L, /* 3ff5c00000000007a109fbaa7e015000 */
++  6.87367172354719289559624829652240928E-36L, /* 3f8a245fa835eceb42bae8128d9336db */
++  1.73950195312501174308226096992992128E-03L, /* 3ff5c80000000003627c8d637a005000 */
++ -2.20824271875474985927385878948759352E-34L, /* bf8f25869b1cbefb25e735992f232f57 */
++  1.77001953124997491747605207736194513E-03L, /* 3ff5cffffffffff8c53c84b6883b8000 */
++  3.43123048533596296514343180408963705E-34L, /* 3f8fc816b91d173ddadbbf09b1287906 */
++  1.80053710937497698911127570705069398E-03L, /* 3ff5d7fffffffff95e1899f4a8430000 */
++  3.99231237340890073475077494556136100E-35L, /* 3f8ca889148f62fa854da5674df41279 */
++  1.83105468750002267094899598630423914E-03L, /* 3ff5e0000000000688d21e62ba674000 */
++ -3.22274595655810623999007524769365273E-34L, /* bf8fac605cb9ae01eb719675ced25560 */
++  1.86157226562500499224728040579690330E-03L, /* 3ff5e80000000001705ce28a6d89e000 */
++  3.07094985075881613489605622068441083E-34L, /* 3f8f98330225ec7e2c8f3c0d1c432b91 */
++  1.89208984374998234666824993196980949E-03L, /* 3ff5effffffffffae969fdc7cd8cf000 */
++ -3.06287628722973914692165056776495733E-34L, /* bf8f9720477d9cfa10e464df7f91020c */
++  1.92260742187501225343755557292811682E-03L, /* 3ff5f800000000038824e428ed49a000 */
++  6.30049124729794620592961282769623368E-35L, /* 3f8d4efdd7cd4336d88a6aa49e1e96bc */
++  1.95312499999998514894032051116231258E-03L, /* 3ff5fffffffffffbb82f6a04f1ae0000 */
++ -6.14610057507500948543216998736262902E-35L, /* bf8d46c862d39255370e7974d48daa7e */
++  1.98364257812501222021119324146882732E-03L, /* 3ff6040000000001c2d8a1aa5188d000 */
++  3.71942298418113774118754986159801984E-34L, /* 3f8fee6567d9940495519ffe62cbc9a4 */
+ 
+-  L(7.06341639425619532977052017486130353E-01), /* 3ffe69a59c8245a9ac00000000000000 */
+-  L(7.09106182437398424589503065362805501E-01), /* 3ffe6b0ff72deb89d000000000000000 */
+-  L(7.11881545564596485142772053222870454E-01), /* 3ffe6c7bbce9a6d93000000000000000 */
+-  L(7.14667771155948150507697391731198877E-01), /* 3ffe6de8ef213d71e000000000000000 */
+-  L(7.17464901725936049503573599395167548E-01), /* 3ffe6f578f41e1a9e400000000000000 */
+-  L(7.20272979955439790478166628417966422E-01), /* 3ffe70c79eba33c06c00000000000000 */
+-  L(7.23092048692387218133958981525211129E-01), /* 3ffe72391efa434c7400000000000000 */
+-  L(7.25922150952408251622927082280511968E-01), /* 3ffe73ac117390acd800000000000000 */
+-  L(7.28763329919491220643124052003258839E-01), /* 3ffe752077990e79d000000000000000 */
+-  L(7.31615628946641782803794740175362676E-01), /* 3ffe769652df22f7e000000000000000 */
+-  L(7.34479091556544505525749855223693885E-01), /* 3ffe780da4bba98c4800000000000000 */
+-  L(7.37353761442226890432394270646909717E-01), /* 3ffe79866ea5f432d400000000000000 */
+-  L(7.40239682467726090031590047146892175E-01), /* 3ffe7b00b216ccf53000000000000000 */
+-  L(7.43136898668758316688354170764796436E-01), /* 3ffe7c7c70887763c000000000000000 */
+-  L(7.46045454253390638577059235103661194E-01), /* 3ffe7df9ab76b20fd000000000000000 */
+-  L(7.48965393602715662213498148958024103E-01), /* 3ffe7f78645eb8076400000000000000 */
+-  L(7.51896761271528629722027403659012634E-01), /* 3ffe80f89cbf42526400000000000000 */
+-  L(7.54839601989007347171423134568613023E-01), /* 3ffe827a561889716000000000000000 */
+-  L(7.57793960659394638668118204805068672E-01), /* 3ffe83fd91ec46ddc000000000000000 */
+-  L(7.60759882362683631518152083117456641E-01), /* 3ffe858251bdb68b8c00000000000000 */
+-  L(7.63737412355305483879774897104653064E-01), /* 3ffe87089711986c9400000000000000 */
+-  L(7.66726596070820082262642358728044201E-01), /* 3ffe8890636e31f54400000000000000 */
+-  L(7.69727479120609181517664865168626420E-01), /* 3ffe8a19b85b4fa2d800000000000000 */
+-  L(7.72740107294572486917871856348938309E-01), /* 3ffe8ba4976246833800000000000000 */
+-  L(7.75764526561826289752232810315035749E-01), /* 3ffe8d31020df5be4400000000000000 */
+-  L(7.78800783071404878477039801509818062E-01), /* 3ffe8ebef9eac820b000000000000000 */
+-  L(7.81848923152964780936002853195532225E-01), /* 3ffe904e8086b5a87800000000000000 */
+-  L(7.84908993317491698871180005880887620E-01), /* 3ffe91df97714512d800000000000000 */
+-  L(7.87981040258010162480317717381694820E-01), /* 3ffe9372403b8d6bcc00000000000000 */
+-  L(7.91065110850296016042904057030682452E-01), /* 3ffe95067c78379f2800000000000000 */
+-  L(7.94161252153591734614934694036492147E-01), /* 3ffe969c4dbb800b4800000000000000 */
+-  L(7.97269511411324433014513601847284008E-01), /* 3ffe9833b59b38154400000000000000 */
+-  L(8.00389936051826789142893403550260700E-01), /* 3ffe99ccb5aec7bec800000000000000 */
+-  L(8.03522573689060742863077280162542593E-01), /* 3ffe9b674f8f2f3d7c00000000000000 */
+-  L(8.06667472123343942680406826184480451E-01), /* 3ffe9d0384d70893f800000000000000 */
+-  L(8.09824679342079301047618855591281317E-01), /* 3ffe9ea15722892c7800000000000000 */
+-  L(8.12994243520486992160556383169023320E-01), /* 3ffea040c80f8374f000000000000000 */
+-  L(8.16176213022339780422953481320291758E-01), /* 3ffea1e1d93d687d0000000000000000 */
+-  L(8.19370636400700819157449927843117621E-01), /* 3ffea3848c4d49954c00000000000000 */
+-  L(8.22577562398664585696650419777142815E-01), /* 3ffea528e2e1d9f09800000000000000 */
+-  L(8.25797039950100647542896581398963463E-01), /* 3ffea6cede9f70467c00000000000000 */
+-  L(8.29029118180400342863478613253391813E-01), /* 3ffea876812c0877bc00000000000000 */
+-  L(8.32273846407226292054559735333896242E-01), /* 3ffeaa1fcc2f45343800000000000000 */
+-  L(8.35531274141265073440720811959181447E-01), /* 3ffeabcac15271a2a400000000000000 */
+-  L(8.38801451086982535754188461396552157E-01), /* 3ffead7762408309bc00000000000000 */
+-  L(8.42084427143382358016410194068157580E-01), /* 3ffeaf25b0a61a7b4c00000000000000 */
+-  L(8.45380252404767357221615498019673396E-01), /* 3ffeb0d5ae318680c400000000000000 */
+-  L(8.48688977161503960155997106085123960E-01), /* 3ffeb2875c92c4c99400000000000000 */
+-  L(8.52010651900789478530029441571969073E-01), /* 3ffeb43abd7b83db1c00000000000000 */
+-  L(8.55345327307422548246407245642330963E-01), /* 3ffeb5efd29f24c26400000000000000 */
+-  L(8.58693054264576483003423845730139874E-01), /* 3ffeb7a69db2bcc77800000000000000 */
+-  L(8.62053883854575708767242758767679334E-01), /* 3ffeb95f206d17228000000000000000 */
+-  L(8.65427867359675251357487013592617586E-01), /* 3ffebb195c86b6b29000000000000000 */
+-  L(8.68815056262843166123843730019871145E-01), /* 3ffebcd553b9d7b62000000000000000 */
+-  L(8.72215502248546159513864495238522068E-01), /* 3ffebe9307c271855000000000000000 */
+-  L(8.75629257203538208242932228131394368E-01), /* 3ffec0527a5e384ddc00000000000000 */
+-  L(8.79056373217652342599848225290770642E-01), /* 3ffec213ad4c9ed0d800000000000000 */
+-  L(8.82496902584595399599010079327854328E-01), /* 3ffec3d6a24ed8221800000000000000 */
+-  L(8.85950897802745995779361010136199184E-01), /* 3ffec59b5b27d9696800000000000000 */
+-  L(8.89418411575955636383383762222365476E-01), /* 3ffec761d99c5ba58800000000000000 */
+-  L(8.92899496814352794382685374330321793E-01), /* 3ffec92a1f72dd70d400000000000000 */
+-  L(8.96394206635150403439382671422208659E-01), /* 3ffecaf42e73a4c7d800000000000000 */
+-  L(8.99902594363456265202927397695020773E-01), /* 3ffeccc00868c0d18800000000000000 */
+-  L(9.03424713533086704009278378180169966E-01), /* 3ffece8daf1e0ba94c00000000000000 */
+-  L(9.06960617887383580004723171441582963E-01), /* 3ffed05d24612c2af000000000000000 */
+-  L(9.10510361380034133338412516422977205E-01), /* 3ffed22e6a0197c02c00000000000000 */
+-  L(9.14073998175894436579724811053893063E-01), /* 3ffed40181d094303400000000000000 */
+-  L(9.17651582651815816982221463149471674E-01), /* 3ffed5d66da13970f400000000000000 */
+-  L(9.21243169397474526149949269893113524E-01), /* 3ffed7ad2f48737a2000000000000000 */
+-  L(9.24848813216204823639543519675498828E-01), /* 3ffed985c89d041a3000000000000000 */
+-  L(9.28468569125835141431224428743007593E-01), /* 3ffedb603b7784cd1800000000000000 */
+-  L(9.32102492359527579068867453315760940E-01), /* 3ffedd3c89b26894e000000000000000 */
+-  L(9.35750638366620729469147477175283711E-01), /* 3ffedf1ab529fdd41c00000000000000 */
+-  L(9.39413062813475779888605643463961314E-01), /* 3ffee0fabfbc702a3c00000000000000 */
+-  L(9.43089821584325888048638830696290825E-01), /* 3ffee2dcab49ca51b400000000000000 */
+-  L(9.46780970782128888929563004239753354E-01), /* 3ffee4c079b3f8000400000000000000 */
+-  L(9.50486566729423443256052905780961737E-01), /* 3ffee6a62cdec7c7b000000000000000 */
+-  L(9.54206665969188322362626308859034907E-01), /* 3ffee88dc6afecfbfc00000000000000 */
+-  L(9.57941325265705301283958306157728657E-01), /* 3ffeea77490f0196b000000000000000 */
+-  L(9.61690601605425299247542625380447134E-01), /* 3ffeec62b5e5881fb000000000000000 */
+-  L(9.65454552197837823079851204965962097E-01), /* 3ffeee500f1eed967000000000000000 */
+-  L(9.69233234476344074348475032820715569E-01), /* 3ffef03f56a88b5d7800000000000000 */
+-  L(9.73026706099133165128733935489435680E-01), /* 3ffef2308e71a927a800000000000000 */
+-  L(9.76835024950062025261843245971249416E-01), /* 3ffef423b86b7ee79000000000000000 */
+-  L(9.80658249139538557015427500118676107E-01), /* 3ffef618d68936c09c00000000000000 */
+-  L(9.84496437005408397968864164795377292E-01), /* 3ffef80feabfeefa4800000000000000 */
+-  L(9.88349647113845042323276857132441364E-01), /* 3ffefa08f706bbf53800000000000000 */
+-  L(9.92217938260243514925207364285597578E-01), /* 3ffefc03fd56aa225000000000000000 */
+-  L(9.96101369470117486981664001177705359E-01), /* 3ffefe00ffaabffbbc00000000000000 */
++  7.06341639425619532977052017486130353E-01L, /* 3ffe69a59c8245a9ac00000000000000 */
++  7.09106182437398424589503065362805501E-01L, /* 3ffe6b0ff72deb89d000000000000000 */
++  7.11881545564596485142772053222870454E-01L, /* 3ffe6c7bbce9a6d93000000000000000 */
++  7.14667771155948150507697391731198877E-01L, /* 3ffe6de8ef213d71e000000000000000 */
++  7.17464901725936049503573599395167548E-01L, /* 3ffe6f578f41e1a9e400000000000000 */
++  7.20272979955439790478166628417966422E-01L, /* 3ffe70c79eba33c06c00000000000000 */
++  7.23092048692387218133958981525211129E-01L, /* 3ffe72391efa434c7400000000000000 */
++  7.25922150952408251622927082280511968E-01L, /* 3ffe73ac117390acd800000000000000 */
++  7.28763329919491220643124052003258839E-01L, /* 3ffe752077990e79d000000000000000 */
++  7.31615628946641782803794740175362676E-01L, /* 3ffe769652df22f7e000000000000000 */
++  7.34479091556544505525749855223693885E-01L, /* 3ffe780da4bba98c4800000000000000 */
++  7.37353761442226890432394270646909717E-01L, /* 3ffe79866ea5f432d400000000000000 */
++  7.40239682467726090031590047146892175E-01L, /* 3ffe7b00b216ccf53000000000000000 */
++  7.43136898668758316688354170764796436E-01L, /* 3ffe7c7c70887763c000000000000000 */
++  7.46045454253390638577059235103661194E-01L, /* 3ffe7df9ab76b20fd000000000000000 */
++  7.48965393602715662213498148958024103E-01L, /* 3ffe7f78645eb8076400000000000000 */
++  7.51896761271528629722027403659012634E-01L, /* 3ffe80f89cbf42526400000000000000 */
++  7.54839601989007347171423134568613023E-01L, /* 3ffe827a561889716000000000000000 */
++  7.57793960659394638668118204805068672E-01L, /* 3ffe83fd91ec46ddc000000000000000 */
++  7.60759882362683631518152083117456641E-01L, /* 3ffe858251bdb68b8c00000000000000 */
++  7.63737412355305483879774897104653064E-01L, /* 3ffe87089711986c9400000000000000 */
++  7.66726596070820082262642358728044201E-01L, /* 3ffe8890636e31f54400000000000000 */
++  7.69727479120609181517664865168626420E-01L, /* 3ffe8a19b85b4fa2d800000000000000 */
++  7.72740107294572486917871856348938309E-01L, /* 3ffe8ba4976246833800000000000000 */
++  7.75764526561826289752232810315035749E-01L, /* 3ffe8d31020df5be4400000000000000 */
++  7.78800783071404878477039801509818062E-01L, /* 3ffe8ebef9eac820b000000000000000 */
++  7.81848923152964780936002853195532225E-01L, /* 3ffe904e8086b5a87800000000000000 */
++  7.84908993317491698871180005880887620E-01L, /* 3ffe91df97714512d800000000000000 */
++  7.87981040258010162480317717381694820E-01L, /* 3ffe9372403b8d6bcc00000000000000 */
++  7.91065110850296016042904057030682452E-01L, /* 3ffe95067c78379f2800000000000000 */
++  7.94161252153591734614934694036492147E-01L, /* 3ffe969c4dbb800b4800000000000000 */
++  7.97269511411324433014513601847284008E-01L, /* 3ffe9833b59b38154400000000000000 */
++  8.00389936051826789142893403550260700E-01L, /* 3ffe99ccb5aec7bec800000000000000 */
++  8.03522573689060742863077280162542593E-01L, /* 3ffe9b674f8f2f3d7c00000000000000 */
++  8.06667472123343942680406826184480451E-01L, /* 3ffe9d0384d70893f800000000000000 */
++  8.09824679342079301047618855591281317E-01L, /* 3ffe9ea15722892c7800000000000000 */
++  8.12994243520486992160556383169023320E-01L, /* 3ffea040c80f8374f000000000000000 */
++  8.16176213022339780422953481320291758E-01L, /* 3ffea1e1d93d687d0000000000000000 */
++  8.19370636400700819157449927843117621E-01L, /* 3ffea3848c4d49954c00000000000000 */
++  8.22577562398664585696650419777142815E-01L, /* 3ffea528e2e1d9f09800000000000000 */
++  8.25797039950100647542896581398963463E-01L, /* 3ffea6cede9f70467c00000000000000 */
++  8.29029118180400342863478613253391813E-01L, /* 3ffea876812c0877bc00000000000000 */
++  8.32273846407226292054559735333896242E-01L, /* 3ffeaa1fcc2f45343800000000000000 */
++  8.35531274141265073440720811959181447E-01L, /* 3ffeabcac15271a2a400000000000000 */
++  8.38801451086982535754188461396552157E-01L, /* 3ffead7762408309bc00000000000000 */
++  8.42084427143382358016410194068157580E-01L, /* 3ffeaf25b0a61a7b4c00000000000000 */
++  8.45380252404767357221615498019673396E-01L, /* 3ffeb0d5ae318680c400000000000000 */
++  8.48688977161503960155997106085123960E-01L, /* 3ffeb2875c92c4c99400000000000000 */
++  8.52010651900789478530029441571969073E-01L, /* 3ffeb43abd7b83db1c00000000000000 */
++  8.55345327307422548246407245642330963E-01L, /* 3ffeb5efd29f24c26400000000000000 */
++  8.58693054264576483003423845730139874E-01L, /* 3ffeb7a69db2bcc77800000000000000 */
++  8.62053883854575708767242758767679334E-01L, /* 3ffeb95f206d17228000000000000000 */
++  8.65427867359675251357487013592617586E-01L, /* 3ffebb195c86b6b29000000000000000 */
++  8.68815056262843166123843730019871145E-01L, /* 3ffebcd553b9d7b62000000000000000 */
++  8.72215502248546159513864495238522068E-01L, /* 3ffebe9307c271855000000000000000 */
++  8.75629257203538208242932228131394368E-01L, /* 3ffec0527a5e384ddc00000000000000 */
++  8.79056373217652342599848225290770642E-01L, /* 3ffec213ad4c9ed0d800000000000000 */
++  8.82496902584595399599010079327854328E-01L, /* 3ffec3d6a24ed8221800000000000000 */
++  8.85950897802745995779361010136199184E-01L, /* 3ffec59b5b27d9696800000000000000 */
++  8.89418411575955636383383762222365476E-01L, /* 3ffec761d99c5ba58800000000000000 */
++  8.92899496814352794382685374330321793E-01L, /* 3ffec92a1f72dd70d400000000000000 */
++  8.96394206635150403439382671422208659E-01L, /* 3ffecaf42e73a4c7d800000000000000 */
++  8.99902594363456265202927397695020773E-01L, /* 3ffeccc00868c0d18800000000000000 */
++  9.03424713533086704009278378180169966E-01L, /* 3ffece8daf1e0ba94c00000000000000 */
++  9.06960617887383580004723171441582963E-01L, /* 3ffed05d24612c2af000000000000000 */
++  9.10510361380034133338412516422977205E-01L, /* 3ffed22e6a0197c02c00000000000000 */
++  9.14073998175894436579724811053893063E-01L, /* 3ffed40181d094303400000000000000 */
++  9.17651582651815816982221463149471674E-01L, /* 3ffed5d66da13970f400000000000000 */
++  9.21243169397474526149949269893113524E-01L, /* 3ffed7ad2f48737a2000000000000000 */
++  9.24848813216204823639543519675498828E-01L, /* 3ffed985c89d041a3000000000000000 */
++  9.28468569125835141431224428743007593E-01L, /* 3ffedb603b7784cd1800000000000000 */
++  9.32102492359527579068867453315760940E-01L, /* 3ffedd3c89b26894e000000000000000 */
++  9.35750638366620729469147477175283711E-01L, /* 3ffedf1ab529fdd41c00000000000000 */
++  9.39413062813475779888605643463961314E-01L, /* 3ffee0fabfbc702a3c00000000000000 */
++  9.43089821584325888048638830696290825E-01L, /* 3ffee2dcab49ca51b400000000000000 */
++  9.46780970782128888929563004239753354E-01L, /* 3ffee4c079b3f8000400000000000000 */
++  9.50486566729423443256052905780961737E-01L, /* 3ffee6a62cdec7c7b000000000000000 */
++  9.54206665969188322362626308859034907E-01L, /* 3ffee88dc6afecfbfc00000000000000 */
++  9.57941325265705301283958306157728657E-01L, /* 3ffeea77490f0196b000000000000000 */
++  9.61690601605425299247542625380447134E-01L, /* 3ffeec62b5e5881fb000000000000000 */
++  9.65454552197837823079851204965962097E-01L, /* 3ffeee500f1eed967000000000000000 */
++  9.69233234476344074348475032820715569E-01L, /* 3ffef03f56a88b5d7800000000000000 */
++  9.73026706099133165128733935489435680E-01L, /* 3ffef2308e71a927a800000000000000 */
++  9.76835024950062025261843245971249416E-01L, /* 3ffef423b86b7ee79000000000000000 */
++  9.80658249139538557015427500118676107E-01L, /* 3ffef618d68936c09c00000000000000 */
++  9.84496437005408397968864164795377292E-01L, /* 3ffef80feabfeefa4800000000000000 */
++  9.88349647113845042323276857132441364E-01L, /* 3ffefa08f706bbf53800000000000000 */
++  9.92217938260243514925207364285597578E-01L, /* 3ffefc03fd56aa225000000000000000 */
++  9.96101369470117486981664001177705359E-01L, /* 3ffefe00ffaabffbbc00000000000000 */
+ #define T_EXPL_RES1 (T_EXPL_ARG2 + 2 + 2*65 + 89)
+-  L(1.00000000000000000000000000000000000E+00), /* 3fff0000000000000000000000000000 */
+-  L(1.00391388933834757590801700644078664E+00), /* 3fff0100802ab5577800000000000000 */
+-  L(1.00784309720644799091004983893071767E+00), /* 3fff0202015600445c00000000000000 */
+-  L(1.01178768355933151879000320150225889E+00), /* 3fff0304848362076c00000000000000 */
+-  L(1.01574770858668572692806719715008512E+00), /* 3fff04080ab55de39000000000000000 */
+-  L(1.01972323271377413034244341361045372E+00), /* 3fff050c94ef7a206c00000000000000 */
+-  L(1.02371431660235789884438872832106426E+00), /* 3fff06122436410dd000000000000000 */
+-  L(1.02772102115162167201845022646011785E+00), /* 3fff0718b98f42085000000000000000 */
+-  L(1.03174340749910264936062276319717057E+00), /* 3fff08205601127ec800000000000000 */
+-  L(1.03578153702162378824169763902318664E+00), /* 3fff0928fa934ef90800000000000000 */
+-  L(1.03983547133622999947277776300325058E+00), /* 3fff0a32a84e9c1f5800000000000000 */
+-  L(1.04390527230112850620713516036630608E+00), /* 3fff0b3d603ca7c32800000000000000 */
+-  L(1.04799100201663270004459604933799710E+00), /* 3fff0c49236829e8bc00000000000000 */
+-  L(1.05209272282610977189420964350574650E+00), /* 3fff0d55f2dce5d1e800000000000000 */
+-  L(1.05621049731693195106174698594259098E+00), /* 3fff0e63cfa7ab09d000000000000000 */
+-  L(1.06034438832143151909548350886325352E+00), /* 3fff0f72bad65671b800000000000000 */
+-  L(1.06449445891785943185681162503897212E+00), /* 3fff1082b577d34ed800000000000000 */
+-  L(1.06866077243134810492719566354935523E+00), /* 3fff1193c09c1c595c00000000000000 */
+-  L(1.07284339243487741866189821848820429E+00), /* 3fff12a5dd543ccc4c00000000000000 */
+-  L(1.07704238275024494209120007326419000E+00), /* 3fff13b90cb25176a400000000000000 */
+-  L(1.08125780744903959851299646288680378E+00), /* 3fff14cd4fc989cd6400000000000000 */
+-  L(1.08548973085361949442173568058933597E+00), /* 3fff15e2a7ae28fecc00000000000000 */
+-  L(1.08973821753809324563988525369495619E+00), /* 3fff16f9157587069400000000000000 */
+-  L(1.09400333232930546678574046381982043E+00), /* 3fff18109a3611c35000000000000000 */
+-  L(1.09828514030782586896606289883493446E+00), /* 3fff192937074e0cd800000000000000 */
+-  L(1.10258370680894224324930519287590869E+00), /* 3fff1a42ed01d8cbc800000000000000 */
+-  L(1.10689909742365749645287564817408565E+00), /* 3fff1b5dbd3f68122400000000000000 */
+-  L(1.11123137799969046168868658241990488E+00), /* 3fff1c79a8dacc350c00000000000000 */
+-  L(1.11558061464248076122274255794764031E+00), /* 3fff1d96b0eff0e79400000000000000 */
+-  L(1.11994687371619722204840741142106708E+00), /* 3fff1eb4d69bde569c00000000000000 */
+-  L(1.12433022184475073235176978414529003E+00), /* 3fff1fd41afcba45e800000000000000 */
+-  L(1.12873072591281087273529237791080959E+00), /* 3fff20f47f31c92e4800000000000000 */
+-  L(1.13314845306682632219974493636982515E+00), /* 3fff2216045b6f5cd000000000000000 */
+-  L(1.13758347071604959399593326452304609E+00), /* 3fff2338ab9b32134800000000000000 */
+-  L(1.14203584653356560174586320499656722E+00), /* 3fff245c7613b8a9b000000000000000 */
+-  L(1.14650564845732405583333957110880874E+00), /* 3fff258164e8cdb0d800000000000000 */
+-  L(1.15099294469117646722011727433709893E+00), /* 3fff26a7793f60164400000000000000 */
+-  L(1.15549780370591653744227755851170514E+00), /* 3fff27ceb43d84490400000000000000 */
+-  L(1.16002029424032515603215642840950750E+00), /* 3fff28f7170a755fd800000000000000 */
+-  L(1.16456048530221917269855680387991015E+00), /* 3fff2a20a2ce96406400000000000000 */
+-  L(1.16911844616950438835445424956560601E+00), /* 3fff2b4b58b372c79400000000000000 */
+-  L(1.17369424639123270948104504896036815E+00), /* 3fff2c7739e3c0f32c00000000000000 */
+-  L(1.17828795578866324378353169777255971E+00), /* 3fff2da4478b620c7400000000000000 */
+-  L(1.18289964445632783673900689791480545E+00), /* 3fff2ed282d763d42400000000000000 */
+-  L(1.18752938276310060494722620205720887E+00), /* 3fff3001ecf601af7000000000000000 */
+-  L(1.19217724135327157730657177125976887E+00), /* 3fff31328716a5d63c00000000000000 */
+-  L(1.19684329114762477708211463323095813E+00), /* 3fff32645269ea829000000000000000 */
+-  L(1.20152760334452030077656559114984702E+00), /* 3fff339750219b212c00000000000000 */
+-  L(1.20623024942098072687102217059873510E+00), /* 3fff34cb8170b5835400000000000000 */
+-  L(1.21095130113378179892436037334846333E+00), /* 3fff3600e78b6b11d000000000000000 */
+-  L(1.21569083052054743854242246925423387E+00), /* 3fff373783a722012400000000000000 */
+-  L(1.22044890990084875515009343871497549E+00), /* 3fff386f56fa7686e800000000000000 */
+-  L(1.22522561187730755216662714701669756E+00), /* 3fff39a862bd3c106400000000000000 */
+-  L(1.23002100933670455162882717559114099E+00), /* 3fff3ae2a8287e7a8000000000000000 */
+-  L(1.23483517545109100499445276000187732E+00), /* 3fff3c1e2876834aa800000000000000 */
+-  L(1.23966818367890557750499169742397498E+00), /* 3fff3d5ae4e2cae92c00000000000000 */
+-  L(1.24452010776609517384017067342938390E+00), /* 3fff3e98deaa11dcbc00000000000000 */
+-  L(1.24939102174724003813111039562500082E+00), /* 3fff3fd8170a52071800000000000000 */
+-  L(1.25428099994668373895478907797951251E+00), /* 3fff41188f42c3e32000000000000000 */
+-  L(1.25919011697966698459794088194030337E+00), /* 3fff425a4893dfc3f800000000000000 */
+-  L(1.26411844775346637881341393949696794E+00), /* 3fff439d443f5f159000000000000000 */
+-  L(1.26906606746853711786826579555054195E+00), /* 3fff44e183883d9e4800000000000000 */
+-  L(1.27403305161966090564007458851847332E+00), /* 3fff462707b2bac20c00000000000000 */
+-  L(1.27901947599709753244923149395617656E+00), /* 3fff476dd2045ac67800000000000000 */
+-  L(1.28402541668774150540599521264084615E+00), /* 3fff48b5e3c3e8186800000000000000 */
+-  L(1.28905095007628295311619126550795045E+00), /* 3fff49ff3e397492bc00000000000000 */
+-  L(1.29409615284637330434591717676084954E+00), /* 3fff4b49e2ae5ac67400000000000000 */
+-  L(1.29916110198179535206719492634874769E+00), /* 3fff4c95d26d3f440800000000000000 */
+-  L(1.30424587476763775839572190307080746E+00), /* 3fff4de30ec211e60000000000000000 */
+-  L(1.30935054879147461104338390214252286E+00), /* 3fff4f3198fa0f1cf800000000000000 */
+-  L(1.31447520194454914310711046709911898E+00), /* 3fff50817263c13cd000000000000000 */
+-  L(1.31961991242296217130558488861424848E+00), /* 3fff51d29c4f01cb3000000000000000 */
+-  L(1.32478475872886558573071624778094701E+00), /* 3fff5325180cfacf7800000000000000 */
+-  L(1.32996981967165983640200010995613411E+00), /* 3fff5478e6f02823d000000000000000 */
+-  L(1.33517517436919680440254865061433520E+00), /* 3fff55ce0a4c58c7bc00000000000000 */
+-  L(1.34040090224898678084031189428060316E+00), /* 3fff57248376b033d800000000000000 */
+-  L(1.34564708304941055283521222918352578E+00), /* 3fff587c53c5a7af0400000000000000 */
+-  L(1.35091379682093615244298234756570309E+00), /* 3fff59d57c910fa4e000000000000000 */
+-  L(1.35620112392734021300455538039386738E+00), /* 3fff5b2fff3210fd9400000000000000 */
+-  L(1.36150914504693443252136830778908916E+00), /* 3fff5c8bdd032e770800000000000000 */
+-  L(1.36683794117379636690046140756749082E+00), /* 3fff5de9176045ff5400000000000000 */
+-  L(1.37218759361900544124779344201670028E+00), /* 3fff5f47afa69210a800000000000000 */
+-  L(1.37755818401188367960941150158760138E+00), /* 3fff60a7a734ab0e8800000000000000 */
+-  L(1.38294979430124120867162673675920814E+00), /* 3fff6208ff6a88a46000000000000000 */
+-  L(1.38836250675662681297595213436579797E+00), /* 3fff636bb9a983258400000000000000 */
+-  L(1.39379640396958309755959248832368758E+00), /* 3fff64cfd75454ee7c00000000000000 */
+-  L(1.39925156885490681313299887733592186E+00), /* 3fff663559cf1bc7c400000000000000 */
+-  L(1.40472808465191417726103395580139477E+00), /* 3fff679c427f5a49f400000000000000 */
+-  L(1.41022603492571069194738697660795879E+00), /* 3fff690492cbf9432c00000000000000 */
+-  L(1.41574550356846662335641440222389065E+00), /* 3fff6a6e4c1d491e1800000000000000 */
++  1.00000000000000000000000000000000000E+00L, /* 3fff0000000000000000000000000000 */
++  1.00391388933834757590801700644078664E+00L, /* 3fff0100802ab5577800000000000000 */
++  1.00784309720644799091004983893071767E+00L, /* 3fff0202015600445c00000000000000 */
++  1.01178768355933151879000320150225889E+00L, /* 3fff0304848362076c00000000000000 */
++  1.01574770858668572692806719715008512E+00L, /* 3fff04080ab55de39000000000000000 */
++  1.01972323271377413034244341361045372E+00L, /* 3fff050c94ef7a206c00000000000000 */
++  1.02371431660235789884438872832106426E+00L, /* 3fff06122436410dd000000000000000 */
++  1.02772102115162167201845022646011785E+00L, /* 3fff0718b98f42085000000000000000 */
++  1.03174340749910264936062276319717057E+00L, /* 3fff08205601127ec800000000000000 */
++  1.03578153702162378824169763902318664E+00L, /* 3fff0928fa934ef90800000000000000 */
++  1.03983547133622999947277776300325058E+00L, /* 3fff0a32a84e9c1f5800000000000000 */
++  1.04390527230112850620713516036630608E+00L, /* 3fff0b3d603ca7c32800000000000000 */
++  1.04799100201663270004459604933799710E+00L, /* 3fff0c49236829e8bc00000000000000 */
++  1.05209272282610977189420964350574650E+00L, /* 3fff0d55f2dce5d1e800000000000000 */
++  1.05621049731693195106174698594259098E+00L, /* 3fff0e63cfa7ab09d000000000000000 */
++  1.06034438832143151909548350886325352E+00L, /* 3fff0f72bad65671b800000000000000 */
++  1.06449445891785943185681162503897212E+00L, /* 3fff1082b577d34ed800000000000000 */
++  1.06866077243134810492719566354935523E+00L, /* 3fff1193c09c1c595c00000000000000 */
++  1.07284339243487741866189821848820429E+00L, /* 3fff12a5dd543ccc4c00000000000000 */
++  1.07704238275024494209120007326419000E+00L, /* 3fff13b90cb25176a400000000000000 */
++  1.08125780744903959851299646288680378E+00L, /* 3fff14cd4fc989cd6400000000000000 */
++  1.08548973085361949442173568058933597E+00L, /* 3fff15e2a7ae28fecc00000000000000 */
++  1.08973821753809324563988525369495619E+00L, /* 3fff16f9157587069400000000000000 */
++  1.09400333232930546678574046381982043E+00L, /* 3fff18109a3611c35000000000000000 */
++  1.09828514030782586896606289883493446E+00L, /* 3fff192937074e0cd800000000000000 */
++  1.10258370680894224324930519287590869E+00L, /* 3fff1a42ed01d8cbc800000000000000 */
++  1.10689909742365749645287564817408565E+00L, /* 3fff1b5dbd3f68122400000000000000 */
++  1.11123137799969046168868658241990488E+00L, /* 3fff1c79a8dacc350c00000000000000 */
++  1.11558061464248076122274255794764031E+00L, /* 3fff1d96b0eff0e79400000000000000 */
++  1.11994687371619722204840741142106708E+00L, /* 3fff1eb4d69bde569c00000000000000 */
++  1.12433022184475073235176978414529003E+00L, /* 3fff1fd41afcba45e800000000000000 */
++  1.12873072591281087273529237791080959E+00L, /* 3fff20f47f31c92e4800000000000000 */
++  1.13314845306682632219974493636982515E+00L, /* 3fff2216045b6f5cd000000000000000 */
++  1.13758347071604959399593326452304609E+00L, /* 3fff2338ab9b32134800000000000000 */
++  1.14203584653356560174586320499656722E+00L, /* 3fff245c7613b8a9b000000000000000 */
++  1.14650564845732405583333957110880874E+00L, /* 3fff258164e8cdb0d800000000000000 */
++  1.15099294469117646722011727433709893E+00L, /* 3fff26a7793f60164400000000000000 */
++  1.15549780370591653744227755851170514E+00L, /* 3fff27ceb43d84490400000000000000 */
++  1.16002029424032515603215642840950750E+00L, /* 3fff28f7170a755fd800000000000000 */
++  1.16456048530221917269855680387991015E+00L, /* 3fff2a20a2ce96406400000000000000 */
++  1.16911844616950438835445424956560601E+00L, /* 3fff2b4b58b372c79400000000000000 */
++  1.17369424639123270948104504896036815E+00L, /* 3fff2c7739e3c0f32c00000000000000 */
++  1.17828795578866324378353169777255971E+00L, /* 3fff2da4478b620c7400000000000000 */
++  1.18289964445632783673900689791480545E+00L, /* 3fff2ed282d763d42400000000000000 */
++  1.18752938276310060494722620205720887E+00L, /* 3fff3001ecf601af7000000000000000 */
++  1.19217724135327157730657177125976887E+00L, /* 3fff31328716a5d63c00000000000000 */
++  1.19684329114762477708211463323095813E+00L, /* 3fff32645269ea829000000000000000 */
++  1.20152760334452030077656559114984702E+00L, /* 3fff339750219b212c00000000000000 */
++  1.20623024942098072687102217059873510E+00L, /* 3fff34cb8170b5835400000000000000 */
++  1.21095130113378179892436037334846333E+00L, /* 3fff3600e78b6b11d000000000000000 */
++  1.21569083052054743854242246925423387E+00L, /* 3fff373783a722012400000000000000 */
++  1.22044890990084875515009343871497549E+00L, /* 3fff386f56fa7686e800000000000000 */
++  1.22522561187730755216662714701669756E+00L, /* 3fff39a862bd3c106400000000000000 */
++  1.23002100933670455162882717559114099E+00L, /* 3fff3ae2a8287e7a8000000000000000 */
++  1.23483517545109100499445276000187732E+00L, /* 3fff3c1e2876834aa800000000000000 */
++  1.23966818367890557750499169742397498E+00L, /* 3fff3d5ae4e2cae92c00000000000000 */
++  1.24452010776609517384017067342938390E+00L, /* 3fff3e98deaa11dcbc00000000000000 */
++  1.24939102174724003813111039562500082E+00L, /* 3fff3fd8170a52071800000000000000 */
++  1.25428099994668373895478907797951251E+00L, /* 3fff41188f42c3e32000000000000000 */
++  1.25919011697966698459794088194030337E+00L, /* 3fff425a4893dfc3f800000000000000 */
++  1.26411844775346637881341393949696794E+00L, /* 3fff439d443f5f159000000000000000 */
++  1.26906606746853711786826579555054195E+00L, /* 3fff44e183883d9e4800000000000000 */
++  1.27403305161966090564007458851847332E+00L, /* 3fff462707b2bac20c00000000000000 */
++  1.27901947599709753244923149395617656E+00L, /* 3fff476dd2045ac67800000000000000 */
++  1.28402541668774150540599521264084615E+00L, /* 3fff48b5e3c3e8186800000000000000 */
++  1.28905095007628295311619126550795045E+00L, /* 3fff49ff3e397492bc00000000000000 */
++  1.29409615284637330434591717676084954E+00L, /* 3fff4b49e2ae5ac67400000000000000 */
++  1.29916110198179535206719492634874769E+00L, /* 3fff4c95d26d3f440800000000000000 */
++  1.30424587476763775839572190307080746E+00L, /* 3fff4de30ec211e60000000000000000 */
++  1.30935054879147461104338390214252286E+00L, /* 3fff4f3198fa0f1cf800000000000000 */
++  1.31447520194454914310711046709911898E+00L, /* 3fff50817263c13cd000000000000000 */
++  1.31961991242296217130558488861424848E+00L, /* 3fff51d29c4f01cb3000000000000000 */
++  1.32478475872886558573071624778094701E+00L, /* 3fff5325180cfacf7800000000000000 */
++  1.32996981967165983640200010995613411E+00L, /* 3fff5478e6f02823d000000000000000 */
++  1.33517517436919680440254865061433520E+00L, /* 3fff55ce0a4c58c7bc00000000000000 */
++  1.34040090224898678084031189428060316E+00L, /* 3fff57248376b033d800000000000000 */
++  1.34564708304941055283521222918352578E+00L, /* 3fff587c53c5a7af0400000000000000 */
++  1.35091379682093615244298234756570309E+00L, /* 3fff59d57c910fa4e000000000000000 */
++  1.35620112392734021300455538039386738E+00L, /* 3fff5b2fff3210fd9400000000000000 */
++  1.36150914504693443252136830778908916E+00L, /* 3fff5c8bdd032e770800000000000000 */
++  1.36683794117379636690046140756749082E+00L, /* 3fff5de9176045ff5400000000000000 */
++  1.37218759361900544124779344201670028E+00L, /* 3fff5f47afa69210a800000000000000 */
++  1.37755818401188367960941150158760138E+00L, /* 3fff60a7a734ab0e8800000000000000 */
++  1.38294979430124120867162673675920814E+00L, /* 3fff6208ff6a88a46000000000000000 */
++  1.38836250675662681297595213436579797E+00L, /* 3fff636bb9a983258400000000000000 */
++  1.39379640396958309755959248832368758E+00L, /* 3fff64cfd75454ee7c00000000000000 */
++  1.39925156885490681313299887733592186E+00L, /* 3fff663559cf1bc7c400000000000000 */
++  1.40472808465191417726103395580139477E+00L, /* 3fff679c427f5a49f400000000000000 */
++  1.41022603492571069194738697660795879E+00L, /* 3fff690492cbf9432c00000000000000 */
++  1.41574550356846662335641440222389065E+00L, /* 3fff6a6e4c1d491e1800000000000000 */
+ 
+-  L(9.98018323540573404351050612604012713E-01), /* 3ffefefc41f8d4bdb000000000000000 */
+-  L(9.98048781107475468932221929208026268E-01), /* 3ffeff003ff556aa8800000000000000 */
+-  L(9.98079239603882895082165305211674422E-01), /* 3ffeff043df9d4986000000000000000 */
+-  L(9.98109699029824021243584297735651489E-01), /* 3ffeff083c064e972c00000000000000 */
+-  L(9.98140159385327269125909310787392315E-01), /* 3ffeff0c3a1ac4b6ec00000000000000 */
+-  L(9.98170620670420977171843901487591211E-01), /* 3ffeff10383737079400000000000000 */
+-  L(9.98201082885133511579667242585856002E-01), /* 3ffeff14365ba5991c00000000000000 */
+-  L(9.98231546029493238547658506831794512E-01), /* 3ffeff183488107b7c00000000000000 */
+-  L(9.98262010103528552029672482603928074E-01), /* 3ffeff1c32bc77beb000000000000000 */
+-  L(9.98292475107267818223988342651864514E-01), /* 3ffeff2030f8db72b000000000000000 */
+-  L(9.98322941040739375573309644096298143E-01), /* 3ffeff242f3d3ba77000000000000000 */
+-  L(9.98353407903971645787066790944663808E-01), /* 3ffeff282d89986cf000000000000000 */
+-  L(9.98383875696992967307963340317655820E-01), /* 3ffeff2c2bddf1d32400000000000000 */
+-  L(9.98414344419831761845429696222709026E-01), /* 3ffeff302a3a47ea0c00000000000000 */
+-  L(9.98444814072516340086593800151604228E-01), /* 3ffeff34289e9ac19800000000000000 */
+-  L(9.98475284655075123740886056111776270E-01), /* 3ffeff38270aea69c800000000000000 */
+-  L(9.98505756167536479006585636852832977E-01), /* 3ffeff3c257f36f29400000000000000 */
+-  L(9.98536228609928799837547330753295682E-01), /* 3ffeff4023fb806bf800000000000000 */
+-  L(9.98566701982280452432050310562772211E-01), /* 3ffeff44227fc6e5ec00000000000000 */
+-  L(9.98597176284619802988373749030870385E-01), /* 3ffeff48210c0a706800000000000000 */
+-  L(9.98627651516975245460372434536111541E-01), /* 3ffeff4c1fa04b1b6800000000000000 */
+-  L(9.98658127679375173801901155457017012E-01), /* 3ffeff501e3c88f6e800000000000000 */
+-  L(9.98688604771847954211239084543194622E-01), /* 3ffeff541ce0c412e000000000000000 */
+-  L(9.98719082794421980642241010173165705E-01), /* 3ffeff581b8cfc7f4c00000000000000 */
+-  L(9.98749561747125619293186105096538085E-01), /* 3ffeff5c1a41324c2400000000000000 */
+-  L(9.98780041629987291873504773320746608E-01), /* 3ffeff6018fd65896800000000000000 */
+-  L(9.98810522443035364581476187595399097E-01), /* 3ffeff6417c196471000000000000000 */
+-  L(9.98841004186298203615379520670103375E-01), /* 3ffeff68168dc4951400000000000000 */
+-  L(9.98871486859804230684645176552294288E-01), /* 3ffeff6c1561f0837400000000000000 */
+-  L(9.98901970463581839743127943620493170E-01), /* 3ffeff70143e1a222c00000000000000 */
+-  L(9.98932454997659369233531378995394334E-01), /* 3ffeff74132241813000000000000000 */
+-  L(9.98962940462065268620861502313346136E-01), /* 3ffeff78120e66b08400000000000000 */
+-  L(9.98993426856827904103397486323956400E-01), /* 3ffeff7c110289c02000000000000000 */
+-  L(9.99023914181975669634994119405746460E-01), /* 3ffeff800ffeaac00000000000000000 */
+-  L(9.99054402437536959169506189937237650E-01), /* 3ffeff840f02c9c02000000000000000 */
+-  L(9.99084891623540138905212870668037795E-01), /* 3ffeff880e0ee6d07800000000000000 */
+-  L(9.99115381740013658307120181234495249E-01), /* 3ffeff8c0d2302010c00000000000000 */
+-  L(9.99145872786985911329082910015131347E-01), /* 3ffeff900c3f1b61d800000000000000 */
+-  L(9.99176364764485236413804614130640402E-01), /* 3ffeff940b633302d000000000000000 */
+-  L(9.99206857672540083026291313217370771E-01), /* 3ffeff980a8f48f3f800000000000000 */
+-  L(9.99237351511178817364822180024930276E-01), /* 3ffeff9c09c35d454800000000000000 */
+-  L(9.99267846280429861138827618560753763E-01), /* 3ffeffa008ff7006c000000000000000 */
+-  L(9.99298341980321608302162417203362565E-01), /* 3ffeffa4084381485c00000000000000 */
+-  L(9.99328838610882452808681364331278019E-01), /* 3ffeffa8078f911a1800000000000000 */
+-  L(9.99359336172140816367814863951934967E-01), /* 3ffeffac06e39f8bf400000000000000 */
+-  L(9.99389834664125092933417704443854745E-01), /* 3ffeffb0063facadec00000000000000 */
+-  L(9.99420334086863676459344674185558688E-01), /* 3ffeffb405a3b88ffc00000000000000 */
+-  L(9.99450834440384988655026177184481639E-01), /* 3ffeffb8050fc3422400000000000000 */
+-  L(9.99481335724717395718741386190231424E-01), /* 3ffeffbc0483ccd45c00000000000000 */
+-  L(9.99511837939889374871071936468069907E-01), /* 3ffeffc003ffd556ac00000000000000 */
+-  L(9.99542341085929264554721385138691403E-01), /* 3ffeffc40383dcd90800000000000000 */
+-  L(9.99572845162865514234695751838444266E-01), /* 3ffeffc8030fe36b7400000000000000 */
+-  L(9.99603350170726517864849824945849832E-01), /* 3ffeffcc02a3e91dec00000000000000 */
+-  L(9.99633856109540669399038392839429434E-01), /* 3ffeffd0023fee006c00000000000000 */
+-  L(9.99664362979336418302267475155531429E-01), /* 3ffeffd401e3f222f800000000000000 */
+-  L(9.99694870780142130772816244643763639E-01), /* 3ffeffd8018ff5958800000000000000 */
+-  L(9.99725379511986284031266336569387931E-01), /* 3ffeffdc0143f8682400000000000000 */
+-  L(9.99755889174897216520321308053098619E-01), /* 3ffeffe000fffaaac000000000000000 */
+-  L(9.99786399768903377704987178731244057E-01), /* 3ffeffe400c3fc6d6000000000000000 */
+-  L(9.99816911294033217050269968240172602E-01), /* 3ffeffe8008ffdc00800000000000000 */
+-  L(9.99847423750315072998873233700578567E-01), /* 3ffeffec0063feb2ac00000000000000 */
+-  L(9.99877937137777450526954226006637327E-01), /* 3ffefff0003fff555800000000000000 */
+-  L(9.99908451456448688077216502279043198E-01), /* 3ffefff40023ffb80000000000000000 */
+-  L(9.99938966706357262870241697783058044E-01), /* 3ffefff8000fffeaac00000000000000 */
+-  L(9.99969482887531541104308985268289689E-01), /* 3ffefffc0003fffd5400000000000000 */
++  9.98018323540573404351050612604012713E-01L, /* 3ffefefc41f8d4bdb000000000000000 */
++  9.98048781107475468932221929208026268E-01L, /* 3ffeff003ff556aa8800000000000000 */
++  9.98079239603882895082165305211674422E-01L, /* 3ffeff043df9d4986000000000000000 */
++  9.98109699029824021243584297735651489E-01L, /* 3ffeff083c064e972c00000000000000 */
++  9.98140159385327269125909310787392315E-01L, /* 3ffeff0c3a1ac4b6ec00000000000000 */
++  9.98170620670420977171843901487591211E-01L, /* 3ffeff10383737079400000000000000 */
++  9.98201082885133511579667242585856002E-01L, /* 3ffeff14365ba5991c00000000000000 */
++  9.98231546029493238547658506831794512E-01L, /* 3ffeff183488107b7c00000000000000 */
++  9.98262010103528552029672482603928074E-01L, /* 3ffeff1c32bc77beb000000000000000 */
++  9.98292475107267818223988342651864514E-01L, /* 3ffeff2030f8db72b000000000000000 */
++  9.98322941040739375573309644096298143E-01L, /* 3ffeff242f3d3ba77000000000000000 */
++  9.98353407903971645787066790944663808E-01L, /* 3ffeff282d89986cf000000000000000 */
++  9.98383875696992967307963340317655820E-01L, /* 3ffeff2c2bddf1d32400000000000000 */
++  9.98414344419831761845429696222709026E-01L, /* 3ffeff302a3a47ea0c00000000000000 */
++  9.98444814072516340086593800151604228E-01L, /* 3ffeff34289e9ac19800000000000000 */
++  9.98475284655075123740886056111776270E-01L, /* 3ffeff38270aea69c800000000000000 */
++  9.98505756167536479006585636852832977E-01L, /* 3ffeff3c257f36f29400000000000000 */
++  9.98536228609928799837547330753295682E-01L, /* 3ffeff4023fb806bf800000000000000 */
++  9.98566701982280452432050310562772211E-01L, /* 3ffeff44227fc6e5ec00000000000000 */
++  9.98597176284619802988373749030870385E-01L, /* 3ffeff48210c0a706800000000000000 */
++  9.98627651516975245460372434536111541E-01L, /* 3ffeff4c1fa04b1b6800000000000000 */
++  9.98658127679375173801901155457017012E-01L, /* 3ffeff501e3c88f6e800000000000000 */
++  9.98688604771847954211239084543194622E-01L, /* 3ffeff541ce0c412e000000000000000 */
++  9.98719082794421980642241010173165705E-01L, /* 3ffeff581b8cfc7f4c00000000000000 */
++  9.98749561747125619293186105096538085E-01L, /* 3ffeff5c1a41324c2400000000000000 */
++  9.98780041629987291873504773320746608E-01L, /* 3ffeff6018fd65896800000000000000 */
++  9.98810522443035364581476187595399097E-01L, /* 3ffeff6417c196471000000000000000 */
++  9.98841004186298203615379520670103375E-01L, /* 3ffeff68168dc4951400000000000000 */
++  9.98871486859804230684645176552294288E-01L, /* 3ffeff6c1561f0837400000000000000 */
++  9.98901970463581839743127943620493170E-01L, /* 3ffeff70143e1a222c00000000000000 */
++  9.98932454997659369233531378995394334E-01L, /* 3ffeff74132241813000000000000000 */
++  9.98962940462065268620861502313346136E-01L, /* 3ffeff78120e66b08400000000000000 */
++  9.98993426856827904103397486323956400E-01L, /* 3ffeff7c110289c02000000000000000 */
++  9.99023914181975669634994119405746460E-01L, /* 3ffeff800ffeaac00000000000000000 */
++  9.99054402437536959169506189937237650E-01L, /* 3ffeff840f02c9c02000000000000000 */
++  9.99084891623540138905212870668037795E-01L, /* 3ffeff880e0ee6d07800000000000000 */
++  9.99115381740013658307120181234495249E-01L, /* 3ffeff8c0d2302010c00000000000000 */
++  9.99145872786985911329082910015131347E-01L, /* 3ffeff900c3f1b61d800000000000000 */
++  9.99176364764485236413804614130640402E-01L, /* 3ffeff940b633302d000000000000000 */
++  9.99206857672540083026291313217370771E-01L, /* 3ffeff980a8f48f3f800000000000000 */
++  9.99237351511178817364822180024930276E-01L, /* 3ffeff9c09c35d454800000000000000 */
++  9.99267846280429861138827618560753763E-01L, /* 3ffeffa008ff7006c000000000000000 */
++  9.99298341980321608302162417203362565E-01L, /* 3ffeffa4084381485c00000000000000 */
++  9.99328838610882452808681364331278019E-01L, /* 3ffeffa8078f911a1800000000000000 */
++  9.99359336172140816367814863951934967E-01L, /* 3ffeffac06e39f8bf400000000000000 */
++  9.99389834664125092933417704443854745E-01L, /* 3ffeffb0063facadec00000000000000 */
++  9.99420334086863676459344674185558688E-01L, /* 3ffeffb405a3b88ffc00000000000000 */
++  9.99450834440384988655026177184481639E-01L, /* 3ffeffb8050fc3422400000000000000 */
++  9.99481335724717395718741386190231424E-01L, /* 3ffeffbc0483ccd45c00000000000000 */
++  9.99511837939889374871071936468069907E-01L, /* 3ffeffc003ffd556ac00000000000000 */
++  9.99542341085929264554721385138691403E-01L, /* 3ffeffc40383dcd90800000000000000 */
++  9.99572845162865514234695751838444266E-01L, /* 3ffeffc8030fe36b7400000000000000 */
++  9.99603350170726517864849824945849832E-01L, /* 3ffeffcc02a3e91dec00000000000000 */
++  9.99633856109540669399038392839429434E-01L, /* 3ffeffd0023fee006c00000000000000 */
++  9.99664362979336418302267475155531429E-01L, /* 3ffeffd401e3f222f800000000000000 */
++  9.99694870780142130772816244643763639E-01L, /* 3ffeffd8018ff5958800000000000000 */
++  9.99725379511986284031266336569387931E-01L, /* 3ffeffdc0143f8682400000000000000 */
++  9.99755889174897216520321308053098619E-01L, /* 3ffeffe000fffaaac000000000000000 */
++  9.99786399768903377704987178731244057E-01L, /* 3ffeffe400c3fc6d6000000000000000 */
++  9.99816911294033217050269968240172602E-01L, /* 3ffeffe8008ffdc00800000000000000 */
++  9.99847423750315072998873233700578567E-01L, /* 3ffeffec0063feb2ac00000000000000 */
++  9.99877937137777450526954226006637327E-01L, /* 3ffefff0003fff555800000000000000 */
++  9.99908451456448688077216502279043198E-01L, /* 3ffefff40023ffb80000000000000000 */
++  9.99938966706357262870241697783058044E-01L, /* 3ffefff8000fffeaac00000000000000 */
++  9.99969482887531541104308985268289689E-01L, /* 3ffefffc0003fffd5400000000000000 */
+ #define T_EXPL_RES2 (T_EXPL_RES1 + 1 + 89 + 65)
+-  L(1.00000000000000000000000000000000000E+00), /* 3fff0000000000000000000000000000 */
+-  L(1.00003051804379100575559391472779680E+00), /* 3fff0002000200015400000000000000 */
+-  L(1.00006103701893306334724798034585547E+00), /* 3fff00040008000aac00000000000000 */
+-  L(1.00009155692545448346209013834595680E+00), /* 3fff0006001200240000000000000000 */
+-  L(1.00012207776338379883185325525118969E+00), /* 3fff0008002000555800000000000000 */
+-  L(1.00015259953274932014366527255333494E+00), /* 3fff000a003200a6ac00000000000000 */
+-  L(1.00018312223357958012925905677548144E+00), /* 3fff000c004801200400000000000000 */
+-  L(1.00021364586590294498691378066723701E+00), /* 3fff000e006201c95c00000000000000 */
+-  L(1.00024417042974783642605984823603649E+00), /* 3fff0010008002aab400000000000000 */
+-  L(1.00027469592514273166727889474714175E+00), /* 3fff001200a203cc1000000000000000 */
+-  L(1.00030522235211605242000132420798764E+00), /* 3fff001400c805357000000000000000 */
+-  L(1.00033574971069616488250630936818197E+00), /* 3fff001600f206eed000000000000000 */
+-  L(1.00036627800091160178652671675081365E+00), /* 3fff0018012009003800000000000000 */
+-  L(1.00039680722279067381919048784766346E+00), /* 3fff001a01520b71a000000000000000 */
+-  L(1.00042733737636191371223048918182030E+00), /* 3fff001c01880e4b1000000000000000 */
+-  L(1.00045786846165368766392589350289200E+00), /* 3fff001e01c211948400000000000000 */
+-  L(1.00048840047869447289485833607614040E+00), /* 3fff0020020015560000000000000000 */
+-  L(1.00051893342751269111445822090900037E+00), /* 3fff0022024219978400000000000000 */
+-  L(1.00054946730813676403215595200890675E+00), /* 3fff002402881e611000000000000000 */
+-  L(1.00058000212059516886853316464112140E+00), /* 3fff002602d223baa800000000000000 */
+-  L(1.00061053786491632733302026281307917E+00), /* 3fff0028032029ac4c00000000000000 */
+-  L(1.00064107454112866113504765053221490E+00), /* 3fff002a0372303dfc00000000000000 */
+-  L(1.00067161214926059198404573180596344E+00), /* 3fff002c03c83777b800000000000000 */
+-  L(1.00070215068934059710059614189958666E+00), /* 3fff002e04223f618400000000000000 */
+-  L(1.00073269016139709819412928482051939E+00), /* 3fff0030048048036000000000000000 */
+-  L(1.00076323056545857248522679583402351E+00), /* 3fff003204e251655000000000000000 */
+-  L(1.00079377190155338617216784768970683E+00), /* 3fff003405485b8f5000000000000000 */
+-  L(1.00082431416971007198668530691065826E+00), /* 3fff003605b266896800000000000000 */
+-  L(1.00085485736995705163820957750431262E+00), /* 3fff00380620725b9800000000000000 */
+-  L(1.00088540150232269132501983222027775E+00), /* 3fff003a06927f0ddc00000000000000 */
+-  L(1.00091594656683552377884893758164253E+00), /* 3fff003c07088ca83c00000000000000 */
+-  L(1.00094649256352402622027852885366883E+00), /* 3fff003e07829b32bc00000000000000 */
+-  L(1.00097703949241650933643654752813745E+00), /* 3fff00400800aab55400000000000000 */
+-  L(1.00100758735354156137020709138596430E+00), /* 3fff00420882bb381000000000000000 */
+-  L(1.00103813614692760403102056443458423E+00), /* 3fff00440908ccc2f000000000000000 */
+-  L(1.00106868587260300351715613942360505E+00), /* 3fff00460992df5df000000000000000 */
+-  L(1.00109923653059629256034668287611566E+00), /* 3fff00480a20f3111800000000000000 */
+-  L(1.00112978812093589287002259879955091E+00), /* 3fff004a0ab307e46800000000000000 */
+-  L(1.00116034064365022615561429120134562E+00), /* 3fff004c0b491ddfe000000000000000 */
+-  L(1.00119089409876788066000585786241572E+00), /* 3fff004e0be3350b8c00000000000000 */
+-  L(1.00122144848631711155917400901671499E+00), /* 3fff00500c814d6f6000000000000000 */
+-  L(1.00125200380632656260715407370298635E+00), /* 3fff00520d2367136c00000000000000 */
+-  L(1.00128256005882454449107399341301061E+00), /* 3fff00540dc981ffa800000000000000 */
+-  L(1.00131311724383964545381786592770368E+00), /* 3fff00560e739e3c2000000000000000 */
+-  L(1.00134367536140017618251363273884635E+00), /* 3fff00580f21bbd0cc00000000000000 */
+-  L(1.00137423441153472492004539162735455E+00), /* 3fff005a0fd3dac5b800000000000000 */
+-  L(1.00140479439427171337584354660066310E+00), /* 3fff005c1089fb22e400000000000000 */
+-  L(1.00143535530963956325933850166620687E+00), /* 3fff005e11441cf05000000000000000 */
+-  L(1.00146591715766680730226312334707472E+00), /* 3fff0060120240360400000000000000 */
+-  L(1.00149647993838186721404781565070152E+00), /* 3fff006212c464fc0000000000000000 */
+-  L(1.00152704365181316470412298258452211E+00), /* 3fff0064138a8b4a4400000000000000 */
+-  L(1.00155760829798923250422149067162536E+00), /* 3fff00661454b328d800000000000000 */
+-  L(1.00158817387693849232377374391944613E+00), /* 3fff00681522dc9fbc00000000000000 */
+-  L(1.00161874038868942138336137759324629E+00), /* 3fff006a15f507b6f400000000000000 */
+-  L(1.00164930783327055241471725821611471E+00), /* 3fff006c16cb34768800000000000000 */
+-  L(1.00167987621071025161612055853765924E+00), /* 3fff006e17a562e67400000000000000 */
+-  L(1.00171044552103705171930414508096874E+00), /* 3fff00701883930ec000000000000000 */
+-  L(1.00174101576427937443369842185347807E+00), /* 3fff00721965c4f76c00000000000000 */
+-  L(1.00177158694046569697988502412044909E+00), /* 3fff00741a4bf8a87c00000000000000 */
+-  L(1.00180215904962455208959681840497069E+00), /* 3fff00761b362e29f800000000000000 */
+-  L(1.00183273209178441698341543997230474E+00), /* 3fff00781c246583e400000000000000 */
+-  L(1.00186330606697365785962006157205906E+00), /* 3fff007a1d169ebe3c00000000000000 */
+-  L(1.00189388097522080744994354972732253E+00), /* 3fff007c1e0cd9e10800000000000000 */
+-  L(1.00192445681655439848611877096118405E+00), /* 3fff007e1f0716f45000000000000000 */
+-  L(1.00195503359100279716642489802325144E+00), /* 3fff0080200556001000000000000000 */
+-  L(1.00198561129859459173374602869444061E+00), /* 3fff00822107970c5400000000000000 */
++  1.00000000000000000000000000000000000E+00L, /* 3fff0000000000000000000000000000 */
++  1.00003051804379100575559391472779680E+00L, /* 3fff0002000200015400000000000000 */
++  1.00006103701893306334724798034585547E+00L, /* 3fff00040008000aac00000000000000 */
++  1.00009155692545448346209013834595680E+00L, /* 3fff0006001200240000000000000000 */
++  1.00012207776338379883185325525118969E+00L, /* 3fff0008002000555800000000000000 */
++  1.00015259953274932014366527255333494E+00L, /* 3fff000a003200a6ac00000000000000 */
++  1.00018312223357958012925905677548144E+00L, /* 3fff000c004801200400000000000000 */
++  1.00021364586590294498691378066723701E+00L, /* 3fff000e006201c95c00000000000000 */
++  1.00024417042974783642605984823603649E+00L, /* 3fff0010008002aab400000000000000 */
++  1.00027469592514273166727889474714175E+00L, /* 3fff001200a203cc1000000000000000 */
++  1.00030522235211605242000132420798764E+00L, /* 3fff001400c805357000000000000000 */
++  1.00033574971069616488250630936818197E+00L, /* 3fff001600f206eed000000000000000 */
++  1.00036627800091160178652671675081365E+00L, /* 3fff0018012009003800000000000000 */
++  1.00039680722279067381919048784766346E+00L, /* 3fff001a01520b71a000000000000000 */
++  1.00042733737636191371223048918182030E+00L, /* 3fff001c01880e4b1000000000000000 */
++  1.00045786846165368766392589350289200E+00L, /* 3fff001e01c211948400000000000000 */
++  1.00048840047869447289485833607614040E+00L, /* 3fff0020020015560000000000000000 */
++  1.00051893342751269111445822090900037E+00L, /* 3fff0022024219978400000000000000 */
++  1.00054946730813676403215595200890675E+00L, /* 3fff002402881e611000000000000000 */
++  1.00058000212059516886853316464112140E+00L, /* 3fff002602d223baa800000000000000 */
++  1.00061053786491632733302026281307917E+00L, /* 3fff0028032029ac4c00000000000000 */
++  1.00064107454112866113504765053221490E+00L, /* 3fff002a0372303dfc00000000000000 */
++  1.00067161214926059198404573180596344E+00L, /* 3fff002c03c83777b800000000000000 */
++  1.00070215068934059710059614189958666E+00L, /* 3fff002e04223f618400000000000000 */
++  1.00073269016139709819412928482051939E+00L, /* 3fff0030048048036000000000000000 */
++  1.00076323056545857248522679583402351E+00L, /* 3fff003204e251655000000000000000 */
++  1.00079377190155338617216784768970683E+00L, /* 3fff003405485b8f5000000000000000 */
++  1.00082431416971007198668530691065826E+00L, /* 3fff003605b266896800000000000000 */
++  1.00085485736995705163820957750431262E+00L, /* 3fff00380620725b9800000000000000 */
++  1.00088540150232269132501983222027775E+00L, /* 3fff003a06927f0ddc00000000000000 */
++  1.00091594656683552377884893758164253E+00L, /* 3fff003c07088ca83c00000000000000 */
++  1.00094649256352402622027852885366883E+00L, /* 3fff003e07829b32bc00000000000000 */
++  1.00097703949241650933643654752813745E+00L, /* 3fff00400800aab55400000000000000 */
++  1.00100758735354156137020709138596430E+00L, /* 3fff00420882bb381000000000000000 */
++  1.00103813614692760403102056443458423E+00L, /* 3fff00440908ccc2f000000000000000 */
++  1.00106868587260300351715613942360505E+00L, /* 3fff00460992df5df000000000000000 */
++  1.00109923653059629256034668287611566E+00L, /* 3fff00480a20f3111800000000000000 */
++  1.00112978812093589287002259879955091E+00L, /* 3fff004a0ab307e46800000000000000 */
++  1.00116034064365022615561429120134562E+00L, /* 3fff004c0b491ddfe000000000000000 */
++  1.00119089409876788066000585786241572E+00L, /* 3fff004e0be3350b8c00000000000000 */
++  1.00122144848631711155917400901671499E+00L, /* 3fff00500c814d6f6000000000000000 */
++  1.00125200380632656260715407370298635E+00L, /* 3fff00520d2367136c00000000000000 */
++  1.00128256005882454449107399341301061E+00L, /* 3fff00540dc981ffa800000000000000 */
++  1.00131311724383964545381786592770368E+00L, /* 3fff00560e739e3c2000000000000000 */
++  1.00134367536140017618251363273884635E+00L, /* 3fff00580f21bbd0cc00000000000000 */
++  1.00137423441153472492004539162735455E+00L, /* 3fff005a0fd3dac5b800000000000000 */
++  1.00140479439427171337584354660066310E+00L, /* 3fff005c1089fb22e400000000000000 */
++  1.00143535530963956325933850166620687E+00L, /* 3fff005e11441cf05000000000000000 */
++  1.00146591715766680730226312334707472E+00L, /* 3fff0060120240360400000000000000 */
++  1.00149647993838186721404781565070152E+00L, /* 3fff006212c464fc0000000000000000 */
++  1.00152704365181316470412298258452211E+00L, /* 3fff0064138a8b4a4400000000000000 */
++  1.00155760829798923250422149067162536E+00L, /* 3fff00661454b328d800000000000000 */
++  1.00158817387693849232377374391944613E+00L, /* 3fff00681522dc9fbc00000000000000 */
++  1.00161874038868942138336137759324629E+00L, /* 3fff006a15f507b6f400000000000000 */
++  1.00164930783327055241471725821611471E+00L, /* 3fff006c16cb34768800000000000000 */
++  1.00167987621071025161612055853765924E+00L, /* 3fff006e17a562e67400000000000000 */
++  1.00171044552103705171930414508096874E+00L, /* 3fff00701883930ec000000000000000 */
++  1.00174101576427937443369842185347807E+00L, /* 3fff00721965c4f76c00000000000000 */
++  1.00177158694046569697988502412044909E+00L, /* 3fff00741a4bf8a87c00000000000000 */
++  1.00180215904962455208959681840497069E+00L, /* 3fff00761b362e29f800000000000000 */
++  1.00183273209178441698341543997230474E+00L, /* 3fff00781c246583e400000000000000 */
++  1.00186330606697365785962006157205906E+00L, /* 3fff007a1d169ebe3c00000000000000 */
++  1.00189388097522080744994354972732253E+00L, /* 3fff007c1e0cd9e10800000000000000 */
++  1.00192445681655439848611877096118405E+00L, /* 3fff007e1f0716f45000000000000000 */
++  1.00195503359100279716642489802325144E+00L, /* 3fff0080200556001000000000000000 */
++  1.00198561129859459173374602869444061E+00L, /* 3fff00822107970c5400000000000000 */
+ };
diff --git a/gnu/packages/patches/glibc-2-26-0058.patch b/gnu/packages/patches/glibc-2-26-0058.patch
new file mode 100644
index 000000000..d00507901
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0058.patch
@@ -0,0 +1,86 @@
+From f725563967c1f277e0f02bb1516fe9ebfa4737bf Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gabriel@inconstante.eti.br>
+Date: Sun, 10 Sep 2017 10:31:47 -0300
+Subject: [PATCH 58/90] Remove conditional on LDBL_MANT_DIG from e_lgammal_r.c
+
+The IEEE 754 implementation of lgammal in sysdeps/ieee754/ldbl-128/ used
+to be shared by IBM's implementation in sysdeps/ieee754/ldbl-128ibm/ (by
+an inclusion of the source file).  In order for the algorithm to work
+for IBM's implementation, a check for LDBL_MANT_DIG was required. Since
+the source file is no longer shared, the requirement for the check is
+gone.  This patch removes the conditionals.
+
+Tested for powerpc64le and s390x.
+
+	* sysdeps/ieee754/ldbl-128/e_lgammal_r.c (__ieee754_lgammal_r):
+	Remove conditionals on LDBL_MANT_DIG.
+	* sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c
+	(__ieee754_lgammal_r): Likewise.
+
+(cherry picked from commit 9ac3c68218b5bcbc40ae9e27b0b13f5e1c81f84c)
+
+diff --git a/ChangeLog b/ChangeLog
+index 21e923c2f7..846601bc21 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,10 @@
++2017-09-21  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
++
++	* sysdeps/ieee754/ldbl-128/e_lgammal_r.c (__ieee754_lgammal_r):
++	Remove conditionals on LDBL_MANT_DIG.
++	* sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c
++	(__ieee754_lgammal_r): Likewise.
++
+ 2017-09-21  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
+ 
+ 	* sysdeps/ieee754/ldbl-128ibm/e_expl.c: Remove definitions of
+diff --git a/sysdeps/ieee754/ldbl-128/e_lgammal_r.c b/sysdeps/ieee754/ldbl-128/e_lgammal_r.c
+index bef2601bce..a80c9eaf33 100644
+--- a/sysdeps/ieee754/ldbl-128/e_lgammal_r.c
++++ b/sysdeps/ieee754/ldbl-128/e_lgammal_r.c
+@@ -73,11 +73,7 @@
+ #include <float.h>
+ 
+ static const _Float128 PIL = L(3.1415926535897932384626433832795028841972E0);
+-#if LDBL_MANT_DIG == 106
+-static const _Float128 MAXLGM = L(0x5.d53649e2d469dbc1f01e99fd66p+1012);
+-#else
+ static const _Float128 MAXLGM = L(1.0485738685148938358098967157129705071571E4928);
+-#endif
+ static const _Float128 one = 1;
+ static const _Float128 huge = LDBL_MAX;
+ 
+@@ -777,7 +773,7 @@ __ieee754_lgammal_r (_Float128 x, int *signgamp)
+ 
+   if (x < 0)
+     {
+-      if (x < -2 && x > (LDBL_MANT_DIG == 106 ? -48 : -50))
++      if (x < -2 && x > -50)
+ 	return __lgamma_negl (x, signgamp);
+       q = -x;
+       p = __floorl (q);
+diff --git a/sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c b/sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c
+index 474773e81d..f881b8c0a4 100644
+--- a/sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c
++++ b/sysdeps/ieee754/ldbl-128ibm/e_lgammal_r.c
+@@ -23,11 +23,7 @@
+ #include <float.h>
+ 
+ static const long double PIL = 3.1415926535897932384626433832795028841972E0L;
+-#if LDBL_MANT_DIG == 106
+ static const long double MAXLGM = 0x5.d53649e2d469dbc1f01e99fd66p+1012L;
+-#else
+-static const long double MAXLGM = 1.0485738685148938358098967157129705071571E4928L;
+-#endif
+ static const long double one = 1;
+ static const long double huge = LDBL_MAX;
+ 
+@@ -727,7 +723,7 @@ __ieee754_lgammal_r (long double x, int *signgamp)
+ 
+   if (x < 0)
+     {
+-      if (x < -2 && x > (LDBL_MANT_DIG == 106 ? -48 : -50))
++      if (x < -2 && x > -48)
+ 	return __lgamma_negl (x, signgamp);
+       q = -x;
+       p = __floorl (q);
diff --git a/gnu/packages/patches/glibc-2-26-0059.patch b/gnu/packages/patches/glibc-2-26-0059.patch
new file mode 100644
index 000000000..2512b75e1
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0059.patch
@@ -0,0 +1,437 @@
+From 5ebb81e29243ff286bd46dea62fab46a40dfd6c3 Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Tue, 10 Oct 2017 11:50:41 +0200
+Subject: [PATCH 59/90] nss_files: Refactor gethostbyname3 multi case into
+ separate function
+
+This is in preparation of further cleanup work.
+
+(cherry picked from commit 8ed70de2faceb4bd7b35bbdc2b7e8c83d9a297ba)
+
+diff --git a/ChangeLog b/ChangeLog
+index 846601bc21..54347f5485 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-10-10  Florian Weimer  <fweimer@redhat.com>
++
++	* nss/nss_files/files-hosts.c (gethostbyname3_multi): New
++	function.
++	(_nss_files_gethostbyname3_r): Call it.
++
+ 2017-09-21  Gabriel F. T. Gomes  <gabriel@inconstante.eti.br>
+ 
+ 	* sysdeps/ieee754/ldbl-128/e_lgammal_r.c (__ieee754_lgammal_r):
+diff --git a/nss/nss_files/files-hosts.c b/nss/nss_files/files-hosts.c
+index bccb6a5780..867c10c2ef 100644
+--- a/nss/nss_files/files-hosts.c
++++ b/nss/nss_files/files-hosts.c
+@@ -115,6 +115,206 @@ DB_LOOKUP (hostbyaddr, ,,,
+ 	   }, const void *addr, socklen_t len, int af)
+ #undef EXTRA_ARGS_VALUE
+ 
++static enum nss_status
++gethostbyname3_multi (FILE * stream, const char *name, int af,
++		      struct hostent *result, char *buffer, size_t buflen,
++		      int *errnop, int *herrnop, int flags)
++{
++  /* We have to get all host entries from the file.  */
++  size_t tmp_buflen = MIN (buflen, 4096);
++  char tmp_buffer_stack[tmp_buflen]
++    __attribute__ ((__aligned__ (__alignof__ (struct hostent_data))));
++  char *tmp_buffer = tmp_buffer_stack;
++  struct hostent tmp_result_buf;
++  int naddrs = 1;
++  int naliases = 0;
++  char *bufferend;
++  bool tmp_buffer_malloced = false;
++  enum nss_status status;
++
++  while (result->h_aliases[naliases] != NULL)
++    ++naliases;
++
++  bufferend = (char *) &result->h_aliases[naliases + 1];
++
++ again:
++  while ((status = internal_getent (stream, &tmp_result_buf, tmp_buffer,
++				    tmp_buflen, errnop, herrnop, af,
++				    flags))
++	 == NSS_STATUS_SUCCESS)
++    {
++      int matches = 1;
++      struct hostent *old_result = result;
++      result = &tmp_result_buf;
++      /* The following piece is a bit clumsy but we want to use the
++	 `LOOKUP_NAME_CASE' value.  The optimizer should do its
++	 job.  */
++      do
++	{
++	  LOOKUP_NAME_CASE (h_name, h_aliases)
++	    result = old_result;
++	}
++      while ((matches = 0));
++
++      if (matches)
++	{
++	  /* We could be very clever and try to recycle a few bytes
++	     in the buffer instead of generating new arrays.  But
++	     we are not doing this here since it's more work than
++	     it's worth.  Simply let the user provide a bit bigger
++	     buffer.  */
++	  char **new_h_addr_list;
++	  char **new_h_aliases;
++	  int newaliases = 0;
++	  size_t newstrlen = 0;
++	  int cnt;
++
++	  /* Count the new aliases and the length of the strings.  */
++	  while (tmp_result_buf.h_aliases[newaliases] != NULL)
++	    {
++	      char *cp = tmp_result_buf.h_aliases[newaliases];
++	      ++newaliases;
++	      newstrlen += strlen (cp) + 1;
++	    }
++	  /* If the real name is different add it also to the
++	     aliases.  This means that there is a duplication
++	     in the alias list but this is really the user's
++	     problem.  */
++	  if (strcmp (old_result->h_name,
++		      tmp_result_buf.h_name) != 0)
++	    {
++	      ++newaliases;
++	      newstrlen += strlen (tmp_result_buf.h_name) + 1;
++	    }
++
++	  /* Make sure bufferend is aligned.  */
++	  assert ((bufferend - (char *) 0) % sizeof (char *) == 0);
++
++	  /* Now we can check whether the buffer is large enough.
++	     16 is the maximal size of the IP address.  */
++	  if (bufferend + 16 + (naddrs + 2) * sizeof (char *)
++	      + roundup (newstrlen, sizeof (char *))
++	      + (naliases + newaliases + 1) * sizeof (char *)
++	      >= buffer + buflen)
++	    {
++	      *errnop = ERANGE;
++	      *herrnop = NETDB_INTERNAL;
++	      status = NSS_STATUS_TRYAGAIN;
++	      goto out;
++	    }
++
++	  new_h_addr_list =
++	    (char **) (bufferend
++		       + roundup (newstrlen, sizeof (char *))
++		       + 16);
++	  new_h_aliases =
++	    (char **) ((char *) new_h_addr_list
++		       + (naddrs + 2) * sizeof (char *));
++
++	  /* Copy the old data in the new arrays.  */
++	  for (cnt = 0; cnt < naddrs; ++cnt)
++	    new_h_addr_list[cnt] = old_result->h_addr_list[cnt];
++
++	  for (cnt = 0; cnt < naliases; ++cnt)
++	    new_h_aliases[cnt] = old_result->h_aliases[cnt];
++
++	  /* Store the new strings.  */
++	  cnt = 0;
++	  while (tmp_result_buf.h_aliases[cnt] != NULL)
++	    {
++	      new_h_aliases[naliases++] = bufferend;
++	      bufferend = (__stpcpy (bufferend,
++				     tmp_result_buf.h_aliases[cnt])
++			   + 1);
++	      ++cnt;
++	    }
++
++	  if (cnt < newaliases)
++	    {
++	      new_h_aliases[naliases++] = bufferend;
++	      bufferend = __stpcpy (bufferend,
++				    tmp_result_buf.h_name) + 1;
++	    }
++
++	  /* Final NULL pointer.  */
++	  new_h_aliases[naliases] = NULL;
++
++	  /* Round up the buffer end address.  */
++	  bufferend += (sizeof (char *)
++			- ((bufferend - (char *) 0)
++			   % sizeof (char *))) % sizeof (char *);
++
++	  /* Now the new address.  */
++	  new_h_addr_list[naddrs++] =
++	    memcpy (bufferend, tmp_result_buf.h_addr,
++		    tmp_result_buf.h_length);
++
++	  /* Also here a final NULL pointer.  */
++	  new_h_addr_list[naddrs] = NULL;
++
++	  /* Store the new array pointers.  */
++	  old_result->h_aliases = new_h_aliases;
++	  old_result->h_addr_list = new_h_addr_list;
++
++	  /* Compute the new buffer end.  */
++	  bufferend = (char *) &new_h_aliases[naliases + 1];
++	  assert (bufferend <= buffer + buflen);
++
++	  result = old_result;
++	}
++    }
++
++  if (status == NSS_STATUS_TRYAGAIN)
++    {
++      size_t newsize = 2 * tmp_buflen;
++      if (tmp_buffer_malloced)
++	{
++	  char *newp = realloc (tmp_buffer, newsize);
++	  if (newp != NULL)
++	    {
++	      assert ((((uintptr_t) newp)
++		       & (__alignof__ (struct hostent_data) - 1))
++		      == 0);
++	      tmp_buffer = newp;
++	      tmp_buflen = newsize;
++	      goto again;
++	    }
++	}
++      else if (!__libc_use_alloca (buflen + newsize))
++	{
++	  tmp_buffer = malloc (newsize);
++	  if (tmp_buffer != NULL)
++	    {
++	      assert ((((uintptr_t) tmp_buffer)
++		       & (__alignof__ (struct hostent_data) - 1))
++		      == 0);
++	      tmp_buffer_malloced = true;
++	      tmp_buflen = newsize;
++	      goto again;
++	    }
++	}
++      else
++	{
++	  tmp_buffer
++	    = extend_alloca (tmp_buffer, tmp_buflen,
++			     newsize
++			     + __alignof__ (struct hostent_data));
++	  tmp_buffer = (char *) (((uintptr_t) tmp_buffer
++				  + __alignof__ (struct hostent_data)
++				  - 1)
++				 & ~(__alignof__ (struct hostent_data)
++				     - 1));
++	  goto again;
++	}
++    }
++  else
++    status = NSS_STATUS_SUCCESS;
++ out:
++  if (tmp_buffer_malloced)
++    free (tmp_buffer);
++  return status;
++}
++
+ enum nss_status
+ _nss_files_gethostbyname3_r (const char *name, int af, struct hostent *result,
+ 			     char *buffer, size_t buflen, int *errnop,
+@@ -143,199 +343,8 @@ _nss_files_gethostbyname3_r (const char *name, int af, struct hostent *result,
+ 
+       if (status == NSS_STATUS_SUCCESS
+ 	  && _res_hconf.flags & HCONF_FLAG_MULTI)
+-	{
+-	  /* We have to get all host entries from the file.  */
+-	  size_t tmp_buflen = MIN (buflen, 4096);
+-	  char tmp_buffer_stack[tmp_buflen]
+-	    __attribute__ ((__aligned__ (__alignof__ (struct hostent_data))));
+-	  char *tmp_buffer = tmp_buffer_stack;
+-	  struct hostent tmp_result_buf;
+-	  int naddrs = 1;
+-	  int naliases = 0;
+-	  char *bufferend;
+-	  bool tmp_buffer_malloced = false;
+-
+-	  while (result->h_aliases[naliases] != NULL)
+-	    ++naliases;
+-
+-	  bufferend = (char *) &result->h_aliases[naliases + 1];
+-
+-	again:
+-	  while ((status = internal_getent (stream, &tmp_result_buf, tmp_buffer,
+-					    tmp_buflen, errnop, herrnop, af,
+-					    flags))
+-		 == NSS_STATUS_SUCCESS)
+-	    {
+-	      int matches = 1;
+-	      struct hostent *old_result = result;
+-	      result = &tmp_result_buf;
+-	      /* The following piece is a bit clumsy but we want to use the
+-		 `LOOKUP_NAME_CASE' value.  The optimizer should do its
+-		 job.  */
+-	      do
+-		{
+-		  LOOKUP_NAME_CASE (h_name, h_aliases)
+-		  result = old_result;
+-		}
+-	      while ((matches = 0));
+-
+-	      if (matches)
+-		{
+-		  /* We could be very clever and try to recycle a few bytes
+-		     in the buffer instead of generating new arrays.  But
+-		     we are not doing this here since it's more work than
+-		     it's worth.  Simply let the user provide a bit bigger
+-		     buffer.  */
+-		  char **new_h_addr_list;
+-		  char **new_h_aliases;
+-		  int newaliases = 0;
+-		  size_t newstrlen = 0;
+-		  int cnt;
+-
+-		  /* Count the new aliases and the length of the strings.  */
+-		  while (tmp_result_buf.h_aliases[newaliases] != NULL)
+-		    {
+-		      char *cp = tmp_result_buf.h_aliases[newaliases];
+-		      ++newaliases;
+-		      newstrlen += strlen (cp) + 1;
+-		    }
+-		  /* If the real name is different add it also to the
+-		     aliases.  This means that there is a duplication
+-		     in the alias list but this is really the user's
+-		     problem.  */
+-		  if (strcmp (old_result->h_name,
+-			      tmp_result_buf.h_name) != 0)
+-		    {
+-		      ++newaliases;
+-		      newstrlen += strlen (tmp_result_buf.h_name) + 1;
+-		    }
+-
+-		  /* Make sure bufferend is aligned.  */
+-		  assert ((bufferend - (char *) 0) % sizeof (char *) == 0);
+-
+-		  /* Now we can check whether the buffer is large enough.
+-		     16 is the maximal size of the IP address.  */
+-		  if (bufferend + 16 + (naddrs + 2) * sizeof (char *)
+-		      + roundup (newstrlen, sizeof (char *))
+-		      + (naliases + newaliases + 1) * sizeof (char *)
+-		      >= buffer + buflen)
+-		    {
+-		      *errnop = ERANGE;
+-		      *herrnop = NETDB_INTERNAL;
+-		      status = NSS_STATUS_TRYAGAIN;
+-		      goto out;
+-		    }
+-
+-		  new_h_addr_list =
+-		    (char **) (bufferend
+-			       + roundup (newstrlen, sizeof (char *))
+-			       + 16);
+-		  new_h_aliases =
+-		    (char **) ((char *) new_h_addr_list
+-			       + (naddrs + 2) * sizeof (char *));
+-
+-		  /* Copy the old data in the new arrays.  */
+-		  for (cnt = 0; cnt < naddrs; ++cnt)
+-		    new_h_addr_list[cnt] = old_result->h_addr_list[cnt];
+-
+-		  for (cnt = 0; cnt < naliases; ++cnt)
+-		    new_h_aliases[cnt] = old_result->h_aliases[cnt];
+-
+-		  /* Store the new strings.  */
+-		  cnt = 0;
+-		  while (tmp_result_buf.h_aliases[cnt] != NULL)
+-		    {
+-		      new_h_aliases[naliases++] = bufferend;
+-		      bufferend = (__stpcpy (bufferend,
+-					     tmp_result_buf.h_aliases[cnt])
+-				   + 1);
+-		      ++cnt;
+-		    }
+-
+-		  if (cnt < newaliases)
+-		    {
+-		      new_h_aliases[naliases++] = bufferend;
+-		      bufferend = __stpcpy (bufferend,
+-					    tmp_result_buf.h_name) + 1;
+-		    }
+-
+-		  /* Final NULL pointer.  */
+-		  new_h_aliases[naliases] = NULL;
+-
+-		  /* Round up the buffer end address.  */
+-		  bufferend += (sizeof (char *)
+-				- ((bufferend - (char *) 0)
+-				   % sizeof (char *))) % sizeof (char *);
+-
+-		  /* Now the new address.  */
+-		  new_h_addr_list[naddrs++] =
+-		    memcpy (bufferend, tmp_result_buf.h_addr,
+-			    tmp_result_buf.h_length);
+-
+-		  /* Also here a final NULL pointer.  */
+-		  new_h_addr_list[naddrs] = NULL;
+-
+-		  /* Store the new array pointers.  */
+-		  old_result->h_aliases = new_h_aliases;
+-		  old_result->h_addr_list = new_h_addr_list;
+-
+-		  /* Compute the new buffer end.  */
+-		  bufferend = (char *) &new_h_aliases[naliases + 1];
+-		  assert (bufferend <= buffer + buflen);
+-
+-		  result = old_result;
+-		}
+-	    }
+-
+-	  if (status == NSS_STATUS_TRYAGAIN)
+-	    {
+-	      size_t newsize = 2 * tmp_buflen;
+-	      if (tmp_buffer_malloced)
+-		{
+-		  char *newp = realloc (tmp_buffer, newsize);
+-		  if (newp != NULL)
+-		    {
+-		      assert ((((uintptr_t) newp)
+-			       & (__alignof__ (struct hostent_data) - 1))
+-			      == 0);
+-		      tmp_buffer = newp;
+-		      tmp_buflen = newsize;
+-		      goto again;
+-		    }
+-		}
+-	      else if (!__libc_use_alloca (buflen + newsize))
+-		{
+-		  tmp_buffer = malloc (newsize);
+-		  if (tmp_buffer != NULL)
+-		    {
+-		      assert ((((uintptr_t) tmp_buffer)
+-			       & (__alignof__ (struct hostent_data) - 1))
+-			      == 0);
+-		      tmp_buffer_malloced = true;
+-		      tmp_buflen = newsize;
+-		      goto again;
+-		    }
+-		}
+-	      else
+-		{
+-		  tmp_buffer
+-		    = extend_alloca (tmp_buffer, tmp_buflen,
+-				     newsize
+-				     + __alignof__ (struct hostent_data));
+-		  tmp_buffer = (char *) (((uintptr_t) tmp_buffer
+-					  + __alignof__ (struct hostent_data)
+-					  - 1)
+-					 & ~(__alignof__ (struct hostent_data)
+-					     - 1));
+-		  goto again;
+-		}
+-	    }
+-	  else
+-	    status = NSS_STATUS_SUCCESS;
+-	out:
+-	  if (tmp_buffer_malloced)
+-	    free (tmp_buffer);
+-	}
++	status = gethostbyname3_multi
++	  (stream, name, af, result, buffer, buflen, errnop, herrnop, flags);
+ 
+       internal_endent (&stream);
+     }
diff --git a/gnu/packages/patches/glibc-2-26-0060.patch b/gnu/packages/patches/glibc-2-26-0060.patch
new file mode 100644
index 000000000..2be8e2782
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0060.patch
@@ -0,0 +1,369 @@
+From 13728f56f0cdfff536fe6673eae6881a3483a6a2 Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Wed, 11 Oct 2017 07:01:34 +0200
+Subject: [PATCH 60/90] nss_files: Use struct scratch_buffer for gethostbyname
+ [BZ #18023]
+
+(cherry picked from commit 78e806fd8cd8c918d3bbe1bcdf9091ab365e4a69)
+
+diff --git a/ChangeLog b/ChangeLog
+index 54347f5485..40867db75a 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-10-11  Florian Weimer  <fweimer@redhat.com>
++
++	[BZ #18023]
++	* nss/nss_files/files-hosts.c (gethostbyname3_multi): Use struct
++	scratch_buffer.  Eliminate gotos.
++
+ 2017-10-10  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	* nss/nss_files/files-hosts.c (gethostbyname3_multi): New
+diff --git a/nss/nss_files/files-hosts.c b/nss/nss_files/files-hosts.c
+index 867c10c2ef..763fa39a47 100644
+--- a/nss/nss_files/files-hosts.c
++++ b/nss/nss_files/files-hosts.c
+@@ -22,6 +22,7 @@
+ #include <arpa/nameser.h>
+ #include <netdb.h>
+ #include <resolv/resolv-internal.h>
++#include <scratch_buffer.h>
+ 
+ 
+ /* Get implementation for some internal functions.  */
+@@ -121,15 +122,12 @@ gethostbyname3_multi (FILE * stream, const char *name, int af,
+ 		      int *errnop, int *herrnop, int flags)
+ {
+   /* We have to get all host entries from the file.  */
+-  size_t tmp_buflen = MIN (buflen, 4096);
+-  char tmp_buffer_stack[tmp_buflen]
+-    __attribute__ ((__aligned__ (__alignof__ (struct hostent_data))));
+-  char *tmp_buffer = tmp_buffer_stack;
++  struct scratch_buffer tmp_buffer;
++  scratch_buffer_init (&tmp_buffer);
+   struct hostent tmp_result_buf;
+   int naddrs = 1;
+   int naliases = 0;
+   char *bufferend;
+-  bool tmp_buffer_malloced = false;
+   enum nss_status status;
+ 
+   while (result->h_aliases[naliases] != NULL)
+@@ -137,181 +135,165 @@ gethostbyname3_multi (FILE * stream, const char *name, int af,
+ 
+   bufferend = (char *) &result->h_aliases[naliases + 1];
+ 
+- again:
+-  while ((status = internal_getent (stream, &tmp_result_buf, tmp_buffer,
+-				    tmp_buflen, errnop, herrnop, af,
+-				    flags))
+-	 == NSS_STATUS_SUCCESS)
++  while (true)
+     {
+-      int matches = 1;
+-      struct hostent *old_result = result;
+-      result = &tmp_result_buf;
+-      /* The following piece is a bit clumsy but we want to use the
+-	 `LOOKUP_NAME_CASE' value.  The optimizer should do its
+-	 job.  */
+-      do
++      status = internal_getent (stream, &tmp_result_buf, tmp_buffer.data,
++				tmp_buffer.length, errnop, herrnop, af,
++				flags);
++      /* Enlarge the buffer if necessary.  */
++      if (status == NSS_STATUS_TRYAGAIN && *herrnop == NETDB_INTERNAL
++	  && *errnop == ERANGE)
+ 	{
+-	  LOOKUP_NAME_CASE (h_name, h_aliases)
+-	    result = old_result;
++	  if (!scratch_buffer_grow (&tmp_buffer))
++	    {
++	      *errnop = ENOMEM;
++	      /* *herrnop and status already have the right value.  */
++	      break;
++	    }
++	  /* Loop around and retry with a larger buffer.  */
+ 	}
+-      while ((matches = 0));
+-
+-      if (matches)
++      else if (status == NSS_STATUS_SUCCESS)
+ 	{
+-	  /* We could be very clever and try to recycle a few bytes
+-	     in the buffer instead of generating new arrays.  But
+-	     we are not doing this here since it's more work than
+-	     it's worth.  Simply let the user provide a bit bigger
+-	     buffer.  */
+-	  char **new_h_addr_list;
+-	  char **new_h_aliases;
+-	  int newaliases = 0;
+-	  size_t newstrlen = 0;
+-	  int cnt;
+-
+-	  /* Count the new aliases and the length of the strings.  */
+-	  while (tmp_result_buf.h_aliases[newaliases] != NULL)
++	  /* A line was read.  Check that it matches the search
++	     criteria.  */
++
++	  int matches = 1;
++	  struct hostent *old_result = result;
++	  result = &tmp_result_buf;
++	  /* The following piece is a bit clumsy but we want to use
++	     the `LOOKUP_NAME_CASE' value.  The optimizer should do
++	     its job.  */
++	  do
+ 	    {
+-	      char *cp = tmp_result_buf.h_aliases[newaliases];
+-	      ++newaliases;
+-	      newstrlen += strlen (cp) + 1;
++	      LOOKUP_NAME_CASE (h_name, h_aliases)
++		result = old_result;
+ 	    }
+-	  /* If the real name is different add it also to the
+-	     aliases.  This means that there is a duplication
+-	     in the alias list but this is really the user's
+-	     problem.  */
+-	  if (strcmp (old_result->h_name,
+-		      tmp_result_buf.h_name) != 0)
++	  while ((matches = 0));
++
++	  if (matches)
+ 	    {
+-	      ++newaliases;
+-	      newstrlen += strlen (tmp_result_buf.h_name) + 1;
+-	    }
++	      /* We could be very clever and try to recycle a few bytes
++		 in the buffer instead of generating new arrays.  But
++		 we are not doing this here since it's more work than
++		 it's worth.  Simply let the user provide a bit bigger
++		 buffer.  */
++	      char **new_h_addr_list;
++	      char **new_h_aliases;
++	      int newaliases = 0;
++	      size_t newstrlen = 0;
++	      int cnt;
++
++	      /* Count the new aliases and the length of the strings.  */
++	      while (tmp_result_buf.h_aliases[newaliases] != NULL)
++		{
++		  char *cp = tmp_result_buf.h_aliases[newaliases];
++		  ++newaliases;
++		  newstrlen += strlen (cp) + 1;
++		}
++	      /* If the real name is different add it also to the
++		 aliases.  This means that there is a duplication
++		 in the alias list but this is really the user's
++		 problem.  */
++	      if (strcmp (old_result->h_name,
++			  tmp_result_buf.h_name) != 0)
++		{
++		  ++newaliases;
++		  newstrlen += strlen (tmp_result_buf.h_name) + 1;
++		}
+ 
+-	  /* Make sure bufferend is aligned.  */
+-	  assert ((bufferend - (char *) 0) % sizeof (char *) == 0);
++	      /* Make sure bufferend is aligned.  */
++	      assert ((bufferend - (char *) 0) % sizeof (char *) == 0);
+ 
+-	  /* Now we can check whether the buffer is large enough.
+-	     16 is the maximal size of the IP address.  */
+-	  if (bufferend + 16 + (naddrs + 2) * sizeof (char *)
+-	      + roundup (newstrlen, sizeof (char *))
+-	      + (naliases + newaliases + 1) * sizeof (char *)
+-	      >= buffer + buflen)
+-	    {
+-	      *errnop = ERANGE;
+-	      *herrnop = NETDB_INTERNAL;
+-	      status = NSS_STATUS_TRYAGAIN;
+-	      goto out;
+-	    }
++	      /* Now we can check whether the buffer is large enough.
++		 16 is the maximal size of the IP address.  */
++	      if (bufferend + 16 + (naddrs + 2) * sizeof (char *)
++		  + roundup (newstrlen, sizeof (char *))
++		  + (naliases + newaliases + 1) * sizeof (char *)
++		  >= buffer + buflen)
++		{
++		  *errnop = ERANGE;
++		  *herrnop = NETDB_INTERNAL;
++		  status = NSS_STATUS_TRYAGAIN;
++		  break;
++		}
+ 
+-	  new_h_addr_list =
+-	    (char **) (bufferend
+-		       + roundup (newstrlen, sizeof (char *))
+-		       + 16);
+-	  new_h_aliases =
+-	    (char **) ((char *) new_h_addr_list
+-		       + (naddrs + 2) * sizeof (char *));
++	      new_h_addr_list =
++		(char **) (bufferend
++			   + roundup (newstrlen, sizeof (char *))
++			   + 16);
++	      new_h_aliases =
++		(char **) ((char *) new_h_addr_list
++			   + (naddrs + 2) * sizeof (char *));
+ 
+-	  /* Copy the old data in the new arrays.  */
+-	  for (cnt = 0; cnt < naddrs; ++cnt)
+-	    new_h_addr_list[cnt] = old_result->h_addr_list[cnt];
++	      /* Copy the old data in the new arrays.  */
++	      for (cnt = 0; cnt < naddrs; ++cnt)
++		new_h_addr_list[cnt] = old_result->h_addr_list[cnt];
+ 
+-	  for (cnt = 0; cnt < naliases; ++cnt)
+-	    new_h_aliases[cnt] = old_result->h_aliases[cnt];
++	      for (cnt = 0; cnt < naliases; ++cnt)
++		new_h_aliases[cnt] = old_result->h_aliases[cnt];
+ 
+-	  /* Store the new strings.  */
+-	  cnt = 0;
+-	  while (tmp_result_buf.h_aliases[cnt] != NULL)
+-	    {
+-	      new_h_aliases[naliases++] = bufferend;
+-	      bufferend = (__stpcpy (bufferend,
+-				     tmp_result_buf.h_aliases[cnt])
+-			   + 1);
+-	      ++cnt;
+-	    }
++	      /* Store the new strings.  */
++	      cnt = 0;
++	      while (tmp_result_buf.h_aliases[cnt] != NULL)
++		{
++		  new_h_aliases[naliases++] = bufferend;
++		  bufferend = (__stpcpy (bufferend,
++					 tmp_result_buf.h_aliases[cnt])
++			       + 1);
++		  ++cnt;
++		}
+ 
+-	  if (cnt < newaliases)
+-	    {
+-	      new_h_aliases[naliases++] = bufferend;
+-	      bufferend = __stpcpy (bufferend,
+-				    tmp_result_buf.h_name) + 1;
+-	    }
++	      if (cnt < newaliases)
++		{
++		  new_h_aliases[naliases++] = bufferend;
++		  bufferend = __stpcpy (bufferend,
++					tmp_result_buf.h_name) + 1;
++		}
+ 
+-	  /* Final NULL pointer.  */
+-	  new_h_aliases[naliases] = NULL;
++	      /* Final NULL pointer.  */
++	      new_h_aliases[naliases] = NULL;
+ 
+-	  /* Round up the buffer end address.  */
+-	  bufferend += (sizeof (char *)
+-			- ((bufferend - (char *) 0)
+-			   % sizeof (char *))) % sizeof (char *);
++	      /* Round up the buffer end address.  */
++	      bufferend += (sizeof (char *)
++			    - ((bufferend - (char *) 0)
++			       % sizeof (char *))) % sizeof (char *);
+ 
+-	  /* Now the new address.  */
+-	  new_h_addr_list[naddrs++] =
+-	    memcpy (bufferend, tmp_result_buf.h_addr,
+-		    tmp_result_buf.h_length);
++	      /* Now the new address.  */
++	      new_h_addr_list[naddrs++] =
++		memcpy (bufferend, tmp_result_buf.h_addr,
++			tmp_result_buf.h_length);
+ 
+-	  /* Also here a final NULL pointer.  */
+-	  new_h_addr_list[naddrs] = NULL;
++	      /* Also here a final NULL pointer.  */
++	      new_h_addr_list[naddrs] = NULL;
+ 
+-	  /* Store the new array pointers.  */
+-	  old_result->h_aliases = new_h_aliases;
+-	  old_result->h_addr_list = new_h_addr_list;
++	      /* Store the new array pointers.  */
++	      old_result->h_aliases = new_h_aliases;
++	      old_result->h_addr_list = new_h_addr_list;
+ 
+-	  /* Compute the new buffer end.  */
+-	  bufferend = (char *) &new_h_aliases[naliases + 1];
+-	  assert (bufferend <= buffer + buflen);
++	      /* Compute the new buffer end.  */
++	      bufferend = (char *) &new_h_aliases[naliases + 1];
++	      assert (bufferend <= buffer + buflen);
+ 
+-	  result = old_result;
+-	}
+-    }
++	      result = old_result;
++	    } /* If match was found.  */
+ 
+-  if (status == NSS_STATUS_TRYAGAIN)
+-    {
+-      size_t newsize = 2 * tmp_buflen;
+-      if (tmp_buffer_malloced)
+-	{
+-	  char *newp = realloc (tmp_buffer, newsize);
+-	  if (newp != NULL)
+-	    {
+-	      assert ((((uintptr_t) newp)
+-		       & (__alignof__ (struct hostent_data) - 1))
+-		      == 0);
+-	      tmp_buffer = newp;
+-	      tmp_buflen = newsize;
+-	      goto again;
+-	    }
+-	}
+-      else if (!__libc_use_alloca (buflen + newsize))
+-	{
+-	  tmp_buffer = malloc (newsize);
+-	  if (tmp_buffer != NULL)
+-	    {
+-	      assert ((((uintptr_t) tmp_buffer)
+-		       & (__alignof__ (struct hostent_data) - 1))
+-		      == 0);
+-	      tmp_buffer_malloced = true;
+-	      tmp_buflen = newsize;
+-	      goto again;
+-	    }
+-	}
++	  /* If no match is found, loop around and fetch another
++	     line.  */
++
++	} /* status == NSS_STATUS_SUCCESS.  */
+       else
+-	{
+-	  tmp_buffer
+-	    = extend_alloca (tmp_buffer, tmp_buflen,
+-			     newsize
+-			     + __alignof__ (struct hostent_data));
+-	  tmp_buffer = (char *) (((uintptr_t) tmp_buffer
+-				  + __alignof__ (struct hostent_data)
+-				  - 1)
+-				 & ~(__alignof__ (struct hostent_data)
+-				     - 1));
+-	  goto again;
+-	}
+-    }
+-  else
++	/* internal_getent returned an error.  */
++	break;
++    } /* while (true) */
++
++  /* Propagate the NSS_STATUS_TRYAGAIN error to the caller.  It means
++     that we may not have loaded the complete result.
++     NSS_STATUS_NOTFOUND, however, means that we reached the end of
++     the file successfully.  */
++  if (status != NSS_STATUS_TRYAGAIN)
+     status = NSS_STATUS_SUCCESS;
+- out:
+-  if (tmp_buffer_malloced)
+-    free (tmp_buffer);
++
++  scratch_buffer_free (&tmp_buffer);
+   return status;
+ }
+ 
diff --git a/gnu/packages/patches/glibc-2-26-0061.patch b/gnu/packages/patches/glibc-2-26-0061.patch
new file mode 100644
index 000000000..7f665d930
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0061.patch
@@ -0,0 +1,679 @@
+From 05155f0772a4befcc10da16ab64060ae7836ff7c Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Thu, 19 Oct 2017 10:44:31 +0200
+Subject: [PATCH 61/90] nss_files: Avoid large buffers with many host addresses
+ [BZ #22078]
+
+The previous implementation had at least a quadratic space
+requirement in the number of host addresses and aliases.
+
+(cherry picked from commit d8425e116cdd954fea0c04c0f406179b5daebbb3)
+
+diff --git a/ChangeLog b/ChangeLog
+index 40867db75a..ad3adc0bdc 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,13 @@
++2017-10-11  Florian Weimer  <fweimer@redhat.com>
++
++	[BZ #22078]
++	Avoid large NSS buffers with many addresses, aliases.
++	* nss/nss_files/files-hosts.c (gethostbyname3_multi): Rewrite
++	using dynarrays and struct alloc_buffer.
++	* nss/Makefile (tests): Add tst-nss-files-hosts-multi.
++	(tst-nss-files-hosts-multi): Link with -ldl.
++	* nss/tst-nss-files-hosts-multi.c: New file.
++
+ 2017-10-11  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	[BZ #18023]
+diff --git a/NEWS b/NEWS
+index d6d1f90008..9cb8f00529 100644
+--- a/NEWS
++++ b/NEWS
+@@ -31,6 +31,7 @@ The following bugs are resolved with this release:
+   [21982] string: stratcliff.c: error: assuming signed overflow does not
+     occur with -O3
+   [22051] libc: zero terminator in the middle of glibc's .eh_frame
++  [22078] nss_files performance issue in hosts multi mode
+   [22095] resolv: Fix memory leak with OOM during resolv.conf parsing
+   [22096] resolv: __resolv_conf_attach must not free passed conf object
+   [22111] malloc: per thread cache is not returned when thread exits
+diff --git a/nss/Makefile b/nss/Makefile
+index 91b1c21567..8efb2a56fa 100644
+--- a/nss/Makefile
++++ b/nss/Makefile
+@@ -61,6 +61,7 @@ xtests			= bug-erange
+ # Tests which need libdl
+ ifeq (yes,$(build-shared))
+ tests += tst-nss-files-hosts-erange
++tests += tst-nss-files-hosts-multi
+ endif
+ 
+ # If we have a thread library then we can test cancellation against
+@@ -161,3 +162,4 @@ $(objpfx)tst-cancel-getpwuid_r: $(shared-thread-library)
+ endif
+ 
+ $(objpfx)tst-nss-files-hosts-erange: $(libdl)
++$(objpfx)tst-nss-files-hosts-multi: $(libdl)
+diff --git a/nss/nss_files/files-hosts.c b/nss/nss_files/files-hosts.c
+index 763fa39a47..6f7cc4d94b 100644
+--- a/nss/nss_files/files-hosts.c
++++ b/nss/nss_files/files-hosts.c
+@@ -23,6 +23,7 @@
+ #include <netdb.h>
+ #include <resolv/resolv-internal.h>
+ #include <scratch_buffer.h>
++#include <alloc_buffer.h>
+ 
+ 
+ /* Get implementation for some internal functions.  */
+@@ -116,24 +117,45 @@ DB_LOOKUP (hostbyaddr, ,,,
+ 	   }, const void *addr, socklen_t len, int af)
+ #undef EXTRA_ARGS_VALUE
+ 
++/* Type of the address and alias arrays.  */
++#define DYNARRAY_STRUCT array
++#define DYNARRAY_ELEMENT char *
++#define DYNARRAY_PREFIX array_
++#include <malloc/dynarray-skeleton.c>
++
+ static enum nss_status
+ gethostbyname3_multi (FILE * stream, const char *name, int af,
+ 		      struct hostent *result, char *buffer, size_t buflen,
+ 		      int *errnop, int *herrnop, int flags)
+ {
++  assert (af == AF_INET || af == AF_INET6);
++
+   /* We have to get all host entries from the file.  */
+   struct scratch_buffer tmp_buffer;
+   scratch_buffer_init (&tmp_buffer);
+   struct hostent tmp_result_buf;
+-  int naddrs = 1;
+-  int naliases = 0;
+-  char *bufferend;
++  struct array addresses;
++  array_init (&addresses);
++  struct array aliases;
++  array_init (&aliases);
+   enum nss_status status;
+ 
+-  while (result->h_aliases[naliases] != NULL)
+-    ++naliases;
+-
+-  bufferend = (char *) &result->h_aliases[naliases + 1];
++  /* Preserve the addresses and aliases encountered so far.  */
++  for (size_t i = 0; result->h_addr_list[i] != NULL; ++i)
++    array_add (&addresses, result->h_addr_list[i]);
++  for (size_t i = 0; result->h_aliases[i] != NULL; ++i)
++    array_add (&aliases, result->h_aliases[i]);
++
++  /* The output buffer re-uses now-unused space at the end of the
++     buffer, starting with the aliases array.  It comes last in the
++     data produced by internal_getent.  (The alias names themselves
++     are still located in the line read in internal_getent, which is
++     stored at the beginning of the buffer.)  */
++  struct alloc_buffer outbuf;
++  {
++    char *bufferend = (char *) result->h_aliases;
++    outbuf = alloc_buffer_create (bufferend, buffer + buflen - bufferend);
++  }
+ 
+   while (true)
+     {
+@@ -170,110 +192,81 @@ gethostbyname3_multi (FILE * stream, const char *name, int af,
+ 	    }
+ 	  while ((matches = 0));
+ 
++	  /* If the line matches, we need to copy the addresses and
++	     aliases, so that we can reuse tmp_buffer for the next
++	     line.  */
+ 	  if (matches)
+ 	    {
+-	      /* We could be very clever and try to recycle a few bytes
+-		 in the buffer instead of generating new arrays.  But
+-		 we are not doing this here since it's more work than
+-		 it's worth.  Simply let the user provide a bit bigger
+-		 buffer.  */
+-	      char **new_h_addr_list;
+-	      char **new_h_aliases;
+-	      int newaliases = 0;
+-	      size_t newstrlen = 0;
+-	      int cnt;
+-
+-	      /* Count the new aliases and the length of the strings.  */
+-	      while (tmp_result_buf.h_aliases[newaliases] != NULL)
++	      /* Record the addresses.  */
++	      for (size_t i = 0; tmp_result_buf.h_addr_list[i] != NULL; ++i)
+ 		{
+-		  char *cp = tmp_result_buf.h_aliases[newaliases];
+-		  ++newaliases;
+-		  newstrlen += strlen (cp) + 1;
++		  /* Allocate the target space in the output buffer,
++		     depending on the address family.  */
++		  void *target;
++		  if (af == AF_INET)
++		    {
++		      assert (tmp_result_buf.h_length == 4);
++		      target = alloc_buffer_alloc (&outbuf, struct in_addr);
++		    }
++		  else if (af == AF_INET6)
++		    {
++		      assert (tmp_result_buf.h_length == 16);
++		      target = alloc_buffer_alloc (&outbuf, struct in6_addr);
++		    }
++		  else
++		    __builtin_unreachable ();
++
++		  if (target == NULL)
++		    {
++		      /* Request a larger output buffer.  */
++		      *errnop = ERANGE;
++		      *herrnop = NETDB_INTERNAL;
++		      status = NSS_STATUS_TRYAGAIN;
++		      break;
++		    }
++		  memcpy (target, tmp_result_buf.h_addr_list[i],
++			  tmp_result_buf.h_length);
++		  array_add (&addresses, target);
+ 		}
+-	      /* If the real name is different add it also to the
+-		 aliases.  This means that there is a duplication
+-		 in the alias list but this is really the user's
+-		 problem.  */
+-	      if (strcmp (old_result->h_name,
+-			  tmp_result_buf.h_name) != 0)
++
++	      /* Record the aliases.  */
++	      for (size_t i = 0; tmp_result_buf.h_aliases[i] != NULL; ++i)
+ 		{
+-		  ++newaliases;
+-		  newstrlen += strlen (tmp_result_buf.h_name) + 1;
++		  char *alias = tmp_result_buf.h_aliases[i];
++		  array_add (&aliases,
++			     alloc_buffer_copy_string (&outbuf, alias));
+ 		}
+ 
+-	      /* Make sure bufferend is aligned.  */
+-	      assert ((bufferend - (char *) 0) % sizeof (char *) == 0);
+-
+-	      /* Now we can check whether the buffer is large enough.
+-		 16 is the maximal size of the IP address.  */
+-	      if (bufferend + 16 + (naddrs + 2) * sizeof (char *)
+-		  + roundup (newstrlen, sizeof (char *))
+-		  + (naliases + newaliases + 1) * sizeof (char *)
+-		  >= buffer + buflen)
++	      /* If the real name is different add, it also to the
++		 aliases.  This means that there is a duplication in
++		 the alias list but this is really the user's
++		 problem.  */
++	      {
++		char *new_name = tmp_result_buf.h_name;
++		if (strcmp (old_result->h_name, new_name) != 0)
++		  array_add (&aliases,
++			     alloc_buffer_copy_string (&outbuf, new_name));
++	      }
++
++	      /* Report memory allocation failures during the
++		 expansion of the temporary arrays.  */
++	      if (array_has_failed (&addresses) || array_has_failed (&aliases))
+ 		{
+-		  *errnop = ERANGE;
++		  *errnop = ENOMEM;
+ 		  *herrnop = NETDB_INTERNAL;
+-		  status = NSS_STATUS_TRYAGAIN;
++		  status = NSS_STATUS_UNAVAIL;
+ 		  break;
+ 		}
+ 
+-	      new_h_addr_list =
+-		(char **) (bufferend
+-			   + roundup (newstrlen, sizeof (char *))
+-			   + 16);
+-	      new_h_aliases =
+-		(char **) ((char *) new_h_addr_list
+-			   + (naddrs + 2) * sizeof (char *));
+-
+-	      /* Copy the old data in the new arrays.  */
+-	      for (cnt = 0; cnt < naddrs; ++cnt)
+-		new_h_addr_list[cnt] = old_result->h_addr_list[cnt];
+-
+-	      for (cnt = 0; cnt < naliases; ++cnt)
+-		new_h_aliases[cnt] = old_result->h_aliases[cnt];
+-
+-	      /* Store the new strings.  */
+-	      cnt = 0;
+-	      while (tmp_result_buf.h_aliases[cnt] != NULL)
++	      /* Request a larger output buffer if we ran out of room.  */
++	      if (alloc_buffer_has_failed (&outbuf))
+ 		{
+-		  new_h_aliases[naliases++] = bufferend;
+-		  bufferend = (__stpcpy (bufferend,
+-					 tmp_result_buf.h_aliases[cnt])
+-			       + 1);
+-		  ++cnt;
+-		}
+-
+-	      if (cnt < newaliases)
+-		{
+-		  new_h_aliases[naliases++] = bufferend;
+-		  bufferend = __stpcpy (bufferend,
+-					tmp_result_buf.h_name) + 1;
++		  *errnop = ERANGE;
++		  *herrnop = NETDB_INTERNAL;
++		  status = NSS_STATUS_TRYAGAIN;
++		  break;
+ 		}
+ 
+-	      /* Final NULL pointer.  */
+-	      new_h_aliases[naliases] = NULL;
+-
+-	      /* Round up the buffer end address.  */
+-	      bufferend += (sizeof (char *)
+-			    - ((bufferend - (char *) 0)
+-			       % sizeof (char *))) % sizeof (char *);
+-
+-	      /* Now the new address.  */
+-	      new_h_addr_list[naddrs++] =
+-		memcpy (bufferend, tmp_result_buf.h_addr,
+-			tmp_result_buf.h_length);
+-
+-	      /* Also here a final NULL pointer.  */
+-	      new_h_addr_list[naddrs] = NULL;
+-
+-	      /* Store the new array pointers.  */
+-	      old_result->h_aliases = new_h_aliases;
+-	      old_result->h_addr_list = new_h_addr_list;
+-
+-	      /* Compute the new buffer end.  */
+-	      bufferend = (char *) &new_h_aliases[naliases + 1];
+-	      assert (bufferend <= buffer + buflen);
+-
+ 	      result = old_result;
+ 	    } /* If match was found.  */
+ 
+@@ -293,7 +286,47 @@ gethostbyname3_multi (FILE * stream, const char *name, int af,
+   if (status != NSS_STATUS_TRYAGAIN)
+     status = NSS_STATUS_SUCCESS;
+ 
++  if (status == NSS_STATUS_SUCCESS)
++    {
++      /* Copy the address and alias arrays into the output buffer and
++	 add NULL terminators.  The pointed-to elements were directly
++	 written into the output buffer above and do not need to be
++	 copied again.  */
++      size_t addresses_count = array_size (&addresses);
++      size_t aliases_count = array_size (&aliases);
++      char **out_addresses = alloc_buffer_alloc_array
++	(&outbuf, char *, addresses_count + 1);
++      char **out_aliases = alloc_buffer_alloc_array
++	(&outbuf, char *, aliases_count + 1);
++      if (out_addresses == NULL || out_aliases == NULL)
++	{
++	  /* The output buffer is not large enough.  */
++	  *errnop = ERANGE;
++	  *herrnop = NETDB_INTERNAL;
++	  status = NSS_STATUS_TRYAGAIN;
++	  /* Fall through to function exit.  */
++	}
++      else
++	{
++	  /* Everything is allocated in place.  Make the copies and
++	     adjust the array pointers.  */
++	  memcpy (out_addresses, array_begin (&addresses),
++		  addresses_count * sizeof (char *));
++	  out_addresses[addresses_count] = NULL;
++	  memcpy (out_aliases, array_begin (&aliases),
++		  aliases_count * sizeof (char *));
++	  out_aliases[aliases_count] = NULL;
++
++	  result->h_addr_list = out_addresses;
++	  result->h_aliases = out_aliases;
++
++	  status = NSS_STATUS_SUCCESS;
++	}
++    }
++
+   scratch_buffer_free (&tmp_buffer);
++  array_free (&addresses);
++  array_free (&aliases);
+   return status;
+ }
+ 
+diff --git a/nss/tst-nss-files-hosts-multi.c b/nss/tst-nss-files-hosts-multi.c
+new file mode 100644
+index 0000000000..195a19be4f
+--- /dev/null
++++ b/nss/tst-nss-files-hosts-multi.c
+@@ -0,0 +1,331 @@
++/* Parse /etc/hosts in multi mode with many addresses/aliases.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#include <dlfcn.h>
++#include <errno.h>
++#include <gnu/lib-names.h>
++#include <netdb.h>
++#include <nss.h>
++#include <stdbool.h>
++#include <stdlib.h>
++#include <string.h>
++#include <support/check.h>
++#include <support/check_nss.h>
++#include <support/namespace.h>
++#include <support/support.h>
++#include <support/test-driver.h>
++#include <support/test-driver.h>
++#include <support/xmemstream.h>
++#include <support/xstdio.h>
++#include <support/xunistd.h>
++#include <sys/resource.h>
++
++struct support_chroot *chroot_env;
++
++static void
++prepare (int argc, char **argv)
++{
++  chroot_env = support_chroot_create
++    ((struct support_chroot_configuration)
++     {
++       .resolv_conf = "",
++       .hosts = "",             /* See write_hosts below.  */
++       .host_conf = "multi on\n",
++     });
++}
++
++/* Create the /etc/hosts file from outside the chroot.  */
++static void
++write_hosts (int count)
++{
++  TEST_VERIFY (count > 0 && count <= 65535);
++  FILE *fp = xfopen (chroot_env->path_hosts, "w");
++  fputs ("127.0.0.1   localhost localhost.localdomain\n"
++         "::1         localhost localhost.localdomain\n",
++         fp);
++  for (int i = 0; i < count; ++i)
++    {
++      fprintf (fp, "10.4.%d.%d www4.example.com\n",
++               (i / 256) & 0xff, i & 0xff);
++      fprintf (fp, "10.46.%d.%d www.example.com\n",
++               (i / 256) & 0xff, i & 0xff);
++      fprintf (fp, "192.0.2.1 alias.example.com v4-%d.example.com\n", i);
++      fprintf (fp, "2001:db8::6:%x www6.example.com\n", i);
++      fprintf (fp, "2001:db8::46:%x www.example.com\n", i);
++      fprintf (fp, "2001:db8::1 alias.example.com v6-%d.example.com\n", i);
++    }
++  xfclose (fp);
++}
++
++/* Parameters of a single test.  */
++struct test_params
++{
++  const char *name;             /* Name to query.  */
++  const char *marker;           /* Address marker for the name.  */
++  int count;                    /* Number of addresses/aliases.  */
++  int family;                   /* AF_INET, AF_INET_6 or AF_UNSPEC.  */
++  bool canonname;               /* True if AI_CANONNAME should be enabled.  */
++};
++
++/* Expected result of gethostbyname/gethostbyname2.  */
++static char *
++expected_ghbn (const struct test_params *params)
++{
++  TEST_VERIFY (params->family == AF_INET || params->family == AF_INET6);
++
++  struct xmemstream expected;
++  xopen_memstream (&expected);
++  if (strcmp (params->name, "alias.example.com") == 0)
++    {
++      fprintf (expected.out, "name: %s\n", params->name);
++      char af;
++      if (params->family == AF_INET)
++        af = '4';
++      else
++        af = '6';
++      for (int i = 0; i < params->count; ++i)
++        fprintf (expected.out, "alias: v%c-%d.example.com\n", af, i);
++
++      for (int i = 0; i < params->count; ++i)
++        if (params->family == AF_INET)
++          fputs ("address: 192.0.2.1\n", expected.out);
++        else
++          fputs ("address: 2001:db8::1\n", expected.out);
++    }
++  else /* www/www4/www6 name.  */
++    {
++      bool do_ipv4 = params->family == AF_INET
++        && strncmp (params->name, "www6", 4) != 0;
++      bool do_ipv6 = params->family == AF_INET6
++        && strncmp (params->name, "www4", 4) != 0;
++      if (do_ipv4 || do_ipv6)
++        {
++          fprintf (expected.out, "name: %s\n", params->name);
++          if (do_ipv4)
++            for (int i = 0; i < params->count; ++i)
++              fprintf (expected.out, "address: 10.%s.%d.%d\n",
++                       params->marker, i / 256, i % 256);
++          if (do_ipv6)
++            for (int i = 0; i < params->count; ++i)
++              fprintf (expected.out, "address: 2001:db8::%s:%x\n",
++                       params->marker, i);
++        }
++      else
++        fputs ("error: HOST_NOT_FOUND\n", expected.out);
++    }
++  xfclose_memstream (&expected);
++  return expected.buffer;
++}
++
++/* Expected result of getaddrinfo.  */
++static char *
++expected_gai (const struct test_params *params)
++{
++  bool do_ipv4 = false;
++  bool do_ipv6 = false;
++  if (params->family == AF_UNSPEC)
++    do_ipv4 = do_ipv6 = true;
++  else if (params->family == AF_INET)
++    do_ipv4 = true;
++  else if (params->family == AF_INET6)
++    do_ipv6 = true;
++
++  struct xmemstream expected;
++  xopen_memstream (&expected);
++  if (strcmp (params->name, "alias.example.com") == 0)
++    {
++      if (params->canonname)
++        fprintf (expected.out,
++                 "flags: AI_CANONNAME\n"
++                 "canonname: %s\n",
++                 params->name);
++
++      if (do_ipv4)
++        for (int i = 0; i < params->count; ++i)
++          fputs ("address: STREAM/TCP 192.0.2.1 80\n", expected.out);
++      if (do_ipv6)
++        for (int i = 0; i < params->count; ++i)
++          fputs ("address: STREAM/TCP 2001:db8::1 80\n", expected.out);
++    }
++  else /* www/www4/www6 name.  */
++    {
++      if (strncmp (params->name, "www4", 4) == 0)
++        do_ipv6 = false;
++      else if (strncmp (params->name, "www6", 4) == 0)
++        do_ipv4 = false;
++      /* Otherwise, we have www as the name, so we do both.  */
++
++      if (do_ipv4 || do_ipv6)
++        {
++          if (params->canonname)
++            fprintf (expected.out,
++                     "flags: AI_CANONNAME\n"
++                     "canonname: %s\n",
++                     params->name);
++
++          if (do_ipv4)
++            for (int i = 0; i < params->count; ++i)
++              fprintf (expected.out, "address: STREAM/TCP 10.%s.%d.%d 80\n",
++                       params->marker, i / 256, i % 256);
++          if (do_ipv6)
++            for (int i = 0; i < params->count; ++i)
++              fprintf (expected.out,
++                       "address: STREAM/TCP 2001:db8::%s:%x 80\n",
++                       params->marker, i);
++        }
++      else
++        fputs ("error: Name or service not known\n", expected.out);
++    }
++  xfclose_memstream (&expected);
++  return expected.buffer;
++}
++
++static void
++run_gbhn_gai (struct test_params *params)
++{
++  char *ctx = xasprintf ("name=%s marker=%s count=%d family=%d",
++                         params->name, params->marker, params->count,
++                         params->family);
++  if (test_verbose > 0)
++    printf ("info: %s\n", ctx);
++
++  /* Check gethostbyname, gethostbyname2.  */
++  if (params->family == AF_INET)
++    {
++      char *expected = expected_ghbn (params);
++      check_hostent (ctx, gethostbyname (params->name), expected);
++      free (expected);
++    }
++  if (params->family != AF_UNSPEC)
++    {
++      char *expected = expected_ghbn (params);
++      check_hostent (ctx, gethostbyname2 (params->name, params->family),
++                     expected);
++      free (expected);
++    }
++
++  /* Check getaddrinfo.  */
++  for (int do_canonical = 0; do_canonical < 2; ++do_canonical)
++    {
++      params->canonname = do_canonical;
++      char *expected = expected_gai (params);
++      struct addrinfo hints =
++        {
++          .ai_family = params->family,
++          .ai_socktype = SOCK_STREAM,
++          .ai_protocol = IPPROTO_TCP,
++        };
++      if (do_canonical)
++        hints.ai_flags |= AI_CANONNAME;
++      struct addrinfo *ai;
++      int ret = getaddrinfo (params->name, "80", &hints, &ai);
++      check_addrinfo (ctx, ai, ret, expected);
++      if (ret == 0)
++        freeaddrinfo (ai);
++      free (expected);
++    }
++
++  free (ctx);
++}
++
++/* Callback for the subprocess which runs the test in a chroot.  */
++static void
++subprocess (void *closure)
++{
++  struct test_params *params = closure;
++
++  xchroot (chroot_env->path_chroot);
++
++  static const int families[] = { AF_INET, AF_INET6, AF_UNSPEC, -1 };
++  static const char *const names[] =
++    {
++      "www.example.com", "www4.example.com", "www6.example.com",
++      "alias.example.com",
++      NULL
++    };
++  static const char *const names_marker[] = { "46", "4", "6", "" };
++
++  for (int family_idx = 0; families[family_idx] >= 0; ++family_idx)
++    {
++      params->family = families[family_idx];
++      for (int names_idx = 0; names[names_idx] != NULL; ++names_idx)
++        {
++          params->name = names[names_idx];
++          params->marker = names_marker[names_idx];
++          run_gbhn_gai (params);
++        }
++    }
++}
++
++/* Run the test for a specific number of addresses/aliases.  */
++static void
++run_test (int count)
++{
++  write_hosts (count);
++
++  struct test_params params =
++    {
++      .count = count,
++    };
++
++  support_isolate_in_subprocess (subprocess, &params);
++}
++
++static int
++do_test (void)
++{
++  support_become_root ();
++  if (!support_can_chroot ())
++    return EXIT_UNSUPPORTED;
++
++  /* This test should not use gigabytes of memory.   */
++  {
++    struct rlimit limit;
++    if (getrlimit (RLIMIT_AS, &limit) != 0)
++      {
++        printf ("getrlimit (RLIMIT_AS) failed: %m\n");
++        return 1;
++      }
++    long target = 200 * 1024 * 1024;
++    if (limit.rlim_cur == RLIM_INFINITY || limit.rlim_cur > target)
++      {
++        limit.rlim_cur = target;
++        if (setrlimit (RLIMIT_AS, &limit) != 0)
++          {
++            printf ("setrlimit (RLIMIT_AS) failed: %m\n");
++            return 1;
++          }
++      }
++  }
++
++  __nss_configure_lookup ("hosts", "files");
++  if (dlopen (LIBNSS_FILES_SO, RTLD_LAZY) == NULL)
++    FAIL_EXIT1 ("could not load " LIBNSS_DNS_SO ": %s", dlerror ());
++
++  /* Run the tests with a few different address/alias counts.  */
++  for (int count = 1; count <= 111; ++count)
++    run_test (count);
++  run_test (1111);
++  run_test (22222);
++
++  support_chroot_free (chroot_env);
++  return 0;
++}
++
++#define PREPARE prepare
++#include <support/test-driver.c>
diff --git a/gnu/packages/patches/glibc-2-26-0062.patch b/gnu/packages/patches/glibc-2-26-0062.patch
new file mode 100644
index 000000000..be41b448e
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0062.patch
@@ -0,0 +1,160 @@
+From 2e78ea7a207e49a47a3448fbbc387d606141ec9d Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Fri, 20 Oct 2017 04:10:15 +0200
+Subject: [PATCH 62/90] sysconf: Fix missing definition of UIO_MAXIOV on Linux
+ [BZ #22321]
+
+After commit 37f802f86400684c8d13403958b2c598721d6360 (Remove
+__need_IOV_MAX and __need_FOPEN_MAX), UIO_MAXIOV is no longer supplied
+(indirectly) through <bits/stdio_lim.h>, so sysdeps/posix/sysconf.c no
+longer sees the definition.
+
+(cherry picked from commit 63b4baa44e8d22501c433c4093aa3310f91b6aa2)
+
+diff --git a/ChangeLog b/ChangeLog
+index ad3adc0bdc..a1fd1e8a3e 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,13 @@
++2017-10-20  Florian Weimer  <fweimer@redhat.com>
++
++	[BZ #22321]
++	sysconf: Fix missing definition of UIO_MAXIOV on Linux.
++	* sysdeps/posix/sysconf.c: Include <sys/uio.h>.
++	* sysdeps/unix/sysv/linux/Makefile (tests): Add tst-sysconf-iov_max.
++	(tst-sysconf-iov_max): Link with tst-sysconf-iov_max-uapi.o.
++	* sysdeps/unix/sysv/linux/tst-sysconf-iov_max.c: New file.
++	* sysdeps/unix/sysv/linux/tst-sysconf-iov_max-uapi.c: Likewise.
++
+ 2017-10-11  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	[BZ #22078]
+diff --git a/NEWS b/NEWS
+index 9cb8f00529..e5ac109a63 100644
+--- a/NEWS
++++ b/NEWS
+@@ -38,6 +38,7 @@ The following bugs are resolved with this release:
+   [22146] Let fpclassify use the builtin when optimizing for size in C++ mode
+   [22225] math: nearbyint arithmetic moved before feholdexcept
+   [22235] Add C++ versions of iscanonical for ldbl-96 and ldbl-128ibm
++  [22321] sysconf: Fix missing definition of UIO_MAXIOV on Linux
+ \f
+ Version 2.26
+ 
+diff --git a/sysdeps/posix/sysconf.c b/sysdeps/posix/sysconf.c
+index a95e1b3f05..254f87c437 100644
+--- a/sysdeps/posix/sysconf.c
++++ b/sysdeps/posix/sysconf.c
+@@ -29,6 +29,7 @@
+ #include <sys/stat.h>
+ #include <sys/sysinfo.h>
+ #include <sys/types.h>
++#include <sys/uio.h>
+ #include <regex.h>
+ 
+ #define NEED_SPEC_ARRAY 0
+diff --git a/sysdeps/unix/sysv/linux/Makefile b/sysdeps/unix/sysv/linux/Makefile
+index 9d6a2de870..5dce300f7f 100644
+--- a/sysdeps/unix/sysv/linux/Makefile
++++ b/sysdeps/unix/sysv/linux/Makefile
+@@ -50,7 +50,7 @@ sysdep_headers += sys/mount.h sys/acct.h sys/sysctl.h \
+ 		  bits/siginfo-arch.h bits/siginfo-consts-arch.h
+ 
+ tests += tst-clone tst-clone2 tst-clone3 tst-fanotify tst-personality \
+-	 tst-quota tst-sync_file_range test-errno-linux
++	 tst-quota tst-sync_file_range test-errno-linux tst-sysconf-iov_max
+ 
+ # Generate the list of SYS_* macros for the system calls (__NR_* macros).
+ 
+@@ -120,7 +120,11 @@ ifndef no_deps
+ -include $(objpfx)bits/syscall.d
+ endif
+ generated += bits/syscall.h bits/syscall.d
+-endif
++
++# Separate object file for access to the constant from the UAPI header.
++$(objpfx)tst-sysconf-iov_max: $(objpfx)tst-sysconf-iov_max-uapi.o
++
++endif # $(subdir) == misc
+ 
+ ifeq ($(subdir),time)
+ sysdep_headers += sys/timex.h bits/timex.h
+diff --git a/sysdeps/unix/sysv/linux/tst-sysconf-iov_max-uapi.c b/sysdeps/unix/sysv/linux/tst-sysconf-iov_max-uapi.c
+new file mode 100644
+index 0000000000..1240b846e6
+--- /dev/null
++++ b/sysdeps/unix/sysv/linux/tst-sysconf-iov_max-uapi.c
+@@ -0,0 +1,27 @@
++/* Check IOV_MAX definition: Helper function to capture UAPI header value.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++/* Use a separate function to avoid header compatibility issues.  */
++
++#include <linux/uio.h>
++
++long
++uio_maxiov_value (void)
++{
++  return UIO_MAXIOV;
++}
+diff --git a/sysdeps/unix/sysv/linux/tst-sysconf-iov_max.c b/sysdeps/unix/sysv/linux/tst-sysconf-iov_max.c
+new file mode 100644
+index 0000000000..dfdf3da484
+--- /dev/null
++++ b/sysdeps/unix/sysv/linux/tst-sysconf-iov_max.c
+@@ -0,0 +1,40 @@
++/* Check IOV_MAX definition for consistency (bug 22321).
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++/* Defined in tst-sysconf-iov_max-uapi.c.  */
++long uio_maxiov_value (void);
++
++
++#include <limits.h>
++#include <support/check.h>
++#include <sys/uio.h>
++#include <unistd.h>
++
++static int
++do_test (void)
++{
++  TEST_VERIFY (_XOPEN_IOV_MAX == 16); /* Value required by POSIX.  */
++  TEST_VERIFY (uio_maxiov_value () >= _XOPEN_IOV_MAX);
++  TEST_VERIFY (IOV_MAX == uio_maxiov_value ());
++  TEST_VERIFY (UIO_MAXIOV == uio_maxiov_value ());
++  TEST_VERIFY (sysconf (_SC_UIO_MAXIOV) == uio_maxiov_value ());
++  TEST_VERIFY (sysconf (_SC_IOV_MAX) == uio_maxiov_value ());
++  return 0;
++}
++
++#include <support/test-driver.c>
diff --git a/gnu/packages/patches/glibc-2-26-0063.patch b/gnu/packages/patches/glibc-2-26-0063.patch
new file mode 100644
index 000000000..0c37f767d
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0063.patch
@@ -0,0 +1,48 @@
+From c96d7a646b52e8d50e7ca98e0a60af5f24e4b441 Mon Sep 17 00:00:00 2001
+From: "H.J. Lu" <hjl.tools@gmail.com>
+Date: Sun, 20 Aug 2017 10:46:47 -0700
+Subject: [PATCH 63/90] i386: Hide __old_glob64 [BZ #18822]
+
+Hide internal __old_glob64 function to allow direct access within
+libc.so and libc.a without using GOT nor PLT.
+
+	[BZ #18822]
+	* sysdeps/unix/sysv/linux/i386/glob64.c (__old_glob64): Add
+	libc_hidden_proto and libc_hidden_def.
+
+(cherry picked from commit 2585d7b839559e665d5723734862fbe62264b25d)
+
+diff --git a/ChangeLog b/ChangeLog
+index a1fd1e8a3e..1ed253214c 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-08-20  H.J. Lu  <hongjiu.lu@intel.com>
++
++	[BZ #18822]
++	* sysdeps/unix/sysv/linux/i386/glob64.c (__old_glob64): Add
++	libc_hidden_proto and libc_hidden_def.
++
+ 2017-10-20  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	[BZ #22321]
+diff --git a/sysdeps/unix/sysv/linux/i386/glob64.c b/sysdeps/unix/sysv/linux/i386/glob64.c
+index f68195137e..956cb0474a 100644
+--- a/sysdeps/unix/sysv/linux/i386/glob64.c
++++ b/sysdeps/unix/sysv/linux/i386/glob64.c
+@@ -53,6 +53,7 @@ libc_hidden_ver (__glob64, glob64)
+ int __old_glob64 (const char *__pattern, int __flags,
+ 		  int (*__errfunc) (const char *, int),
+ 		  glob64_t *__pglob);
++libc_hidden_proto (__old_glob64);
+ 
+ #undef dirent
+ #define dirent __old_dirent64
+@@ -72,5 +73,7 @@ int __old_glob64 (const char *__pattern, int __flags,
+ 
+ #include <posix/glob.c>
+ 
++libc_hidden_def (__old_glob64);
++
+ compat_symbol (libc, __old_glob64, glob64, GLIBC_2_1);
+ #endif
diff --git a/gnu/packages/patches/glibc-2-26-0064.patch b/gnu/packages/patches/glibc-2-26-0064.patch
new file mode 100644
index 000000000..ffe6b0264
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0064.patch
@@ -0,0 +1,2141 @@
+From 305f4f057dace256e99e4321e21a23267187d77f Mon Sep 17 00:00:00 2001
+From: Adhemerval Zanella <adhemerval.zanella@linaro.org>
+Date: Fri, 20 Oct 2017 19:36:33 +0200
+Subject: [PATCH 64/90] posix: Sync glob with gnulib [BZ #1062]
+
+This patch syncs posix/glob.c implementation with gnulib version
+b5ec983 (glob: simplify symlink detection).  The only difference
+to gnulib code is
+
+  * DT_UNKNOWN, DT_DIR, and DT_LNK definition in the case there
+    were not already defined.  Gnulib code which uses
+    HAVE_STRUCT_DIRENT_D_TYPE will redefine them wrongly because
+    GLIBC does not define HAVE_STRUCT_DIRENT_D_TYPE.  Instead
+    the patch check for each definition instead.
+
+Also, the patch requires additional globfree and globfree64 files
+for compatibility version on some architectures.  Also the code
+simplification leads to not macro simplification (not need for
+NO_GLOB_PATTERN_P anymore).
+
+Checked on x86_64-linux-gnu and on a build using build-many-glibcs.py
+for all major architectures.
+
+	[BZ #1062]
+	* posix/Makefile (routines): Add globfree, globfree64, and
+	glob_pattern_p.
+	* posix/flexmember.h: New file.
+	* posix/glob_internal.h: Likewise.
+	* posix/glob_pattern_p.c: Likewise.
+	* posix/globfree.c: Likewise.
+	* posix/globfree64.c: Likewise.
+	* sysdeps/gnu/globfree64.c: Likewise.
+	* sysdeps/unix/sysv/linux/alpha/globfree.c: Likewise.
+	* sysdeps/unix/sysv/linux/mips/mips64/n64/globfree64.c: Likewise.
+	* sysdeps/unix/sysv/linux/oldglob.c: Likewise.
+	* sysdeps/unix/sysv/linux/wordsize-64/globfree64.c: Likewise.
+	* sysdeps/unix/sysv/linux/x86_64/x32/globfree.c: Likewise.
+	* sysdeps/wordsize-64/globfree.c: Likewise.
+	* sysdeps/wordsize-64/globfree64.c: Likewise.
+	* posix/glob.c (HAVE_CONFIG_H): Use !_LIBC instead.
+	[NDEBUG): Remove comments.
+	(GLOB_ONLY_P, _AMIGA, VMS): Remove define.
+	(dirent_type): New type.  Use uint_fast8_t not
+	uint8_t, as C99 does not require uint8_t.
+	(DT_UNKNOWN, DT_DIR, DT_LNK): New macros.
+	(struct readdir_result): Use dirent_type.  Do not define skip_entry
+	unless it is needed; this saves a byte on platforms lacking d_ino.
+	(readdir_result_type, readdir_result_skip_entry):
+	New functions, replacing ...
+	(readdir_result_might_be_symlink, readdir_result_might_be_dir):
+	 these functions, which were removed.  This makes the callers
+	easier to read.  All callers changed.
+	(D_INO_TO_RESULT): Now empty if there is no d_ino.
+	(size_add_wrapv, glob_use_alloca): New static functions.
+	(glob, glob_in_dir): Check for size_t overflow in several places,
+	and fix some size_t checks that were not quite right.
+	Remove old code using SHELL since Bash no longer
+	uses this.
+	(glob, prefix_array): Separate MS code better.
+	(glob_in_dir): Remove old Amiga and VMS code.
+	(globfree, __glob_pattern_type, __glob_pattern_p): Move to
+	separate files.
+	(glob_in_dir): Do not rely on undefined behavior in accessing
+	struct members beyond their bounds.  Use a flexible array member
+	instead
+	(link_stat): Rename from link_exists2_p and return -1/0 instead of
+	0/1.  Caller changed.
+	(glob): Fix memory leaks.
+	* posix/glob64 (globfree64): Move to separate file.
+	* sysdeps/gnu/glob64.c (NO_GLOB_PATTERN_P): Remove define.
+	(globfree64): Remove hidden alias.
+	* sysdeps/unix/sysv/linux/Makefile (sysdeps_routines): Add
+	oldglob.
+	* sysdeps/unix/sysv/linux/alpha/glob.c (__new_globfree): Move to
+	separate file.
+	* sysdeps/unix/sysv/linux/i386/glob64.c (NO_GLOB_PATTERN_P): Remove
+	define.
+	Move compat code to separate file.
+	* sysdeps/wordsize-64/glob.c (globfree): Move definitions to
+	separate file.
+
+(cherry picked from commit c66c908230169c1bab1f83b071eb585baa214b9f)
+
+diff --git a/ChangeLog b/ChangeLog
+index 1ed253214c..d54d5a895d 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,65 @@
++2017-09-08  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
++
++	[BZ #1062]
++	[BZ #22325]
++	CVE-2017-15671
++	* posix/Makefile (routines): Add globfree, globfree64, and
++	glob_pattern_p.
++	* posix/flexmember.h: New file.
++	* posix/glob_internal.h: Likewise.
++	* posix/glob_pattern_p.c: Likewise.
++	* posix/globfree.c: Likewise.
++	* posix/globfree64.c: Likewise.
++	* sysdeps/gnu/globfree64.c: Likewise.
++	* sysdeps/unix/sysv/linux/alpha/globfree.c: Likewise.
++	* sysdeps/unix/sysv/linux/mips/mips64/n64/globfree64.c: Likewise.
++	* sysdeps/unix/sysv/linux/oldglob.c: Likewise.
++	* sysdeps/unix/sysv/linux/wordsize-64/globfree64.c: Likewise.
++	* sysdeps/unix/sysv/linux/x86_64/x32/globfree.c: Likewise.
++	* sysdeps/wordsize-64/globfree.c: Likewise.
++	* sysdeps/wordsize-64/globfree64.c: Likewise.
++	* posix/glob.c (HAVE_CONFIG_H): Use !_LIBC instead.
++	[NDEBUG): Remove comments.
++	(GLOB_ONLY_P, _AMIGA, VMS): Remove define.
++	(dirent_type): New type.  Use uint_fast8_t not
++	uint8_t, as C99 does not require uint8_t.
++	(DT_UNKNOWN, DT_DIR, DT_LNK): New macros.
++	(struct readdir_result): Use dirent_type.  Do not define skip_entry
++	unless it is needed; this saves a byte on platforms lacking d_ino.
++	(readdir_result_type, readdir_result_skip_entry):
++	New functions, replacing ...
++	(readdir_result_might_be_symlink, readdir_result_might_be_dir):
++	 these functions, which were removed.  This makes the callers
++	easier to read.  All callers changed.
++	(D_INO_TO_RESULT): Now empty if there is no d_ino.
++	(size_add_wrapv, glob_use_alloca): New static functions.
++	(glob, glob_in_dir): Check for size_t overflow in several places,
++	and fix some size_t checks that were not quite right.
++	Remove old code using SHELL since Bash no longer
++	uses this.
++	(glob, prefix_array): Separate MS code better.
++	(glob_in_dir): Remove old Amiga and VMS code.
++	(globfree, __glob_pattern_type, __glob_pattern_p): Move to
++	separate files.
++	(glob_in_dir): Do not rely on undefined behavior in accessing
++	struct members beyond their bounds.  Use a flexible array member
++	instead
++	(link_stat): Rename from link_exists2_p and return -1/0 instead of
++	0/1.  Caller changed.
++	(glob): Fix memory leaks.
++	* posix/glob64 (globfree64): Move to separate file.
++	* sysdeps/gnu/glob64.c (NO_GLOB_PATTERN_P): Remove define.
++	(globfree64): Remove hidden alias.
++	* sysdeps/unix/sysv/linux/Makefile (sysdeps_routines): Add
++	oldglob.
++	* sysdeps/unix/sysv/linux/alpha/glob.c (__new_globfree): Move to
++	separate file.
++	* sysdeps/unix/sysv/linux/i386/glob64.c (NO_GLOB_PATTERN_P): Remove
++	define.
++	Move compat code to separate file.
++	* sysdeps/wordsize-64/glob.c (globfree): Move definitions to
++	separate file.
++
+ 2017-08-20  H.J. Lu  <hongjiu.lu@intel.com>
+ 
+ 	[BZ #18822]
+diff --git a/NEWS b/NEWS
+index e5ac109a63..ddc950c6cf 100644
+--- a/NEWS
++++ b/NEWS
+@@ -39,6 +39,7 @@ The following bugs are resolved with this release:
+   [22225] math: nearbyint arithmetic moved before feholdexcept
+   [22235] Add C++ versions of iscanonical for ldbl-96 and ldbl-128ibm
+   [22321] sysconf: Fix missing definition of UIO_MAXIOV on Linux
++  [22325] glibc: Memory leak in glob with GLOB_TILDE (CVE-2017-15671)
+ \f
+ Version 2.26
+ 
+diff --git a/posix/Makefile b/posix/Makefile
+index 33abcaed7a..51e7e5bcb8 100644
+--- a/posix/Makefile
++++ b/posix/Makefile
+@@ -45,7 +45,7 @@ routines :=								      \
+ 	getpgid setpgid getpgrp bsd-getpgrp setpgrp getsid setsid	      \
+ 	getresuid getresgid setresuid setresgid				      \
+ 	pathconf sysconf fpathconf					      \
+-	glob glob64 fnmatch regex					      \
++	glob glob64 globfree globfree64 glob_pattern_p fnmatch regex	      \
+ 	confstr								      \
+ 	getopt getopt1 							      \
+ 	sched_setp sched_getp sched_sets sched_gets sched_yield sched_primax  \
+diff --git a/posix/flexmember.h b/posix/flexmember.h
+new file mode 100644
+index 0000000000..107c1f09e9
+--- /dev/null
++++ b/posix/flexmember.h
+@@ -0,0 +1,45 @@
++/* Sizes of structs with flexible array members.
++
++   Copyright 2016-2017 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
++   <http://www.gnu.org/licenses/>.
++
++   Written by Paul Eggert.  */
++
++#include <stddef.h>
++
++/* Nonzero multiple of alignment of TYPE, suitable for FLEXSIZEOF below.
++   On older platforms without _Alignof, use a pessimistic bound that is
++   safe in practice even if FLEXIBLE_ARRAY_MEMBER is 1.
++   On newer platforms, use _Alignof to get a tighter bound.  */
++
++#if !defined __STDC_VERSION__ || __STDC_VERSION__ < 201112
++# define FLEXALIGNOF(type) (sizeof (type) & ~ (sizeof (type) - 1))
++#else
++# define FLEXALIGNOF(type) _Alignof (type)
++#endif
++
++/* Upper bound on the size of a struct of type TYPE with a flexible
++   array member named MEMBER that is followed by N bytes of other data.
++   This is not simply sizeof (TYPE) + N, since it may require
++   alignment on unusually picky C11 platforms, and
++   FLEXIBLE_ARRAY_MEMBER may be 1 on pre-C11 platforms.
++   Yield a value less than N if and only if arithmetic overflow occurs.  */
++
++#define FLEXSIZEOF(type, member, n) \
++   ((offsetof (type, member) + FLEXALIGNOF (type) - 1 + (n)) \
++    & ~ (FLEXALIGNOF (type) - 1))
+diff --git a/posix/glob.c b/posix/glob.c
+index c653809118..a7eccf9cb4 100644
+--- a/posix/glob.c
++++ b/posix/glob.c
+@@ -15,7 +15,7 @@
+    License along with the GNU C Library; if not, see
+    <http://www.gnu.org/licenses/>.  */
+ 
+-#ifdef	HAVE_CONFIG_H
++#ifndef _LIBC
+ # include <config.h>
+ #endif
+ 
+@@ -27,29 +27,15 @@
+ #include <stdbool.h>
+ #include <stddef.h>
+ #include <stdint.h>
+-
+-/* Outcomment the following line for production quality code.  */
+-/* #define NDEBUG 1 */
+ #include <assert.h>
++#include <unistd.h>
+ 
+-#include <stdio.h>		/* Needed on stupid SunOS for assert.  */
+-
+-#if !defined _LIBC || !defined GLOB_ONLY_P
+-#if defined HAVE_UNISTD_H || defined _LIBC
+-# include <unistd.h>
+-# ifndef POSIX
+-#  ifdef _POSIX_VERSION
+-#   define POSIX
+-#  endif
+-# endif
++#if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
++# define WINDOWS32
+ #endif
+ 
+-#include <pwd.h>
+-
+-#if defined HAVE_STDINT_H || defined _LIBC
+-# include <stdint.h>
+-#elif !defined UINTPTR_MAX
+-# define UINTPTR_MAX (~((size_t) 0))
++#ifndef WINDOWS32
++# include <pwd.h>
+ #endif
+ 
+ #include <errno.h>
+@@ -57,24 +43,7 @@
+ # define __set_errno(val) errno = (val)
+ #endif
+ 
+-#if defined HAVE_DIRENT_H || defined __GNU_LIBRARY__
+-# include <dirent.h>
+-#else
+-# define dirent direct
+-# ifdef HAVE_SYS_NDIR_H
+-#  include <sys/ndir.h>
+-# endif
+-# ifdef HAVE_SYS_DIR_H
+-#  include <sys/dir.h>
+-# endif
+-# ifdef HAVE_NDIR_H
+-#  include <ndir.h>
+-# endif
+-# ifdef HAVE_VMSDIR_H
+-#  include "vmsdir.h"
+-# endif /* HAVE_VMSDIR_H */
+-#endif
+-
++#include <dirent.h>
+ #include <stdlib.h>
+ #include <string.h>
+ #include <alloca.h>
+@@ -87,27 +56,29 @@
+ # define opendir(name) __opendir (name)
+ # define readdir(str) __readdir64 (str)
+ # define getpwnam_r(name, bufp, buf, len, res) \
+-   __getpwnam_r (name, bufp, buf, len, res)
++    __getpwnam_r (name, bufp, buf, len, res)
+ # ifndef __stat64
+ #  define __stat64(fname, buf) __xstat64 (_STAT_VER, fname, buf)
+ # endif
+ # define struct_stat64		struct stat64
++# define FLEXIBLE_ARRAY_MEMBER
+ #else /* !_LIBC */
+-# include "getlogin_r.h"
+-# include "mempcpy.h"
+-# include "stat-macros.h"
+-# include "strdup.h"
+-# define __stat64(fname, buf)	stat (fname, buf)
+-# define struct_stat64		struct stat
+-# define __stat(fname, buf)	stat (fname, buf)
+-# define __alloca		alloca
+-# define __readdir		readdir
+-# define __readdir64		readdir64
+-# define __glob_pattern_p	glob_pattern_p
++# define __getlogin_r(buf, len) getlogin_r (buf, len)
++# define __stat64(fname, buf)   stat (fname, buf)
++# define __fxstatat64(_, d, f, st, flag) fstatat (d, f, st, flag)
++# define struct_stat64          struct stat
++# ifndef __MVS__
++#  define __alloca              alloca
++# endif
++# define __readdir              readdir
++# define COMPILE_GLOB64
+ #endif /* _LIBC */
+ 
+ #include <fnmatch.h>
+ 
++#include <flexmember.h>
++#include <glob_internal.h>
++
+ #ifdef _SC_GETPW_R_SIZE_MAX
+ # define GETPW_R_SIZE_MAX()	sysconf (_SC_GETPW_R_SIZE_MAX)
+ #else
+@@ -121,61 +92,59 @@
+ \f
+ static const char *next_brace_sub (const char *begin, int flags) __THROWNL;
+ 
++typedef uint_fast8_t dirent_type;
++
++#if !defined _LIBC && !defined HAVE_STRUCT_DIRENT_D_TYPE
++/* Any distinct values will do here.
++   Undef any existing macros out of the way.  */
++# undef DT_UNKNOWN
++# undef DT_DIR
++# undef DT_LNK
++# define DT_UNKNOWN 0
++# define DT_DIR 1
++# define DT_LNK 2
++#endif
++
+ /* A representation of a directory entry which does not depend on the
+    layout of struct dirent, or the size of ino_t.  */
+ struct readdir_result
+ {
+   const char *name;
+-# if defined _DIRENT_HAVE_D_TYPE || defined HAVE_STRUCT_DIRENT_D_TYPE
+-  uint8_t type;
+-# endif
++#if defined _DIRENT_HAVE_D_TYPE || defined HAVE_STRUCT_DIRENT_D_TYPE
++  dirent_type type;
++#endif
++#if defined _LIBC || defined D_INO_IN_DIRENT
+   bool skip_entry;
++#endif
+ };
+ 
+-# if defined _DIRENT_HAVE_D_TYPE || defined HAVE_STRUCT_DIRENT_D_TYPE
+-/* Initializer based on the d_type member of struct dirent.  */
+-#  define D_TYPE_TO_RESULT(source) (source)->d_type,
+-
+-/* True if the directory entry D might be a symbolic link.  */
+-static bool
+-readdir_result_might_be_symlink (struct readdir_result d)
+-{
+-  return d.type == DT_UNKNOWN || d.type == DT_LNK;
+-}
+-
+-/* True if the directory entry D might be a directory.  */
+-static bool
+-readdir_result_might_be_dir (struct readdir_result d)
+-{
+-  return d.type == DT_DIR || readdir_result_might_be_symlink (d);
+-}
+-# else /* defined _DIRENT_HAVE_D_TYPE || defined HAVE_STRUCT_DIRENT_D_TYPE */
+-#  define D_TYPE_TO_RESULT(source)
+-
+-/* If we do not have type information, symbolic links and directories
+-   are always a possibility.  */
+-
+-static bool
+-readdir_result_might_be_symlink (struct readdir_result d)
++/* Initialize and return type member of struct readdir_result.  */
++static dirent_type
++readdir_result_type (struct readdir_result d)
+ {
+-  return true;
++#if defined _DIRENT_HAVE_D_TYPE || defined HAVE_STRUCT_DIRENT_D_TYPE
++# define D_TYPE_TO_RESULT(source) (source)->d_type,
++  return d.type;
++#else
++# define D_TYPE_TO_RESULT(source)
++  return DT_UNKNOWN;
++#endif
+ }
+ 
++/* Initialize and return skip_entry member of struct readdir_result.  */
+ static bool
+-readdir_result_might_be_dir (struct readdir_result d)
++readdir_result_skip_entry (struct readdir_result d)
+ {
+-  return true;
+-}
+-
+-# endif /* defined _DIRENT_HAVE_D_TYPE || defined HAVE_STRUCT_DIRENT_D_TYPE */
+-
+-# if (defined POSIX || defined WINDOWS32) && !defined __GNU_LIBRARY__
+ /* Initializer for skip_entry.  POSIX does not require that the d_ino
+    field be present, and some systems do not provide it. */
+-#  define D_INO_TO_RESULT(source) false,
+-# else
+-#  define D_INO_TO_RESULT(source) (source)->d_ino == 0,
+-# endif
++#if defined _LIBC || defined D_INO_IN_DIRENT
++# define D_INO_TO_RESULT(source) (source)->d_ino == 0,
++  return d.skip_entry;
++#else
++# define D_INO_TO_RESULT(source)
++  return false;
++#endif
++}
+ 
+ /* Construct an initializer for a struct readdir_result object from a
+    struct dirent *.  No copy of the name is made.  */
+@@ -186,8 +155,6 @@ readdir_result_might_be_dir (struct readdir_result d)
+     D_INO_TO_RESULT (source)		   \
+   }
+ 
+-#endif /* !defined _LIBC || !defined GLOB_ONLY_P */
+-
+ /* Call gl_readdir on STREAM.  This macro can be overridden to reduce
+    type safety if an old interface version needs to be supported.  */
+ #ifndef GL_READDIR
+@@ -225,18 +192,55 @@ convert_dirent64 (const struct dirent64 *source)
+ }
+ #endif
+ 
++#ifndef _LIBC
++/* The results of opendir() in this file are not used with dirfd and fchdir,
++   and we do not leak fds to any single-threaded code that could use stdio,
++   therefore save some unnecessary recursion in fchdir.c and opendir_safer.c.
++   FIXME - if the kernel ever adds support for multi-thread safety for
++   avoiding standard fds, then we should use opendir_safer.  */
++# ifdef GNULIB_defined_opendir
++#  undef opendir
++# endif
++# ifdef GNULIB_defined_closedir
++#  undef closedir
++# endif
+ 
+-#ifndef attribute_hidden
+-# define attribute_hidden
++/* Just use malloc.  */
++# define __libc_use_alloca(n) false
++# define alloca_account(len, avar) ((void) (len), (void) (avar), (void *) 0)
++# define extend_alloca_account(buf, len, newlen, avar) \
++    ((void) (buf), (void) (len), (void) (newlen), (void) (avar), (void *) 0)
+ #endif
+ 
++/* Set *R = A + B.  Return true if the answer is mathematically
++   incorrect due to overflow; in this case, *R is the low order
++   bits of the correct answer.  */
++
++static bool
++size_add_wrapv (size_t a, size_t b, size_t *r)
++{
++#if 5 <= __GNUC__ && !defined __ICC
++  return __builtin_add_overflow (a, b, r);
++#else
++  *r = a + b;
++  return *r < a;
++#endif
++}
++
++static bool
++glob_use_alloca (size_t alloca_used, size_t len)
++{
++  size_t size;
++  return (!size_add_wrapv (alloca_used, len, &size)
++          && __libc_use_alloca (size));
++}
++
+ static int glob_in_dir (const char *pattern, const char *directory,
+ 			int flags, int (*errfunc) (const char *, int),
+ 			glob_t *pglob, size_t alloca_used);
+ extern int __glob_pattern_type (const char *pattern, int quote)
+     attribute_hidden;
+ 
+-#if !defined _LIBC || !defined GLOB_ONLY_P
+ static int prefix_array (const char *prefix, char **array, size_t n) __THROWNL;
+ static int collated_compare (const void *, const void *) __THROWNL;
+ 
+@@ -265,16 +269,15 @@ next_brace_sub (const char *cp, int flags)
+   return *cp != '\0' ? cp : NULL;
+ }
+ 
+-#endif /* !defined _LIBC || !defined GLOB_ONLY_P */
+ 
+ /* Do glob searching for PATTERN, placing results in PGLOB.
+    The bits defined above may be set in FLAGS.
+    If a directory cannot be opened or read and ERRFUNC is not nil,
+    it is called with the pathname that caused the error, and the
+-   `errno' value from the failing call; if it returns non-zero
+-   `glob' returns GLOB_ABORTED; if it returns zero, the error is ignored.
++   'errno' value from the failing call; if it returns non-zero
++   'glob' returns GLOB_ABORTED; if it returns zero, the error is ignored.
+    If memory cannot be allocated for PGLOB, GLOB_NOSPACE is returned.
+-   Otherwise, `glob' returns zero.  */
++   Otherwise, 'glob' returns zero.  */
+ int
+ #ifdef GLOB_ATTRIBUTE
+ GLOB_ATTRIBUTE
+@@ -292,9 +295,7 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+   int malloc_dirname = 0;
+   glob_t dirs;
+   int retval = 0;
+-#ifdef _LIBC
+   size_t alloca_used = 0;
+-#endif
+ 
+   if (pattern == NULL || pglob == NULL || (flags & ~__GLOB_FLAGS) != 0)
+     {
+@@ -308,7 +309,7 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+     flags |= GLOB_ONLYDIR;
+ 
+   if (!(flags & GLOB_DOOFFS))
+-    /* Have to do this so `globfree' knows where to start freeing.  It
++    /* Have to do this so 'globfree' knows where to start freeing.  It
+        also makes all the code that uses gl_offs simpler. */
+     pglob->gl_offs = 0;
+ 
+@@ -372,14 +373,12 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	  size_t rest_len;
+ 	  char *onealt;
+ 	  size_t pattern_len = strlen (pattern) - 1;
+-#ifdef _LIBC
+-	  int alloca_onealt = __libc_use_alloca (alloca_used + pattern_len);
++	  int alloca_onealt = glob_use_alloca (alloca_used, pattern_len);
+ 	  if (alloca_onealt)
+ 	    onealt = alloca_account (pattern_len, alloca_used);
+ 	  else
+-#endif
+ 	    {
+-	      onealt = (char *) malloc (pattern_len);
++	      onealt = malloc (pattern_len);
+ 	      if (onealt == NULL)
+ 		return GLOB_NOSPACE;
+ 	    }
+@@ -392,11 +391,9 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	  next = next_brace_sub (begin + 1, flags);
+ 	  if (next == NULL)
+ 	    {
+-	      /* It is an illegal expression.  */
++	      /* It is an invalid expression.  */
+ 	    illegal_brace:
+-#ifdef _LIBC
+ 	      if (__glibc_unlikely (!alloca_onealt))
+-#endif
+ 		free (onealt);
+ 	      flags &= ~GLOB_BRACE;
+ 	      goto no_brace;
+@@ -437,9 +434,7 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	      /* If we got an error, return it.  */
+ 	      if (result && result != GLOB_NOMATCH)
+ 		{
+-#ifdef _LIBC
+ 		  if (__glibc_unlikely (!alloca_onealt))
+-#endif
+ 		    free (onealt);
+ 		  if (!(flags & GLOB_APPEND))
+ 		    {
+@@ -458,9 +453,7 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	      assert (next != NULL);
+ 	    }
+ 
+-#ifdef _LIBC
+ 	  if (__glibc_unlikely (!alloca_onealt))
+-#endif
+ 	    free (onealt);
+ 
+ 	  if (pglob->gl_pathc != firstc)
+@@ -476,14 +469,16 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 
+   /* Find the filename.  */
+   filename = strrchr (pattern, '/');
++
+ #if defined __MSDOS__ || defined WINDOWS32
+-  /* The case of "d:pattern".  Since `:' is not allowed in
++  /* The case of "d:pattern".  Since ':' is not allowed in
+      file names, we can safely assume that wherever it
+      happens in pattern, it signals the filename part.  This
+      is so we could some day support patterns like "[a-z]:foo".  */
+   if (filename == NULL)
+     filename = strchr (pattern, ':');
+ #endif /* __MSDOS__ || WINDOWS32 */
++
+   dirname_modified = 0;
+   if (filename == NULL)
+     {
+@@ -508,11 +503,7 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	    }
+ 
+ 	  filename = pattern;
+-#ifdef _AMIGA
+-	  dirname = (char *) "";
+-#else
+ 	  dirname = (char *) ".";
+-#endif
+ 	  dirlen = 0;
+ 	}
+     }
+@@ -536,22 +527,21 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	  char *drive_spec;
+ 
+ 	  ++dirlen;
+-	  drive_spec = (char *) __alloca (dirlen + 1);
++	  drive_spec = __alloca (dirlen + 1);
+ 	  *((char *) mempcpy (drive_spec, pattern, dirlen)) = '\0';
+ 	  /* For now, disallow wildcards in the drive spec, to
+ 	     prevent infinite recursion in glob.  */
+ 	  if (__glob_pattern_p (drive_spec, !(flags & GLOB_NOESCAPE)))
+ 	    return GLOB_NOMATCH;
+-	  /* If this is "d:pattern", we need to copy `:' to DIRNAME
++	  /* If this is "d:pattern", we need to copy ':' to DIRNAME
+ 	     as well.  If it's "d:/pattern", don't remove the slash
+ 	     from "d:/", since "d:" and "d:/" are not the same.*/
+ 	}
+ #endif
+-#ifdef _LIBC
+-      if (__libc_use_alloca (alloca_used + dirlen + 1))
++
++      if (glob_use_alloca (alloca_used, dirlen + 1))
+ 	newp = alloca_account (dirlen + 1, alloca_used);
+       else
+-#endif
+ 	{
+ 	  newp = malloc (dirlen + 1);
+ 	  if (newp == NULL)
+@@ -562,14 +552,17 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+       dirname = newp;
+       ++filename;
+ 
+-      if (filename[0] == '\0'
+ #if defined __MSDOS__ || defined WINDOWS32
+-	  && dirname[dirlen - 1] != ':'
+-	  && (dirlen < 3 || dirname[dirlen - 2] != ':'
+-	      || dirname[dirlen - 1] != '/')
++      bool drive_root = (dirlen > 1
++                         && (dirname[dirlen - 1] == ':'
++                             || (dirlen > 2 && dirname[dirlen - 2] == ':'
++                                 && dirname[dirlen - 1] == '/')));
++#else
++      bool drive_root = false;
+ #endif
+-	  && dirlen > 1)
+-	/* "pattern/".  Expand "pattern", appending slashes.  */
++
++      if (filename[0] == '\0' && dirlen > 1 && !drive_root)
++        /* "pattern/".  Expand "pattern", appending slashes.  */
+ 	{
+ 	  int orig_flags = flags;
+ 	  if (!(flags & GLOB_NOESCAPE) && dirname[dirlen - 1] == '\\')
+@@ -602,7 +595,6 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	}
+     }
+ 
+-#ifndef VMS
+   if ((flags & (GLOB_TILDE|GLOB_TILDE_CHECK)) && dirname[0] == '~')
+     {
+       if (dirname[1] == '\0' || dirname[1] == '/'
+@@ -612,100 +604,127 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	  /* Look up home directory.  */
+ 	  char *home_dir = getenv ("HOME");
+ 	  int malloc_home_dir = 0;
+-# ifdef _AMIGA
+-	  if (home_dir == NULL || home_dir[0] == '\0')
+-	    home_dir = "SYS:";
+-# else
+-#  ifdef WINDOWS32
+-	  if (home_dir == NULL || home_dir[0] == '\0')
+-	    home_dir = "c:/users/default"; /* poor default */
+-#  else
+ 	  if (home_dir == NULL || home_dir[0] == '\0')
+ 	    {
++#ifdef WINDOWS32
++	      /* Windows NT defines HOMEDRIVE and HOMEPATH.  But give
++		 preference to HOME, because the user can change HOME.  */
++	      const char *home_drive = getenv ("HOMEDRIVE");
++	      const char *home_path = getenv ("HOMEPATH");
++
++	      if (home_drive != NULL && home_path != NULL)
++		{
++		  size_t home_drive_len = strlen (home_drive);
++		  size_t home_path_len = strlen (home_path);
++		  char *mem = alloca (home_drive_len + home_path_len + 1);
++
++		  memcpy (mem, home_drive, home_drive_len);
++		  memcpy (mem + home_drive_len, home_path, home_path_len + 1);
++		  home_dir = mem;
++		}
++	      else
++		home_dir = "c:/users/default"; /* poor default */
++#else
+ 	      int success;
+ 	      char *name;
++	      int malloc_name = 0;
+ 	      size_t buflen = GET_LOGIN_NAME_MAX () + 1;
+ 
+ 	      if (buflen == 0)
+-		/* `sysconf' does not support _SC_LOGIN_NAME_MAX.  Try
++		/* 'sysconf' does not support _SC_LOGIN_NAME_MAX.  Try
+ 		   a moderate value.  */
+ 		buflen = 20;
+-	      name = alloca_account (buflen, alloca_used);
++	      if (glob_use_alloca (alloca_used, buflen))
++		name = alloca_account (buflen, alloca_used);
++	      else
++		{
++		  name = malloc (buflen);
++		  if (name == NULL)
++		    {
++		      retval = GLOB_NOSPACE;
++		      goto out;
++		    }
++		  malloc_name = 1;
++		}
+ 
+ 	      success = __getlogin_r (name, buflen) == 0;
+ 	      if (success)
+ 		{
+ 		  struct passwd *p;
+-#   if defined HAVE_GETPWNAM_R || defined _LIBC
+-		  long int pwbuflen = GETPW_R_SIZE_MAX ();
++		  char *malloc_pwtmpbuf = NULL;
+ 		  char *pwtmpbuf;
++# if defined HAVE_GETPWNAM_R || defined _LIBC
++		  long int pwbuflenmax = GETPW_R_SIZE_MAX ();
++		  size_t pwbuflen = pwbuflenmax;
+ 		  struct passwd pwbuf;
+-		  int malloc_pwtmpbuf = 0;
+ 		  int save = errno;
+ 
+-#    ifndef _LIBC
+-		  if (pwbuflen == -1)
+-		    /* `sysconf' does not support _SC_GETPW_R_SIZE_MAX.
++#  ifndef _LIBC
++		  if (! (0 < pwbuflenmax && pwbuflenmax <= SIZE_MAX))
++		    /* 'sysconf' does not support _SC_GETPW_R_SIZE_MAX.
+ 		       Try a moderate value.  */
+ 		    pwbuflen = 1024;
+-#    endif
+-		  if (__libc_use_alloca (alloca_used + pwbuflen))
++#  endif
++		  if (glob_use_alloca (alloca_used, pwbuflen))
+ 		    pwtmpbuf = alloca_account (pwbuflen, alloca_used);
+ 		  else
+ 		    {
+ 		      pwtmpbuf = malloc (pwbuflen);
+ 		      if (pwtmpbuf == NULL)
+ 			{
++			  if (__glibc_unlikely (malloc_name))
++			    free (name);
+ 			  retval = GLOB_NOSPACE;
+ 			  goto out;
+ 			}
+-		      malloc_pwtmpbuf = 1;
++		      malloc_pwtmpbuf = pwtmpbuf;
+ 		    }
+ 
+ 		  while (getpwnam_r (name, &pwbuf, pwtmpbuf, pwbuflen, &p)
+ 			 != 0)
+ 		    {
++		      size_t newlen;
++		      bool v;
+ 		      if (errno != ERANGE)
+ 			{
+ 			  p = NULL;
+ 			  break;
+ 			}
+-
+-		      if (!malloc_pwtmpbuf
+-			  && __libc_use_alloca (alloca_used
+-						+ 2 * pwbuflen))
++		      v = size_add_wrapv (pwbuflen, pwbuflen, &newlen);
++		      if (!v && malloc_pwtmpbuf == NULL
++			  && glob_use_alloca (alloca_used, newlen))
+ 			pwtmpbuf = extend_alloca_account (pwtmpbuf, pwbuflen,
+-							  2 * pwbuflen,
+-							  alloca_used);
++							  newlen, alloca_used);
+ 		      else
+ 			{
+-			  char *newp = realloc (malloc_pwtmpbuf
+-						? pwtmpbuf : NULL,
+-						2 * pwbuflen);
++			  char *newp = (v ? NULL
++					: realloc (malloc_pwtmpbuf, newlen));
+ 			  if (newp == NULL)
+ 			    {
+-			      if (__glibc_unlikely (malloc_pwtmpbuf))
+-				free (pwtmpbuf);
++			      free (malloc_pwtmpbuf);
++			      if (__glibc_unlikely (malloc_name))
++				free (name);
+ 			      retval = GLOB_NOSPACE;
+ 			      goto out;
+ 			    }
+-			  pwtmpbuf = newp;
+-			  pwbuflen = 2 * pwbuflen;
+-			  malloc_pwtmpbuf = 1;
++			  malloc_pwtmpbuf = pwtmpbuf = newp;
+ 			}
++		      pwbuflen = newlen;
+ 		      __set_errno (save);
+ 		    }
+-#   else
++# else
+ 		  p = getpwnam (name);
+-#   endif
++# endif
++		  if (__glibc_unlikely (malloc_name))
++		    free (name);
+ 		  if (p != NULL)
+ 		    {
+-		      if (!malloc_pwtmpbuf)
++		      if (malloc_pwtmpbuf == NULL)
+ 			home_dir = p->pw_dir;
+ 		      else
+ 			{
+ 			  size_t home_dir_len = strlen (p->pw_dir) + 1;
+-			  if (__libc_use_alloca (alloca_used + home_dir_len))
++			  if (glob_use_alloca (alloca_used, home_dir_len))
+ 			    home_dir = alloca_account (home_dir_len,
+ 						       alloca_used);
+ 			  else
+@@ -720,26 +739,32 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 			      malloc_home_dir = 1;
+ 			    }
+ 			  memcpy (home_dir, p->pw_dir, home_dir_len);
+-
+-			  free (pwtmpbuf);
+ 			}
+ 		    }
++		  free (malloc_pwtmpbuf);
+ 		}
++	      else
++		{
++		  if (__glibc_unlikely (malloc_name))
++		    free (name);
++		}
++#endif /* WINDOWS32 */
+ 	    }
+ 	  if (home_dir == NULL || home_dir[0] == '\0')
+ 	    {
++	      if (__glibc_unlikely (malloc_home_dir))
++		free (home_dir);
+ 	      if (flags & GLOB_TILDE_CHECK)
+ 		{
+-		  if (__glibc_unlikely (malloc_home_dir))
+-		    free (home_dir);
+ 		  retval = GLOB_NOMATCH;
+ 		  goto out;
+ 		}
+ 	      else
+-		home_dir = (char *) "~"; /* No luck.  */
++		{
++		  home_dir = (char *) "~"; /* No luck.  */
++		  malloc_home_dir = 0;
++		}
+ 	    }
+-#  endif /* WINDOWS32 */
+-# endif
+ 	  /* Now construct the full directory.  */
+ 	  if (dirname[1] == '\0')
+ 	    {
+@@ -754,8 +779,7 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	    {
+ 	      char *newp;
+ 	      size_t home_len = strlen (home_dir);
+-	      int use_alloca = __libc_use_alloca (alloca_used
+-						  + home_len + dirlen);
++	      int use_alloca = glob_use_alloca (alloca_used, home_len + dirlen);
+ 	      if (use_alloca)
+ 		newp = alloca_account (home_len + dirlen, alloca_used);
+ 	      else
+@@ -779,12 +803,15 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	      dirname = newp;
+ 	      dirlen += home_len - 1;
+ 	      malloc_dirname = !use_alloca;
++
++	      if (__glibc_unlikely (malloc_home_dir))
++		free (home_dir);
+ 	    }
+ 	  dirname_modified = 1;
+ 	}
+-# if !defined _AMIGA && !defined WINDOWS32
+       else
+ 	{
++#ifndef WINDOWS32
+ 	  char *end_name = strchr (dirname, '/');
+ 	  char *user_name;
+ 	  int malloc_user_name = 0;
+@@ -806,7 +833,7 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	  else
+ 	    {
+ 	      char *newp;
+-	      if (__libc_use_alloca (alloca_used + (end_name - dirname)))
++	      if (glob_use_alloca (alloca_used, end_name - dirname))
+ 		newp = alloca_account (end_name - dirname, alloca_used);
+ 	      else
+ 		{
+@@ -851,20 +878,21 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	  /* Look up specific user's home directory.  */
+ 	  {
+ 	    struct passwd *p;
++	    char *malloc_pwtmpbuf = NULL;
+ #  if defined HAVE_GETPWNAM_R || defined _LIBC
+-	    long int buflen = GETPW_R_SIZE_MAX ();
++	    long int buflenmax = GETPW_R_SIZE_MAX ();
++	    size_t buflen = buflenmax;
+ 	    char *pwtmpbuf;
+-	    int malloc_pwtmpbuf = 0;
+ 	    struct passwd pwbuf;
+ 	    int save = errno;
+ 
+ #   ifndef _LIBC
+-	    if (buflen == -1)
+-	      /* `sysconf' does not support _SC_GETPW_R_SIZE_MAX.  Try a
++	    if (! (0 <= buflenmax && buflenmax <= SIZE_MAX))
++	      /* Perhaps 'sysconf' does not support _SC_GETPW_R_SIZE_MAX.  Try a
+ 		 moderate value.  */
+ 	      buflen = 1024;
+ #   endif
+-	    if (__libc_use_alloca (alloca_used + buflen))
++	    if (glob_use_alloca (alloca_used, buflen))
+ 	      pwtmpbuf = alloca_account (buflen, alloca_used);
+ 	    else
+ 	      {
+@@ -877,32 +905,32 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 		    retval = GLOB_NOSPACE;
+ 		    goto out;
+ 		  }
+-		malloc_pwtmpbuf = 1;
++		malloc_pwtmpbuf = pwtmpbuf;
+ 	      }
+ 
+ 	    while (getpwnam_r (user_name, &pwbuf, pwtmpbuf, buflen, &p) != 0)
+ 	      {
++		size_t newlen;
++		bool v;
+ 		if (errno != ERANGE)
+ 		  {
+ 		    p = NULL;
+ 		    break;
+ 		  }
+-		if (!malloc_pwtmpbuf
+-		    && __libc_use_alloca (alloca_used + 2 * buflen))
++		v = size_add_wrapv (buflen, buflen, &newlen);
++		if (!v && malloc_pwtmpbuf == NULL
++		    && glob_use_alloca (alloca_used, newlen))
+ 		  pwtmpbuf = extend_alloca_account (pwtmpbuf, buflen,
+-						    2 * buflen, alloca_used);
++						    newlen, alloca_used);
+ 		else
+ 		  {
+-		    char *newp = realloc (malloc_pwtmpbuf ? pwtmpbuf : NULL,
+-					  2 * buflen);
++		    char *newp = v ? NULL : realloc (malloc_pwtmpbuf, newlen);
+ 		    if (newp == NULL)
+ 		      {
+-			if (__glibc_unlikely (malloc_pwtmpbuf))
+-			  free (pwtmpbuf);
++			free (malloc_pwtmpbuf);
+ 			goto nomem_getpw;
+ 		      }
+-		    pwtmpbuf = newp;
+-		    malloc_pwtmpbuf = 1;
++		    malloc_pwtmpbuf = pwtmpbuf = newp;
+ 		  }
+ 		__set_errno (save);
+ 	      }
+@@ -923,7 +951,7 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 		  free (dirname);
+ 		malloc_dirname = 0;
+ 
+-		if (__libc_use_alloca (alloca_used + home_len + rest_len + 1))
++		if (glob_use_alloca (alloca_used, home_len + rest_len + 1))
+ 		  dirname = alloca_account (home_len + rest_len + 1,
+ 					    alloca_used);
+ 		else
+@@ -931,8 +959,7 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 		    dirname = malloc (home_len + rest_len + 1);
+ 		    if (dirname == NULL)
+ 		      {
+-			if (__glibc_unlikely (malloc_pwtmpbuf))
+-			  free (pwtmpbuf);
++			free (malloc_pwtmpbuf);
+ 			retval = GLOB_NOSPACE;
+ 			goto out;
+ 		      }
+@@ -944,24 +971,24 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 		dirlen = home_len + rest_len;
+ 		dirname_modified = 1;
+ 
+-		if (__glibc_unlikely (malloc_pwtmpbuf))
+-		  free (pwtmpbuf);
++		free (malloc_pwtmpbuf);
+ 	      }
+ 	    else
+ 	      {
+-		if (__glibc_unlikely (malloc_pwtmpbuf))
+-		  free (pwtmpbuf);
++		free (malloc_pwtmpbuf);
+ 
+ 		if (flags & GLOB_TILDE_CHECK)
+-		  /* We have to regard it as an error if we cannot find the
+-		     home directory.  */
+-		  return GLOB_NOMATCH;
++		  {
++		    /* We have to regard it as an error if we cannot find the
++		       home directory.  */
++		    retval = GLOB_NOMATCH;
++		    goto out;
++		  }
+ 	      }
+ 	  }
++#endif /* !WINDOWS32 */
+ 	}
+-# endif	/* Not Amiga && not WINDOWS32.  */
+     }
+-#endif	/* Not VMS.  */
+ 
+   /* Now test whether we looked for "~" or "~NAME".  In this case we
+      can give the answer now.  */
+@@ -980,19 +1007,18 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	  size_t newcount = pglob->gl_pathc + pglob->gl_offs;
+ 	  char **new_gl_pathv;
+ 
+-	  if (newcount > UINTPTR_MAX - (1 + 1)
+-	      || newcount + 1 + 1 > ~((size_t) 0) / sizeof (char *))
++	  if (newcount > SIZE_MAX / sizeof (char *) - 2)
+ 	    {
+ 	    nospace:
+ 	      free (pglob->gl_pathv);
+ 	      pglob->gl_pathv = NULL;
+ 	      pglob->gl_pathc = 0;
+-	      return GLOB_NOSPACE;
++	      retval = GLOB_NOSPACE;
++	      goto out;
+ 	    }
+ 
+-	  new_gl_pathv
+-	    = (char **) realloc (pglob->gl_pathv,
+-				 (newcount + 1 + 1) * sizeof (char *));
++	  new_gl_pathv = realloc (pglob->gl_pathv,
++				  (newcount + 2) * sizeof (char *));
+ 	  if (new_gl_pathv == NULL)
+ 	    goto nospace;
+ 	  pglob->gl_pathv = new_gl_pathv;
+@@ -1006,12 +1032,19 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	      p = mempcpy (pglob->gl_pathv[newcount], dirname, dirlen);
+ 	      p[0] = '/';
+ 	      p[1] = '\0';
++	      if (__glibc_unlikely (malloc_dirname))
++		free (dirname);
+ 	    }
+ 	  else
+ 	    {
+-	      pglob->gl_pathv[newcount] = strdup (dirname);
+-	      if (pglob->gl_pathv[newcount] == NULL)
+-		goto nospace;
++	      if (__glibc_unlikely (malloc_dirname))
++		pglob->gl_pathv[newcount] = dirname;
++	      else
++		{
++		  pglob->gl_pathv[newcount] = strdup (dirname);
++		  if (pglob->gl_pathv[newcount] == NULL)
++		    goto nospace;
++		}
+ 	    }
+ 	  pglob->gl_pathv[++newcount] = NULL;
+ 	  ++pglob->gl_pathc;
+@@ -1021,7 +1054,8 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	}
+ 
+       /* Not found.  */
+-      return GLOB_NOMATCH;
++      retval = GLOB_NOMATCH;
++      goto out;
+     }
+ 
+   meta = __glob_pattern_type (dirname, !(flags & GLOB_NOESCAPE));
+@@ -1067,7 +1101,10 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+       if (status != 0)
+ 	{
+ 	  if ((flags & GLOB_NOCHECK) == 0 || status != GLOB_NOMATCH)
+-	    return status;
++	    {
++	      retval = status;
++	      goto out;
++	    }
+ 	  goto no_matches;
+ 	}
+ 
+@@ -1078,19 +1115,6 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	{
+ 	  size_t old_pathc;
+ 
+-#ifdef	SHELL
+-	  {
+-	    /* Make globbing interruptible in the bash shell. */
+-	    extern int interrupt_state;
+-
+-	    if (interrupt_state)
+-	      {
+-		globfree (&dirs);
+-		return GLOB_ABORTED;
+-	      }
+-	  }
+-#endif /* SHELL.  */
+-
+ 	  old_pathc = pglob->gl_pathc;
+ 	  status = glob_in_dir (filename, dirs.gl_pathv[i],
+ 				((flags | GLOB_APPEND)
+@@ -1105,7 +1129,8 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	      globfree (&dirs);
+ 	      globfree (pglob);
+ 	      pglob->gl_pathc = 0;
+-	      return status;
++	      retval = status;
++	      goto out;
+ 	    }
+ 
+ 	  /* Stick the directory on the front of each name.  */
+@@ -1116,13 +1141,14 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	      globfree (&dirs);
+ 	      globfree (pglob);
+ 	      pglob->gl_pathc = 0;
+-	      return GLOB_NOSPACE;
++	      retval = GLOB_NOSPACE;
++	      goto out;
+ 	    }
+ 	}
+ 
+       flags |= GLOB_MAGCHAR;
+ 
+-      /* We have ignored the GLOB_NOCHECK flag in the `glob_in_dir' calls.
++      /* We have ignored the GLOB_NOCHECK flag in the 'glob_in_dir' calls.
+ 	 But if we have not found any matching entry and the GLOB_NOCHECK
+ 	 flag was set we must return the input pattern itself.  */
+       if (pglob->gl_pathc + pglob->gl_offs == oldcount)
+@@ -1134,28 +1160,28 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	      size_t newcount = pglob->gl_pathc + pglob->gl_offs;
+ 	      char **new_gl_pathv;
+ 
+-	      if (newcount > UINTPTR_MAX - 2
+-		  || newcount + 2 > ~((size_t) 0) / sizeof (char *))
++	      if (newcount > SIZE_MAX / sizeof (char *) - 2)
+ 		{
+ 		nospace2:
+ 		  globfree (&dirs);
+-		  return GLOB_NOSPACE;
++		  retval = GLOB_NOSPACE;
++		  goto out;
+ 		}
+ 
+-	      new_gl_pathv = (char **) realloc (pglob->gl_pathv,
+-						(newcount + 2)
+-						* sizeof (char *));
++	      new_gl_pathv = realloc (pglob->gl_pathv,
++				      (newcount + 2) * sizeof (char *));
+ 	      if (new_gl_pathv == NULL)
+ 		goto nospace2;
+ 	      pglob->gl_pathv = new_gl_pathv;
+ 
+-	      pglob->gl_pathv[newcount] = __strdup (pattern);
++	      pglob->gl_pathv[newcount] = strdup (pattern);
+ 	      if (pglob->gl_pathv[newcount] == NULL)
+ 		{
+ 		  globfree (&dirs);
+ 		  globfree (pglob);
+ 		  pglob->gl_pathc = 0;
+-		  return GLOB_NOSPACE;
++		  retval = GLOB_NOSPACE;
++		  goto out;
+ 		}
+ 
+ 	      ++pglob->gl_pathc;
+@@ -1167,7 +1193,8 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	  else
+ 	    {
+ 	      globfree (&dirs);
+-	      return GLOB_NOMATCH;
++	      retval = GLOB_NOMATCH;
++	      goto out;
+ 	    }
+ 	}
+ 
+@@ -1213,7 +1240,8 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	      flags = orig_flags;
+ 	      goto no_matches;
+ 	    }
+-	  return status;
++	  retval = status;
++	  goto out;
+ 	}
+ 
+       if (dirlen > 0)
+@@ -1225,7 +1253,8 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	    {
+ 	      globfree (pglob);
+ 	      pglob->gl_pathc = 0;
+-	      return GLOB_NOSPACE;
++	      retval = GLOB_NOSPACE;
++	      goto out;
+ 	    }
+ 	}
+     }
+@@ -1250,7 +1279,8 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 	      {
+ 		globfree (pglob);
+ 		pglob->gl_pathc = 0;
+-		return GLOB_NOSPACE;
++		retval = GLOB_NOSPACE;
++		goto out;
+ 	      }
+ 	    strcpy (&new[len - 2], "/");
+ 	    pglob->gl_pathv[i] = new;
+@@ -1276,32 +1306,12 @@ libc_hidden_def (glob)
+ #endif
+ 
+ 
+-#if !defined _LIBC || !defined GLOB_ONLY_P
+-
+-/* Free storage allocated in PGLOB by a previous `glob' call.  */
+-void
+-globfree (glob_t *pglob)
+-{
+-  if (pglob->gl_pathv != NULL)
+-    {
+-      size_t i;
+-      for (i = 0; i < pglob->gl_pathc; ++i)
+-	free (pglob->gl_pathv[pglob->gl_offs + i]);
+-      free (pglob->gl_pathv);
+-      pglob->gl_pathv = NULL;
+-    }
+-}
+-#if defined _LIBC && !defined globfree
+-libc_hidden_def (globfree)
+-#endif
+-
+-
+ /* Do a collated comparison of A and B.  */
+ static int
+ collated_compare (const void *a, const void *b)
+ {
+-  const char *const s1 = *(const char *const * const) a;
+-  const char *const s2 = *(const char *const * const) b;
++  char *const *ps1 = a; char *s1 = *ps1;
++  char *const *ps2 = b; char *s2 = *ps2;
+ 
+   if (s1 == s2)
+     return 0;
+@@ -1322,28 +1332,24 @@ prefix_array (const char *dirname, char **array, size_t n)
+ {
+   size_t i;
+   size_t dirlen = strlen (dirname);
+-#if defined __MSDOS__ || defined WINDOWS32
+-  int sep_char = '/';
+-# define DIRSEP_CHAR sep_char
+-#else
+-# define DIRSEP_CHAR '/'
+-#endif
++  char dirsep_char = '/';
+ 
+   if (dirlen == 1 && dirname[0] == '/')
+     /* DIRNAME is just "/", so normal prepending would get us "//foo".
+        We want "/foo" instead, so don't prepend any chars from DIRNAME.  */
+     dirlen = 0;
++
+ #if defined __MSDOS__ || defined WINDOWS32
+-  else if (dirlen > 1)
++  if (dirlen > 1)
+     {
+       if (dirname[dirlen - 1] == '/' && dirname[dirlen - 2] == ':')
+ 	/* DIRNAME is "d:/".  Don't prepend the slash from DIRNAME.  */
+ 	--dirlen;
+       else if (dirname[dirlen - 1] == ':')
+ 	{
+-	  /* DIRNAME is "d:".  Use `:' instead of `/'.  */
++	  /* DIRNAME is "d:".  Use ':' instead of '/'.  */
+ 	  --dirlen;
+-	  sep_char = ':';
++	  dirsep_char = ':';
+ 	}
+     }
+ #endif
+@@ -1351,7 +1357,7 @@ prefix_array (const char *dirname, char **array, size_t n)
+   for (i = 0; i < n; ++i)
+     {
+       size_t eltlen = strlen (array[i]) + 1;
+-      char *new = (char *) malloc (dirlen + 1 + eltlen);
++      char *new = malloc (dirlen + 1 + eltlen);
+       if (new == NULL)
+ 	{
+ 	  while (i > 0)
+@@ -1361,7 +1367,7 @@ prefix_array (const char *dirname, char **array, size_t n)
+ 
+       {
+ 	char *endp = mempcpy (new, dirname, dirlen);
+-	*endp++ = DIRSEP_CHAR;
++	*endp++ = dirsep_char;
+ 	mempcpy (endp, array[i], eltlen);
+       }
+       free (array[i]);
+@@ -1371,103 +1377,57 @@ prefix_array (const char *dirname, char **array, size_t n)
+   return 0;
+ }
+ 
+-
+-/* We must not compile this function twice.  */
+-#if !defined _LIBC || !defined NO_GLOB_PATTERN_P
+-int
+-__glob_pattern_type (const char *pattern, int quote)
+-{
+-  const char *p;
+-  int ret = 0;
+-
+-  for (p = pattern; *p != '\0'; ++p)
+-    switch (*p)
+-      {
+-      case '?':
+-      case '*':
+-	return 1;
+-
+-      case '\\':
+-	if (quote)
+-	  {
+-	    if (p[1] != '\0')
+-	      ++p;
+-	    ret |= 2;
+-	  }
+-	break;
+-
+-      case '[':
+-	ret |= 4;
+-	break;
+-
+-      case ']':
+-	if (ret & 4)
+-	  return 1;
+-	break;
+-      }
+-
+-  return ret;
+-}
+-
+-/* Return nonzero if PATTERN contains any metacharacters.
+-   Metacharacters can be quoted with backslashes if QUOTE is nonzero.  */
+-int
+-__glob_pattern_p (const char *pattern, int quote)
+-{
+-  return __glob_pattern_type (pattern, quote) == 1;
+-}
+-# ifdef _LIBC
+-weak_alias (__glob_pattern_p, glob_pattern_p)
+-# endif
+-#endif
+-
+-#endif /* !GLOB_ONLY_P */
+-
+-
+ /* We put this in a separate function mainly to allow the memory
+    allocated with alloca to be recycled.  */
+-#if !defined _LIBC || !defined GLOB_ONLY_P
+ static int
+ __attribute_noinline__
+-link_exists2_p (const char *dir, size_t dirlen, const char *fname,
+-	       glob_t *pglob
+-# ifndef _LIBC
+-		, int flags
++link_stat (const char *dir, size_t dirlen, const char *fname,
++	   glob_t *pglob
++# if !defined _LIBC && !HAVE_FSTATAT
++	   , int flags
+ # endif
+-		)
++	   )
+ {
+   size_t fnamelen = strlen (fname);
+-  char *fullname = (char *) __alloca (dirlen + 1 + fnamelen + 1);
++  char *fullname = __alloca (dirlen + 1 + fnamelen + 1);
+   struct stat st;
+-# ifndef _LIBC
+-  struct_stat64 st64;
+-# endif
+ 
+   mempcpy (mempcpy (mempcpy (fullname, dir, dirlen), "/", 1),
+ 	   fname, fnamelen + 1);
+ 
+-# ifdef _LIBC
+-  return (*pglob->gl_stat) (fullname, &st) == 0;
+-# else
+-  return ((__builtin_expect (flags & GLOB_ALTDIRFUNC, 0)
+-	   ? (*pglob->gl_stat) (fullname, &st)
+-	   : __stat64 (fullname, &st64)) == 0);
++# if !defined _LIBC && !HAVE_FSTATAT
++  if (__builtin_expect ((flags & GLOB_ALTDIRFUNC) == 0, 1))
++    {
++      struct_stat64 st64;
++      return __stat64 (fullname, &st64);
++    }
+ # endif
++  return (*pglob->gl_stat) (fullname, &st);
+ }
+-# ifdef _LIBC
+-#  define link_exists_p(dfd, dirname, dirnamelen, fname, pglob, flags) \
+-  (__builtin_expect (flags & GLOB_ALTDIRFUNC, 0)			      \
+-   ? link_exists2_p (dirname, dirnamelen, fname, pglob)			      \
+-   : ({ struct stat64 st64;						      \
+-       __fxstatat64 (_STAT_VER, dfd, fname, &st64, 0) == 0; }))
++
++/* Return true if DIR/FNAME exists.  */
++static int
++link_exists_p (int dfd, const char *dir, size_t dirlen, const char *fname,
++	       glob_t *pglob, int flags)
++{
++  int status;
++# if defined _LIBC || HAVE_FSTATAT
++  if (__builtin_expect (flags & GLOB_ALTDIRFUNC, 0))
++    status = link_stat (dir, dirlen, fname, pglob);
++  else
++    {
++      /* dfd cannot be -1 here, because dirfd never returns -1 on
++	 glibc, or on hosts that have fstatat.  */
++      struct_stat64 st64;
++      status = __fxstatat64 (_STAT_VER, dfd, fname, &st64, 0);
++    }
+ # else
+-#  define link_exists_p(dfd, dirname, dirnamelen, fname, pglob, flags) \
+-  link_exists2_p (dirname, dirnamelen, fname, pglob, flags)
++  status = link_stat (dir, dirlen, fname, pglob, flags);
+ # endif
+-#endif
+-
++  return status == 0 || errno == EOVERFLOW;
++}
+ 
+-/* Like `glob', but PATTERN is a final pathname component,
++/* Like 'glob', but PATTERN is a final pathname component,
+    and matches are searched for in DIRECTORY.
+    The GLOB_NOSORT bit in FLAGS is ignored.  No sorting is ever done.
+    The GLOB_APPEND flag is assumed to be set (always appends).  */
+@@ -1478,25 +1438,25 @@ glob_in_dir (const char *pattern, const char *directory, int flags,
+ {
+   size_t dirlen = strlen (directory);
+   void *stream = NULL;
+-  struct globnames
+-    {
+-      struct globnames *next;
+-      size_t count;
+-      char *name[64];
+-    };
+-#define INITIAL_COUNT sizeof (init_names.name) / sizeof (init_names.name[0])
+-  struct globnames init_names;
+-  struct globnames *names = &init_names;
+-  struct globnames *names_alloca = &init_names;
++# define GLOBNAMES_MEMBERS(nnames) \
++    struct globnames *next; size_t count; char *name[nnames];
++  struct globnames { GLOBNAMES_MEMBERS (FLEXIBLE_ARRAY_MEMBER) };
++  struct { GLOBNAMES_MEMBERS (64) } init_names_buf;
++  struct globnames *init_names = (struct globnames *) &init_names_buf;
++  struct globnames *names = init_names;
++  struct globnames *names_alloca = init_names;
+   size_t nfound = 0;
+   size_t cur = 0;
+   int meta;
+   int save;
++  int result;
+ 
+-  alloca_used += sizeof (init_names);
++  alloca_used += sizeof init_names_buf;
+ 
+-  init_names.next = NULL;
+-  init_names.count = INITIAL_COUNT;
++  init_names->next = NULL;
++  init_names->count = ((sizeof init_names_buf
++                        - offsetof (struct globnames, name))
++                       / sizeof init_names->name[0]);
+ 
+   meta = __glob_pattern_type (pattern, !(flags & GLOB_NOESCAPE));
+   if (meta == 0 && (flags & (GLOB_NOCHECK|GLOB_NOMAGIC)))
+@@ -1516,14 +1476,16 @@ glob_in_dir (const char *pattern, const char *directory, int flags,
+ 	struct_stat64 st64;
+       } ust;
+       size_t patlen = strlen (pattern);
+-      int alloca_fullname = __libc_use_alloca (alloca_used
+-					       + dirlen + 1 + patlen + 1);
++      size_t fullsize;
++      bool alloca_fullname
++        = (! size_add_wrapv (dirlen + 1, patlen + 1, &fullsize)
++           && glob_use_alloca (alloca_used, fullsize));
+       char *fullname;
+       if (alloca_fullname)
+-	fullname = alloca_account (dirlen + 1 + patlen + 1, alloca_used);
++        fullname = alloca_account (fullsize, alloca_used);
+       else
+ 	{
+-	  fullname = malloc (dirlen + 1 + patlen + 1);
++	  fullname = malloc (fullsize);
+ 	  if (fullname == NULL)
+ 	    return GLOB_NOSPACE;
+ 	}
+@@ -1531,9 +1493,11 @@ glob_in_dir (const char *pattern, const char *directory, int flags,
+       mempcpy (mempcpy (mempcpy (fullname, directory, dirlen),
+ 			"/", 1),
+ 	       pattern, patlen + 1);
+-      if ((__builtin_expect (flags & GLOB_ALTDIRFUNC, 0)
++      if (((__builtin_expect (flags & GLOB_ALTDIRFUNC, 0)
+ 	   ? (*pglob->gl_stat) (fullname, &ust.st)
+-	   : __stat64 (fullname, &ust.st64)) == 0)
++	    : __stat64 (fullname, &ust.st64))
++	   == 0)
++	  || errno == EOVERFLOW)
+ 	/* We found this file to be existing.  Now tell the rest
+ 	   of the function to copy this name into the result.  */
+ 	flags |= GLOB_NOCHECK;
+@@ -1555,16 +1519,10 @@ glob_in_dir (const char *pattern, const char *directory, int flags,
+ 	}
+       else
+ 	{
+-#ifdef _LIBC
+ 	  int dfd = (__builtin_expect (flags & GLOB_ALTDIRFUNC, 0)
+ 		     ? -1 : dirfd ((DIR *) stream));
+-#endif
+ 	  int fnm_flags = ((!(flags & GLOB_PERIOD) ? FNM_PERIOD : 0)
+-			   | ((flags & GLOB_NOESCAPE) ? FNM_NOESCAPE : 0)
+-#if defined _AMIGA || defined VMS
+-			   | FNM_CASEFOLD
+-#endif
+-			   );
++			   | ((flags & GLOB_NOESCAPE) ? FNM_NOESCAPE : 0));
+ 	  flags |= GLOB_MAGCHAR;
+ 
+ 	  while (1)
+@@ -1584,19 +1542,24 @@ glob_in_dir (const char *pattern, const char *directory, int flags,
+ 	      }
+ 	      if (d.name == NULL)
+ 		break;
+-	      if (d.skip_entry)
++	      if (readdir_result_skip_entry (d))
+ 		continue;
+ 
+ 	      /* If we shall match only directories use the information
+ 		 provided by the dirent call if possible.  */
+-	      if ((flags & GLOB_ONLYDIR) && !readdir_result_might_be_dir (d))
+-		continue;
++	      if (flags & GLOB_ONLYDIR)
++		switch (readdir_result_type (d))
++		  {
++		  case DT_DIR: case DT_LNK: case DT_UNKNOWN: break;
++		  default: continue;
++		  }
+ 
+ 	      if (fnmatch (pattern, d.name, fnm_flags) == 0)
+ 		{
+ 		  /* If the file we found is a symlink we have to
+ 		     make sure the target file exists.  */
+-		  if (!readdir_result_might_be_symlink (d)
++		  dirent_type type = readdir_result_type (d);
++		  if (! (type == DT_LNK || type == DT_UNKNOWN)
+ 		      || link_exists_p (dfd, directory, dirlen, d.name,
+ 					pglob, flags))
+ 		    {
+@@ -1604,10 +1567,13 @@ glob_in_dir (const char *pattern, const char *directory, int flags,
+ 			{
+ 			  struct globnames *newnames;
+ 			  size_t count = names->count * 2;
+-			  size_t size = (sizeof (struct globnames)
+-					 + ((count - INITIAL_COUNT)
+-					    * sizeof (char *)));
+-			  if (__libc_use_alloca (alloca_used + size))
++			  size_t nameoff = offsetof (struct globnames, name);
++			  size_t size = FLEXSIZEOF (struct globnames, name,
++						    count * sizeof (char *));
++			  if ((SIZE_MAX - nameoff) / 2 / sizeof (char *)
++			      < names->count)
++			    goto memory_error;
++			  if (glob_use_alloca (alloca_used, size))
+ 			    newnames = names_alloca
+ 			      = alloca_account (size, alloca_used);
+ 			  else if ((newnames = malloc (size))
+@@ -1623,6 +1589,8 @@ glob_in_dir (const char *pattern, const char *directory, int flags,
+ 			goto memory_error;
+ 		      ++cur;
+ 		      ++nfound;
++		      if (SIZE_MAX - pglob->gl_offs <= nfound)
++			goto memory_error;
+ 		    }
+ 		}
+ 	    }
+@@ -1633,29 +1601,27 @@ glob_in_dir (const char *pattern, const char *directory, int flags,
+     {
+       size_t len = strlen (pattern);
+       nfound = 1;
+-      names->name[cur] = (char *) malloc (len + 1);
++      names->name[cur] = malloc (len + 1);
+       if (names->name[cur] == NULL)
+ 	goto memory_error;
+       *((char *) mempcpy (names->name[cur++], pattern, len)) = '\0';
+     }
+ 
+-  int result = GLOB_NOMATCH;
++  result = GLOB_NOMATCH;
+   if (nfound != 0)
+     {
++      char **new_gl_pathv;
+       result = 0;
+ 
+-      if (pglob->gl_pathc > UINTPTR_MAX - pglob->gl_offs
+-	  || pglob->gl_pathc + pglob->gl_offs > UINTPTR_MAX - nfound
+-	  || pglob->gl_pathc + pglob->gl_offs + nfound > UINTPTR_MAX - 1
+-	  || (pglob->gl_pathc + pglob->gl_offs + nfound + 1
+-	      > UINTPTR_MAX / sizeof (char *)))
++      if (SIZE_MAX / sizeof (char *) - pglob->gl_pathc
++	  < pglob->gl_offs + nfound + 1)
+ 	goto memory_error;
+ 
+-      char **new_gl_pathv;
+       new_gl_pathv
+-	= (char **) realloc (pglob->gl_pathv,
+-			     (pglob->gl_pathc + pglob->gl_offs + nfound + 1)
+-			     * sizeof (char *));
++	= realloc (pglob->gl_pathv,
++		   (pglob->gl_pathc + pglob->gl_offs + nfound + 1)
++		    * sizeof (char *));
++
+       if (new_gl_pathv == NULL)
+ 	{
+ 	memory_error:
+@@ -1671,7 +1637,7 @@ glob_in_dir (const char *pattern, const char *directory, int flags,
+ 		 and this is the block assigned to OLD here.  */
+ 	      if (names == NULL)
+ 		{
+-		  assert (old == &init_names);
++		  assert (old == init_names);
+ 		  break;
+ 		}
+ 	      cur = names->count;
+@@ -1697,7 +1663,7 @@ glob_in_dir (const char *pattern, const char *directory, int flags,
+ 		 and this is the block assigned to OLD here.  */
+ 	      if (names == NULL)
+ 		{
+-		  assert (old == &init_names);
++		  assert (old == init_names);
+ 		  break;
+ 		}
+ 	      cur = names->count;
+diff --git a/posix/glob64.c b/posix/glob64.c
+index 6cb3d654a8..a515a1c12f 100644
+--- a/posix/glob64.c
++++ b/posix/glob64.c
+@@ -43,10 +43,4 @@ glob64 (const char *pattern, int flags,
+ }
+ libc_hidden_def (glob64)
+ 
+-void
+-globfree64 (glob64_t *pglob)
+-{
+-}
+-libc_hidden_def (globfree64)
+-
+ stub_warning (glob64)
+diff --git a/posix/glob_internal.h b/posix/glob_internal.h
+new file mode 100644
+index 0000000000..12c93660b7
+--- /dev/null
++++ b/posix/glob_internal.h
+@@ -0,0 +1,57 @@
++/* Shared definition for glob and glob_pattern_p.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#ifndef GLOB_INTERNAL_H
++# define GLOB_INTERNAL_H
++
++static inline int
++__glob_pattern_type (const char *pattern, int quote)
++{
++  const char *p;
++  int ret = 0;
++
++  for (p = pattern; *p != '\0'; ++p)
++    switch (*p)
++      {
++      case '?':
++      case '*':
++        return 1;
++
++      case '\\':
++        if (quote)
++          {
++            if (p[1] != '\0')
++              ++p;
++            ret |= 2;
++          }
++        break;
++
++      case '[':
++        ret |= 4;
++        break;
++
++      case ']':
++        if (ret & 4)
++          return 1;
++        break;
++      }
++
++  return ret;
++}
++
++#endif /* GLOB_INTERNAL_H  */
+diff --git a/posix/glob_pattern_p.c b/posix/glob_pattern_p.c
+new file mode 100644
+index 0000000000..a17d337182
+--- /dev/null
++++ b/posix/glob_pattern_p.c
+@@ -0,0 +1,33 @@
++/* Return nonzero if PATTERN contains any metacharacters.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#ifndef _LIBC
++# include <config.h>
++#endif
++
++#include <glob.h>
++#include "glob_internal.h"
++
++/* Return nonzero if PATTERN contains any metacharacters.
++   Metacharacters can be quoted with backslashes if QUOTE is nonzero.  */
++int
++__glob_pattern_p (const char *pattern, int quote)
++{
++  return __glob_pattern_type (pattern, quote) == 1;
++}
++weak_alias (__glob_pattern_p, glob_pattern_p)
+diff --git a/posix/globfree.c b/posix/globfree.c
+new file mode 100644
+index 0000000000..042e29d9b0
+--- /dev/null
++++ b/posix/globfree.c
+@@ -0,0 +1,41 @@
++/* Frees the dynamically allocated storage from an earlier call to glob.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#ifndef _LIBC
++# include <config.h>
++#endif
++
++#include <glob.h>
++#include <stdlib.h>
++
++/* Free storage allocated in PGLOB by a previous `glob' call.  */
++void
++globfree (glob_t *pglob)
++{
++  if (pglob->gl_pathv != NULL)
++    {
++      size_t i;
++      for (i = 0; i < pglob->gl_pathc; ++i)
++        free (pglob->gl_pathv[pglob->gl_offs + i]);
++      free (pglob->gl_pathv);
++      pglob->gl_pathv = NULL;
++    }
++}
++#ifndef globfree
++libc_hidden_def (globfree)
++#endif
+diff --git a/posix/globfree64.c b/posix/globfree64.c
+new file mode 100644
+index 0000000000..c9f8908a4e
+--- /dev/null
++++ b/posix/globfree64.c
+@@ -0,0 +1,31 @@
++/* Frees the dynamically allocated storage from an earlier call to glob.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#ifndef _LIBC
++# include <config.h>
++#endif
++
++#include <glob.h>
++#include <stdlib.h>
++
++/* Free storage allocated in PGLOB by a previous `glob' call.  */
++void
++globfree64 (glob64_t *pglob)
++{
++}
++libc_hidden_def (globfree64)
+diff --git a/sysdeps/gnu/glob64.c b/sysdeps/gnu/glob64.c
+index d1e4e6f0d5..52e97e2f6a 100644
+--- a/sysdeps/gnu/glob64.c
++++ b/sysdeps/gnu/glob64.c
+@@ -15,11 +15,8 @@
+ #undef __stat
+ #define __stat(file, buf) __xstat64 (_STAT_VER, file, buf)
+ 
+-#define NO_GLOB_PATTERN_P 1
+-
+ #define COMPILE_GLOB64	1
+ 
+ #include <posix/glob.c>
+ 
+ libc_hidden_def (glob64)
+-libc_hidden_def (globfree64)
+diff --git a/sysdeps/gnu/globfree64.c b/sysdeps/gnu/globfree64.c
+new file mode 100644
+index 0000000000..f092d0bf8b
+--- /dev/null
++++ b/sysdeps/gnu/globfree64.c
+@@ -0,0 +1,10 @@
++#include <dirent.h>
++#include <glob.h>
++#include <sys/stat.h>
++
++#define glob_t glob64_t
++#define globfree(pglob) globfree64 (pglob)
++
++#include <posix/globfree.c>
++
++libc_hidden_def (globfree64)
+diff --git a/sysdeps/unix/sysv/linux/Makefile b/sysdeps/unix/sysv/linux/Makefile
+index 5dce300f7f..dbe6a36c57 100644
+--- a/sysdeps/unix/sysv/linux/Makefile
++++ b/sysdeps/unix/sysv/linux/Makefile
+@@ -166,7 +166,7 @@ endif
+ ifeq ($(subdir),posix)
+ sysdep_headers += bits/initspin.h
+ 
+-sysdep_routines += sched_getcpu
++sysdep_routines += sched_getcpu oldglob
+ 
+ tests += tst-affinity tst-affinity-pid
+ 
+diff --git a/sysdeps/unix/sysv/linux/alpha/glob.c b/sysdeps/unix/sysv/linux/alpha/glob.c
+index 2d7d287a25..1b813c1cfd 100644
+--- a/sysdeps/unix/sysv/linux/alpha/glob.c
++++ b/sysdeps/unix/sysv/linux/alpha/glob.c
+@@ -42,10 +42,6 @@ extern void __new_globfree (glob_t *__pglob);
+ #undef globfree64
+ 
+ versioned_symbol (libc, __new_glob, glob, GLIBC_2_1);
+-versioned_symbol (libc, __new_globfree, globfree, GLIBC_2_1);
+ libc_hidden_ver (__new_glob, glob)
+-libc_hidden_ver (__new_globfree, globfree)
+ 
+ weak_alias (__new_glob, glob64)
+-weak_alias (__new_globfree, globfree64)
+-libc_hidden_ver (__new_globfree, globfree64)
+diff --git a/sysdeps/unix/sysv/linux/alpha/globfree.c b/sysdeps/unix/sysv/linux/alpha/globfree.c
+new file mode 100644
+index 0000000000..98cf1c200b
+--- /dev/null
++++ b/sysdeps/unix/sysv/linux/alpha/globfree.c
+@@ -0,0 +1,37 @@
++/* Compat globfree.  Linux/alpha version.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#define globfree64 __no_globfree64_decl
++#include <sys/types.h>
++#include <glob.h>
++#include <shlib-compat.h>
++
++#define globfree(pglob) \
++  __new_globfree (pglob)
++
++extern void __new_globfree (glob_t *__pglob);
++
++#include <posix/globfree.c>
++
++#undef globfree64
++
++versioned_symbol (libc, __new_globfree, globfree, GLIBC_2_1);
++libc_hidden_ver (__new_globfree, globfree)
++
++weak_alias (__new_globfree, globfree64)
++libc_hidden_ver (__new_globfree, globfree64)
+diff --git a/sysdeps/unix/sysv/linux/i386/glob64.c b/sysdeps/unix/sysv/linux/i386/glob64.c
+index 956cb0474a..230f9fc037 100644
+--- a/sysdeps/unix/sysv/linux/i386/glob64.c
++++ b/sysdeps/unix/sysv/linux/i386/glob64.c
+@@ -19,6 +19,7 @@
+ #include <dirent.h>
+ #include <glob.h>
+ #include <sys/stat.h>
++#include <shlib-compat.h>
+ 
+ #define dirent dirent64
+ #define __readdir(dirp) __readdir64 (dirp)
+@@ -33,47 +34,9 @@
+ #undef __stat
+ #define __stat(file, buf) __xstat64 (_STAT_VER, file, buf)
+ 
+-#define NO_GLOB_PATTERN_P 1
+-
+ #define COMPILE_GLOB64	1
+ 
+ #include <posix/glob.c>
+ 
+-#include "shlib-compat.h"
+-
+-libc_hidden_def (globfree64)
+-
+ versioned_symbol (libc, __glob64, glob64, GLIBC_2_2);
+ libc_hidden_ver (__glob64, glob64)
+-
+-#if SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2)
+-
+-#include <sysdeps/unix/sysv/linux/i386/olddirent.h>
+-
+-int __old_glob64 (const char *__pattern, int __flags,
+-		  int (*__errfunc) (const char *, int),
+-		  glob64_t *__pglob);
+-libc_hidden_proto (__old_glob64);
+-
+-#undef dirent
+-#define dirent __old_dirent64
+-#undef GL_READDIR
+-# define GL_READDIR(pglob, stream) \
+-  ((struct __old_dirent64 *) (pglob)->gl_readdir (stream))
+-#undef __readdir
+-#define __readdir(dirp) __old_readdir64 (dirp)
+-#undef glob
+-#define glob(pattern, flags, errfunc, pglob) \
+-  __old_glob64 (pattern, flags, errfunc, pglob)
+-#define convert_dirent __old_convert_dirent
+-#define glob_in_dir __old_glob_in_dir
+-#define GLOB_ATTRIBUTE attribute_compat_text_section
+-
+-#define GLOB_ONLY_P 1
+-
+-#include <posix/glob.c>
+-
+-libc_hidden_def (__old_glob64);
+-
+-compat_symbol (libc, __old_glob64, glob64, GLIBC_2_1);
+-#endif
+diff --git a/sysdeps/unix/sysv/linux/mips/mips64/n64/globfree64.c b/sysdeps/unix/sysv/linux/mips/mips64/n64/globfree64.c
+new file mode 100644
+index 0000000000..abc35fdd2b
+--- /dev/null
++++ b/sysdeps/unix/sysv/linux/mips/mips64/n64/globfree64.c
+@@ -0,0 +1 @@
++/* glob64 is in globfree64.c */
+diff --git a/sysdeps/unix/sysv/linux/oldglob.c b/sysdeps/unix/sysv/linux/oldglob.c
+new file mode 100644
+index 0000000000..8233e57ce9
+--- /dev/null
++++ b/sysdeps/unix/sysv/linux/oldglob.c
+@@ -0,0 +1,42 @@
++#include <shlib-compat.h>
++
++#if SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2)
++
++#include <dirent.h>
++#include <glob.h>
++#include <sys/stat.h>
++
++#include <sysdeps/unix/sysv/linux/i386/olddirent.h>
++
++int __old_glob64 (const char *__pattern, int __flags,
++		  int (*__errfunc) (const char *, int),
++		  glob64_t *__pglob);
++libc_hidden_proto (__old_glob64);
++
++#define dirent __old_dirent64
++#define GL_READDIR(pglob, stream) \
++  ((struct __old_dirent64 *) (pglob)->gl_readdir (stream))
++#undef __readdir
++#define __readdir(dirp) __old_readdir64 (dirp)
++
++#define glob_t glob64_t
++#define glob(pattern, flags, errfunc, pglob) \
++  __old_glob64 (pattern, flags, errfunc, pglob)
++#define globfree(pglob) globfree64(pglob)
++
++#define convert_dirent __old_convert_dirent
++#define glob_in_dir __old_glob_in_dir
++
++#undef stat
++#define stat stat64
++#undef __stat
++#define __stat(file, buf) __xstat64 (_STAT_VER, file, buf)
++
++#define GLOB_ATTRIBUTE attribute_compat_text_section
++
++#include <posix/glob.c>
++
++libc_hidden_def (__old_glob64);
++
++compat_symbol (libc, __old_glob64, glob64, GLIBC_2_1);
++#endif
+diff --git a/sysdeps/unix/sysv/linux/wordsize-64/globfree64.c b/sysdeps/unix/sysv/linux/wordsize-64/globfree64.c
+new file mode 100644
+index 0000000000..af035e1514
+--- /dev/null
++++ b/sysdeps/unix/sysv/linux/wordsize-64/globfree64.c
+@@ -0,0 +1,2 @@
++/* This file is here so sysdeps/gnu/glob64.c doesn't take precedence.  */
++#include <sysdeps/wordsize-64/globfree64.c>
+diff --git a/sysdeps/unix/sysv/linux/x86_64/x32/globfree.c b/sysdeps/unix/sysv/linux/x86_64/x32/globfree.c
+new file mode 100644
+index 0000000000..b76a761c17
+--- /dev/null
++++ b/sysdeps/unix/sysv/linux/x86_64/x32/globfree.c
+@@ -0,0 +1 @@
++#include <sysdeps/wordsize-64/globfree.c>
+diff --git a/sysdeps/wordsize-64/glob.c b/sysdeps/wordsize-64/glob.c
+index 082faf1c70..954e8d37e2 100644
+--- a/sysdeps/wordsize-64/glob.c
++++ b/sysdeps/wordsize-64/glob.c
+@@ -4,5 +4,3 @@
+ #undef glob64
+ #undef globfree64
+ weak_alias (glob, glob64)
+-weak_alias (globfree, globfree64)
+-libc_hidden_ver (globfree, globfree64)
+diff --git a/sysdeps/wordsize-64/globfree.c b/sysdeps/wordsize-64/globfree.c
+new file mode 100644
+index 0000000000..ec8c35b489
+--- /dev/null
++++ b/sysdeps/wordsize-64/globfree.c
+@@ -0,0 +1,5 @@
++#define globfree64 __no_globfree64_decl
++#include <posix/globfree.c>
++#undef globfree64
++weak_alias (globfree, globfree64)
++libc_hidden_ver (globfree, globfree64)
+diff --git a/sysdeps/wordsize-64/globfree64.c b/sysdeps/wordsize-64/globfree64.c
+new file mode 100644
+index 0000000000..a0f57ff4b3
+--- /dev/null
++++ b/sysdeps/wordsize-64/globfree64.c
+@@ -0,0 +1 @@
++/* globfree64 is in globfree.c */
diff --git a/gnu/packages/patches/glibc-2-26-0065.patch b/gnu/packages/patches/glibc-2-26-0065.patch
new file mode 100644
index 000000000..8fc7fcd9e
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0065.patch
@@ -0,0 +1,50 @@
+From a76376df7c07e577a9515c3faa5dbd50bda5da07 Mon Sep 17 00:00:00 2001
+From: Paul Eggert <eggert@cs.ucla.edu>
+Date: Fri, 20 Oct 2017 18:41:14 +0200
+Subject: [PATCH 65/90] CVE-2017-15670: glob: Fix one-byte overflow [BZ #22320]
+
+(cherry picked from commit c369d66e5426a30e4725b100d5cd28e372754f90)
+
+diff --git a/ChangeLog b/ChangeLog
+index d54d5a895d..e05c7fe433 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-10-20  Paul Eggert <eggert@cs.ucla.edu>
++
++	[BZ #22320]
++	CVE-2017-15670
++	* posix/glob.c (__glob): Fix one-byte overflow.
++
+ 2017-09-08  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
+ 
+ 	[BZ #1062]
+diff --git a/NEWS b/NEWS
+index ddc950c6cf..80248fec89 100644
+--- a/NEWS
++++ b/NEWS
+@@ -15,6 +15,11 @@ Security related changes:
+   vulnerability; only trusted binaries must be examined using the ldd
+   script.)
+ 
++  CVE-2017-15670: The glob function, when invoked with GLOB_TILDE,
++  suffered from a one-byte overflow during ~ operator processing (either
++  on the stack or the heap, depending on the length of the user name).
++  Reported by Tim Rühsen.
++
+ The following bugs are resolved with this release:
+ 
+   [16750] ldd: Never run file directly.
+diff --git a/posix/glob.c b/posix/glob.c
+index a7eccf9cb4..c761c0861d 100644
+--- a/posix/glob.c
++++ b/posix/glob.c
+@@ -870,7 +870,7 @@ glob (const char *pattern, int flags, int (*errfunc) (const char *, int),
+ 		  *p = '\0';
+ 		}
+ 	      else
+-		*((char *) mempcpy (newp, dirname + 1, end_name - dirname))
++		*((char *) mempcpy (newp, dirname + 1, end_name - dirname - 1))
+ 		  = '\0';
+ 	      user_name = newp;
+ 	    }
diff --git a/gnu/packages/patches/glibc-2-26-0066.patch b/gnu/packages/patches/glibc-2-26-0066.patch
new file mode 100644
index 000000000..cb6831cd0
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0066.patch
@@ -0,0 +1,204 @@
+From 6182b3708b7af316454c81467538a8c20c1b046d Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Sat, 21 Oct 2017 18:03:30 +0200
+Subject: [PATCH 66/90] glob: Add new test tst-glob-tilde
+
+The new test checks for memory leaks (see bug 22325) and attempts
+to trigger the buffer overflow in bug 22320.
+
+(cherry picked from commit e80fc1fc98bf614eb01cf8325503df3a1451a99c)
+
+diff --git a/ChangeLog b/ChangeLog
+index e05c7fe433..fccc246b20 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,11 @@
++2017-10-21  Florian Weimer  <fweimer@redhat.com>
++
++	* posix/Makefile (tests): Add tst-glob-tilde.
++	(tests-special): Add tst-glob-tilde-mem.out
++	(tst-glob-tilde-ENV): Set MALLOC_TRACE.
++	(tst-glob-tilde-mem.out): Add mtrace check.
++	* posix/tst-glob-tilde.c: New file.
++
+ 2017-10-20  Paul Eggert <eggert@cs.ucla.edu>
+ 
+ 	[BZ #22320]
+diff --git a/posix/Makefile b/posix/Makefile
+index 51e7e5bcb8..d35b7921b1 100644
+--- a/posix/Makefile
++++ b/posix/Makefile
+@@ -93,7 +93,7 @@ tests		:= test-errno tstgetopt testfnm runtests runptests \
+ 		   tst-fnmatch3 bug-regex36 tst-getaddrinfo5 \
+ 		   tst-posix_spawn-fd tst-posix_spawn-setsid \
+ 		   tst-posix_fadvise tst-posix_fadvise64 \
+-		   tst-sysconf-empty-chroot
++		   tst-sysconf-empty-chroot tst-glob-tilde
+ tests-internal	:= bug-regex5 bug-regex20 bug-regex33 \
+ 		   tst-rfc3484 tst-rfc3484-2 tst-rfc3484-3
+ xtests		:= bug-ga2
+@@ -141,7 +141,8 @@ tests-special += $(objpfx)bug-regex2-mem.out $(objpfx)bug-regex14-mem.out \
+ 		 $(objpfx)tst-rxspencer-no-utf8-mem.out $(objpfx)tst-pcre-mem.out \
+ 		 $(objpfx)tst-boost-mem.out $(objpfx)tst-getconf.out \
+ 		 $(objpfx)bug-glob2-mem.out $(objpfx)tst-vfork3-mem.out \
+-		 $(objpfx)tst-fnmatch-mem.out $(objpfx)bug-regex36-mem.out
++		 $(objpfx)tst-fnmatch-mem.out $(objpfx)bug-regex36-mem.out \
++		 $(objpfx)tst-glob-tilde-mem.out
+ xtests-special += $(objpfx)bug-ga2-mem.out
+ endif
+ 
+@@ -350,6 +351,12 @@ $(objpfx)bug-glob2-mem.out: $(objpfx)bug-glob2.out
+ 	$(common-objpfx)malloc/mtrace $(objpfx)bug-glob2.mtrace > $@; \
+ 	$(evaluate-test)
+ 
++tst-glob-tilde-ENV = MALLOC_TRACE=$(objpfx)tst-glob-tilde.mtrace
++
++$(objpfx)tst-glob-tilde-mem.out: $(objpfx)tst-glob-tilde.out
++	$(common-objpfx)malloc/mtrace $(objpfx)tst-glob-tilde.mtrace > $@; \
++	$(evaluate-test)
++
+ $(inst_libexecdir)/getconf: $(inst_bindir)/getconf \
+ 			    $(objpfx)getconf.speclist FORCE
+ 	$(addprefix $(..)./scripts/mkinstalldirs ,\
+diff --git a/posix/tst-glob-tilde.c b/posix/tst-glob-tilde.c
+new file mode 100644
+index 0000000000..9518b4a6f8
+--- /dev/null
++++ b/posix/tst-glob-tilde.c
+@@ -0,0 +1,136 @@
++/* Check for GLOB_TIDLE heap allocation issues (bug 22320, bug 22325).
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#include <glob.h>
++#include <mcheck.h>
++#include <nss.h>
++#include <pwd.h>
++#include <stdlib.h>
++#include <string.h>
++#include <support/check.h>
++#include <support/support.h>
++
++/* Flag which indicates whether to pass the GLOB_ONLYDIR flag.  */
++static int do_onlydir;
++
++/* Flag which indicates whether to pass the GLOB_NOCHECK flag.  */
++static int do_nocheck;
++
++/* Flag which indicates whether to pass the GLOB_MARK flag.  */
++static int do_mark;
++
++static void
++one_test (const char *prefix, const char *middle, const char *suffix)
++{
++  char *pattern = xasprintf ("%s%s%s", prefix, middle, suffix);
++  int flags = GLOB_TILDE;
++  if (do_onlydir)
++    flags |= GLOB_ONLYDIR;
++  if (do_nocheck)
++    flags |= GLOB_NOCHECK;
++  if (do_mark)
++    flags |= GLOB_MARK;
++  glob_t gl;
++  /* This glob call might result in crashes or memory leaks.  */
++  if (glob (pattern, flags, NULL, &gl) == 0)
++    globfree (&gl);
++  free (pattern);
++}
++
++enum
++  {
++    /* The largest base being tested.  */
++    largest_base_size = 500000,
++
++    /* The actual size is the base size plus a variable whose absolute
++       value is not greater than this.  This helps malloc to trigger
++       overflows.  */
++    max_size_skew = 16,
++
++    /* The maximum string length supported by repeating_string
++       below.  */
++    repeat_size = largest_base_size + max_size_skew,
++  };
++
++/* Used to construct strings which repeat a single character 'x'.  */
++static char *repeat;
++
++/* Return a string of SIZE characters.  */
++const char *
++repeating_string (int size)
++{
++  TEST_VERIFY (size >= 0);
++  TEST_VERIFY (size <= repeat_size);
++  const char *repeated_shifted = repeat + repeat_size - size;
++  TEST_VERIFY (strlen (repeated_shifted) == size);
++  return repeated_shifted;
++}
++
++static int
++do_test (void)
++{
++  /* Avoid network-based NSS modules and initialize nss_files with a
++     dummy lookup.  This has to come before mtrace because NSS does
++     not free all memory.  */
++  __nss_configure_lookup ("passwd", "files");
++  (void) getpwnam ("root");
++
++  mtrace ();
++
++  repeat = xmalloc (repeat_size + 1);
++  memset (repeat, 'x', repeat_size);
++  repeat[repeat_size] = '\0';
++
++  /* These numbers control the size of the user name.  The values
++     cover the minimum (0), a typical size (8), a large
++     stack-allocated size (100000), and a somewhat large
++     heap-allocated size (largest_base_size).  */
++  static const int base_sizes[] = { 0, 8, 100, 100000, largest_base_size, -1 };
++
++  for (do_onlydir = 0; do_onlydir < 2; ++do_onlydir)
++    for (do_nocheck = 0; do_nocheck < 2; ++do_nocheck)
++      for (do_mark = 0; do_mark < 2; ++do_mark)
++        for (int base_idx = 0; base_sizes[base_idx] >= 0; ++base_idx)
++          {
++            for (int size_skew = -max_size_skew; size_skew <= max_size_skew;
++                 ++size_skew)
++              {
++                int size = base_sizes[base_idx] + size_skew;
++                if (size < 0)
++                  continue;
++
++                const char *user_name = repeating_string (size);
++                one_test ("~", user_name, "/a/b");
++              }
++
++            const char *user_name = repeating_string (base_sizes[base_idx]);
++            one_test ("~", user_name, "");
++            one_test ("~", user_name, "/");
++            one_test ("~", user_name, "/a");
++            one_test ("~", user_name, "/*/*");
++            one_test ("~", user_name, "\\/");
++            one_test ("/~", user_name, "");
++            one_test ("*/~", user_name, "/a/b");
++          }
++
++  free (repeat);
++
++  return 0;
++}
++
++#include <support/test-driver.c>
diff --git a/gnu/packages/patches/glibc-2-26-0067.patch b/gnu/packages/patches/glibc-2-26-0067.patch
new file mode 100644
index 000000000..7f4226074
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0067.patch
@@ -0,0 +1,251 @@
+From b2c78ae69eb5845c94db94e87a2addd695f978c0 Mon Sep 17 00:00:00 2001
+From: "H.J. Lu" <hjl.tools@gmail.com>
+Date: Sun, 22 Oct 2017 04:14:54 -0700
+Subject: [PATCH 67/90] x86: Add x86_64 to x86-64 HWCAP [BZ #22093]
+
+Before glibc 2.26, ld.so set dl_platform to "x86_64" and searched the
+"x86_64" subdirectory when loading a shared library.  ld.so in glibc
+2.26 was changed to set dl_platform to "haswell" or "xeon_phi", based
+on supported ISAs.  This led to shared library loading failure for
+shared libraries placed under the "x86_64" subdirectory.
+
+This patch adds "x86_64" to x86-64 dl_hwcap so that ld.so will always
+search the "x86_64" subdirectory when loading a shared library.
+
+NB: We can't set x86-64 dl_platform to "x86-64" since ld.so will skip
+the "haswell" and "xeon_phi" subdirectories on "haswell" and "xeon_phi"
+machines.
+
+Tested on i686 and x86-64.
+
+	[BZ #22093]
+	* sysdeps/x86/cpu-features.c (init_cpu_features): Initialize
+	GLRO(dl_hwcap) to HWCAP_X86_64 for x86-64.
+	* sysdeps/x86/dl-hwcap.h (HWCAP_COUNT): Updated.
+	(HWCAP_IMPORTANT): Likewise.
+	(HWCAP_X86_64): New enum.
+	(HWCAP_X86_AVX512_1): Updated.
+	* sysdeps/x86/dl-procinfo.c (_dl_x86_hwcap_flags): Add "x86_64".
+	* sysdeps/x86_64/Makefile (tests): Add tst-x86_64-1.
+	(modules-names): Add x86_64/tst-x86_64mod-1.
+	(LDFLAGS-tst-x86_64mod-1.so): New.
+	($(objpfx)tst-x86_64-1): Likewise.
+	($(objpfx)x86_64/tst-x86_64mod-1.os): Likewise.
+	(tst-x86_64-1-clean): Likewise.
+	* sysdeps/x86_64/tst-x86_64-1.c: New file.
+	* sysdeps/x86_64/tst-x86_64mod-1.c: Likewise.
+
+(cherry picked from commit 45ff34638f034877b6a490c217d6a0632ce263f4)
+
+diff --git a/ChangeLog b/ChangeLog
+index fccc246b20..2c1ee0bac1 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,22 @@
++2017-10-22  H.J. Lu  <hongjiu.lu@intel.com>
++
++	[BZ #22093]
++	* sysdeps/x86/cpu-features.c (init_cpu_features): Initialize
++	GLRO(dl_hwcap) to HWCAP_X86_64 for x86-64.
++	* sysdeps/x86/dl-hwcap.h (HWCAP_COUNT): Updated.
++	(HWCAP_IMPORTANT): Likewise.
++	(HWCAP_X86_64): New enum.
++	(HWCAP_X86_AVX512_1): Updated.
++	* sysdeps/x86/dl-procinfo.c (_dl_x86_hwcap_flags): Add "x86_64".
++	* sysdeps/x86_64/Makefile (tests): Add tst-x86_64-1.
++	(modules-names): Add x86_64/tst-x86_64mod-1.
++	(LDFLAGS-tst-x86_64mod-1.so): New.
++	($(objpfx)tst-x86_64-1): Likewise.
++	($(objpfx)x86_64/tst-x86_64mod-1.os): Likewise.
++	(tst-x86_64-1-clean): Likewise.
++	* sysdeps/x86_64/tst-x86_64-1.c: New file.
++	* sysdeps/x86_64/tst-x86_64mod-1.c: Likewise.
++
+ 2017-10-21  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	* posix/Makefile (tests): Add tst-glob-tilde.
+diff --git a/NEWS b/NEWS
+index 80248fec89..bb625e699e 100644
+--- a/NEWS
++++ b/NEWS
+@@ -37,6 +37,7 @@ The following bugs are resolved with this release:
+     occur with -O3
+   [22051] libc: zero terminator in the middle of glibc's .eh_frame
+   [22078] nss_files performance issue in hosts multi mode
++  [22093] x86: Add x86_64 to x86-64 HWCAP
+   [22095] resolv: Fix memory leak with OOM during resolv.conf parsing
+   [22096] resolv: __resolv_conf_attach must not free passed conf object
+   [22111] malloc: per thread cache is not returned when thread exits
+diff --git a/sysdeps/x86/cpu-features.c b/sysdeps/x86/cpu-features.c
+index 6f900840d4..c267f17b76 100644
+--- a/sysdeps/x86/cpu-features.c
++++ b/sysdeps/x86/cpu-features.c
+@@ -336,7 +336,6 @@ no_cpuid:
+ 
+   /* Reuse dl_platform, dl_hwcap and dl_hwcap_mask for x86.  */
+   GLRO(dl_platform) = NULL;
+-  GLRO(dl_hwcap) = 0;
+ #if !HAVE_TUNABLES && defined SHARED
+   /* The glibc.tune.hwcap_mask tunable is initialized already, so no need to do
+      this.  */
+@@ -344,6 +343,7 @@ no_cpuid:
+ #endif
+ 
+ #ifdef __x86_64__
++  GLRO(dl_hwcap) = HWCAP_X86_64;
+   if (cpu_features->kind == arch_kind_intel)
+     {
+       if (CPU_FEATURES_ARCH_P (cpu_features, AVX512F_Usable)
+@@ -374,6 +374,7 @@ no_cpuid:
+ 	GLRO(dl_platform) = "haswell";
+     }
+ #else
++  GLRO(dl_hwcap) = 0;
+   if (CPU_FEATURES_CPU_P (cpu_features, SSE2))
+     GLRO(dl_hwcap) |= HWCAP_X86_SSE2;
+ 
+diff --git a/sysdeps/x86/dl-hwcap.h b/sysdeps/x86/dl-hwcap.h
+index c95668415a..38627e9eef 100644
+--- a/sysdeps/x86/dl-hwcap.h
++++ b/sysdeps/x86/dl-hwcap.h
+@@ -24,15 +24,16 @@
+ # define HWCAP_PLATFORMS_START	0
+ # define HWCAP_PLATFORMS_COUNT	4
+ # define HWCAP_START		0
+-# define HWCAP_COUNT		2
+-# define HWCAP_IMPORTANT	(HWCAP_X86_SSE2 | HWCAP_X86_AVX512_1)
++# define HWCAP_COUNT		3
++# define HWCAP_IMPORTANT \
++  (HWCAP_X86_SSE2 | HWCAP_X86_64 | HWCAP_X86_AVX512_1)
+ #elif defined __x86_64__
+ /* For 64 bit, only cover x86-64 platforms and capabilities.  */
+ # define HWCAP_PLATFORMS_START	2
+ # define HWCAP_PLATFORMS_COUNT	4
+ # define HWCAP_START		1
+-# define HWCAP_COUNT		2
+-# define HWCAP_IMPORTANT	(HWCAP_X86_AVX512_1)
++# define HWCAP_COUNT		3
++# define HWCAP_IMPORTANT	(HWCAP_X86_64 | HWCAP_X86_AVX512_1)
+ #else
+ /* For 32 bit, only cover i586, i686 and SSE2.  */
+ # define HWCAP_PLATFORMS_START	0
+@@ -45,7 +46,8 @@
+ enum
+ {
+   HWCAP_X86_SSE2		= 1 << 0,
+-  HWCAP_X86_AVX512_1		= 1 << 1
++  HWCAP_X86_64			= 1 << 1,
++  HWCAP_X86_AVX512_1		= 1 << 2
+ };
+ 
+ static inline const char *
+diff --git a/sysdeps/x86/dl-procinfo.c b/sysdeps/x86/dl-procinfo.c
+index 43ab8fe25b..0192feb850 100644
+--- a/sysdeps/x86/dl-procinfo.c
++++ b/sysdeps/x86/dl-procinfo.c
+@@ -58,11 +58,11 @@ PROCINFO_CLASS struct cpu_features _dl_x86_cpu_features
+ #if !defined PROCINFO_DECL && defined SHARED
+   ._dl_x86_hwcap_flags
+ #else
+-PROCINFO_CLASS const char _dl_x86_hwcap_flags[2][9]
++PROCINFO_CLASS const char _dl_x86_hwcap_flags[3][9]
+ #endif
+ #ifndef PROCINFO_DECL
+ = {
+-    "sse2", "avx512_1"
++    "sse2", "x86_64", "avx512_1"
+   }
+ #endif
+ #if !defined SHARED || defined PROCINFO_DECL
+diff --git a/sysdeps/x86_64/Makefile b/sysdeps/x86_64/Makefile
+index 132470d9cb..457cf5d129 100644
+--- a/sysdeps/x86_64/Makefile
++++ b/sysdeps/x86_64/Makefile
+@@ -52,6 +52,12 @@ $(objpfx)tst-quad2pie: $(objpfx)tst-quadmod2pie.o
+ CFLAGS-tst-quad1pie.c = $(PIE-ccflag)
+ CFLAGS-tst-quad2pie.c = $(PIE-ccflag)
+ 
++tests += tst-x86_64-1
++modules-names += x86_64/tst-x86_64mod-1
++LDFLAGS-tst-x86_64mod-1.so = -Wl,-soname,tst-x86_64mod-1.so
++
++$(objpfx)tst-x86_64-1: $(objpfx)x86_64/tst-x86_64mod-1.so
++
+ tests += tst-audit3 tst-audit4 tst-audit5 tst-audit6 tst-audit7 \
+ 	 tst-audit10 tst-sse tst-avx tst-avx512
+ test-extras += tst-audit4-aux tst-audit10-aux \
+@@ -122,3 +128,14 @@ endif
+ ifeq ($(subdir),csu)
+ gen-as-const-headers += tlsdesc.sym rtld-offsets.sym
+ endif
++
++$(objpfx)x86_64/tst-x86_64mod-1.os: $(objpfx)tst-x86_64mod-1.os
++	$(make-target-directory)
++	rm -f $@
++	ln $< $@
++
++do-tests-clean common-mostlyclean: tst-x86_64-1-clean
++
++.PHONY: tst-x86_64-1-clean
++tst-x86_64-1-clean:
++	-rm -rf $(objpfx)x86_64
+diff --git a/sysdeps/x86_64/tst-x86_64-1.c b/sysdeps/x86_64/tst-x86_64-1.c
+new file mode 100644
+index 0000000000..ba1a55cdaf
+--- /dev/null
++++ b/sysdeps/x86_64/tst-x86_64-1.c
+@@ -0,0 +1,26 @@
++/* Test searching the "x86_64" directory for shared libraries.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++extern void foo (void);
++
++int
++main (void)
++{
++  foo ();
++  return 0;
++}
+diff --git a/sysdeps/x86_64/tst-x86_64mod-1.c b/sysdeps/x86_64/tst-x86_64mod-1.c
+new file mode 100644
+index 0000000000..83dfafb5a8
+--- /dev/null
++++ b/sysdeps/x86_64/tst-x86_64mod-1.c
+@@ -0,0 +1,22 @@
++/* Test searching the "x86_64" directory for shared libraries.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++void
++foo (void)
++{
++}
diff --git a/gnu/packages/patches/glibc-2-26-0068.patch b/gnu/packages/patches/glibc-2-26-0068.patch
new file mode 100644
index 000000000..25b615e95
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0068.patch
@@ -0,0 +1,970 @@
+From f82a6fc223cbd890b9de9007cfce63e6cae8f799 Mon Sep 17 00:00:00 2001
+From: "H.J. Lu" <hjl.tools@gmail.com>
+Date: Sun, 22 Oct 2017 07:40:39 -0700
+Subject: [PATCH 68/90] x86-64: Use fxsave/xsave/xsavec in _dl_runtime_resolve
+ [BZ #21265]
+
+In _dl_runtime_resolve, use fxsave/xsave/xsavec to preserve all vector,
+mask and bound registers.  It simplifies _dl_runtime_resolve and supports
+different calling conventions.  ld.so code size is reduced by more than
+1 KB.  However, use fxsave/xsave/xsavec takes a little bit more cycles
+than saving and restoring vector and bound registers individually.
+
+Latency for _dl_runtime_resolve to lookup the function, foo, from one
+shared library plus libc.so:
+
+                             Before    After     Change
+
+Westmere (SSE)/fxsave         345      866       151%
+IvyBridge (AVX)/xsave         420      643       53%
+Haswell (AVX)/xsave           713      1252      75%
+Skylake (AVX+MPX)/xsavec      559      719       28%
+Skylake (AVX512+MPX)/xsavec   145      272       87%
+Ryzen (AVX)/xsavec            280      553       97%
+
+This is the worst case where portion of time spent for saving and
+restoring registers is bigger than majority of cases.  With smaller
+_dl_runtime_resolve code size, overall performance impact is negligible.
+
+On IvyBridge, differences in build and test time of binutils with lazy
+binding GCC and binutils are noises.  On Westmere, differences in
+bootstrap and "makc check" time of GCC 7 with lazy binding GCC and
+binutils are also noises.
+
+	[BZ #21265]
+	* sysdeps/x86/cpu-features-offsets.sym (XSAVE_STATE_SIZE_OFFSET):
+	New.
+	* sysdeps/x86/cpu-features.c: Include <libc-pointer-arith.h>.
+	(get_common_indeces): Set xsave_state_size, xsave_state_full_size
+	and bit_arch_XSAVEC_Usable if needed.
+	(init_cpu_features): Remove bit_arch_Use_dl_runtime_resolve_slow
+	and bit_arch_Use_dl_runtime_resolve_opt.
+	* sysdeps/x86/cpu-features.h (bit_arch_Use_dl_runtime_resolve_opt):
+	Removed.
+	(bit_arch_Use_dl_runtime_resolve_slow): Likewise.
+	(bit_arch_Prefer_No_AVX512): Updated.
+	(bit_arch_MathVec_Prefer_No_AVX512): Likewise.
+	(bit_arch_XSAVEC_Usable): New.
+	(STATE_SAVE_OFFSET): Likewise.
+	(STATE_SAVE_MASK): Likewise.
+	[__ASSEMBLER__]: Include <cpu-features-offsets.h>.
+	(cpu_features): Add xsave_state_size and xsave_state_full_size.
+	(index_arch_Use_dl_runtime_resolve_opt): Removed.
+	(index_arch_Use_dl_runtime_resolve_slow): Likewise.
+	(index_arch_XSAVEC_Usable): New.
+	* sysdeps/x86/cpu-tunables.c (TUNABLE_CALLBACK (set_hwcaps)):
+	Support XSAVEC_Usable.  Remove Use_dl_runtime_resolve_slow.
+	* sysdeps/x86_64/Makefile (tst-x86_64-1-ENV): New if tunables
+	is enabled.
+	* sysdeps/x86_64/dl-machine.h (elf_machine_runtime_setup):
+	Replace _dl_runtime_resolve_sse, _dl_runtime_resolve_avx,
+	_dl_runtime_resolve_avx_slow, _dl_runtime_resolve_avx_opt,
+	_dl_runtime_resolve_avx512 and _dl_runtime_resolve_avx512_opt
+	with _dl_runtime_resolve_fxsave, _dl_runtime_resolve_xsave and
+	_dl_runtime_resolve_xsavec.
+	* sysdeps/x86_64/dl-trampoline.S (DL_RUNTIME_UNALIGNED_VEC_SIZE):
+	Removed.
+	(DL_RUNTIME_RESOLVE_REALIGN_STACK): Check STATE_SAVE_ALIGNMENT
+	instead of VEC_SIZE.
+	(REGISTER_SAVE_BND0): Removed.
+	(REGISTER_SAVE_BND1): Likewise.
+	(REGISTER_SAVE_BND3): Likewise.
+	(REGISTER_SAVE_RAX): Always defined to 0.
+	(VMOV): Removed.
+	(_dl_runtime_resolve_avx): Likewise.
+	(_dl_runtime_resolve_avx_slow): Likewise.
+	(_dl_runtime_resolve_avx_opt): Likewise.
+	(_dl_runtime_resolve_avx512): Likewise.
+	(_dl_runtime_resolve_avx512_opt): Likewise.
+	(_dl_runtime_resolve_sse): Likewise.
+	(_dl_runtime_resolve_sse_vex): Likewise.
+	(USE_FXSAVE): New.
+	(_dl_runtime_resolve_fxsave): Likewise.
+	(USE_XSAVE): Likewise.
+	(_dl_runtime_resolve_xsave): Likewise.
+	(USE_XSAVEC): Likewise.
+	(_dl_runtime_resolve_xsavec): Likewise.
+	* sysdeps/x86_64/dl-trampoline.h (_dl_runtime_resolve_avx512):
+	Removed.
+	(_dl_runtime_resolve_avx512_opt): Likewise.
+	(_dl_runtime_resolve_avx): Likewise.
+	(_dl_runtime_resolve_avx_opt): Likewise.
+	(_dl_runtime_resolve_sse): Likewise.
+	(_dl_runtime_resolve_sse_vex): Likewise.
+	(_dl_runtime_resolve_fxsave): New.
+	(_dl_runtime_resolve_xsave): Likewise.
+	(_dl_runtime_resolve_xsavec): Likewise.
+
+(cherry picked from commit b52b0d793dcb226ecb0ecca1e672ca265973233c)
+
+diff --git a/ChangeLog b/ChangeLog
+index 2c1ee0bac1..cd598788f1 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,69 @@
++2017-10-22  H.J. Lu  <hongjiu.lu@intel.com>
++
++	[BZ #21265]
++	* sysdeps/x86/cpu-features-offsets.sym (XSAVE_STATE_SIZE_OFFSET):
++	New.
++	* sysdeps/x86/cpu-features.c: Include <libc-pointer-arith.h>.
++	(get_common_indeces): Set xsave_state_size, xsave_state_full_size
++	and bit_arch_XSAVEC_Usable if needed.
++	(init_cpu_features): Remove bit_arch_Use_dl_runtime_resolve_slow
++	and bit_arch_Use_dl_runtime_resolve_opt.
++	* sysdeps/x86/cpu-features.h (bit_arch_Use_dl_runtime_resolve_opt):
++	Removed.
++	(bit_arch_Use_dl_runtime_resolve_slow): Likewise.
++	(bit_arch_Prefer_No_AVX512): Updated.
++	(bit_arch_MathVec_Prefer_No_AVX512): Likewise.
++	(bit_arch_XSAVEC_Usable): New.
++	(STATE_SAVE_OFFSET): Likewise.
++	(STATE_SAVE_MASK): Likewise.
++	[__ASSEMBLER__]: Include <cpu-features-offsets.h>.
++	(cpu_features): Add xsave_state_size and xsave_state_full_size.
++	(index_arch_Use_dl_runtime_resolve_opt): Removed.
++	(index_arch_Use_dl_runtime_resolve_slow): Likewise.
++	(index_arch_XSAVEC_Usable): New.
++	* sysdeps/x86/cpu-tunables.c (TUNABLE_CALLBACK (set_hwcaps)):
++	Support XSAVEC_Usable.  Remove Use_dl_runtime_resolve_slow.
++	* sysdeps/x86_64/Makefile (tst-x86_64-1-ENV): New if tunables
++	is enabled.
++	* sysdeps/x86_64/dl-machine.h (elf_machine_runtime_setup):
++	Replace _dl_runtime_resolve_sse, _dl_runtime_resolve_avx,
++	_dl_runtime_resolve_avx_slow, _dl_runtime_resolve_avx_opt,
++	_dl_runtime_resolve_avx512 and _dl_runtime_resolve_avx512_opt
++	with _dl_runtime_resolve_fxsave, _dl_runtime_resolve_xsave and
++	_dl_runtime_resolve_xsavec.
++	* sysdeps/x86_64/dl-trampoline.S (DL_RUNTIME_UNALIGNED_VEC_SIZE):
++	Removed.
++	(DL_RUNTIME_RESOLVE_REALIGN_STACK): Check STATE_SAVE_ALIGNMENT
++	instead of VEC_SIZE.
++	(REGISTER_SAVE_BND0): Removed.
++	(REGISTER_SAVE_BND1): Likewise.
++	(REGISTER_SAVE_BND3): Likewise.
++	(REGISTER_SAVE_RAX): Always defined to 0.
++	(VMOV): Removed.
++	(_dl_runtime_resolve_avx): Likewise.
++	(_dl_runtime_resolve_avx_slow): Likewise.
++	(_dl_runtime_resolve_avx_opt): Likewise.
++	(_dl_runtime_resolve_avx512): Likewise.
++	(_dl_runtime_resolve_avx512_opt): Likewise.
++	(_dl_runtime_resolve_sse): Likewise.
++	(_dl_runtime_resolve_sse_vex): Likewise.
++	(USE_FXSAVE): New.
++	(_dl_runtime_resolve_fxsave): Likewise.
++	(USE_XSAVE): Likewise.
++	(_dl_runtime_resolve_xsave): Likewise.
++	(USE_XSAVEC): Likewise.
++	(_dl_runtime_resolve_xsavec): Likewise.
++	* sysdeps/x86_64/dl-trampoline.h (_dl_runtime_resolve_avx512):
++	Removed.
++	(_dl_runtime_resolve_avx512_opt): Likewise.
++	(_dl_runtime_resolve_avx): Likewise.
++	(_dl_runtime_resolve_avx_opt): Likewise.
++	(_dl_runtime_resolve_sse): Likewise.
++	(_dl_runtime_resolve_sse_vex): Likewise.
++	(_dl_runtime_resolve_fxsave): New.
++	(_dl_runtime_resolve_xsave): Likewise.
++	(_dl_runtime_resolve_xsavec): Likewise.
++
+ 2017-10-22  H.J. Lu  <hongjiu.lu@intel.com>
+ 
+ 	[BZ #22093]
+diff --git a/NEWS b/NEWS
+index bb625e699e..87d48025e2 100644
+--- a/NEWS
++++ b/NEWS
+@@ -24,6 +24,7 @@ The following bugs are resolved with this release:
+ 
+   [16750] ldd: Never run file directly.
+   [21242] assert: Suppress pedantic warning caused by statement expression
++  [21265] x86-64: Use fxsave/xsave/xsavec in _dl_runtime_resolve
+   [21780] posix: Set p{read,write}v2 to return ENOTSUP
+   [21871] x86-64: Use _dl_runtime_resolve_opt only with AVX512F
+   [21885] getaddrinfo: Release resolver context on error in gethosts
+diff --git a/sysdeps/x86/cpu-features-offsets.sym b/sysdeps/x86/cpu-features-offsets.sym
+index f6739fae81..33dd094e37 100644
+--- a/sysdeps/x86/cpu-features-offsets.sym
++++ b/sysdeps/x86/cpu-features-offsets.sym
+@@ -15,6 +15,7 @@ CPUID_ECX_OFFSET	offsetof (struct cpuid_registers, ecx)
+ CPUID_EDX_OFFSET	offsetof (struct cpuid_registers, edx)
+ FAMILY_OFFSET		offsetof (struct cpu_features, family)
+ MODEL_OFFSET		offsetof (struct cpu_features, model)
++XSAVE_STATE_SIZE_OFFSET	offsetof (struct cpu_features, xsave_state_size)
+ FEATURE_OFFSET		offsetof (struct cpu_features, feature)
+ FEATURE_SIZE		sizeof (unsigned int)
+ 
+diff --git a/sysdeps/x86/cpu-features.c b/sysdeps/x86/cpu-features.c
+index c267f17b76..3a5c3e8bfd 100644
+--- a/sysdeps/x86/cpu-features.c
++++ b/sysdeps/x86/cpu-features.c
+@@ -19,6 +19,7 @@
+ #include <cpuid.h>
+ #include <cpu-features.h>
+ #include <dl-hwcap.h>
++#include <libc-pointer-arith.h>
+ 
+ #if HAVE_TUNABLES
+ # define TUNABLE_NAMESPACE tune
+@@ -103,6 +104,76 @@ get_common_indeces (struct cpu_features *cpu_features,
+ 		}
+ 	    }
+ 	}
++
++      /* For _dl_runtime_resolve, set xsave_state_size to xsave area
++	 size + integer register save size and align it to 64 bytes.  */
++      if (cpu_features->max_cpuid >= 0xd)
++	{
++	  unsigned int eax, ebx, ecx, edx;
++
++	  __cpuid_count (0xd, 0, eax, ebx, ecx, edx);
++	  if (ebx != 0)
++	    {
++	      unsigned int xsave_state_full_size
++		= ALIGN_UP (ebx + STATE_SAVE_OFFSET, 64);
++
++	      cpu_features->xsave_state_size
++		= xsave_state_full_size;
++	      cpu_features->xsave_state_full_size
++		= xsave_state_full_size;
++
++	      __cpuid_count (0xd, 1, eax, ebx, ecx, edx);
++
++	      /* Check if XSAVEC is available.  */
++	      if ((eax & (1 << 1)) != 0)
++		{
++		  unsigned int xstate_comp_offsets[32];
++		  unsigned int xstate_comp_sizes[32];
++		  unsigned int i;
++
++		  xstate_comp_offsets[0] = 0;
++		  xstate_comp_offsets[1] = 160;
++		  xstate_comp_offsets[2] = 576;
++		  xstate_comp_sizes[0] = 160;
++		  xstate_comp_sizes[1] = 256;
++
++		  for (i = 2; i < 32; i++)
++		    {
++		      if ((STATE_SAVE_MASK & (1 << i)) != 0)
++			{
++			  __cpuid_count (0xd, i, eax, ebx, ecx, edx);
++			  xstate_comp_sizes[i] = eax;
++			}
++		      else
++			{
++			  ecx = 0;
++			  xstate_comp_sizes[i] = 0;
++			}
++
++		      if (i > 2)
++			{
++			  xstate_comp_offsets[i]
++			    = (xstate_comp_offsets[i - 1]
++			       + xstate_comp_sizes[i -1]);
++			  if ((ecx & (1 << 1)) != 0)
++			    xstate_comp_offsets[i]
++			      = ALIGN_UP (xstate_comp_offsets[i], 64);
++			}
++		    }
++
++		  /* Use XSAVEC.  */
++		  unsigned int size
++		    = xstate_comp_offsets[31] + xstate_comp_sizes[31];
++		  if (size)
++		    {
++		      cpu_features->xsave_state_size
++			= ALIGN_UP (size + STATE_SAVE_OFFSET, 64);
++		      cpu_features->feature[index_arch_XSAVEC_Usable]
++			|= bit_arch_XSAVEC_Usable;
++		    }
++		}
++	    }
++	}
+     }
+ }
+ 
+@@ -242,23 +313,6 @@ init_cpu_features (struct cpu_features *cpu_features)
+       else
+ 	cpu_features->feature[index_arch_Prefer_No_AVX512]
+ 	  |= bit_arch_Prefer_No_AVX512;
+-
+-      /* To avoid SSE transition penalty, use _dl_runtime_resolve_slow.
+-         If XGETBV suports ECX == 1, use _dl_runtime_resolve_opt.
+-	 Use _dl_runtime_resolve_opt only with AVX512F since it is
+-	 slower than _dl_runtime_resolve_slow with AVX.  */
+-      cpu_features->feature[index_arch_Use_dl_runtime_resolve_slow]
+-	|= bit_arch_Use_dl_runtime_resolve_slow;
+-      if (CPU_FEATURES_ARCH_P (cpu_features, AVX512F_Usable)
+-	  && cpu_features->max_cpuid >= 0xd)
+-	{
+-	  unsigned int eax;
+-
+-	  __cpuid_count (0xd, 1, eax, ebx, ecx, edx);
+-	  if ((eax & (1 << 2)) != 0)
+-	    cpu_features->feature[index_arch_Use_dl_runtime_resolve_opt]
+-	      |= bit_arch_Use_dl_runtime_resolve_opt;
+-	}
+     }
+   /* This spells out "AuthenticAMD".  */
+   else if (ebx == 0x68747541 && ecx == 0x444d4163 && edx == 0x69746e65)
+diff --git a/sysdeps/x86/cpu-features.h b/sysdeps/x86/cpu-features.h
+index 3ed67f5800..1d88f7a68c 100644
+--- a/sysdeps/x86/cpu-features.h
++++ b/sysdeps/x86/cpu-features.h
+@@ -37,9 +37,8 @@
+ #define bit_arch_Prefer_No_VZEROUPPER		(1 << 17)
+ #define bit_arch_Fast_Unaligned_Copy		(1 << 18)
+ #define bit_arch_Prefer_ERMS			(1 << 19)
+-#define bit_arch_Use_dl_runtime_resolve_opt	(1 << 20)
+-#define bit_arch_Use_dl_runtime_resolve_slow	(1 << 21)
+-#define bit_arch_Prefer_No_AVX512		(1 << 22)
++#define bit_arch_Prefer_No_AVX512		(1 << 20)
++#define bit_arch_XSAVEC_Usable			(1 << 21)
+ 
+ /* CPUID Feature flags.  */
+ 
+@@ -88,6 +87,15 @@
+ /* The current maximum size of the feature integer bit array.  */
+ #define FEATURE_INDEX_MAX 1
+ 
++/* Offset for fxsave/xsave area used by _dl_runtime_resolve.  Also need
++   space to preserve RCX, RDX, RSI, RDI, R8, R9 and RAX.  It must be
++   aligned to 16 bytes for fxsave and 64 bytes for xsave.  */
++#define STATE_SAVE_OFFSET (8 * 7 + 8)
++
++/* Save SSE, AVX, AVX512, mask and bound registers.  */
++#define STATE_SAVE_MASK \
++  ((1 << 1) | (1 << 2) | (1 << 3) | (1 << 5) | (1 << 6) | (1 << 7))
++
+ #ifdef	__ASSEMBLER__
+ 
+ # include <cpu-features-offsets.h>
+@@ -123,8 +131,6 @@
+ # define index_arch_Prefer_No_VZEROUPPER FEATURE_INDEX_1*FEATURE_SIZE
+ # define index_arch_Fast_Unaligned_Copy	FEATURE_INDEX_1*FEATURE_SIZE
+ # define index_arch_Prefer_ERMS		FEATURE_INDEX_1*FEATURE_SIZE
+-# define index_arch_Use_dl_runtime_resolve_opt FEATURE_INDEX_1*FEATURE_SIZE
+-# define index_arch_Use_dl_runtime_resolve_slow FEATURE_INDEX_1*FEATURE_SIZE
+ # define index_arch_Prefer_No_AVX512	FEATURE_INDEX_1*FEATURE_SIZE
+ 
+ 
+@@ -214,6 +220,18 @@ struct cpu_features
+   } cpuid[COMMON_CPUID_INDEX_MAX];
+   unsigned int family;
+   unsigned int model;
++  /* The state size for XSAVEC or XSAVE.  The type must be unsigned long
++     int so that we use
++
++	sub xsave_state_size_offset(%rip) %RSP_LP
++
++     in _dl_runtime_resolve.  */
++  unsigned long int xsave_state_size;
++  /* The full state size for XSAVE when XSAVEC is disabled by
++
++     GLIBC_TUNABLES=glibc.tune.hwcaps=-XSAVEC_Usable
++   */
++  unsigned int xsave_state_full_size;
+   unsigned int feature[FEATURE_INDEX_MAX];
+   /* Data cache size for use in memory and string routines, typically
+      L1 size.  */
+@@ -326,9 +344,8 @@ extern const struct cpu_features *__get_cpu_features (void)
+ # define index_arch_Prefer_No_VZEROUPPER FEATURE_INDEX_1
+ # define index_arch_Fast_Unaligned_Copy	FEATURE_INDEX_1
+ # define index_arch_Prefer_ERMS		FEATURE_INDEX_1
+-# define index_arch_Use_dl_runtime_resolve_opt FEATURE_INDEX_1
+-# define index_arch_Use_dl_runtime_resolve_slow FEATURE_INDEX_1
+ # define index_arch_Prefer_No_AVX512	FEATURE_INDEX_1
++# define index_arch_XSAVEC_Usable	FEATURE_INDEX_1
+ 
+ #endif	/* !__ASSEMBLER__ */
+ 
+diff --git a/sysdeps/x86/cpu-tunables.c b/sysdeps/x86/cpu-tunables.c
+index 872dd1267f..0488f03d32 100644
+--- a/sysdeps/x86/cpu-tunables.c
++++ b/sysdeps/x86/cpu-tunables.c
+@@ -240,6 +240,16 @@ TUNABLE_CALLBACK (set_hwcaps) (tunable_val_t *valp)
+ 						Slow_SSE4_2, SSE4_2,
+ 						disable, 11);
+ 	  break;
++	case 13:
++	  if (disable)
++	    {
++	      /* Update xsave_state_size to XSAVE state size.  */
++	      cpu_features->xsave_state_size
++		= cpu_features->xsave_state_full_size;
++	      CHECK_GLIBC_IFUNC_ARCH_OFF (n, cpu_features,
++					  XSAVEC_Usable, 13);
++	    }
++	  break;
+ 	case 14:
+ 	  if (disable)
+ 	    {
+@@ -308,13 +318,6 @@ TUNABLE_CALLBACK (set_hwcaps) (tunable_val_t *valp)
+ 		 disable, 26);
+ 	    }
+ 	  break;
+-	case 27:
+-	    {
+-	      CHECK_GLIBC_IFUNC_ARCH_BOTH (n, cpu_features,
+-					   Use_dl_runtime_resolve_slow,
+-					   disable, 27);
+-	    }
+-	  break;
+ 	}
+       p += len + 1;
+     }
+diff --git a/sysdeps/x86_64/Makefile b/sysdeps/x86_64/Makefile
+index 457cf5d129..cb4e63897c 100644
+--- a/sysdeps/x86_64/Makefile
++++ b/sysdeps/x86_64/Makefile
+@@ -55,6 +55,10 @@ CFLAGS-tst-quad2pie.c = $(PIE-ccflag)
+ tests += tst-x86_64-1
+ modules-names += x86_64/tst-x86_64mod-1
+ LDFLAGS-tst-x86_64mod-1.so = -Wl,-soname,tst-x86_64mod-1.so
++ifneq (no,$(have-tunables))
++# Test the state size for XSAVE when XSAVEC is disabled.
++tst-x86_64-1-ENV = GLIBC_TUNABLES=glibc.tune.hwcaps=-XSAVEC_Usable
++endif
+ 
+ $(objpfx)tst-x86_64-1: $(objpfx)x86_64/tst-x86_64mod-1.so
+ 
+diff --git a/sysdeps/x86_64/dl-machine.h b/sysdeps/x86_64/dl-machine.h
+index 6a04cbcdc9..905a37a5cc 100644
+--- a/sysdeps/x86_64/dl-machine.h
++++ b/sysdeps/x86_64/dl-machine.h
+@@ -66,12 +66,9 @@ static inline int __attribute__ ((unused, always_inline))
+ elf_machine_runtime_setup (struct link_map *l, int lazy, int profile)
+ {
+   Elf64_Addr *got;
+-  extern void _dl_runtime_resolve_sse (ElfW(Word)) attribute_hidden;
+-  extern void _dl_runtime_resolve_avx (ElfW(Word)) attribute_hidden;
+-  extern void _dl_runtime_resolve_avx_slow (ElfW(Word)) attribute_hidden;
+-  extern void _dl_runtime_resolve_avx_opt (ElfW(Word)) attribute_hidden;
+-  extern void _dl_runtime_resolve_avx512 (ElfW(Word)) attribute_hidden;
+-  extern void _dl_runtime_resolve_avx512_opt (ElfW(Word)) attribute_hidden;
++  extern void _dl_runtime_resolve_fxsave (ElfW(Word)) attribute_hidden;
++  extern void _dl_runtime_resolve_xsave (ElfW(Word)) attribute_hidden;
++  extern void _dl_runtime_resolve_xsavec (ElfW(Word)) attribute_hidden;
+   extern void _dl_runtime_profile_sse (ElfW(Word)) attribute_hidden;
+   extern void _dl_runtime_profile_avx (ElfW(Word)) attribute_hidden;
+   extern void _dl_runtime_profile_avx512 (ElfW(Word)) attribute_hidden;
+@@ -120,29 +117,14 @@ elf_machine_runtime_setup (struct link_map *l, int lazy, int profile)
+ 	  /* This function will get called to fix up the GOT entry
+ 	     indicated by the offset on the stack, and then jump to
+ 	     the resolved address.  */
+-	  if (HAS_ARCH_FEATURE (AVX512F_Usable))
+-	    {
+-	      if (HAS_ARCH_FEATURE (Use_dl_runtime_resolve_opt))
+-		*(ElfW(Addr) *) (got + 2)
+-		  = (ElfW(Addr)) &_dl_runtime_resolve_avx512_opt;
+-	      else
+-		*(ElfW(Addr) *) (got + 2)
+-		  = (ElfW(Addr)) &_dl_runtime_resolve_avx512;
+-	    }
+-	  else if (HAS_ARCH_FEATURE (AVX_Usable))
+-	    {
+-	      if (HAS_ARCH_FEATURE (Use_dl_runtime_resolve_opt))
+-		*(ElfW(Addr) *) (got + 2)
+-		  = (ElfW(Addr)) &_dl_runtime_resolve_avx_opt;
+-	      else if (HAS_ARCH_FEATURE (Use_dl_runtime_resolve_slow))
+-		*(ElfW(Addr) *) (got + 2)
+-		  = (ElfW(Addr)) &_dl_runtime_resolve_avx_slow;
+-	      else
+-		*(ElfW(Addr) *) (got + 2)
+-		  = (ElfW(Addr)) &_dl_runtime_resolve_avx;
+-	    }
++	  if (GLRO(dl_x86_cpu_features).xsave_state_size != 0)
++	    *(ElfW(Addr) *) (got + 2)
++	      = (HAS_ARCH_FEATURE (XSAVEC_Usable)
++		 ? (ElfW(Addr)) &_dl_runtime_resolve_xsavec
++		 : (ElfW(Addr)) &_dl_runtime_resolve_xsave);
+ 	  else
+-	    *(ElfW(Addr) *) (got + 2) = (ElfW(Addr)) &_dl_runtime_resolve_sse;
++	    *(ElfW(Addr) *) (got + 2)
++	      = (ElfW(Addr)) &_dl_runtime_resolve_fxsave;
+ 	}
+     }
+ 
+diff --git a/sysdeps/x86_64/dl-trampoline.S b/sysdeps/x86_64/dl-trampoline.S
+index c14c61aa58..a645572e44 100644
+--- a/sysdeps/x86_64/dl-trampoline.S
++++ b/sysdeps/x86_64/dl-trampoline.S
+@@ -34,41 +34,24 @@
+ # define DL_STACK_ALIGNMENT 8
+ #endif
+ 
+-#ifndef DL_RUNTIME_UNALIGNED_VEC_SIZE
+-/* The maximum size in bytes of unaligned vector load and store in the
+-   dynamic linker.  Since SSE optimized memory/string functions with
+-   aligned SSE register load and store are used in the dynamic linker,
+-   we must set this to 8 so that _dl_runtime_resolve_sse will align the
+-   stack before calling _dl_fixup.  */
+-# define DL_RUNTIME_UNALIGNED_VEC_SIZE 8
+-#endif
+-
+-/* True if _dl_runtime_resolve should align stack to VEC_SIZE bytes.  */
++/* True if _dl_runtime_resolve should align stack for STATE_SAVE or align
++   stack to 16 bytes before calling _dl_fixup.  */
+ #define DL_RUNTIME_RESOLVE_REALIGN_STACK \
+-  (VEC_SIZE > DL_STACK_ALIGNMENT \
+-   && VEC_SIZE > DL_RUNTIME_UNALIGNED_VEC_SIZE)
+-
+-/* Align vector register save area to 16 bytes.  */
+-#define REGISTER_SAVE_VEC_OFF	0
++  (STATE_SAVE_ALIGNMENT > DL_STACK_ALIGNMENT \
++   || 16 > DL_STACK_ALIGNMENT)
+ 
+ /* Area on stack to save and restore registers used for parameter
+    passing when calling _dl_fixup.  */
+ #ifdef __ILP32__
+-# define REGISTER_SAVE_RAX	(REGISTER_SAVE_VEC_OFF + VEC_SIZE * 8)
+ # define PRESERVE_BND_REGS_PREFIX
+ #else
+-/* Align bound register save area to 16 bytes.  */
+-# define REGISTER_SAVE_BND0	(REGISTER_SAVE_VEC_OFF + VEC_SIZE * 8)
+-# define REGISTER_SAVE_BND1	(REGISTER_SAVE_BND0 + 16)
+-# define REGISTER_SAVE_BND2	(REGISTER_SAVE_BND1 + 16)
+-# define REGISTER_SAVE_BND3	(REGISTER_SAVE_BND2 + 16)
+-# define REGISTER_SAVE_RAX	(REGISTER_SAVE_BND3 + 16)
+ # ifdef HAVE_MPX_SUPPORT
+ #  define PRESERVE_BND_REGS_PREFIX bnd
+ # else
+ #  define PRESERVE_BND_REGS_PREFIX .byte 0xf2
+ # endif
+ #endif
++#define REGISTER_SAVE_RAX	0
+ #define REGISTER_SAVE_RCX	(REGISTER_SAVE_RAX + 8)
+ #define REGISTER_SAVE_RDX	(REGISTER_SAVE_RCX + 8)
+ #define REGISTER_SAVE_RSI	(REGISTER_SAVE_RDX + 8)
+@@ -80,68 +63,56 @@
+ 
+ #define VEC_SIZE		64
+ #define VMOVA			vmovdqa64
+-#if DL_RUNTIME_RESOLVE_REALIGN_STACK || VEC_SIZE <= DL_STACK_ALIGNMENT
+-# define VMOV			vmovdqa64
+-#else
+-# define VMOV			vmovdqu64
+-#endif
+ #define VEC(i)			zmm##i
+-#define _dl_runtime_resolve	_dl_runtime_resolve_avx512
+ #define _dl_runtime_profile	_dl_runtime_profile_avx512
+ #include "dl-trampoline.h"
+-#undef _dl_runtime_resolve
+ #undef _dl_runtime_profile
+ #undef VEC
+-#undef VMOV
+ #undef VMOVA
+ #undef VEC_SIZE
+ 
+ #define VEC_SIZE		32
+ #define VMOVA			vmovdqa
+-#if DL_RUNTIME_RESOLVE_REALIGN_STACK || VEC_SIZE <= DL_STACK_ALIGNMENT
+-# define VMOV			vmovdqa
+-#else
+-# define VMOV			vmovdqu
+-#endif
+ #define VEC(i)			ymm##i
+-#define _dl_runtime_resolve	_dl_runtime_resolve_avx
+-#define _dl_runtime_resolve_opt	_dl_runtime_resolve_avx_opt
+ #define _dl_runtime_profile	_dl_runtime_profile_avx
+ #include "dl-trampoline.h"
+-#undef _dl_runtime_resolve
+-#undef _dl_runtime_resolve_opt
+ #undef _dl_runtime_profile
+ #undef VEC
+-#undef VMOV
+ #undef VMOVA
+ #undef VEC_SIZE
+ 
+ /* movaps/movups is 1-byte shorter.  */
+ #define VEC_SIZE		16
+ #define VMOVA			movaps
+-#if DL_RUNTIME_RESOLVE_REALIGN_STACK || VEC_SIZE <= DL_STACK_ALIGNMENT
+-# define VMOV			movaps
+-#else
+-# define VMOV			movups
+-#endif
+ #define VEC(i)			xmm##i
+-#define _dl_runtime_resolve	_dl_runtime_resolve_sse
+ #define _dl_runtime_profile	_dl_runtime_profile_sse
+ #undef RESTORE_AVX
+ #include "dl-trampoline.h"
+-#undef _dl_runtime_resolve
+ #undef _dl_runtime_profile
+-#undef VMOV
++#undef VEC
+ #undef VMOVA
++#undef VEC_SIZE
+ 
+-/* Used by _dl_runtime_resolve_avx_opt/_dl_runtime_resolve_avx512_opt
+-   to preserve the full vector registers with zero upper bits.  */
+-#define VMOVA			vmovdqa
+-#if DL_RUNTIME_RESOLVE_REALIGN_STACK || VEC_SIZE <= DL_STACK_ALIGNMENT
+-# define VMOV			vmovdqa
+-#else
+-# define VMOV			vmovdqu
+-#endif
+-#define _dl_runtime_resolve	_dl_runtime_resolve_sse_vex
+-#define _dl_runtime_resolve_opt	_dl_runtime_resolve_avx512_opt
++#define USE_FXSAVE
++#define STATE_SAVE_ALIGNMENT	16
++#define _dl_runtime_resolve	_dl_runtime_resolve_fxsave
++#include "dl-trampoline.h"
++#undef _dl_runtime_resolve
++#undef USE_FXSAVE
++#undef STATE_SAVE_ALIGNMENT
++
++#define USE_XSAVE
++#define STATE_SAVE_ALIGNMENT	64
++#define _dl_runtime_resolve	_dl_runtime_resolve_xsave
++#include "dl-trampoline.h"
++#undef _dl_runtime_resolve
++#undef USE_XSAVE
++#undef STATE_SAVE_ALIGNMENT
++
++#define USE_XSAVEC
++#define STATE_SAVE_ALIGNMENT	64
++#define _dl_runtime_resolve	_dl_runtime_resolve_xsavec
+ #include "dl-trampoline.h"
++#undef _dl_runtime_resolve
++#undef USE_XSAVEC
++#undef STATE_SAVE_ALIGNMENT
+diff --git a/sysdeps/x86_64/dl-trampoline.h b/sysdeps/x86_64/dl-trampoline.h
+index 8db24c16ac..9ddaafee17 100644
+--- a/sysdeps/x86_64/dl-trampoline.h
++++ b/sysdeps/x86_64/dl-trampoline.h
+@@ -16,140 +16,47 @@
+    License along with the GNU C Library; if not, see
+    <http://www.gnu.org/licenses/>.  */
+ 
+-#undef REGISTER_SAVE_AREA_RAW
+-#ifdef __ILP32__
+-/* X32 saves RCX, RDX, RSI, RDI, R8 and R9 plus RAX as well as VEC0 to
+-   VEC7.  */
+-# define REGISTER_SAVE_AREA_RAW	(8 * 7 + VEC_SIZE * 8)
+-#else
+-/* X86-64 saves RCX, RDX, RSI, RDI, R8 and R9 plus RAX as well as
+-   BND0, BND1, BND2, BND3 and VEC0 to VEC7. */
+-# define REGISTER_SAVE_AREA_RAW	(8 * 7 + 16 * 4 + VEC_SIZE * 8)
+-#endif
++	.text
++#ifdef _dl_runtime_resolve
+ 
+-#undef REGISTER_SAVE_AREA
+-#undef LOCAL_STORAGE_AREA
+-#undef BASE
+-#if DL_RUNTIME_RESOLVE_REALIGN_STACK
+-# define REGISTER_SAVE_AREA	(REGISTER_SAVE_AREA_RAW + 8)
+-/* Local stack area before jumping to function address: RBX.  */
+-# define LOCAL_STORAGE_AREA	8
+-# define BASE			rbx
+-# if (REGISTER_SAVE_AREA % VEC_SIZE) != 0
+-#  error REGISTER_SAVE_AREA must be multples of VEC_SIZE
+-# endif
+-#else
+-# define REGISTER_SAVE_AREA	REGISTER_SAVE_AREA_RAW
+-/* Local stack area before jumping to function address:  All saved
+-   registers.  */
+-# define LOCAL_STORAGE_AREA	REGISTER_SAVE_AREA
+-# define BASE			rsp
+-# if (REGISTER_SAVE_AREA % 16) != 8
+-#  error REGISTER_SAVE_AREA must be odd multples of 8
++# undef REGISTER_SAVE_AREA
++# undef LOCAL_STORAGE_AREA
++# undef BASE
++
++# if (STATE_SAVE_ALIGNMENT % 16) != 0
++#  error STATE_SAVE_ALIGNMENT must be multples of 16
+ # endif
+-#endif
+ 
+-	.text
+-#ifdef _dl_runtime_resolve_opt
+-/* Use the smallest vector registers to preserve the full YMM/ZMM
+-   registers to avoid SSE transition penalty.  */
+-
+-# if VEC_SIZE == 32
+-/* Check if the upper 128 bits in %ymm0 - %ymm7 registers are non-zero
+-   and preserve %xmm0 - %xmm7 registers with the zero upper bits.  Since
+-   there is no SSE transition penalty on AVX512 processors which don't
+-   support XGETBV with ECX == 1, _dl_runtime_resolve_avx512_slow isn't
+-   provided.   */
+-	.globl _dl_runtime_resolve_avx_slow
+-	.hidden _dl_runtime_resolve_avx_slow
+-	.type _dl_runtime_resolve_avx_slow, @function
+-	.align 16
+-_dl_runtime_resolve_avx_slow:
+-	cfi_startproc
+-	cfi_adjust_cfa_offset(16) # Incorporate PLT
+-	vorpd %ymm0, %ymm1, %ymm8
+-	vorpd %ymm2, %ymm3, %ymm9
+-	vorpd %ymm4, %ymm5, %ymm10
+-	vorpd %ymm6, %ymm7, %ymm11
+-	vorpd %ymm8, %ymm9, %ymm9
+-	vorpd %ymm10, %ymm11, %ymm10
+-	vpcmpeqd %xmm8, %xmm8, %xmm8
+-	vorpd %ymm9, %ymm10, %ymm10
+-	vptest %ymm10, %ymm8
+-	# Preserve %ymm0 - %ymm7 registers if the upper 128 bits of any
+-	# %ymm0 - %ymm7 registers aren't zero.
+-	PRESERVE_BND_REGS_PREFIX
+-	jnc _dl_runtime_resolve_avx
+-	# Use vzeroupper to avoid SSE transition penalty.
+-	vzeroupper
+-	# Preserve %xmm0 - %xmm7 registers with the zero upper 128 bits
+-	# when the upper 128 bits of %ymm0 - %ymm7 registers are zero.
+-	PRESERVE_BND_REGS_PREFIX
+-	jmp _dl_runtime_resolve_sse_vex
+-	cfi_adjust_cfa_offset(-16) # Restore PLT adjustment
+-	cfi_endproc
+-	.size _dl_runtime_resolve_avx_slow, .-_dl_runtime_resolve_avx_slow
++# if (STATE_SAVE_OFFSET % STATE_SAVE_ALIGNMENT) != 0
++#  error STATE_SAVE_OFFSET must be multples of STATE_SAVE_ALIGNMENT
+ # endif
+ 
+-/* Use XGETBV with ECX == 1 to check which bits in vector registers are
+-   non-zero and only preserve the non-zero lower bits with zero upper
+-   bits.  */
+-	.globl _dl_runtime_resolve_opt
+-	.hidden _dl_runtime_resolve_opt
+-	.type _dl_runtime_resolve_opt, @function
+-	.align 16
+-_dl_runtime_resolve_opt:
+-	cfi_startproc
+-	cfi_adjust_cfa_offset(16) # Incorporate PLT
+-	pushq %rax
+-	cfi_adjust_cfa_offset(8)
+-	cfi_rel_offset(%rax, 0)
+-	pushq %rcx
+-	cfi_adjust_cfa_offset(8)
+-	cfi_rel_offset(%rcx, 0)
+-	pushq %rdx
+-	cfi_adjust_cfa_offset(8)
+-	cfi_rel_offset(%rdx, 0)
+-	movl $1, %ecx
+-	xgetbv
+-	movl %eax, %r11d
+-	popq %rdx
+-	cfi_adjust_cfa_offset(-8)
+-	cfi_restore (%rdx)
+-	popq %rcx
+-	cfi_adjust_cfa_offset(-8)
+-	cfi_restore (%rcx)
+-	popq %rax
+-	cfi_adjust_cfa_offset(-8)
+-	cfi_restore (%rax)
+-# if VEC_SIZE == 32
+-	# For YMM registers, check if YMM state is in use.
+-	andl $bit_YMM_state, %r11d
+-	# Preserve %xmm0 - %xmm7 registers with the zero upper 128 bits if
+-	# YMM state isn't in use.
+-	PRESERVE_BND_REGS_PREFIX
+-	jz _dl_runtime_resolve_sse_vex
+-# elif VEC_SIZE == 16
+-	# For ZMM registers, check if YMM state and ZMM state are in
+-	# use.
+-	andl $(bit_YMM_state | bit_ZMM0_15_state), %r11d
+-	cmpl $bit_YMM_state, %r11d
+-	# Preserve %zmm0 - %zmm7 registers if ZMM state is in use.
+-	PRESERVE_BND_REGS_PREFIX
+-	jg _dl_runtime_resolve_avx512
+-	# Preserve %ymm0 - %ymm7 registers with the zero upper 256 bits if
+-	# ZMM state isn't in use.
+-	PRESERVE_BND_REGS_PREFIX
+-	je _dl_runtime_resolve_avx
+-	# Preserve %xmm0 - %xmm7 registers with the zero upper 384 bits if
+-	# neither YMM state nor ZMM state are in use.
++# if DL_RUNTIME_RESOLVE_REALIGN_STACK
++/* Local stack area before jumping to function address: RBX.  */
++#  define LOCAL_STORAGE_AREA	8
++#  define BASE			rbx
++#  ifdef USE_FXSAVE
++/* Use fxsave to save XMM registers.  */
++#   define REGISTER_SAVE_AREA	(512 + STATE_SAVE_OFFSET)
++#   if (REGISTER_SAVE_AREA % 16) != 0
++#    error REGISTER_SAVE_AREA must be multples of 16
++#   endif
++#  endif
+ # else
+-#  error Unsupported VEC_SIZE!
++#  ifndef USE_FXSAVE
++#   error USE_FXSAVE must be defined
++#  endif
++/* Use fxsave to save XMM registers.  */
++#  define REGISTER_SAVE_AREA	(512 + STATE_SAVE_OFFSET + 8)
++/* Local stack area before jumping to function address:  All saved
++   registers.  */
++#  define LOCAL_STORAGE_AREA	REGISTER_SAVE_AREA
++#  define BASE			rsp
++#  if (REGISTER_SAVE_AREA % 16) != 8
++#   error REGISTER_SAVE_AREA must be odd multples of 8
++#  endif
+ # endif
+-	cfi_adjust_cfa_offset(-16) # Restore PLT adjustment
+-	cfi_endproc
+-	.size _dl_runtime_resolve_opt, .-_dl_runtime_resolve_opt
+-#endif
++
+ 	.globl _dl_runtime_resolve
+ 	.hidden _dl_runtime_resolve
+ 	.type _dl_runtime_resolve, @function
+@@ -157,21 +64,30 @@ _dl_runtime_resolve_opt:
+ 	cfi_startproc
+ _dl_runtime_resolve:
+ 	cfi_adjust_cfa_offset(16) # Incorporate PLT
+-#if DL_RUNTIME_RESOLVE_REALIGN_STACK
+-# if LOCAL_STORAGE_AREA != 8
+-#  error LOCAL_STORAGE_AREA must be 8
+-# endif
++# if DL_RUNTIME_RESOLVE_REALIGN_STACK
++#  if LOCAL_STORAGE_AREA != 8
++#   error LOCAL_STORAGE_AREA must be 8
++#  endif
+ 	pushq %rbx			# push subtracts stack by 8.
+ 	cfi_adjust_cfa_offset(8)
+ 	cfi_rel_offset(%rbx, 0)
+ 	mov %RSP_LP, %RBX_LP
+ 	cfi_def_cfa_register(%rbx)
+-	and $-VEC_SIZE, %RSP_LP
+-#endif
++	and $-STATE_SAVE_ALIGNMENT, %RSP_LP
++# endif
++# ifdef REGISTER_SAVE_AREA
+ 	sub $REGISTER_SAVE_AREA, %RSP_LP
+-#if !DL_RUNTIME_RESOLVE_REALIGN_STACK
++#  if !DL_RUNTIME_RESOLVE_REALIGN_STACK
+ 	cfi_adjust_cfa_offset(REGISTER_SAVE_AREA)
+-#endif
++#  endif
++# else
++	# Allocate stack space of the required size to save the state.
++#  if IS_IN (rtld)
++	sub _rtld_local_ro+RTLD_GLOBAL_RO_DL_X86_CPU_FEATURES_OFFSET+XSAVE_STATE_SIZE_OFFSET(%rip), %RSP_LP
++#  else
++	sub _dl_x86_cpu_features+XSAVE_STATE_SIZE_OFFSET(%rip), %RSP_LP
++#  endif
++# endif
+ 	# Preserve registers otherwise clobbered.
+ 	movq %rax, REGISTER_SAVE_RAX(%rsp)
+ 	movq %rcx, REGISTER_SAVE_RCX(%rsp)
+@@ -180,59 +96,42 @@ _dl_runtime_resolve:
+ 	movq %rdi, REGISTER_SAVE_RDI(%rsp)
+ 	movq %r8, REGISTER_SAVE_R8(%rsp)
+ 	movq %r9, REGISTER_SAVE_R9(%rsp)
+-	VMOV %VEC(0), (REGISTER_SAVE_VEC_OFF)(%rsp)
+-	VMOV %VEC(1), (REGISTER_SAVE_VEC_OFF + VEC_SIZE)(%rsp)
+-	VMOV %VEC(2), (REGISTER_SAVE_VEC_OFF + VEC_SIZE * 2)(%rsp)
+-	VMOV %VEC(3), (REGISTER_SAVE_VEC_OFF + VEC_SIZE * 3)(%rsp)
+-	VMOV %VEC(4), (REGISTER_SAVE_VEC_OFF + VEC_SIZE * 4)(%rsp)
+-	VMOV %VEC(5), (REGISTER_SAVE_VEC_OFF + VEC_SIZE * 5)(%rsp)
+-	VMOV %VEC(6), (REGISTER_SAVE_VEC_OFF + VEC_SIZE * 6)(%rsp)
+-	VMOV %VEC(7), (REGISTER_SAVE_VEC_OFF + VEC_SIZE * 7)(%rsp)
+-#ifndef __ILP32__
+-	# We also have to preserve bound registers.  These are nops if
+-	# Intel MPX isn't available or disabled.
+-# ifdef HAVE_MPX_SUPPORT
+-	bndmov %bnd0, REGISTER_SAVE_BND0(%rsp)
+-	bndmov %bnd1, REGISTER_SAVE_BND1(%rsp)
+-	bndmov %bnd2, REGISTER_SAVE_BND2(%rsp)
+-	bndmov %bnd3, REGISTER_SAVE_BND3(%rsp)
++# ifdef USE_FXSAVE
++	fxsave STATE_SAVE_OFFSET(%rsp)
+ # else
+-#  if REGISTER_SAVE_BND0 == 0
+-	.byte 0x66,0x0f,0x1b,0x04,0x24
++	movl $STATE_SAVE_MASK, %eax
++	xorl %edx, %edx
++	# Clear the XSAVE Header.
++#  ifdef USE_XSAVE
++	movq %rdx, (STATE_SAVE_OFFSET + 512)(%rsp)
++	movq %rdx, (STATE_SAVE_OFFSET + 512 + 8)(%rsp)
++#  endif
++	movq %rdx, (STATE_SAVE_OFFSET + 512 + 8 * 2)(%rsp)
++	movq %rdx, (STATE_SAVE_OFFSET + 512 + 8 * 3)(%rsp)
++	movq %rdx, (STATE_SAVE_OFFSET + 512 + 8 * 4)(%rsp)
++	movq %rdx, (STATE_SAVE_OFFSET + 512 + 8 * 5)(%rsp)
++	movq %rdx, (STATE_SAVE_OFFSET + 512 + 8 * 6)(%rsp)
++	movq %rdx, (STATE_SAVE_OFFSET + 512 + 8 * 7)(%rsp)
++#  ifdef USE_XSAVE
++	xsave STATE_SAVE_OFFSET(%rsp)
+ #  else
+-	.byte 0x66,0x0f,0x1b,0x44,0x24,REGISTER_SAVE_BND0
++	xsavec STATE_SAVE_OFFSET(%rsp)
+ #  endif
+-	.byte 0x66,0x0f,0x1b,0x4c,0x24,REGISTER_SAVE_BND1
+-	.byte 0x66,0x0f,0x1b,0x54,0x24,REGISTER_SAVE_BND2
+-	.byte 0x66,0x0f,0x1b,0x5c,0x24,REGISTER_SAVE_BND3
+ # endif
+-#endif
+ 	# Copy args pushed by PLT in register.
+ 	# %rdi: link_map, %rsi: reloc_index
+ 	mov (LOCAL_STORAGE_AREA + 8)(%BASE), %RSI_LP
+ 	mov LOCAL_STORAGE_AREA(%BASE), %RDI_LP
+ 	call _dl_fixup		# Call resolver.
+ 	mov %RAX_LP, %R11_LP	# Save return value
+-#ifndef __ILP32__
+-	# Restore bound registers.  These are nops if Intel MPX isn't
+-	# avaiable or disabled.
+-# ifdef HAVE_MPX_SUPPORT
+-	bndmov REGISTER_SAVE_BND3(%rsp), %bnd3
+-	bndmov REGISTER_SAVE_BND2(%rsp), %bnd2
+-	bndmov REGISTER_SAVE_BND1(%rsp), %bnd1
+-	bndmov REGISTER_SAVE_BND0(%rsp), %bnd0
++	# Get register content back.
++# ifdef USE_FXSAVE
++	fxrstor STATE_SAVE_OFFSET(%rsp)
+ # else
+-	.byte 0x66,0x0f,0x1a,0x5c,0x24,REGISTER_SAVE_BND3
+-	.byte 0x66,0x0f,0x1a,0x54,0x24,REGISTER_SAVE_BND2
+-	.byte 0x66,0x0f,0x1a,0x4c,0x24,REGISTER_SAVE_BND1
+-#  if REGISTER_SAVE_BND0 == 0
+-	.byte 0x66,0x0f,0x1a,0x04,0x24
+-#  else
+-	.byte 0x66,0x0f,0x1a,0x44,0x24,REGISTER_SAVE_BND0
+-#  endif
++	movl $STATE_SAVE_MASK, %eax
++	xorl %edx, %edx
++	xrstor STATE_SAVE_OFFSET(%rsp)
+ # endif
+-#endif
+-	# Get register content back.
+ 	movq REGISTER_SAVE_R9(%rsp), %r9
+ 	movq REGISTER_SAVE_R8(%rsp), %r8
+ 	movq REGISTER_SAVE_RDI(%rsp), %rdi
+@@ -240,20 +139,12 @@ _dl_runtime_resolve:
+ 	movq REGISTER_SAVE_RDX(%rsp), %rdx
+ 	movq REGISTER_SAVE_RCX(%rsp), %rcx
+ 	movq REGISTER_SAVE_RAX(%rsp), %rax
+-	VMOV (REGISTER_SAVE_VEC_OFF)(%rsp), %VEC(0)
+-	VMOV (REGISTER_SAVE_VEC_OFF + VEC_SIZE)(%rsp), %VEC(1)
+-	VMOV (REGISTER_SAVE_VEC_OFF + VEC_SIZE * 2)(%rsp), %VEC(2)
+-	VMOV (REGISTER_SAVE_VEC_OFF + VEC_SIZE * 3)(%rsp), %VEC(3)
+-	VMOV (REGISTER_SAVE_VEC_OFF + VEC_SIZE * 4)(%rsp), %VEC(4)
+-	VMOV (REGISTER_SAVE_VEC_OFF + VEC_SIZE * 5)(%rsp), %VEC(5)
+-	VMOV (REGISTER_SAVE_VEC_OFF + VEC_SIZE * 6)(%rsp), %VEC(6)
+-	VMOV (REGISTER_SAVE_VEC_OFF + VEC_SIZE * 7)(%rsp), %VEC(7)
+-#if DL_RUNTIME_RESOLVE_REALIGN_STACK
++# if DL_RUNTIME_RESOLVE_REALIGN_STACK
+ 	mov %RBX_LP, %RSP_LP
+ 	cfi_def_cfa_register(%rsp)
+ 	movq (%rsp), %rbx
+ 	cfi_restore(%rbx)
+-#endif
++# endif
+ 	# Adjust stack(PLT did 2 pushes)
+ 	add $(LOCAL_STORAGE_AREA + 16), %RSP_LP
+ 	cfi_adjust_cfa_offset(-(LOCAL_STORAGE_AREA + 16))
+@@ -262,11 +153,9 @@ _dl_runtime_resolve:
+ 	jmp *%r11		# Jump to function address.
+ 	cfi_endproc
+ 	.size _dl_runtime_resolve, .-_dl_runtime_resolve
++#endif
+ 
+ 
+-/* To preserve %xmm0 - %xmm7 registers, dl-trampoline.h is included
+-   twice, for _dl_runtime_resolve_sse and _dl_runtime_resolve_sse_vex.
+-   But we don't need another _dl_runtime_profile for XMM registers.  */
+ #if !defined PROF && defined _dl_runtime_profile
+ # if (LR_VECTOR_OFFSET % VEC_SIZE) != 0
+ #  error LR_VECTOR_OFFSET must be multples of VEC_SIZE
diff --git a/gnu/packages/patches/glibc-2-26-0069.patch b/gnu/packages/patches/glibc-2-26-0069.patch
new file mode 100644
index 000000000..04cb67f00
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0069.patch
@@ -0,0 +1,81 @@
+From f8279a4b3cc66d3ec8bfb8519e9987b8f7727f53 Mon Sep 17 00:00:00 2001
+From: Romain Naour <romain.naour@gmail.com>
+Date: Mon, 16 Oct 2017 23:21:56 +0200
+Subject: [PATCH 69/90] Let signbit use the builtin in C++ mode with gcc < 6.x
+ (bug 22296)
+
+When using gcc < 6.x, signbit does not use the type-generic
+__builtin_signbit builtin, instead it uses __MATH_TG.
+However, when library support for float128 is available, __MATH_TG uses
+__builtin_types_compatible_p, which is not available in C++ mode.
+
+On the other hand, libstdc++ undefines (in cmath) many macros from
+math.h, including signbit, so that it can provide its own functions.
+However, during its configure tests, libstdc++ just tests for the
+availability of the macros (it does not undefine them, nor does it
+provide its own functions).
+
+Finally, libstdc++ configure tests include math.h and get the definition
+of signbit that uses __MATH_TG (and __builtin_types_compatible_p).
+Since libstdc++ does not undefine the macros during its configure
+tests, they fail.
+
+This patch lets signbit use the builtin in C++ mode when gcc < 6.x is
+used. This allows the configure test in libstdc++ to work.
+
+Tested for x86_64.
+
+	[BZ #22296]
+	* math/math.h: Let signbit use the builtin in C++ mode with gcc
+	< 6.x
+
+Cc: Gabriel F. T. Gomes <gftg@linux.vnet.ibm.com>
+Cc: Joseph Myers <joseph@codesourcery.com>
+(cherry picked from commit 386e1c26ac473d6863133ab9cbe3bbda16c15816)
+
+diff --git a/ChangeLog b/ChangeLog
+index cd598788f1..6e53277670 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-10-17  Romain Naour  <romain.naour@gmail.com>  (tiny change)
++
++	[BZ #22296]
++	* math/math.h: Let signbit use the builtin in C++ mode with gcc
++	< 6.x
++
+ 2017-10-22  H.J. Lu  <hongjiu.lu@intel.com>
+ 
+ 	[BZ #21265]
+diff --git a/NEWS b/NEWS
+index 87d48025e2..c92ec03617 100644
+--- a/NEWS
++++ b/NEWS
+@@ -45,6 +45,7 @@ The following bugs are resolved with this release:
+   [22146] Let fpclassify use the builtin when optimizing for size in C++ mode
+   [22225] math: nearbyint arithmetic moved before feholdexcept
+   [22235] Add C++ versions of iscanonical for ldbl-96 and ldbl-128ibm
++  [22296] Let signbit use the builtin in C++ mode with gcc < 6.x
+   [22321] sysconf: Fix missing definition of UIO_MAXIOV on Linux
+   [22325] glibc: Memory leak in glob with GLOB_TILDE (CVE-2017-15671)
+ \f
+diff --git a/math/math.h b/math/math.h
+index 2b216c6da1..ba26624835 100644
+--- a/math/math.h
++++ b/math/math.h
+@@ -418,6 +418,15 @@ enum
+ /* Return nonzero value if sign of X is negative.  */
+ # if __GNUC_PREREQ (6,0)
+ #  define signbit(x) __builtin_signbit (x)
++# elif defined __cplusplus
++  /* In C++ mode, __MATH_TG cannot be used, because it relies on
++     __builtin_types_compatible_p, which is a C-only builtin.
++     The check for __cplusplus allows the use of the builtin instead of
++     __MATH_TG. This is provided for libstdc++, only to let its configure
++     test work. No further use of this definition of signbit is expected
++     in C++ mode, since libstdc++ provides its own version of signbit
++     in cmath (which undefines signbit). */
++#  define signbit(x) __builtin_signbitl (x)
+ # elif __GNUC_PREREQ (4,0)
+ #  define signbit(x) __MATH_TG ((x), __builtin_signbit, (x))
+ # else
diff --git a/gnu/packages/patches/glibc-2-26-0070.patch b/gnu/packages/patches/glibc-2-26-0070.patch
new file mode 100644
index 000000000..157307029
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0070.patch
@@ -0,0 +1,26 @@
+From b1b8d8aa95a055dc7929259679a995189d444809 Mon Sep 17 00:00:00 2001
+From: "Gabriel F. T. Gomes" <gabriel@inconstante.eti.br>
+Date: Fri, 20 Oct 2017 16:06:19 -0200
+Subject: [PATCH 70/90] Add missing bug fixes to NEWS
+
+
+diff --git a/NEWS b/NEWS
+index c92ec03617..bf4fd66c82 100644
+--- a/NEWS
++++ b/NEWS
+@@ -36,6 +36,7 @@ The following bugs are resolved with this release:
+   [21972] assert macro requires operator== (int) for its argument type
+   [21982] string: stratcliff.c: error: assuming signed overflow does not
+     occur with -O3
++  [21987] Fix sparc32 bits/long-double.h
+   [22051] libc: zero terminator in the middle of glibc's .eh_frame
+   [22078] nss_files performance issue in hosts multi mode
+   [22093] x86: Add x86_64 to x86-64 HWCAP
+@@ -46,6 +47,7 @@ The following bugs are resolved with this release:
+   [22225] math: nearbyint arithmetic moved before feholdexcept
+   [22235] Add C++ versions of iscanonical for ldbl-96 and ldbl-128ibm
+   [22296] Let signbit use the builtin in C++ mode with gcc < 6.x
++  [22320] glob: Fix one-byte overflow (CVE-2017-15670)
+   [22321] sysconf: Fix missing definition of UIO_MAXIOV on Linux
+   [22325] glibc: Memory leak in glob with GLOB_TILDE (CVE-2017-15671)
+ \f
diff --git a/gnu/packages/patches/glibc-2-26-0071.patch b/gnu/packages/patches/glibc-2-26-0071.patch
new file mode 100644
index 000000000..5cf177e9a
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0071.patch
@@ -0,0 +1,60 @@
+From 04acd597943e90147e4bc139911564788e04ae51 Mon Sep 17 00:00:00 2001
+From: Joseph Myers <joseph@codesourcery.com>
+Date: Thu, 19 Oct 2017 17:32:20 +0000
+Subject: [PATCH 71/90] Install correct bits/long-double.h for MIPS64 (bug
+ 22322).
+
+Similar to bug 21987 for SPARC, MIPS64 wrongly installs the ldbl-128
+version of bits/long-double.h, meaning incorrect results when using
+headers installed from a 64-bit installation for a 32-bit build.  (I
+haven't actually seen this cause build failures before its interaction
+with bits/floatn.h did so - installed headers wrongly expecting
+_Float128 to be available in a 32-bit configuration.)
+
+This patch fixes the bug by moving the MIPS header to
+sysdeps/mips/ieee754, which comes before sysdeps/ieee754/ldbl-128 in
+the sysdeps directory ordering.  (bits/floatn.h will need a similar
+fix - duplicating the ldbl-128 version for MIPS will suffice - for
+headers from a 32-bit installation to be correct for 64-bit builds.)
+
+Tested with build-many-glibcs.py (compilers build for
+mips64-linux-gnu, where there was previously a libstdc++ build failure
+as at
+<https://sourceware.org/ml/libc-testresults/2017-q4/msg00130.html>).
+
+	[BZ #22322]
+	* sysdeps/mips/bits/long-double.h: Move to ....
+	* sysdeps/mips/ieee754/bits/long-double.h: ... here.
+
+(cherry picked from commit 37bb78cb8c1fb6b5813407c8856b1557359e6343)
+
+diff --git a/ChangeLog b/ChangeLog
+index 6e53277670..7a3bcf7de0 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-10-19  Joseph Myers  <joseph@codesourcery.com>
++
++	[BZ #22322]
++	* sysdeps/mips/bits/long-double.h: Move to ....
++	* sysdeps/mips/ieee754/bits/long-double.h: ... here.
++
+ 2017-10-17  Romain Naour  <romain.naour@gmail.com>  (tiny change)
+ 
+ 	[BZ #22296]
+diff --git a/NEWS b/NEWS
+index bf4fd66c82..cd6636d0e0 100644
+--- a/NEWS
++++ b/NEWS
+@@ -49,6 +49,7 @@ The following bugs are resolved with this release:
+   [22296] Let signbit use the builtin in C++ mode with gcc < 6.x
+   [22320] glob: Fix one-byte overflow (CVE-2017-15670)
+   [22321] sysconf: Fix missing definition of UIO_MAXIOV on Linux
++  [22322] libc: [mips64] wrong bits/long-double.h installed
+   [22325] glibc: Memory leak in glob with GLOB_TILDE (CVE-2017-15671)
+ \f
+ Version 2.26
+diff --git a/sysdeps/mips/bits/long-double.h b/sysdeps/mips/ieee754/bits/long-double.h
+similarity index 100%
+rename from sysdeps/mips/bits/long-double.h
+rename to sysdeps/mips/ieee754/bits/long-double.h
diff --git a/gnu/packages/patches/glibc-2-26-0072.patch b/gnu/packages/patches/glibc-2-26-0072.patch
new file mode 100644
index 000000000..bab52ea57
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0072.patch
@@ -0,0 +1,135 @@
+From 77eea8950ce5495ff033bca3465ccfd2db072ae6 Mon Sep 17 00:00:00 2001
+From: Alexey Makhalov <amakhalov@vmware.com>
+Date: Wed, 27 Sep 2017 02:44:09 +0530
+Subject: [PATCH 72/90] Fix range check in do_tunable_update_val
+
+Current implementation of tunables does not set arena_max and arena_test
+values. Any value provided by glibc.malloc.arena_max and
+glibc.malloc.arena_test parameters is ignored.
+
+These tunables have minval value set to 1 (see elf/dl-tunables.list file)
+and undefined maxval value. In that case default value (which is 0. see
+scripts/gen-tunables.awk) is being used to set maxval.
+
+For instance, generated tunable_list[] entry for arena_max is:
+(gdb) p *cur
+$1 = {name = 0x7ffff7df6217 "glibc.malloc.arena_max",
+ type = {type_code = TUNABLE_TYPE_SIZE_T, min = 1, max = 0},
+  val = {numval = 0, strval = 0x0}, initialized = false,
+   security_level = TUNABLE_SECLEVEL_SXID_IGNORE,
+    env_alias = 0x7ffff7df622e "MALLOC_ARENA_MAX"}
+
+As a result, any value of glibc.malloc.arena_max is ignored by
+TUNABLE_SET_VAL_IF_VALID_RANGE macro
+  __type min = (__cur)->type.min;                    <- initialized to 1
+  __type max = (__cur)->type.max;                    <- initialized to 0!
+  if (min == max)                                    <- false
+    {
+      min = __default_min;
+      max = __default_max;
+    }
+  if ((__type) (__val) >= min && (__type) (val) <= max)  <- false
+    {
+      (__cur)->val.numval = val;
+      (__cur)->initialized = true;
+    }
+
+Assigning correct min/max values at a build time fixes a problem.
+Plus, a bit of optimization: Setting of default min/max values for the
+given type at a run time might be eliminated.
+
+	* elf/dl-tunables.c (do_tunable_update_val): Range checking fix.
+	* scripts/gen-tunables.awk: Set unspecified minval and/or maxval
+	values to correct default value for given type.
+
+diff --git a/ChangeLog b/ChangeLog
+index 7a3bcf7de0..366eaba804 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-10-23  Alexey Makhalov  <amakhalov@vmware.com>
++
++	* elf/dl-tunables.c (do_tunable_update_val): Range checking fix.
++	* scripts/gen-tunables.awk: Set unspecified minval and/or maxval
++	values to correct default value for given type.
++
+ 2017-10-19  Joseph Myers  <joseph@codesourcery.com>
+ 
+ 	[BZ #22322]
+diff --git a/elf/dl-tunables.c b/elf/dl-tunables.c
+index 231fb8ca93..d9975ef2d0 100644
+--- a/elf/dl-tunables.c
++++ b/elf/dl-tunables.c
+@@ -88,18 +88,11 @@ get_next_env (char **envp, char **name, size_t *namelen, char **val,
+   return NULL;
+ }
+ 
+-#define TUNABLE_SET_VAL_IF_VALID_RANGE(__cur, __val, __type, __default_min, \
+-				       __default_max)			      \
++#define TUNABLE_SET_VAL_IF_VALID_RANGE(__cur, __val, __type)		      \
+ ({									      \
+   __type min = (__cur)->type.min;					      \
+   __type max = (__cur)->type.max;					      \
+ 									      \
+-  if (min == max)							      \
+-    {									      \
+-      min = __default_min;						      \
+-      max = __default_max;						      \
+-    }									      \
+-									      \
+   if ((__type) (__val) >= min && (__type) (val) <= max)			      \
+     {									      \
+       (__cur)->val.numval = val;					      \
+@@ -119,17 +112,17 @@ do_tunable_update_val (tunable_t *cur, const void *valp)
+     {
+     case TUNABLE_TYPE_INT_32:
+ 	{
+-	  TUNABLE_SET_VAL_IF_VALID_RANGE (cur, val, int64_t, INT32_MIN, INT32_MAX);
++	  TUNABLE_SET_VAL_IF_VALID_RANGE (cur, val, int64_t);
+ 	  break;
+ 	}
+     case TUNABLE_TYPE_UINT_64:
+ 	{
+-	  TUNABLE_SET_VAL_IF_VALID_RANGE (cur, val, uint64_t, 0, UINT64_MAX);
++	  TUNABLE_SET_VAL_IF_VALID_RANGE (cur, val, uint64_t);
+ 	  break;
+ 	}
+     case TUNABLE_TYPE_SIZE_T:
+ 	{
+-	  TUNABLE_SET_VAL_IF_VALID_RANGE (cur, val, uint64_t, 0, SIZE_MAX);
++	  TUNABLE_SET_VAL_IF_VALID_RANGE (cur, val, uint64_t);
+ 	  break;
+ 	}
+     case TUNABLE_TYPE_STRING:
+diff --git a/scripts/gen-tunables.awk b/scripts/gen-tunables.awk
+index ccdd0c6c71..622199061a 100644
+--- a/scripts/gen-tunables.awk
++++ b/scripts/gen-tunables.awk
+@@ -1,6 +1,14 @@
+ # Generate dl-tunable-list.h from dl-tunables.list
+ 
+ BEGIN {
++  min_of["STRING"]="0"
++  max_of["STRING"]="0"
++  min_of["INT_32"]="INT32_MIN"
++  max_of["INT_32"]="INT32_MAX"
++  min_of["UINT_64"]="0"
++  max_of["UINT_64"]="UINT64_MAX"
++  min_of["SIZE_T"]="0"
++  max_of["SIZE_T"]="SIZE_MAX"
+   tunable=""
+   ns=""
+   top_ns=""
+@@ -43,10 +51,10 @@ $1 == "}" {
+       types[top_ns,ns,tunable] = "STRING"
+     }
+     if (!minvals[top_ns,ns,tunable]) {
+-      minvals[top_ns,ns,tunable] = "0"
++      minvals[top_ns,ns,tunable] = min_of[types[top_ns,ns,tunable]]
+     }
+     if (!maxvals[top_ns,ns,tunable]) {
+-      maxvals[top_ns,ns,tunable] = "0"
++      maxvals[top_ns,ns,tunable] = max_of[types[top_ns,ns,tunable]]
+     }
+     if (!env_alias[top_ns,ns,tunable]) {
+       env_alias[top_ns,ns,tunable] = "NULL"
diff --git a/gnu/packages/patches/glibc-2-26-0073.patch b/gnu/packages/patches/glibc-2-26-0073.patch
new file mode 100644
index 000000000..bac08008f
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0073.patch
@@ -0,0 +1,247 @@
+From 4b692dffb95ac4812b161eb6a16113d7e824982e Mon Sep 17 00:00:00 2001
+From: "H.J. Lu" <hjl.tools@gmail.com>
+Date: Thu, 19 Oct 2017 08:28:09 -0700
+Subject: [PATCH 73/90] x86-64: Don't set GLRO(dl_platform) to NULL [BZ #22299]
+
+Since ld.so expands $PLATFORM with GLRO(dl_platform), don't set
+GLRO(dl_platform) to NULL.
+
+	[BZ #22299]
+	* sysdeps/x86/cpu-features.c (init_cpu_features): Don't set
+	GLRO(dl_platform) to NULL.
+	* sysdeps/x86_64/Makefile (tests): Add tst-platform-1.
+	(modules-names): Add tst-platformmod-1 and
+	x86_64/tst-platformmod-2.
+	(CFLAGS-tst-platform-1.c): New.
+	(CFLAGS-tst-platformmod-1.c): Likewise.
+	(CFLAGS-tst-platformmod-2.c): Likewise.
+	(LDFLAGS-tst-platformmod-2.so): Likewise.
+	($(objpfx)tst-platform-1): Likewise.
+	($(objpfx)tst-platform-1.out): Likewise.
+	(tst-platform-1-ENV): Likewise.
+	($(objpfx)x86_64/tst-platformmod-2.os): Likewise.
+	* sysdeps/x86_64/tst-platform-1.c: New file.
+	* sysdeps/x86_64/tst-platformmod-1.c: Likewise.
+	* sysdeps/x86_64/tst-platformmod-2.c: Likewise.
+
+(cherry picked from commit 4d916f0f12b230f49967797f98b2b613c734a047)
+
+diff --git a/ChangeLog b/ChangeLog
+index 366eaba804..26ebb2e7c9 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,24 @@
++2017-10-26  Valery Reznic <valery_reznic@yahoo.com>
++	    H.J. Lu  <hongjiu.lu@intel.com>
++
++	[BZ #22299]
++	* sysdeps/x86/cpu-features.c (init_cpu_features): Don't set
++	GLRO(dl_platform) to NULL.
++	* sysdeps/x86_64/Makefile (tests): Add tst-platform-1.
++	(modules-names): Add tst-platformmod-1 and
++	x86_64/tst-platformmod-2.
++	(CFLAGS-tst-platform-1.c): New.
++	(CFLAGS-tst-platformmod-1.c): Likewise.
++	(CFLAGS-tst-platformmod-2.c): Likewise.
++	(LDFLAGS-tst-platformmod-2.so): Likewise.
++	($(objpfx)tst-platform-1): Likewise.
++	($(objpfx)tst-platform-1.out): Likewise.
++	(tst-platform-1-ENV): Likewise.
++	($(objpfx)x86_64/tst-platformmod-2.os): Likewise.
++	* sysdeps/x86_64/tst-platform-1.c: New file.
++	* sysdeps/x86_64/tst-platformmod-1.c: Likewise.
++	* sysdeps/x86_64/tst-platformmod-2.c: Likewise.
++
+ 2017-10-23  Alexey Makhalov  <amakhalov@vmware.com>
+ 
+ 	* elf/dl-tunables.c (do_tunable_update_val): Range checking fix.
+diff --git a/NEWS b/NEWS
+index cd6636d0e0..ea1c1f1c04 100644
+--- a/NEWS
++++ b/NEWS
+@@ -47,6 +47,7 @@ The following bugs are resolved with this release:
+   [22225] math: nearbyint arithmetic moved before feholdexcept
+   [22235] Add C++ versions of iscanonical for ldbl-96 and ldbl-128ibm
+   [22296] Let signbit use the builtin in C++ mode with gcc < 6.x
++  [22299] x86-64: Don't set GLRO(dl_platform) to NULL
+   [22320] glob: Fix one-byte overflow (CVE-2017-15670)
+   [22321] sysconf: Fix missing definition of UIO_MAXIOV on Linux
+   [22322] libc: [mips64] wrong bits/long-double.h installed
+diff --git a/sysdeps/x86/cpu-features.c b/sysdeps/x86/cpu-features.c
+index 3a5c3e8bfd..87aaa8683c 100644
+--- a/sysdeps/x86/cpu-features.c
++++ b/sysdeps/x86/cpu-features.c
+@@ -389,7 +389,6 @@ no_cpuid:
+ #endif
+ 
+   /* Reuse dl_platform, dl_hwcap and dl_hwcap_mask for x86.  */
+-  GLRO(dl_platform) = NULL;
+ #if !HAVE_TUNABLES && defined SHARED
+   /* The glibc.tune.hwcap_mask tunable is initialized already, so no need to do
+      this.  */
+@@ -400,13 +399,15 @@ no_cpuid:
+   GLRO(dl_hwcap) = HWCAP_X86_64;
+   if (cpu_features->kind == arch_kind_intel)
+     {
++      const char *platform = NULL;
++
+       if (CPU_FEATURES_ARCH_P (cpu_features, AVX512F_Usable)
+ 	  && CPU_FEATURES_CPU_P (cpu_features, AVX512CD))
+ 	{
+ 	  if (CPU_FEATURES_CPU_P (cpu_features, AVX512ER))
+ 	    {
+ 	      if (CPU_FEATURES_CPU_P (cpu_features, AVX512PF))
+-		GLRO(dl_platform) = "xeon_phi";
++		platform = "xeon_phi";
+ 	    }
+ 	  else
+ 	    {
+@@ -417,7 +418,7 @@ no_cpuid:
+ 	    }
+ 	}
+ 
+-      if (GLRO(dl_platform) == NULL
++      if (platform == NULL
+ 	  && CPU_FEATURES_ARCH_P (cpu_features, AVX2_Usable)
+ 	  && CPU_FEATURES_ARCH_P (cpu_features, FMA_Usable)
+ 	  && CPU_FEATURES_CPU_P (cpu_features, BMI1)
+@@ -425,7 +426,10 @@ no_cpuid:
+ 	  && CPU_FEATURES_CPU_P (cpu_features, LZCNT)
+ 	  && CPU_FEATURES_CPU_P (cpu_features, MOVBE)
+ 	  && CPU_FEATURES_CPU_P (cpu_features, POPCNT))
+-	GLRO(dl_platform) = "haswell";
++	platform = "haswell";
++
++      if (platform != NULL)
++	GLRO(dl_platform) = platform;
+     }
+ #else
+   GLRO(dl_hwcap) = 0;
+diff --git a/sysdeps/x86_64/Makefile b/sysdeps/x86_64/Makefile
+index cb4e63897c..a7e26ac485 100644
+--- a/sysdeps/x86_64/Makefile
++++ b/sysdeps/x86_64/Makefile
+@@ -62,6 +62,21 @@ endif
+ 
+ $(objpfx)tst-x86_64-1: $(objpfx)x86_64/tst-x86_64mod-1.so
+ 
++ifneq (no,$(have-tunables))
++tests += tst-platform-1
++modules-names += tst-platformmod-1 x86_64/tst-platformmod-2
++CFLAGS-tst-platform-1.c = -mno-avx
++CFLAGS-tst-platformmod-1.c = -mno-avx
++CFLAGS-tst-platformmod-2.c = -mno-avx
++LDFLAGS-tst-platformmod-2.so = -Wl,-soname,tst-platformmod-2.so
++$(objpfx)tst-platform-1: $(objpfx)tst-platformmod-1.so
++$(objpfx)tst-platform-1.out: $(objpfx)x86_64/tst-platformmod-2.so
++# Turn off AVX512F_Usable and AVX2_Usable so that GLRO(dl_platform) is
++# always set to x86_64.
++tst-platform-1-ENV = LD_PRELOAD=$(objpfx)\$$PLATFORM/tst-platformmod-2.so \
++	GLIBC_TUNABLES=glibc.tune.hwcaps=-AVX512F_Usable,-AVX2_Usable
++endif
++
+ tests += tst-audit3 tst-audit4 tst-audit5 tst-audit6 tst-audit7 \
+ 	 tst-audit10 tst-sse tst-avx tst-avx512
+ test-extras += tst-audit4-aux tst-audit10-aux \
+@@ -143,3 +158,8 @@ do-tests-clean common-mostlyclean: tst-x86_64-1-clean
+ .PHONY: tst-x86_64-1-clean
+ tst-x86_64-1-clean:
+ 	-rm -rf $(objpfx)x86_64
++
++$(objpfx)x86_64/tst-platformmod-2.os: $(objpfx)tst-platformmod-2.os
++	$(make-target-directory)
++	rm -f $@
++	ln $< $@
+diff --git a/sysdeps/x86_64/tst-platform-1.c b/sysdeps/x86_64/tst-platform-1.c
+new file mode 100644
+index 0000000000..76a02e4b6d
+--- /dev/null
++++ b/sysdeps/x86_64/tst-platform-1.c
+@@ -0,0 +1,29 @@
++/* Test PRELOAD with $PLATFORM.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#include <stdlib.h>
++
++extern int preload (void);
++
++static int
++do_test (void)
++{
++  return preload () == 0x1234 ? EXIT_SUCCESS : EXIT_FAILURE;
++}
++
++#include <support/test-driver.c>
+diff --git a/sysdeps/x86_64/tst-platformmod-1.c b/sysdeps/x86_64/tst-platformmod-1.c
+new file mode 100644
+index 0000000000..9ef5e2b5be
+--- /dev/null
++++ b/sysdeps/x86_64/tst-platformmod-1.c
+@@ -0,0 +1,23 @@
++/* Test PRELOAD with $PLATFORM.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++int
++preload (void)
++{
++  return 0;
++}
+diff --git a/sysdeps/x86_64/tst-platformmod-2.c b/sysdeps/x86_64/tst-platformmod-2.c
+new file mode 100644
+index 0000000000..d0e5103892
+--- /dev/null
++++ b/sysdeps/x86_64/tst-platformmod-2.c
+@@ -0,0 +1,23 @@
++/* Test PRELOAD with $PLATFORM.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++int
++preload (void)
++{
++  return 0x1234;
++}
diff --git a/gnu/packages/patches/glibc-2-26-0074.patch b/gnu/packages/patches/glibc-2-26-0074.patch
new file mode 100644
index 000000000..91b7ef397
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0074.patch
@@ -0,0 +1,482 @@
+From ee5bce43eb281e85bac7370922e3674e70229c1d Mon Sep 17 00:00:00 2001
+From: Adhemerval Zanella <adhemerval.zanella@linaro.org>
+Date: Mon, 4 Sep 2017 18:07:03 -0300
+Subject: [PATCH 74/90] posix: Consolidate Linux glob implementation
+
+This patch consolidates the glob implementation.  The main changes are:
+
+  * On Linux all implementation now uses the default one at
+    sysdeps/unix/sysv/linux/glob{free}{64}.c with the exception
+    of alpha (which requires specific versioning) and s390-32 (which
+    different than other 32 bits ports it does not add a compat one
+    symbol for 2.1 version).
+
+  * The default implementation uses XSTAT_IS_XSTAT64 to define whether
+    both glob{free} and glob{free}64 should be different implementations.
+    For archictures that define XSTAT_IS_XSTAT64, glob{free} is an alias
+    to glob{free}64.
+
+  * Move i386 olddirent.h header to Linux default directory, since it is
+    the only header with this name and it is shared among different
+    architectures (and used on compat glob symbol as well).
+
+Checked on x86_64-linux-gnu and on a build using build-many-glibcs.py
+for all major architectures.
+
+	* sysdeps/unix/sysv/linux/arm/glob64.c: Remove file.
+	* sysdeps/unix/sysv/linux/i386/glob64.c: Likewise.
+	* sysdeps/unix/sysv/linux/m68k/glob64.c: Likewise.
+	* sysdeps/unix/sysv/linux/mips/mips64/n64/glob64.c: Likewise.
+	* sysdeps/unix/sysv/linux/mips/mips64/n64/globfree64.c: Likewise.
+	* sysdeps/unix/sysv/linux/powerpc/powerpc32/glob64.c: Likewise.
+	* sysdeps/unix/sysv/linux/sparc/sparc32/glob64.c: Likewise.
+	* sysdeps/unix/sysv/linux/wordsize-64/glob64.c: Likewise.
+	* sysdeps/unix/sysv/linux/wordsize-64/globfree64.c: Likewise.
+	* sysdeps/unix/sysv/linux/x86_64/x32/glob.c: Likewise.
+	* sysdeps/unix/sysv/linux/x86_64/x32/globfree.c: Likewise.
+	* sysdeps/wordsize-64/glob.c: Likewise.
+	* sysdeps/wordsize-64/glob64.c: Likewise.
+	* sysdeps/wordsize-64/globfree64.c: Likewise.
+	* sysdeps/unix/sysv/linux/glob.c: New file.
+	* sysdeps/unix/sysv/linux/glob64.c: Likewise.
+	* sysdeps/unix/sysv/linux/globfree.c: Likewise.
+	* sysdeps/unix/sysv/linux/globfree64.c: Likewise.
+	* sysdeps/unix/sysv/linux/s390/s390-32/glob64.c: Likewise.
+	* sysdeps/unix/sysv/linux/oldglob.c [SHLIB_COMPAT]: Also
+	adds !GLOB_NO_OLD_VERSION as an extra condition.
+	* sysdeps/unix/sysv/linux/i386/alphasort64.c: Include olddirent.h
+	using relative path instead of absolute one.
+	* sysdeps/unix/sysv/linux/i386/getdents64.c: Likewise.
+	* sysdeps/unix/sysv/linux/i386/readdir64.c: Likewise.
+	* sysdeps/unix/sysv/linux/i386/readdir64_r.c: Likewise.
+	* sysdeps/unix/sysv/linux/i386/versionsort64.c: Likewise.
+	* sysdeps/unix/sysv/linux/i386/olddirent.h: Move to ...
+	* sysdeps/unix/sysv/linux//olddirent.h: ... here.
+
+(cherry picked from commit 116f1c64d8d84ecbf269ac70a35657aa057f26c3)
+
+diff --git a/ChangeLog b/ChangeLog
+index 26ebb2e7c9..c9b900f4a0 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,36 @@
++2017-09-08  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
++
++	* sysdeps/unix/sysv/linux/arm/glob64.c: Remove file.
++	* sysdeps/unix/sysv/linux/i386/glob64.c: Likewise.
++	* sysdeps/unix/sysv/linux/m68k/glob64.c: Likewise.
++	* sysdeps/unix/sysv/linux/mips/mips64/n64/glob64.c: Likewise.
++	* sysdeps/unix/sysv/linux/mips/mips64/n64/globfree64.c: Likewise.
++	* sysdeps/unix/sysv/linux/powerpc/powerpc32/glob64.c: Likewise.
++	* sysdeps/unix/sysv/linux/sparc/sparc32/glob64.c: Likewise.
++	* sysdeps/unix/sysv/linux/wordsize-64/glob64.c: Likewise.
++	* sysdeps/unix/sysv/linux/wordsize-64/globfree64.c: Likewise.
++	* sysdeps/unix/sysv/linux/x86_64/x32/glob.c: Likewise.
++	* sysdeps/unix/sysv/linux/x86_64/x32/globfree.c: Likewise.
++	* sysdeps/wordsize-64/glob.c: Likewise.
++	* sysdeps/wordsize-64/glob64.c: Likewise.
++	* sysdeps/wordsize-64/globfree.c: Likewise.
++	* sysdeps/wordsize-64/globfree64.c: Likewise.
++	* sysdeps/unix/sysv/linux/glob.c: New file.
++	* sysdeps/unix/sysv/linux/glob64.c: Likewise.
++	* sysdeps/unix/sysv/linux/globfree.c: Likewise.
++	* sysdeps/unix/sysv/linux/globfree64.c: Likewise.
++	* sysdeps/unix/sysv/linux/s390/s390-32/glob64.c: Likewise.
++	* sysdeps/unix/sysv/linux/oldglob.c [SHLIB_COMPAT]: Also
++	adds !GLOB_NO_OLD_VERSION as an extra condition.
++	* sysdeps/unix/sysv/linux/i386/alphasort64.c: Include olddirent.h
++	using relative path instead of absolute one.
++	* sysdeps/unix/sysv/linux/i386/getdents64.c: Likewise.
++	* sysdeps/unix/sysv/linux/i386/readdir64.c: Likewise.
++	* sysdeps/unix/sysv/linux/i386/readdir64_r.c: Likewise.
++	* sysdeps/unix/sysv/linux/i386/versionsort64.c: Likewise.
++	* sysdeps/unix/sysv/linux/i386/olddirent.h: Move to ...
++	* sysdeps/unix/sysv/linux//olddirent.h: ... here.
++
+ 2017-10-26  Valery Reznic <valery_reznic@yahoo.com>
+ 	    H.J. Lu  <hongjiu.lu@intel.com>
+ 
+diff --git a/sysdeps/unix/sysv/linux/arm/glob64.c b/sysdeps/unix/sysv/linux/arm/glob64.c
+deleted file mode 100644
+index 82a9a296a7..0000000000
+--- a/sysdeps/unix/sysv/linux/arm/glob64.c
++++ /dev/null
+@@ -1 +0,0 @@
+-#include <sysdeps/unix/sysv/linux/i386/glob64.c>
+diff --git a/sysdeps/unix/sysv/linux/glob.c b/sysdeps/unix/sysv/linux/glob.c
+new file mode 100644
+index 0000000000..057ae7fe25
+--- /dev/null
++++ b/sysdeps/unix/sysv/linux/glob.c
+@@ -0,0 +1,28 @@
++/* Find pathnames matching a pattern.  Linux version.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#include <sys/stat.h>
++#include <kernel_stat.h>
++
++#define glob64 __no_glob64_decl
++#include <posix/glob.c>
++#undef glob64
++
++#if XSTAT_IS_XSTAT64
++weak_alias (glob, glob64)
++#endif
+diff --git a/sysdeps/unix/sysv/linux/i386/glob64.c b/sysdeps/unix/sysv/linux/glob64.c
+similarity index 57%
+rename from sysdeps/unix/sysv/linux/i386/glob64.c
+rename to sysdeps/unix/sysv/linux/glob64.c
+index 230f9fc037..428bbacb11 100644
+--- a/sysdeps/unix/sysv/linux/i386/glob64.c
++++ b/sysdeps/unix/sysv/linux/glob64.c
+@@ -1,5 +1,5 @@
+-/* Two glob variants with 64-bit support, for dirent64 and __olddirent64.
+-   Copyright (C) 1998-2017 Free Software Foundation, Inc.
++/* Find pathnames matching a pattern.  Linux version.
++   Copyright (C) 2017 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
+@@ -16,27 +16,36 @@
+    License along with the GNU C Library; if not, see
+    <http://www.gnu.org/licenses/>.  */
+ 
+-#include <dirent.h>
+-#include <glob.h>
+ #include <sys/stat.h>
+-#include <shlib-compat.h>
++#include <kernel_stat.h>
+ 
+-#define dirent dirent64
+-#define __readdir(dirp) __readdir64 (dirp)
++#if !XSTAT_IS_XSTAT64
++# include <glob.h>
++# include <dirent.h>
++# include <sys/stat.h>
+ 
+-#define glob_t glob64_t
+-#define glob(pattern, flags, errfunc, pglob) \
++# define dirent dirent64
++# define __readdir(dirp) __readdir64 (dirp)
++
++# define glob_t glob64_t
++# define glob(pattern, flags, errfunc, pglob) \
+   __glob64 (pattern, flags, errfunc, pglob)
+-#define globfree(pglob) globfree64 (pglob)
++# define globfree(pglob) globfree64 (pglob)
++
++# undef stat
++# define stat stat64
+ 
+-#undef stat
+-#define stat stat64
+-#undef __stat
+-#define __stat(file, buf) __xstat64 (_STAT_VER, file, buf)
++# define COMPILE_GLOB64	1
+ 
+-#define COMPILE_GLOB64	1
++# include <posix/glob.c>
+ 
+-#include <posix/glob.c>
++# include "shlib-compat.h"
+ 
++# ifdef GLOB_NO_OLD_VERSION
++strong_alias (__glob64, glob64)
++libc_hidden_def (glob64)
++# else
+ versioned_symbol (libc, __glob64, glob64, GLIBC_2_2);
+ libc_hidden_ver (__glob64, glob64)
++# endif
++#endif /* XSTAT_IS_XSTAT64  */
+diff --git a/sysdeps/unix/sysv/linux/globfree.c b/sysdeps/unix/sysv/linux/globfree.c
+new file mode 100644
+index 0000000000..48d4aec332
+--- /dev/null
++++ b/sysdeps/unix/sysv/linux/globfree.c
+@@ -0,0 +1,30 @@
++/* Frees the dynamically allocated storage from an earlier call to glob.
++   Linux version.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#include <sys/stat.h>
++#include <kernel_stat.h>
++
++#define globfree64 __no_globfree64_decl
++#include <posix/globfree.c>
++#undef globfree64
++
++#if XSTAT_IS_XSTAT64
++weak_alias (globfree, globfree64)
++libc_hidden_ver (globfree, globfree64)
++#endif
+diff --git a/sysdeps/unix/sysv/linux/globfree64.c b/sysdeps/unix/sysv/linux/globfree64.c
+new file mode 100644
+index 0000000000..0020466372
+--- /dev/null
++++ b/sysdeps/unix/sysv/linux/globfree64.c
+@@ -0,0 +1,36 @@
++/* Frees the dynamically allocated storage from an earlier call to glob.
++   Linux version.
++   Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++#include <sys/stat.h>
++#include <kernel_stat.h>
++
++#if !XSTAT_IS_XSTAT64
++
++# include <glob.h>
++
++# define glob_t glob64_t
++# define globfree(pglob) globfree64 (pglob)
++
++# undef stat
++# define stat stat64
++
++# include <posix/globfree.c>
++
++libc_hidden_def (globfree64)
++#endif
+diff --git a/sysdeps/unix/sysv/linux/i386/alphasort64.c b/sysdeps/unix/sysv/linux/i386/alphasort64.c
+index d5fd47a9ae..04b29b6e0e 100644
+--- a/sysdeps/unix/sysv/linux/i386/alphasort64.c
++++ b/sysdeps/unix/sysv/linux/i386/alphasort64.c
+@@ -30,7 +30,7 @@ versioned_symbol (libc, __alphasort64, alphasort64, GLIBC_2_2);
+ 
+ #if SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2)
+ 
+-#include <sysdeps/unix/sysv/linux/i386/olddirent.h>
++#include <olddirent.h>
+ 
+ int
+ __old_alphasort64 (const struct __old_dirent64 **a,
+diff --git a/sysdeps/unix/sysv/linux/i386/getdents64.c b/sysdeps/unix/sysv/linux/i386/getdents64.c
+index e8b257f059..2010bbf8df 100644
+--- a/sysdeps/unix/sysv/linux/i386/getdents64.c
++++ b/sysdeps/unix/sysv/linux/i386/getdents64.c
+@@ -28,7 +28,7 @@
+ 
+ #if SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2)
+ 
+-#include <sysdeps/unix/sysv/linux/i386/olddirent.h>
++#include <olddirent.h>
+ 
+ #define __GETDENTS __old_getdents64
+ #define DIRENT_TYPE struct __old_dirent64
+diff --git a/sysdeps/unix/sysv/linux/i386/readdir64.c b/sysdeps/unix/sysv/linux/i386/readdir64.c
+index f80b6a7ba2..bd2375f9a6 100644
+--- a/sysdeps/unix/sysv/linux/i386/readdir64.c
++++ b/sysdeps/unix/sysv/linux/i386/readdir64.c
+@@ -31,7 +31,7 @@ versioned_symbol (libc, __readdir64, readdir64, GLIBC_2_2);
+ 
+ #if SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2)
+ 
+-#include <sysdeps/unix/sysv/linux/i386/olddirent.h>
++#include <olddirent.h>
+ 
+ #define __READDIR attribute_compat_text_section __old_readdir64
+ #define __GETDENTS __old_getdents64
+diff --git a/sysdeps/unix/sysv/linux/i386/readdir64_r.c b/sysdeps/unix/sysv/linux/i386/readdir64_r.c
+index 344fd53d02..8c0262d1dc 100644
+--- a/sysdeps/unix/sysv/linux/i386/readdir64_r.c
++++ b/sysdeps/unix/sysv/linux/i386/readdir64_r.c
+@@ -31,7 +31,7 @@ versioned_symbol (libc, __readdir64_r, readdir64_r, GLIBC_2_2);
+ 
+ #if SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2)
+ 
+-#include <sysdeps/unix/sysv/linux/i386/olddirent.h>
++#include <olddirent.h>
+ 
+ #define __READDIR_R attribute_compat_text_section __old_readdir64_r
+ #define __GETDENTS __old_getdents64
+diff --git a/sysdeps/unix/sysv/linux/i386/versionsort64.c b/sysdeps/unix/sysv/linux/i386/versionsort64.c
+index 3e1c6ea35b..87f2f9578d 100644
+--- a/sysdeps/unix/sysv/linux/i386/versionsort64.c
++++ b/sysdeps/unix/sysv/linux/i386/versionsort64.c
+@@ -30,7 +30,7 @@ versioned_symbol (libc, __versionsort64, versionsort64, GLIBC_2_2);
+ 
+ #if SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2)
+ 
+-#include <sysdeps/unix/sysv/linux/i386/olddirent.h>
++#include <olddirent.h>
+ 
+ int
+ __old_versionsort64 (const struct __old_dirent64 **a,
+diff --git a/sysdeps/unix/sysv/linux/m68k/glob64.c b/sysdeps/unix/sysv/linux/m68k/glob64.c
+deleted file mode 100644
+index 82a9a296a7..0000000000
+--- a/sysdeps/unix/sysv/linux/m68k/glob64.c
++++ /dev/null
+@@ -1 +0,0 @@
+-#include <sysdeps/unix/sysv/linux/i386/glob64.c>
+diff --git a/sysdeps/unix/sysv/linux/mips/mips64/n64/glob64.c b/sysdeps/unix/sysv/linux/mips/mips64/n64/glob64.c
+deleted file mode 100644
+index 33918ea6a5..0000000000
+--- a/sysdeps/unix/sysv/linux/mips/mips64/n64/glob64.c
++++ /dev/null
+@@ -1 +0,0 @@
+-/* glob64 is in glob.c */
+diff --git a/sysdeps/unix/sysv/linux/mips/mips64/n64/globfree64.c b/sysdeps/unix/sysv/linux/mips/mips64/n64/globfree64.c
+deleted file mode 100644
+index abc35fdd2b..0000000000
+--- a/sysdeps/unix/sysv/linux/mips/mips64/n64/globfree64.c
++++ /dev/null
+@@ -1 +0,0 @@
+-/* glob64 is in globfree64.c */
+diff --git a/sysdeps/unix/sysv/linux/i386/olddirent.h b/sysdeps/unix/sysv/linux/olddirent.h
+similarity index 100%
+rename from sysdeps/unix/sysv/linux/i386/olddirent.h
+rename to sysdeps/unix/sysv/linux/olddirent.h
+diff --git a/sysdeps/unix/sysv/linux/oldglob.c b/sysdeps/unix/sysv/linux/oldglob.c
+index 8233e57ce9..5402450f55 100644
+--- a/sysdeps/unix/sysv/linux/oldglob.c
++++ b/sysdeps/unix/sysv/linux/oldglob.c
+@@ -1,12 +1,13 @@
+ #include <shlib-compat.h>
+ 
+-#if SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2)
++#if SHLIB_COMPAT(libc, GLIBC_2_1, GLIBC_2_2) \
++    && !defined(GLOB_NO_OLD_VERSION)
+ 
+ #include <dirent.h>
+ #include <glob.h>
+ #include <sys/stat.h>
+ 
+-#include <sysdeps/unix/sysv/linux/i386/olddirent.h>
++#include <olddirent.h>
+ 
+ int __old_glob64 (const char *__pattern, int __flags,
+ 		  int (*__errfunc) (const char *, int),
+diff --git a/sysdeps/unix/sysv/linux/powerpc/powerpc32/glob64.c b/sysdeps/unix/sysv/linux/powerpc/powerpc32/glob64.c
+deleted file mode 100644
+index 82a9a296a7..0000000000
+--- a/sysdeps/unix/sysv/linux/powerpc/powerpc32/glob64.c
++++ /dev/null
+@@ -1 +0,0 @@
+-#include <sysdeps/unix/sysv/linux/i386/glob64.c>
+diff --git a/sysdeps/unix/sysv/linux/s390/s390-32/glob64.c b/sysdeps/unix/sysv/linux/s390/s390-32/glob64.c
+new file mode 100644
+index 0000000000..d220e22e30
+--- /dev/null
++++ b/sysdeps/unix/sysv/linux/s390/s390-32/glob64.c
+@@ -0,0 +1,2 @@
++#define GLOB_NO_OLD_VERSION
++#include <sysdeps/unix/sysv/linux/glob64.c>
+diff --git a/sysdeps/unix/sysv/linux/sparc/sparc32/glob64.c b/sysdeps/unix/sysv/linux/sparc/sparc32/glob64.c
+deleted file mode 100644
+index 82a9a296a7..0000000000
+--- a/sysdeps/unix/sysv/linux/sparc/sparc32/glob64.c
++++ /dev/null
+@@ -1 +0,0 @@
+-#include <sysdeps/unix/sysv/linux/i386/glob64.c>
+diff --git a/sysdeps/unix/sysv/linux/wordsize-64/glob64.c b/sysdeps/unix/sysv/linux/wordsize-64/glob64.c
+deleted file mode 100644
+index eab7703d5c..0000000000
+--- a/sysdeps/unix/sysv/linux/wordsize-64/glob64.c
++++ /dev/null
+@@ -1,2 +0,0 @@
+-/* This file is here so sysdeps/gnu/glob64.c doesn't take precedence.  */
+-#include <sysdeps/wordsize-64/glob64.c>
+diff --git a/sysdeps/unix/sysv/linux/wordsize-64/globfree64.c b/sysdeps/unix/sysv/linux/wordsize-64/globfree64.c
+deleted file mode 100644
+index af035e1514..0000000000
+--- a/sysdeps/unix/sysv/linux/wordsize-64/globfree64.c
++++ /dev/null
+@@ -1,2 +0,0 @@
+-/* This file is here so sysdeps/gnu/glob64.c doesn't take precedence.  */
+-#include <sysdeps/wordsize-64/globfree64.c>
+diff --git a/sysdeps/unix/sysv/linux/x86_64/x32/glob.c b/sysdeps/unix/sysv/linux/x86_64/x32/glob.c
+deleted file mode 100644
+index e5427475f6..0000000000
+--- a/sysdeps/unix/sysv/linux/x86_64/x32/glob.c
++++ /dev/null
+@@ -1 +0,0 @@
+-#include <sysdeps/wordsize-64/glob.c>
+diff --git a/sysdeps/unix/sysv/linux/x86_64/x32/globfree.c b/sysdeps/unix/sysv/linux/x86_64/x32/globfree.c
+deleted file mode 100644
+index b76a761c17..0000000000
+--- a/sysdeps/unix/sysv/linux/x86_64/x32/globfree.c
++++ /dev/null
+@@ -1 +0,0 @@
+-#include <sysdeps/wordsize-64/globfree.c>
+diff --git a/sysdeps/wordsize-64/glob.c b/sysdeps/wordsize-64/glob.c
+deleted file mode 100644
+index 954e8d37e2..0000000000
+--- a/sysdeps/wordsize-64/glob.c
++++ /dev/null
+@@ -1,6 +0,0 @@
+-#define glob64 __no_glob64_decl
+-#define globfree64 __no_globfree64_decl
+-#include <posix/glob.c>
+-#undef glob64
+-#undef globfree64
+-weak_alias (glob, glob64)
+diff --git a/sysdeps/wordsize-64/glob64.c b/sysdeps/wordsize-64/glob64.c
+deleted file mode 100644
+index 33918ea6a5..0000000000
+--- a/sysdeps/wordsize-64/glob64.c
++++ /dev/null
+@@ -1 +0,0 @@
+-/* glob64 is in glob.c */
+diff --git a/sysdeps/wordsize-64/globfree.c b/sysdeps/wordsize-64/globfree.c
+deleted file mode 100644
+index ec8c35b489..0000000000
+--- a/sysdeps/wordsize-64/globfree.c
++++ /dev/null
+@@ -1,5 +0,0 @@
+-#define globfree64 __no_globfree64_decl
+-#include <posix/globfree.c>
+-#undef globfree64
+-weak_alias (globfree, globfree64)
+-libc_hidden_ver (globfree, globfree64)
+diff --git a/sysdeps/wordsize-64/globfree64.c b/sysdeps/wordsize-64/globfree64.c
+deleted file mode 100644
+index a0f57ff4b3..0000000000
+--- a/sysdeps/wordsize-64/globfree64.c
++++ /dev/null
+@@ -1 +0,0 @@
+-/* globfree64 is in globfree.c */
diff --git a/gnu/packages/patches/glibc-2-26-0075.patch b/gnu/packages/patches/glibc-2-26-0075.patch
new file mode 100644
index 000000000..0e9ddf6a3
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0075.patch
@@ -0,0 +1,56 @@
+From caa6857ec1087c705b11d8000716fbc67152e428 Mon Sep 17 00:00:00 2001
+From: Adhemerval Zanella <adhemerval.zanella@linaro.org>
+Date: Tue, 12 Sep 2017 18:52:05 -0300
+Subject: [PATCH 75/90] posix: Fix compat glob code on s390 and alpha
+
+This patch fixes the compat glob implementation consolidation from
+commit 116f1c64d with the following changes:
+
+  - Add a compat implementation on s390 to avoid the architecture
+    to build the symbols on default linux oldglob.c by setting
+    GLOB_NO_OLD_VERSION.
+
+  - Remove the duplicate rule to build oldglob on alpha.
+
+Checked on s390-linux-gnu and alpha-linux-gnu using build-many-glibc.py.
+
+	* sysdeps/unix/sysv/linux/s390/s390-32/oldglob.c: New file.
+	* sysdeps/unix/sysv/linux/alpha/Makefile
+	[$(subdir) = csu] (sysdep_routines): Remove rule.
+
+(cherry picked from commit 3ca622e4d6054c0b99b2df36580462663edc8d12)
+
+diff --git a/ChangeLog b/ChangeLog
+index c9b900f4a0..c36ef25b53 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-09-13  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
++
++	* sysdeps/unix/sysv/linux/s390/s390-32/oldglob.c: New file.
++	* sysdeps/unix/sysv/linux/alpha/Makefile
++	[$(subdir) = csu] (sysdep_routines): Remove rule.
++
+ 2017-09-08  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
+ 
+ 	* sysdeps/unix/sysv/linux/arm/glob64.c: Remove file.
+diff --git a/sysdeps/unix/sysv/linux/alpha/Makefile b/sysdeps/unix/sysv/linux/alpha/Makefile
+index 47bd189f94..50f4fb1183 100644
+--- a/sysdeps/unix/sysv/linux/alpha/Makefile
++++ b/sysdeps/unix/sysv/linux/alpha/Makefile
+@@ -1,7 +1,3 @@
+-ifeq ($(subdir),posix)
+-sysdep_routines += oldglob
+-endif
+-
+ ifeq ($(subdir),stdlib)
+ gen-as-const-headers += ucontext-offsets.sym
+ endif
+diff --git a/sysdeps/unix/sysv/linux/s390/s390-32/oldglob.c b/sysdeps/unix/sysv/linux/s390/s390-32/oldglob.c
+new file mode 100644
+index 0000000000..56d7d12ea6
+--- /dev/null
++++ b/sysdeps/unix/sysv/linux/s390/s390-32/oldglob.c
+@@ -0,0 +1,2 @@
++#define GLOB_NO_OLD_VERSION
++#include <sysdeps/unix/sysv/linux/oldglob.c>
diff --git a/gnu/packages/patches/glibc-2-26-0076.patch b/gnu/packages/patches/glibc-2-26-0076.patch
new file mode 100644
index 000000000..c7a9a01dd
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0076.patch
@@ -0,0 +1,158 @@
+From f8ee700e8959236bb2c54f3aacf57edca5dab186 Mon Sep 17 00:00:00 2001
+From: Adhemerval Zanella <adhemerval.zanella@linaro.org>
+Date: Thu, 12 Oct 2017 15:20:57 -0300
+Subject: [PATCH 76/90] posix: Fix improper assert in Linux posix_spawn
+ (BZ#22273)
+
+As noted by Florian Weimer, current Linux posix_spawn implementation
+can trigger an assert if the auxiliary process is terminated before
+actually setting the err member:
+
+    340   /* Child must set args.err to something non-negative - we rely on
+    341      the parent and child sharing VM.  */
+    342   args.err = -1;
+    [...]
+    362   new_pid = CLONE (__spawni_child, STACK (stack, stack_size), stack_size,
+    363                    CLONE_VM | CLONE_VFORK | SIGCHLD, &args);
+    364
+    365   if (new_pid > 0)
+    366     {
+    367       ec = args.err;
+    368       assert (ec >= 0);
+
+Another possible issue is killing the child between setting the err and
+actually calling execve.  In this case the process will not ran, but
+posix_spawn also will not report any error:
+
+    269
+    270   args->err = 0;
+    271   args->exec (args->file, args->argv, args->envp);
+
+As suggested by Andreas Schwab, this patch removes the faulty assert
+and also handles any signal that happens before fork and execve as the
+spawn was successful (and thus relaying the handling to the caller to
+figure this out).  Different than Florian, I can not see why using
+atomics to set err would help here, essentially the code runs
+sequentially (due CLONE_VFORK) and I think it would not be legal the
+compiler evaluate ec without checking for new_pid result (thus there
+is no need to compiler barrier).
+
+Summarizing the possible scenarios on posix_spawn execution, we
+have:
+
+  1. For default case with a success execution, args.err will be 0, pid
+     will not be collected and it will be reported to caller.
+
+  2. For default failure case, args.err will be positive and the it will
+     be collected by the waitpid.  An error will be reported to the
+     caller.
+
+  3. For the unlikely case where the process was terminated and not
+     collected by a caller signal handler, it will be reported as succeful
+     execution and not be collected by posix_spawn (since args.err will
+     be 0). The caller will need to actually handle this case.
+
+  4. For the unlikely case where the process was terminated and collected
+     by caller we have 3 other possible scenarios:
+
+     4.1. The auxiliary process was terminated with args.err equal to 0:
+	  it will handled as 1. (so it does not matter if we hit the pid
+          reuse race since we won't possible collect an unexpected
+          process).
+
+     4.2. The auxiliary process was terminated after execve (due a failure
+          in calling it) and before setting args.err to -1: it will also
+          be handle as 1. but with the issue of not be able to report the
+          caller a possible execve failures.
+
+     4.3. The auxiliary process was terminated after args.err is set to -1:
+          this is the case where it will be possible to hit the pid reuse
+          case where we will need to collected the auxiliary pid but we
+          can not be sure if it will be expected one.  I think for this
+          case we need to actually change waitpid to use WNOHANG to avoid
+          hanging indefinitely on the call and report an error to caller
+          since we can't differentiate between a default failure as 2.
+          and a possible pid reuse race issue.
+
+Checked on x86_64-linux-gnu.
+
+	* sysdeps/unix/sysv/linux/spawni.c (__spawnix): Handle the case where
+	the auxiliary process is terminated by a signal before calling _exit
+	or execve.
+
+(cherry picked from commit fe05e1cb6d64dba6172249c79526f1e9af8f2bfd)
+
+diff --git a/ChangeLog b/ChangeLog
+index c36ef25b53..34709f792e 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,10 @@
++2017-11-07  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
++
++	[BZ #22273]
++	* sysdeps/unix/sysv/linux/spawni.c (__spawnix): Handle the case where
++	the auxiliary process is terminated by a signal before calling _exit
++	or execve.
++
+ 2017-09-13  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
+ 
+ 	* sysdeps/unix/sysv/linux/s390/s390-32/oldglob.c: New file.
+diff --git a/sysdeps/unix/sysv/linux/spawni.c b/sysdeps/unix/sysv/linux/spawni.c
+index c56f894a82..76001b6624 100644
+--- a/sysdeps/unix/sysv/linux/spawni.c
++++ b/sysdeps/unix/sysv/linux/spawni.c
+@@ -17,7 +17,6 @@
+    <http://www.gnu.org/licenses/>.  */
+ 
+ #include <spawn.h>
+-#include <assert.h>
+ #include <fcntl.h>
+ #include <paths.h>
+ #include <string.h>
+@@ -268,7 +267,6 @@ __spawni_child (void *arguments)
+   __sigprocmask (SIG_SETMASK, (attr->__flags & POSIX_SPAWN_SETSIGMASK)
+ 		 ? &attr->__ss : &args->oldmask, 0);
+ 
+-  args->err = 0;
+   args->exec (args->file, args->argv, args->envp);
+ 
+   /* This is compatibility function required to enable posix_spawn run
+@@ -339,7 +337,7 @@ __spawnix (pid_t * pid, const char *file,
+ 
+   /* Child must set args.err to something non-negative - we rely on
+      the parent and child sharing VM.  */
+-  args.err = -1;
++  args.err = 0;
+   args.file = file;
+   args.exec = exec;
+   args.fa = file_actions;
+@@ -362,12 +360,26 @@ __spawnix (pid_t * pid, const char *file,
+   new_pid = CLONE (__spawni_child, STACK (stack, stack_size), stack_size,
+ 		   CLONE_VM | CLONE_VFORK | SIGCHLD, &args);
+ 
++  /* It needs to collect the case where the auxiliary process was created
++     but failed to execute the file (due either any preparation step or
++     for execve itself).  */
+   if (new_pid > 0)
+     {
++      /* Also, it handles the unlikely case where the auxiliary process was
++	 terminated before calling execve as if it was successfully.  The
++	 args.err is set to 0 as default and changed to a positive value
++	 only in case of failure, so in case of premature termination
++	 due a signal args.err will remain zeroed and it will be up to
++	 caller to actually collect it.  */
+       ec = args.err;
+-      assert (ec >= 0);
+-      if (ec != 0)
+-	  __waitpid (new_pid, NULL, 0);
++      if (ec > 0)
++	/* There still an unlikely case where the child is cancelled after
++	   setting args.err, due to a positive error value.  Also due a
++	   possible pid reuse race (where the kernel allocated the same pid
++	   to unrelated process) we need not to undefinitely hang expecting
++	   an invalid pid.  In both cases an error is returned to the
++	   caller.  */
++	__waitpid (new_pid, NULL, WNOHANG);
+     }
+   else
+     ec = -new_pid;
diff --git a/gnu/packages/patches/glibc-2-26-0077.patch b/gnu/packages/patches/glibc-2-26-0077.patch
new file mode 100644
index 000000000..d8e0d9f74
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0077.patch
@@ -0,0 +1,61 @@
+From bfdb34f2f26933a831684c09cadc2b782f7fbd7a Mon Sep 17 00:00:00 2001
+From: Adhemerval Zanella <adhemerval.zanella@linaro.org>
+Date: Sat, 21 Oct 2017 11:33:27 -0200
+Subject: [PATCH 77/90] posix: Do not use WNOHANG in waitpid call for Linux
+ posix_spawn
+
+As shown in some buildbot issues on aarch64 and powerpc, calling
+clone (VFORK) and waitpid (WNOHANG) does not guarantee the child
+is ready to be collected.  This patch changes the call back to 0
+as before fe05e1cb6d64 fix.
+
+This change can lead to the scenario 4.3 described in the commit,
+where the waitpid call can hang undefinitely on the call.  However
+this is also a very unlikely and also undefinied situation where
+both the caller is trying to terminate a pid before posix_spawn
+returns and the race pid reuse is triggered.  I don't see how to
+correct handle this specific situation within posix_spawn.
+
+Checked on x86_64-linux-gnu, aarch64-linux-gnu and
+powerpc64-linux-gnu.
+
+	* sysdeps/unix/sysv/linux/spawni.c (__spawnix): Use 0 instead of
+	WNOHANG in waitpid call.
+
+(cherry picked from commit aa95a2414e4f664ca740ad5f4a72d9145abbd426)
+
+diff --git a/ChangeLog b/ChangeLog
+index 34709f792e..c3418c3277 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,5 +1,8 @@
+ 2017-11-07  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
+ 
++	* sysdeps/unix/sysv/linux/spawni.c (__spawnix): Use 0 instead of
++	WNOHANG in waitpid call.
++
+ 	[BZ #22273]
+ 	* sysdeps/unix/sysv/linux/spawni.c (__spawnix): Handle the case where
+ 	the auxiliary process is terminated by a signal before calling _exit
+diff --git a/sysdeps/unix/sysv/linux/spawni.c b/sysdeps/unix/sysv/linux/spawni.c
+index 76001b6624..7d23df84d2 100644
+--- a/sysdeps/unix/sysv/linux/spawni.c
++++ b/sysdeps/unix/sysv/linux/spawni.c
+@@ -374,12 +374,12 @@ __spawnix (pid_t * pid, const char *file,
+       ec = args.err;
+       if (ec > 0)
+ 	/* There still an unlikely case where the child is cancelled after
+-	   setting args.err, due to a positive error value.  Also due a
++	   setting args.err, due to a positive error value.  Also there is
+ 	   possible pid reuse race (where the kernel allocated the same pid
+-	   to unrelated process) we need not to undefinitely hang expecting
+-	   an invalid pid.  In both cases an error is returned to the
+-	   caller.  */
+-	__waitpid (new_pid, NULL, WNOHANG);
++	   to an unrelated process).  Unfortunately due synchronization
++	   issues where the kernel might not have the process collected
++	   the waitpid below can not use WNOHANG.  */
++	__waitpid (new_pid, NULL, 0);
+     }
+   else
+     ec = -new_pid;
diff --git a/gnu/packages/patches/glibc-2-26-0078.patch b/gnu/packages/patches/glibc-2-26-0078.patch
new file mode 100644
index 000000000..20d45566d
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0078.patch
@@ -0,0 +1,354 @@
+From 5712f8db265a75132dde7ffa4b5aab41c89a6b89 Mon Sep 17 00:00:00 2001
+From: Adhemerval Zanella <adhemerval.zanella@linaro.org>
+Date: Mon, 16 Oct 2017 14:27:29 -0200
+Subject: [PATCH 78/90] nptl: Add tests for internal pthread_mutex_t offsets
+
+This patch adds a new build test to check for internal fields
+offsets for user visible internal field.  Although currently
+the only field which is statically initialized to a non zero value
+is pthread_mutex_t.__data.__kind value, the tests also check the
+offset of __kind, __spins, __elision (if supported), and __list
+internal member.  A internal header (pthread-offset.h) is added
+to each major ABI with the reference value.
+
+Checked on x86_64-linux-gnu and with a build check for all affected
+ABIs (aarch64-linux-gnu, alpha-linux-gnu, arm-linux-gnueabihf,
+hppa-linux-gnu, i686-linux-gnu, ia64-linux-gnu, m68k-linux-gnu,
+microblaze-linux-gnu, mips64-linux-gnu, mips64-n32-linux-gnu,
+mips-linux-gnu, powerpc64le-linux-gnu, powerpc-linux-gnu,
+s390-linux-gnu, s390x-linux-gnu, sh4-linux-gnu, sparc64-linux-gnu,
+sparcv9-linux-gnu, tilegx-linux-gnu, tilegx-linux-gnu-x32,
+tilepro-linux-gnu, x86_64-linux-gnu, and x86_64-linux-x32).
+
+	* nptl/pthreadP.h (ASSERT_PTHREAD_STRING,
+	ASSERT_PTHREAD_INTERNAL_OFFSET): New macro.
+	* nptl/pthread_mutex_init.c (__pthread_mutex_init): Add build time
+	checks for internal pthread_mutex_t offsets.
+	* sysdeps/aarch64/nptl/pthread-offsets.h
+	(__PTHREAD_MUTEX_NUSERS_OFFSET, __PTHREAD_MUTEX_KIND_OFFSET,
+	__PTHREAD_MUTEX_SPINS_OFFSET, __PTHREAD_MUTEX_ELISION_OFFSET,
+	__PTHREAD_MUTEX_LIST_OFFSET): New macro.
+	* sysdeps/alpha/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/arm/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/hppa/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/i386/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/ia64/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/m68k/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/microblaze/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/mips/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/nios2/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/powerpc/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/s390/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/sh/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/sparc/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/tile/nptl/pthread-offsets.h: Likewise.
+	* sysdeps/x86_64/nptl/pthread-offsets.h: Likewise.
+
+Signed-off-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
+
+(cherry picked from commit dff91cd45e35e47d567274331f3deb8e87a188c9)
+
+diff --git a/ChangeLog b/ChangeLog
+index c3418c3277..910bfe5d9f 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,5 +1,29 @@
+ 2017-11-07  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
+ 
++	* nptl/pthreadP.h (ASSERT_PTHREAD_STRING,
++	ASSERT_PTHREAD_INTERNAL_OFFSET): New macro.
++	* nptl/pthread_mutex_init.c (__pthread_mutex_init): Add build time
++	checks for internal pthread_mutex_t offsets.
++	* sysdeps/aarch64/nptl/pthread-offsets.h
++	(__PTHREAD_MUTEX_NUSERS_OFFSET, __PTHREAD_MUTEX_KIND_OFFSET,
++	__PTHREAD_MUTEX_SPINS_OFFSET, __PTHREAD_MUTEX_ELISION_OFFSET,
++	__PTHREAD_MUTEX_LIST_OFFSET): New macro.
++	* sysdeps/alpha/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/arm/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/hppa/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/i386/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/ia64/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/m68k/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/microblaze/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/mips/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/nios2/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/powerpc/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/s390/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/sh/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/sparc/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/tile/nptl/pthread-offsets.h: Likewise.
++	* sysdeps/x86_64/nptl/pthread-offsets.h: Likewise.
++
+ 	* sysdeps/unix/sysv/linux/spawni.c (__spawnix): Use 0 instead of
+ 	WNOHANG in waitpid call.
+ 
+diff --git a/nptl/pthreadP.h b/nptl/pthreadP.h
+index 6e7d6ff09e..c5ae04692e 100644
+--- a/nptl/pthreadP.h
++++ b/nptl/pthreadP.h
+@@ -647,4 +647,10 @@ check_stacksize_attr (size_t st)
+   return EINVAL;
+ }
+ 
++#define ASSERT_PTHREAD_STRING(x) __STRING (x)
++#define ASSERT_PTHREAD_INTERNAL_OFFSET(type, member, offset)		\
++  _Static_assert (offsetof (type, member) == offset,			\
++		  "offset of " #member " field of " #type " != "	\
++		  ASSERT_PTHREAD_STRING (offset))
++
+ #endif	/* pthreadP.h */
+diff --git a/nptl/pthread_mutex_init.c b/nptl/pthread_mutex_init.c
+index 6f2fc808ff..e1f911bf29 100644
+--- a/nptl/pthread_mutex_init.c
++++ b/nptl/pthread_mutex_init.c
+@@ -23,6 +23,7 @@
+ #include <kernel-features.h>
+ #include "pthreadP.h"
+ #include <atomic.h>
++#include <pthread-offsets.h>
+ 
+ #include <stap-probe.h>
+ 
+@@ -58,6 +59,18 @@ __pthread_mutex_init (pthread_mutex_t *mutex,
+   const struct pthread_mutexattr *imutexattr;
+ 
+   assert (sizeof (pthread_mutex_t) <= __SIZEOF_PTHREAD_MUTEX_T);
++  ASSERT_PTHREAD_INTERNAL_OFFSET (pthread_mutex_t, __data.__nusers,
++				  __PTHREAD_MUTEX_NUSERS_OFFSET);
++  ASSERT_PTHREAD_INTERNAL_OFFSET (pthread_mutex_t, __data.__kind,
++				  __PTHREAD_MUTEX_KIND_OFFSET);
++  ASSERT_PTHREAD_INTERNAL_OFFSET (pthread_mutex_t, __data.__spins,
++				  __PTHREAD_MUTEX_SPINS_OFFSET);
++#if __PTHREAD_MUTEX_LOCK_ELISION
++  ASSERT_PTHREAD_INTERNAL_OFFSET (pthread_mutex_t, __data.__elision,
++				  __PTHREAD_MUTEX_ELISION_OFFSET);
++#endif
++  ASSERT_PTHREAD_INTERNAL_OFFSET (pthread_mutex_t, __data.__list,
++				  __PTHREAD_MUTEX_LIST_OFFSET);
+ 
+   imutexattr = ((const struct pthread_mutexattr *) mutexattr
+ 		?: &default_mutexattr);
+diff --git a/sysdeps/aarch64/nptl/pthread-offsets.h b/sysdeps/aarch64/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..16c6b0d9fd
+--- /dev/null
++++ b/sysdeps/aarch64/nptl/pthread-offsets.h
+@@ -0,0 +1,5 @@
++#define __PTHREAD_MUTEX_NUSERS_OFFSET   12
++#define __PTHREAD_MUTEX_KIND_OFFSET     16
++#define __PTHREAD_MUTEX_SPINS_OFFSET    20
++#define __PTHREAD_MUTEX_ELISION_OFFSET  22
++#define __PTHREAD_MUTEX_LIST_OFFSET     24
+diff --git a/sysdeps/alpha/nptl/pthread-offsets.h b/sysdeps/alpha/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..16c6b0d9fd
+--- /dev/null
++++ b/sysdeps/alpha/nptl/pthread-offsets.h
+@@ -0,0 +1,5 @@
++#define __PTHREAD_MUTEX_NUSERS_OFFSET   12
++#define __PTHREAD_MUTEX_KIND_OFFSET     16
++#define __PTHREAD_MUTEX_SPINS_OFFSET    20
++#define __PTHREAD_MUTEX_ELISION_OFFSET  22
++#define __PTHREAD_MUTEX_LIST_OFFSET     24
+diff --git a/sysdeps/arm/nptl/pthread-offsets.h b/sysdeps/arm/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..9617354dc7
+--- /dev/null
++++ b/sysdeps/arm/nptl/pthread-offsets.h
+@@ -0,0 +1,5 @@
++#define __PTHREAD_MUTEX_NUSERS_OFFSET   16
++#define __PTHREAD_MUTEX_KIND_OFFSET     12
++#define __PTHREAD_MUTEX_SPINS_OFFSET    20
++#define __PTHREAD_MUTEX_ELISION_OFFSET  22
++#define __PTHREAD_MUTEX_LIST_OFFSET     20
+diff --git a/sysdeps/hppa/nptl/pthread-offsets.h b/sysdeps/hppa/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..8ae01b9d95
+--- /dev/null
++++ b/sysdeps/hppa/nptl/pthread-offsets.h
+@@ -0,0 +1,5 @@
++#define __PTHREAD_MUTEX_NUSERS_OFFSET   32
++#define __PTHREAD_MUTEX_KIND_OFFSET     12
++#define __PTHREAD_MUTEX_SPINS_OFFSET    36
++#define __PTHREAD_MUTEX_ELISION_OFFSET  22
++#define __PTHREAD_MUTEX_LIST_OFFSET     36
+diff --git a/sysdeps/i386/nptl/pthread-offsets.h b/sysdeps/i386/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..9617354dc7
+--- /dev/null
++++ b/sysdeps/i386/nptl/pthread-offsets.h
+@@ -0,0 +1,5 @@
++#define __PTHREAD_MUTEX_NUSERS_OFFSET   16
++#define __PTHREAD_MUTEX_KIND_OFFSET     12
++#define __PTHREAD_MUTEX_SPINS_OFFSET    20
++#define __PTHREAD_MUTEX_ELISION_OFFSET  22
++#define __PTHREAD_MUTEX_LIST_OFFSET     20
+diff --git a/sysdeps/ia64/nptl/pthread-offsets.h b/sysdeps/ia64/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..16c6b0d9fd
+--- /dev/null
++++ b/sysdeps/ia64/nptl/pthread-offsets.h
+@@ -0,0 +1,5 @@
++#define __PTHREAD_MUTEX_NUSERS_OFFSET   12
++#define __PTHREAD_MUTEX_KIND_OFFSET     16
++#define __PTHREAD_MUTEX_SPINS_OFFSET    20
++#define __PTHREAD_MUTEX_ELISION_OFFSET  22
++#define __PTHREAD_MUTEX_LIST_OFFSET     24
+diff --git a/sysdeps/m68k/nptl/pthread-offsets.h b/sysdeps/m68k/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..9617354dc7
+--- /dev/null
++++ b/sysdeps/m68k/nptl/pthread-offsets.h
+@@ -0,0 +1,5 @@
++#define __PTHREAD_MUTEX_NUSERS_OFFSET   16
++#define __PTHREAD_MUTEX_KIND_OFFSET     12
++#define __PTHREAD_MUTEX_SPINS_OFFSET    20
++#define __PTHREAD_MUTEX_ELISION_OFFSET  22
++#define __PTHREAD_MUTEX_LIST_OFFSET     20
+diff --git a/sysdeps/microblaze/nptl/pthread-offsets.h b/sysdeps/microblaze/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..9617354dc7
+--- /dev/null
++++ b/sysdeps/microblaze/nptl/pthread-offsets.h
+@@ -0,0 +1,5 @@
++#define __PTHREAD_MUTEX_NUSERS_OFFSET   16
++#define __PTHREAD_MUTEX_KIND_OFFSET     12
++#define __PTHREAD_MUTEX_SPINS_OFFSET    20
++#define __PTHREAD_MUTEX_ELISION_OFFSET  22
++#define __PTHREAD_MUTEX_LIST_OFFSET     20
+diff --git a/sysdeps/mips/nptl/pthread-offsets.h b/sysdeps/mips/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..0ac3eda3fb
+--- /dev/null
++++ b/sysdeps/mips/nptl/pthread-offsets.h
+@@ -0,0 +1,13 @@
++#if _MIPS_SIM == _ABI64
++# define __PTHREAD_MUTEX_NUSERS_OFFSET   12
++# define __PTHREAD_MUTEX_KIND_OFFSET     16
++# define __PTHREAD_MUTEX_SPINS_OFFSET    20
++# define __PTHREAD_MUTEX_ELISION_OFFSET  22
++# define __PTHREAD_MUTEX_LIST_OFFSET     24
++#else
++# define __PTHREAD_MUTEX_NUSERS_OFFSET   16
++# define __PTHREAD_MUTEX_KIND_OFFSET     12
++# define __PTHREAD_MUTEX_SPINS_OFFSET    20
++# define __PTHREAD_MUTEX_ELISION_OFFSET  22
++# define __PTHREAD_MUTEX_LIST_OFFSET     20
++#endif
+diff --git a/sysdeps/nios2/nptl/pthread-offsets.h b/sysdeps/nios2/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..9617354dc7
+--- /dev/null
++++ b/sysdeps/nios2/nptl/pthread-offsets.h
+@@ -0,0 +1,5 @@
++#define __PTHREAD_MUTEX_NUSERS_OFFSET   16
++#define __PTHREAD_MUTEX_KIND_OFFSET     12
++#define __PTHREAD_MUTEX_SPINS_OFFSET    20
++#define __PTHREAD_MUTEX_ELISION_OFFSET  22
++#define __PTHREAD_MUTEX_LIST_OFFSET     20
+diff --git a/sysdeps/powerpc/nptl/pthread-offsets.h b/sysdeps/powerpc/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..bdda1f197e
+--- /dev/null
++++ b/sysdeps/powerpc/nptl/pthread-offsets.h
+@@ -0,0 +1,15 @@
++#include <bits/wordsize.h>
++
++#if __WORDSIZE == 64
++# define __PTHREAD_MUTEX_NUSERS_OFFSET   12
++# define __PTHREAD_MUTEX_KIND_OFFSET     16
++# define __PTHREAD_MUTEX_SPINS_OFFSET    20
++# define __PTHREAD_MUTEX_ELISION_OFFSET  22
++# define __PTHREAD_MUTEX_LIST_OFFSET     24
++#else
++# define __PTHREAD_MUTEX_NUSERS_OFFSET   16
++# define __PTHREAD_MUTEX_KIND_OFFSET     12
++# define __PTHREAD_MUTEX_SPINS_OFFSET    20
++# define __PTHREAD_MUTEX_ELISION_OFFSET  22
++# define __PTHREAD_MUTEX_LIST_OFFSET     20
++#endif
+diff --git a/sysdeps/s390/nptl/pthread-offsets.h b/sysdeps/s390/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..bdda1f197e
+--- /dev/null
++++ b/sysdeps/s390/nptl/pthread-offsets.h
+@@ -0,0 +1,15 @@
++#include <bits/wordsize.h>
++
++#if __WORDSIZE == 64
++# define __PTHREAD_MUTEX_NUSERS_OFFSET   12
++# define __PTHREAD_MUTEX_KIND_OFFSET     16
++# define __PTHREAD_MUTEX_SPINS_OFFSET    20
++# define __PTHREAD_MUTEX_ELISION_OFFSET  22
++# define __PTHREAD_MUTEX_LIST_OFFSET     24
++#else
++# define __PTHREAD_MUTEX_NUSERS_OFFSET   16
++# define __PTHREAD_MUTEX_KIND_OFFSET     12
++# define __PTHREAD_MUTEX_SPINS_OFFSET    20
++# define __PTHREAD_MUTEX_ELISION_OFFSET  22
++# define __PTHREAD_MUTEX_LIST_OFFSET     20
++#endif
+diff --git a/sysdeps/sh/nptl/pthread-offsets.h b/sysdeps/sh/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..9617354dc7
+--- /dev/null
++++ b/sysdeps/sh/nptl/pthread-offsets.h
+@@ -0,0 +1,5 @@
++#define __PTHREAD_MUTEX_NUSERS_OFFSET   16
++#define __PTHREAD_MUTEX_KIND_OFFSET     12
++#define __PTHREAD_MUTEX_SPINS_OFFSET    20
++#define __PTHREAD_MUTEX_ELISION_OFFSET  22
++#define __PTHREAD_MUTEX_LIST_OFFSET     20
+diff --git a/sysdeps/sparc/nptl/pthread-offsets.h b/sysdeps/sparc/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..bdda1f197e
+--- /dev/null
++++ b/sysdeps/sparc/nptl/pthread-offsets.h
+@@ -0,0 +1,15 @@
++#include <bits/wordsize.h>
++
++#if __WORDSIZE == 64
++# define __PTHREAD_MUTEX_NUSERS_OFFSET   12
++# define __PTHREAD_MUTEX_KIND_OFFSET     16
++# define __PTHREAD_MUTEX_SPINS_OFFSET    20
++# define __PTHREAD_MUTEX_ELISION_OFFSET  22
++# define __PTHREAD_MUTEX_LIST_OFFSET     24
++#else
++# define __PTHREAD_MUTEX_NUSERS_OFFSET   16
++# define __PTHREAD_MUTEX_KIND_OFFSET     12
++# define __PTHREAD_MUTEX_SPINS_OFFSET    20
++# define __PTHREAD_MUTEX_ELISION_OFFSET  22
++# define __PTHREAD_MUTEX_LIST_OFFSET     20
++#endif
+diff --git a/sysdeps/tile/nptl/pthread-offsets.h b/sysdeps/tile/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..bdda1f197e
+--- /dev/null
++++ b/sysdeps/tile/nptl/pthread-offsets.h
+@@ -0,0 +1,15 @@
++#include <bits/wordsize.h>
++
++#if __WORDSIZE == 64
++# define __PTHREAD_MUTEX_NUSERS_OFFSET   12
++# define __PTHREAD_MUTEX_KIND_OFFSET     16
++# define __PTHREAD_MUTEX_SPINS_OFFSET    20
++# define __PTHREAD_MUTEX_ELISION_OFFSET  22
++# define __PTHREAD_MUTEX_LIST_OFFSET     24
++#else
++# define __PTHREAD_MUTEX_NUSERS_OFFSET   16
++# define __PTHREAD_MUTEX_KIND_OFFSET     12
++# define __PTHREAD_MUTEX_SPINS_OFFSET    20
++# define __PTHREAD_MUTEX_ELISION_OFFSET  22
++# define __PTHREAD_MUTEX_LIST_OFFSET     20
++#endif
+diff --git a/sysdeps/x86_64/nptl/pthread-offsets.h b/sysdeps/x86_64/nptl/pthread-offsets.h
+new file mode 100644
+index 0000000000..16c6b0d9fd
+--- /dev/null
++++ b/sysdeps/x86_64/nptl/pthread-offsets.h
+@@ -0,0 +1,5 @@
++#define __PTHREAD_MUTEX_NUSERS_OFFSET   12
++#define __PTHREAD_MUTEX_KIND_OFFSET     16
++#define __PTHREAD_MUTEX_SPINS_OFFSET    20
++#define __PTHREAD_MUTEX_ELISION_OFFSET  22
++#define __PTHREAD_MUTEX_LIST_OFFSET     24
diff --git a/gnu/packages/patches/glibc-2-26-0079.patch b/gnu/packages/patches/glibc-2-26-0079.patch
new file mode 100644
index 000000000..b069b6bdb
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0079.patch
@@ -0,0 +1,535 @@
+From a81c1156c1a9a6161d49b295a09a4e4cff7a88d0 Mon Sep 17 00:00:00 2001
+From: Adhemerval Zanella <adhemerval.zanella@linaro.org>
+Date: Thu, 19 Oct 2017 10:11:57 -0200
+Subject: [PATCH 79/90] nptl: Define
+ __PTHREAD_MUTEX_{NUSERS_AFTER_KIND,USE_UNION}
+
+This patch adds two new internal defines to set the internal
+pthread_mutex_t layout required by the supported ABIS:
+
+  1. __PTHREAD_MUTEX_NUSERS_AFTER_KIND which control whether to define
+     __nusers fields before or after __kind.  The preferred value for
+     is 0 for new ports and it sets __nusers before __kind.
+
+  2. __PTHREAD_MUTEX_USE_UNION which control whether internal __spins and
+     __list members will be place inside an union for linuxthreads
+     compatibility.  The preferred value is 0 for ports and it sets
+     to not use an union to define both fields.
+
+It fixes the wrong offsets value for __kind value on x86_64-linux-gnu-x32.
+Checked with a make check run-built-tests=no on all afected ABIs.
+
+	[BZ #22298]
+	* nptl/allocatestack.c (allocate_stack): Check if
+	__PTHREAD_MUTEX_HAVE_PREV is non-zero, instead if
+	__PTHREAD_MUTEX_HAVE_PREV is defined.
+	* nptl/descr.h (pthread): Likewise.
+	* nptl/nptl-init.c (__pthread_initialize_minimal_internal):
+	Likewise.
+	* nptl/pthread_create.c (START_THREAD_DEFN): Likewise.
+	* sysdeps/nptl/fork.c (__libc_fork): Likewise.
+	* sysdeps/nptl/pthread.h (PTHREAD_MUTEX_INITIALIZER): Likewise.
+	* sysdeps/nptl/bits/thread-shared-types.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION): New
+	defines.
+	(__pthread_internal_list): Check __PTHREAD_MUTEX_USE_UNION instead
+	of __WORDSIZE for internal layout.
+	(__pthread_mutex_s): Check __PTHREAD_MUTEX_NUSERS_AFTER_KIND instead
+	of __WORDSIZE for internal __nusers layout and __PTHREAD_MUTEX_USE_UNION
+	instead of __WORDSIZE whether to use an union for __spins and __list
+	fields.
+	(__PTHREAD_MUTEX_HAVE_PREV): Define also for __PTHREAD_MUTEX_USE_UNION
+	case.
+	* sysdeps/aarch64/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION): New
+	defines.
+	* sysdeps/alpha/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+	* sysdeps/arm/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+	* sysdeps/hppa/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+	* sysdeps/ia64/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+	* sysdeps/m68k/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+	* sysdeps/microblaze/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+	* sysdeps/mips/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+	* sysdeps/nios2/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+	* sysdeps/powerpc/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+	* sysdeps/s390/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+	* sysdeps/sh/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+	* sysdeps/sparc/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+	* sysdeps/tile/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+	* sysdeps/x86/nptl/bits/pthreadtypes-arch.h
+	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
+	Likewise.
+
+Signed-off-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
+
+(cherry picked from commit 06be6368da16104be51ebf23f7c68a51f321673f)
+
+diff --git a/ChangeLog b/ChangeLog
+index 910bfe5d9f..a314b167f3 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,5 +1,72 @@
+ 2017-11-07  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
+ 
++	[BZ #22298]
++	* nptl/allocatestack.c (allocate_stack): Check if
++	__PTHREAD_MUTEX_HAVE_PREV is non-zero, instead if
++	__PTHREAD_MUTEX_HAVE_PREV is defined.
++	* nptl/descr.h (pthread): Likewise.
++	* nptl/nptl-init.c (__pthread_initialize_minimal_internal):
++	Likewise.
++	* nptl/pthread_create.c (START_THREAD_DEFN): Likewise.
++	* sysdeps/nptl/fork.c (__libc_fork): Likewise.
++	* sysdeps/nptl/pthread.h (PTHREAD_MUTEX_INITIALIZER): Likewise.
++	* sysdeps/nptl/bits/thread-shared-types.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION): New
++	defines.
++	(__pthread_internal_list): Check __PTHREAD_MUTEX_USE_UNION instead
++	of __WORDSIZE for internal layout.
++	(__pthread_mutex_s): Check __PTHREAD_MUTEX_NUSERS_AFTER_KIND instead
++	of __WORDSIZE for internal __nusers layout and __PTHREAD_MUTEX_USE_UNION
++	instead of __WORDSIZE whether to use an union for __spins and __list
++	fields.
++	(__PTHREAD_MUTEX_HAVE_PREV): Define also for __PTHREAD_MUTEX_USE_UNION
++	case.
++	* sysdeps/aarch64/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION): New
++	defines.
++	* sysdeps/alpha/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++	* sysdeps/arm/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++	* sysdeps/hppa/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++	* sysdeps/ia64/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++	* sysdeps/m68k/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++	* sysdeps/microblaze/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++	* sysdeps/mips/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++	* sysdeps/nios2/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++	* sysdeps/powerpc/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++	* sysdeps/s390/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++	* sysdeps/sh/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++	* sysdeps/sparc/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++	* sysdeps/tile/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++	* sysdeps/x86/nptl/bits/pthreadtypes-arch.h
++	(__PTHREAD_MUTEX_NUSERS_AFTER_KIND, __PTHREAD_MUTEX_USE_UNION):
++	Likewise.
++
+ 	* nptl/pthreadP.h (ASSERT_PTHREAD_STRING,
+ 	ASSERT_PTHREAD_INTERNAL_OFFSET): New macro.
+ 	* nptl/pthread_mutex_init.c (__pthread_mutex_init): Add build time
+diff --git a/nptl/allocatestack.c b/nptl/allocatestack.c
+index ce2e24af95..dff5d3469e 100644
+--- a/nptl/allocatestack.c
++++ b/nptl/allocatestack.c
+@@ -727,7 +727,7 @@ allocate_stack (const struct pthread_attr *attr, struct pthread **pdp,
+ 				  - offsetof (pthread_mutex_t,
+ 					      __data.__list.__next));
+   pd->robust_head.list_op_pending = NULL;
+-#ifdef __PTHREAD_MUTEX_HAVE_PREV
++#if __PTHREAD_MUTEX_HAVE_PREV
+   pd->robust_prev = &pd->robust_head;
+ #endif
+   pd->robust_head.list = &pd->robust_head;
+diff --git a/nptl/descr.h b/nptl/descr.h
+index c5ad0c8dba..c83b17b674 100644
+--- a/nptl/descr.h
++++ b/nptl/descr.h
+@@ -169,7 +169,7 @@ struct pthread
+   pid_t pid_ununsed;
+ 
+   /* List of robust mutexes the thread is holding.  */
+-#ifdef __PTHREAD_MUTEX_HAVE_PREV
++#if __PTHREAD_MUTEX_HAVE_PREV
+   void *robust_prev;
+   struct robust_list_head robust_head;
+ 
+diff --git a/nptl/nptl-init.c b/nptl/nptl-init.c
+index 29216077a2..869e926f17 100644
+--- a/nptl/nptl-init.c
++++ b/nptl/nptl-init.c
+@@ -297,7 +297,7 @@ __pthread_initialize_minimal_internal (void)
+ 
+   /* Initialize the robust mutex data.  */
+   {
+-#ifdef __PTHREAD_MUTEX_HAVE_PREV
++#if __PTHREAD_MUTEX_HAVE_PREV
+     pd->robust_prev = &pd->robust_head;
+ #endif
+     pd->robust_head.list = &pd->robust_head;
+diff --git a/nptl/pthread_create.c b/nptl/pthread_create.c
+index 2f8ada34d6..16c05c3a58 100644
+--- a/nptl/pthread_create.c
++++ b/nptl/pthread_create.c
+@@ -520,7 +520,7 @@ START_THREAD_DEFN
+ 
+ #ifndef __ASSUME_SET_ROBUST_LIST
+   /* If this thread has any robust mutexes locked, handle them now.  */
+-# ifdef __PTHREAD_MUTEX_HAVE_PREV
++# if __PTHREAD_MUTEX_HAVE_PREV
+   void *robust = pd->robust_head.list;
+ # else
+   __pthread_slist_t *robust = pd->robust_list.__next;
+@@ -538,7 +538,7 @@ START_THREAD_DEFN
+ 					 __list.__next));
+ 	  robust = *((void **) robust);
+ 
+-# ifdef __PTHREAD_MUTEX_HAVE_PREV
++# if __PTHREAD_MUTEX_HAVE_PREV
+ 	  this->__list.__prev = NULL;
+ # endif
+ 	  this->__list.__next = NULL;
+diff --git a/sysdeps/aarch64/nptl/bits/pthreadtypes-arch.h b/sysdeps/aarch64/nptl/bits/pthreadtypes-arch.h
+index d13a75db07..9ab23d0474 100644
+--- a/sysdeps/aarch64/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/aarch64/nptl/bits/pthreadtypes-arch.h
+@@ -45,6 +45,8 @@
+ #define __PTHREAD_COMPAT_PADDING_MID
+ #define __PTHREAD_COMPAT_PADDING_END
+ #define __PTHREAD_MUTEX_LOCK_ELISION	0
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  0
++#define __PTHREAD_MUTEX_USE_UNION          0
+ 
+ #define __LOCK_ALIGNMENT
+ #define __ONCE_ALIGNMENT
+diff --git a/sysdeps/alpha/nptl/bits/pthreadtypes-arch.h b/sysdeps/alpha/nptl/bits/pthreadtypes-arch.h
+index b6f6cb1347..429df10c0c 100644
+--- a/sysdeps/alpha/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/alpha/nptl/bits/pthreadtypes-arch.h
+@@ -33,6 +33,8 @@
+ #define __PTHREAD_COMPAT_PADDING_MID
+ #define __PTHREAD_COMPAT_PADDING_END
+ #define __PTHREAD_MUTEX_LOCK_ELISION    0
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  0
++#define __PTHREAD_MUTEX_USE_UNION          0
+ 
+ #define __LOCK_ALIGNMENT
+ #define __ONCE_ALIGNMENT
+diff --git a/sysdeps/arm/nptl/bits/pthreadtypes-arch.h b/sysdeps/arm/nptl/bits/pthreadtypes-arch.h
+index 3f9eca4645..3911c8183d 100644
+--- a/sysdeps/arm/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/arm/nptl/bits/pthreadtypes-arch.h
+@@ -34,6 +34,8 @@
+ #define __PTHREAD_COMPAT_PADDING_MID
+ #define __PTHREAD_COMPAT_PADDING_END
+ #define __PTHREAD_MUTEX_LOCK_ELISION    0
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  1
++#define __PTHREAD_MUTEX_USE_UNION          1
+ 
+ #define __LOCK_ALIGNMENT
+ #define __ONCE_ALIGNMENT
+diff --git a/sysdeps/hppa/nptl/bits/pthreadtypes-arch.h b/sysdeps/hppa/nptl/bits/pthreadtypes-arch.h
+index c1585625d1..865a14ee4a 100644
+--- a/sysdeps/hppa/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/hppa/nptl/bits/pthreadtypes-arch.h
+@@ -48,6 +48,8 @@
+    pthread_mutex_t is larger than Linuxthreads.  */
+ #define __PTHREAD_COMPAT_PADDING_END  int __reserved[2];
+ #define __PTHREAD_MUTEX_LOCK_ELISION    0
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  1
++#define __PTHREAD_MUTEX_USE_UNION          1
+ 
+ #define __LOCK_ALIGNMENT __attribute__ ((__aligned__(16)))
+ #define __ONCE_ALIGNMENT
+diff --git a/sysdeps/ia64/nptl/bits/pthreadtypes-arch.h b/sysdeps/ia64/nptl/bits/pthreadtypes-arch.h
+index 631cb33d09..2a3bc75b20 100644
+--- a/sysdeps/ia64/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/ia64/nptl/bits/pthreadtypes-arch.h
+@@ -33,6 +33,8 @@
+ #define __PTHREAD_COMPAT_PADDING_MID
+ #define __PTHREAD_COMPAT_PADDING_END
+ #define __PTHREAD_MUTEX_LOCK_ELISION    0
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  0
++#define __PTHREAD_MUTEX_USE_UNION          0
+ 
+ #define __LOCK_ALIGNMENT
+ #define __ONCE_ALIGNMENT
+diff --git a/sysdeps/m68k/nptl/bits/pthreadtypes-arch.h b/sysdeps/m68k/nptl/bits/pthreadtypes-arch.h
+index 845b9e6c2b..966cc7569f 100644
+--- a/sysdeps/m68k/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/m68k/nptl/bits/pthreadtypes-arch.h
+@@ -35,6 +35,8 @@
+ #define __PTHREAD_COMPAT_PADDING_MID
+ #define __PTHREAD_COMPAT_PADDING_END
+ #define __PTHREAD_MUTEX_LOCK_ELISION    0
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  1
++#define __PTHREAD_MUTEX_USE_UNION          1
+ 
+ #define __LOCK_ALIGNMENT __attribute__ ((__aligned__ (4)))
+ #define __ONCE_ALIGNMENT __attribute__ ((__aligned__ (4)))
+diff --git a/sysdeps/microblaze/nptl/bits/pthreadtypes-arch.h b/sysdeps/microblaze/nptl/bits/pthreadtypes-arch.h
+index d687e2c076..e44f2dcb6a 100644
+--- a/sysdeps/microblaze/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/microblaze/nptl/bits/pthreadtypes-arch.h
+@@ -35,6 +35,8 @@
+ #define __PTHREAD_COMPAT_PADDING_MID
+ #define __PTHREAD_COMPAT_PADDING_END
+ #define __PTHREAD_MUTEX_LOCK_ELISION    0
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  1
++#define __PTHREAD_MUTEX_USE_UNION          1
+ 
+ #define __LOCK_ALIGNMENT
+ #define __ONCE_ALIGNMENT
+diff --git a/sysdeps/mips/nptl/bits/pthreadtypes-arch.h b/sysdeps/mips/nptl/bits/pthreadtypes-arch.h
+index 6aa1bda172..f03389acc6 100644
+--- a/sysdeps/mips/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/mips/nptl/bits/pthreadtypes-arch.h
+@@ -42,6 +42,8 @@
+ #define __PTHREAD_COMPAT_PADDING_MID
+ #define __PTHREAD_COMPAT_PADDING_END
+ #define __PTHREAD_MUTEX_LOCK_ELISION    0
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  (_MIPS_SIM != _ABI64)
++#define __PTHREAD_MUTEX_USE_UNION          (_MIPS_SIM != _ABI64)
+ 
+ #define __LOCK_ALIGNMENT
+ #define __ONCE_ALIGNMENT
+diff --git a/sysdeps/nios2/nptl/bits/pthreadtypes-arch.h b/sysdeps/nios2/nptl/bits/pthreadtypes-arch.h
+index e2732f9771..83f8684604 100644
+--- a/sysdeps/nios2/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/nios2/nptl/bits/pthreadtypes-arch.h
+@@ -35,6 +35,8 @@
+ #define __PTHREAD_COMPAT_PADDING_MID
+ #define __PTHREAD_COMPAT_PADDING_END
+ #define __PTHREAD_MUTEX_LOCK_ELISION    0
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  1
++#define __PTHREAD_MUTEX_USE_UNION          1
+ 
+ #define __LOCK_ALIGNMENT
+ #define __ONCE_ALIGNMENT
+diff --git a/sysdeps/nptl/bits/thread-shared-types.h b/sysdeps/nptl/bits/thread-shared-types.h
+index 68b82b6bd6..da4358a965 100644
+--- a/sysdeps/nptl/bits/thread-shared-types.h
++++ b/sysdeps/nptl/bits/thread-shared-types.h
+@@ -42,6 +42,25 @@
+ 				    the internal structure.
+    __PTHREAD_MUTEX_LOCK_ELISION   - 1 if the architecture supports lock
+ 				    elision or 0 otherwise.
++   __PTHREAD_MUTEX_NUSERS_AFTER_KIND - control where to put __nusers.  The
++				       preferred value for new architectures
++				       is 0.
++   __PTHREAD_MUTEX_USE_UNION      - control whether internal __spins and
++				    __list will be place inside a union for
++				    linuxthreads compatibility.
++				    The preferred value for new architectures
++				    is 0.
++
++   For a new port the preferred values for the required defines are:
++
++   #define __PTHREAD_COMPAT_PADDING_MID
++   #define __PTHREAD_COMPAT_PADDING_END
++   #define __PTHREAD_MUTEX_LOCK_ELISION         0
++   #define __PTHREAD_MUTEX_NUSERS_AFTER_KIND    0
++   #define __PTHREAD_MUTEX_USE_UNION            0
++
++   __PTHREAD_MUTEX_LOCK_ELISION can be set to 1 if the hardware plans to
++   eventually support lock elision using transactional memory.
+ 
+    The additional macro defines any constraint for the lock alignment
+    inside the thread structures:
+@@ -59,7 +78,7 @@
+ 
+ /* Common definition of pthread_mutex_t. */
+ 
+-#if __WORDSIZE == 64
++#if !__PTHREAD_MUTEX_USE_UNION
+ typedef struct __pthread_internal_list
+ {
+   struct __pthread_internal_list *__prev;
+@@ -74,7 +93,7 @@ typedef struct __pthread_internal_slist
+ 
+ /* Lock elision support.  */
+ #if __PTHREAD_MUTEX_LOCK_ELISION
+-# if __WORDSIZE == 64
++# if !__PTHREAD_MUTEX_USE_UNION
+ #  define __PTHREAD_SPINS_DATA	\
+   short __spins;		\
+   short __elision
+@@ -101,24 +120,27 @@ struct __pthread_mutex_s
+   int __lock __LOCK_ALIGNMENT;
+   unsigned int __count;
+   int __owner;
+-#if __WORDSIZE == 64
++#if !__PTHREAD_MUTEX_NUSERS_AFTER_KIND
+   unsigned int __nusers;
+ #endif
+   /* KIND must stay at this position in the structure to maintain
+      binary compatibility with static initializers.  */
+   int __kind;
+   __PTHREAD_COMPAT_PADDING_MID
+-#if __WORDSIZE == 64
++#if __PTHREAD_MUTEX_NUSERS_AFTER_KIND
++  unsigned int __nusers;
++#endif
++#if !__PTHREAD_MUTEX_USE_UNION
+   __PTHREAD_SPINS_DATA;
+   __pthread_list_t __list;
+ # define __PTHREAD_MUTEX_HAVE_PREV      1
+ #else
+-  unsigned int __nusers;
+   __extension__ union
+   {
+     __PTHREAD_SPINS_DATA;
+     __pthread_slist_t __list;
+   };
++# define __PTHREAD_MUTEX_HAVE_PREV      0
+ #endif
+   __PTHREAD_COMPAT_PADDING_END
+ };
+diff --git a/sysdeps/nptl/fork.c b/sysdeps/nptl/fork.c
+index 4bb87e2331..48676c2f48 100644
+--- a/sysdeps/nptl/fork.c
++++ b/sysdeps/nptl/fork.c
+@@ -166,7 +166,7 @@ __libc_fork (void)
+ 	 inherit the correct value from the parent.  We do not need to clear
+ 	 the pending operation because it must have been zero when fork was
+ 	 called.  */
+-# ifdef __PTHREAD_MUTEX_HAVE_PREV
++# if __PTHREAD_MUTEX_HAVE_PREV
+       self->robust_prev = &self->robust_head;
+ # endif
+       self->robust_head.list = &self->robust_head;
+diff --git a/sysdeps/nptl/pthread.h b/sysdeps/nptl/pthread.h
+index 632ea7bc36..2b2b386ab3 100644
+--- a/sysdeps/nptl/pthread.h
++++ b/sysdeps/nptl/pthread.h
+@@ -83,7 +83,7 @@ enum
+ #endif
+ 
+ 
+-#ifdef __PTHREAD_MUTEX_HAVE_PREV
++#if __PTHREAD_MUTEX_HAVE_PREV
+ # define PTHREAD_MUTEX_INITIALIZER \
+   { { 0, 0, 0, 0, 0, __PTHREAD_SPINS, { 0, 0 } } }
+ # ifdef __USE_GNU
+diff --git a/sysdeps/powerpc/nptl/bits/pthreadtypes-arch.h b/sysdeps/powerpc/nptl/bits/pthreadtypes-arch.h
+index f29119b794..8158cb5abd 100644
+--- a/sysdeps/powerpc/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/powerpc/nptl/bits/pthreadtypes-arch.h
+@@ -42,6 +42,8 @@
+ #define __PTHREAD_COMPAT_PADDING_MID
+ #define __PTHREAD_COMPAT_PADDING_END
+ #define __PTHREAD_MUTEX_LOCK_ELISION    1
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  (__WORDSIZE != 64)
++#define __PTHREAD_MUTEX_USE_UNION          (__WORDSIZE != 64)
+ 
+ #define __LOCK_ALIGNMENT
+ #define __ONCE_ALIGNMENT
+diff --git a/sysdeps/s390/nptl/bits/pthreadtypes-arch.h b/sysdeps/s390/nptl/bits/pthreadtypes-arch.h
+index 3a9ac57625..1ae277367d 100644
+--- a/sysdeps/s390/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/s390/nptl/bits/pthreadtypes-arch.h
+@@ -45,6 +45,8 @@
+ #else
+ #define __PTHREAD_MUTEX_LOCK_ELISION	0
+ #endif
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  (__WORDSIZE != 64)
++#define __PTHREAD_MUTEX_USE_UNION          (__WORDSIZE != 64)
+ 
+ #define __LOCK_ALIGNMENT
+ #define __ONCE_ALIGNMENT
+diff --git a/sysdeps/sh/nptl/bits/pthreadtypes-arch.h b/sysdeps/sh/nptl/bits/pthreadtypes-arch.h
+index b2615fe314..e707751aa6 100644
+--- a/sysdeps/sh/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/sh/nptl/bits/pthreadtypes-arch.h
+@@ -34,6 +34,8 @@
+ #define __PTHREAD_COMPAT_PADDING_MID
+ #define __PTHREAD_COMPAT_PADDING_END
+ #define __PTHREAD_MUTEX_LOCK_ELISION    0
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  1
++#define __PTHREAD_MUTEX_USE_UNION          1
+ 
+ #define __LOCK_ALIGNMENT
+ #define __ONCE_ALIGNMENT
+diff --git a/sysdeps/sparc/nptl/bits/pthreadtypes-arch.h b/sysdeps/sparc/nptl/bits/pthreadtypes-arch.h
+index 1e188cf91f..0f96f3711e 100644
+--- a/sysdeps/sparc/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/sparc/nptl/bits/pthreadtypes-arch.h
+@@ -43,6 +43,8 @@
+ #define __PTHREAD_COMPAT_PADDING_MID
+ #define __PTHREAD_COMPAT_PADDING_END
+ #define __PTHREAD_MUTEX_LOCK_ELISION    0
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  (__WORDSIZE != 64)
++#define __PTHREAD_MUTEX_USE_UNION          (__WORDSIZE != 64)
+ 
+ #define __LOCK_ALIGNMENT
+ #define __ONCE_ALIGNMENT
+diff --git a/sysdeps/tile/nptl/bits/pthreadtypes-arch.h b/sysdeps/tile/nptl/bits/pthreadtypes-arch.h
+index 145ee42ddb..054474f770 100644
+--- a/sysdeps/tile/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/tile/nptl/bits/pthreadtypes-arch.h
+@@ -43,6 +43,8 @@
+ #define __PTHREAD_COMPAT_PADDING_MID
+ #define __PTHREAD_COMPAT_PADDING_END
+ #define __PTHREAD_MUTEX_LOCK_ELISION    0
++#define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  (__WORDSIZE != 64)
++#define __PTHREAD_MUTEX_USE_UNION          (__WORDSIZE != 64)
+ 
+ #define __LOCK_ALIGNMENT
+ #define __ONCE_ALIGNMENT
+diff --git a/sysdeps/x86/nptl/bits/pthreadtypes-arch.h b/sysdeps/x86/nptl/bits/pthreadtypes-arch.h
+index fd86806800..74d5f6d6e8 100644
+--- a/sysdeps/x86/nptl/bits/pthreadtypes-arch.h
++++ b/sysdeps/x86/nptl/bits/pthreadtypes-arch.h
+@@ -51,6 +51,13 @@
+ #define __PTHREAD_COMPAT_PADDING_MID
+ #define __PTHREAD_COMPAT_PADDING_END
+ #define __PTHREAD_MUTEX_LOCK_ELISION    1
++#ifdef __x86_64__
++# define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  0
++# define __PTHREAD_MUTEX_USE_UNION          0
++#else
++# define __PTHREAD_MUTEX_NUSERS_AFTER_KIND  1
++# define __PTHREAD_MUTEX_USE_UNION          1
++#endif
+ 
+ #define __LOCK_ALIGNMENT
+ #define __ONCE_ALIGNMENT
diff --git a/gnu/packages/patches/glibc-2-26-0080.patch b/gnu/packages/patches/glibc-2-26-0080.patch
new file mode 100644
index 000000000..7e30e24ee
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0080.patch
@@ -0,0 +1,50 @@
+From 6a094c0ff15dbf71e87eccc57e192a7b55cf79b0 Mon Sep 17 00:00:00 2001
+From: "H.J. Lu" <hjl.tools@gmail.com>
+Date: Wed, 23 Aug 2017 09:11:41 -0700
+Subject: [PATCH 80/90] x86-64: Regenerate libm-test-ulps for AVX512 mathvec
+ tests
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+Update libm-test-ulps for AVX512 mathvec tests by running
+“make regen-ulps” on Intel Xeon processor with AVX512.
+
+	* sysdeps/x86_64/fpu/libm-test-ulps: Regenerated.
+
+(cherry picked from commit fcaaca412fecb6097c902acd1260f585819b8b7e)
+
+diff --git a/ChangeLog b/ChangeLog
+index a314b167f3..e084305548 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,7 @@
++2017-08-23  H.J. Lu  <hongjiu.lu@intel.com>
++
++	* sysdeps/x86_64/fpu/libm-test-ulps: Regenerated.
++
+ 2017-11-07  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
+ 
+ 	[BZ #22298]
+diff --git a/sysdeps/x86_64/fpu/libm-test-ulps b/sysdeps/x86_64/fpu/libm-test-ulps
+index 1e28aaa9f1..e7ec433b7b 100644
+--- a/sysdeps/x86_64/fpu/libm-test-ulps
++++ b/sysdeps/x86_64/fpu/libm-test-ulps
+@@ -1305,7 +1305,7 @@ Function: "cos_vlen4_avx2":
+ double: 2
+ 
+ Function: "cos_vlen8":
+-double: 1
++double: 2
+ float: 1
+ 
+ Function: "cos_vlen8_avx2":
+@@ -2645,7 +2645,7 @@ Function: "sincos_vlen4_avx2":
+ double: 2
+ 
+ Function: "sincos_vlen8":
+-double: 1
++double: 2
+ float: 1
+ 
+ Function: "sincos_vlen8_avx2":
diff --git a/gnu/packages/patches/glibc-2-26-0081.patch b/gnu/packages/patches/glibc-2-26-0081.patch
new file mode 100644
index 000000000..ecf167271
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0081.patch
@@ -0,0 +1,84 @@
+From 77f921dac17c5fa99bd9e926d926c327982895f7 Mon Sep 17 00:00:00 2001
+From: James Clarke <jrtc27@jrtc27.com>
+Date: Fri, 13 Oct 2017 15:44:39 -0300
+Subject: [PATCH 81/90] Fix TLS relocations against local symbols on powerpc32,
+ sparc32 and sparc64
+
+Normally, TLS relocations against local symbols are optimised by the linker
+to be absolute.  However, gold does not do this, and so it is possible to
+end up with, for example, R_SPARC_TLS_DTPMOD64 referring to a local symbol.
+Since sym_map is left as null in elf_machine_rela for the special local
+symbol case, the relocation handling thinks it has nothing to do, and so
+the module gets left as 0.  Havoc then ensues when the variable in question
+is accessed.
+
+Before this fix, the main_local_gold program would receive a SIGBUS on
+sparc64, and SIGSEGV on powerpc32.  With this fix applied, that test now
+passes like the rest of them.
+
+	* sysdeps/powerpc/powerpc32/dl-machine.h (elf_machine_rela):
+	Assign sym_map to be map for local symbols, as TLS relocations
+	use sym_map to determine whether the symbol is defined and to
+	extract the TLS information.
+	* sysdeps/sparc/sparc32/dl-machine.h (elf_machine_rela): Likewise.
+	* sysdeps/sparc/sparc64/dl-machine.h (elf_machine_rela): Likewise.
+
+(cherry picked from commit 8644588807215ab09716ac04a150f91ac83acffd)
+
+diff --git a/ChangeLog b/ChangeLog
+index e084305548..e17a716e53 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,12 @@
++2017-10-13  James Clarke  <jrtc27@jrtc27.com>
++
++	* sysdeps/powerpc/powerpc32/dl-machine.h (elf_machine_rela):
++	Assign sym_map to be map for local symbols, as TLS relocations
++	use sym_map to determine whether the symbol is defined and to
++	extract the TLS information.
++	* sysdeps/sparc/sparc32/dl-machine.h (elf_machine_rela): Likewise.
++	* sysdeps/sparc/sparc64/dl-machine.h (elf_machine_rela): Likewise.
++
+ 2017-08-23  H.J. Lu  <hongjiu.lu@intel.com>
+ 
+ 	* sysdeps/x86_64/fpu/libm-test-ulps: Regenerated.
+diff --git a/sysdeps/powerpc/powerpc32/dl-machine.h b/sysdeps/powerpc/powerpc32/dl-machine.h
+index 1f8437ed9c..c19b3b7a16 100644
+--- a/sysdeps/powerpc/powerpc32/dl-machine.h
++++ b/sysdeps/powerpc/powerpc32/dl-machine.h
+@@ -310,7 +310,10 @@ elf_machine_rela (struct link_map *map, const Elf32_Rela *reloc,
+      against local symbols.  */
+   if (__builtin_expect (ELF32_ST_BIND (sym->st_info) == STB_LOCAL, 0)
+       && sym->st_shndx != SHN_UNDEF)
+-    value = map->l_addr;
++    {
++      sym_map = map;
++      value = map->l_addr;
++    }
+   else
+     {
+       sym_map = RESOLVE_MAP (&sym, version, r_type);
+diff --git a/sysdeps/sparc/sparc32/dl-machine.h b/sysdeps/sparc/sparc32/dl-machine.h
+index 436e4e6cc3..debf67bd1b 100644
+--- a/sysdeps/sparc/sparc32/dl-machine.h
++++ b/sysdeps/sparc/sparc32/dl-machine.h
+@@ -376,6 +376,7 @@ elf_machine_rela (struct link_map *map, const Elf32_Rela *reloc,
+   if (__builtin_expect (ELF32_ST_BIND (sym->st_info) == STB_LOCAL, 0)
+       && sym->st_shndx != SHN_UNDEF)
+     {
++      sym_map = map;
+       value = map->l_addr;
+     }
+   else
+diff --git a/sysdeps/sparc/sparc64/dl-machine.h b/sysdeps/sparc/sparc64/dl-machine.h
+index c2871dca3a..e1ec7a532c 100644
+--- a/sysdeps/sparc/sparc64/dl-machine.h
++++ b/sysdeps/sparc/sparc64/dl-machine.h
+@@ -403,6 +403,7 @@ elf_machine_rela (struct link_map *map, const Elf64_Rela *reloc,
+   if (__builtin_expect (ELF64_ST_BIND (sym->st_info) == STB_LOCAL, 0)
+       && sym->st_shndx != SHN_UNDEF)
+     {
++      sym_map = map;
+       value = map->l_addr;
+     }
+   else
diff --git a/gnu/packages/patches/glibc-2-26-0082.patch b/gnu/packages/patches/glibc-2-26-0082.patch
new file mode 100644
index 000000000..db14023a6
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0082.patch
@@ -0,0 +1,51 @@
+From ade53e0df7a1257c54ce96e01fa659b374db2117 Mon Sep 17 00:00:00 2001
+From: Wilco Dijkstra <wdijkstr@arm.com>
+Date: Tue, 17 Oct 2017 18:25:43 +0100
+Subject: [PATCH 82/90] Inline tcache functions
+
+The functions tcache_get and tcache_put show up in profiles as they
+are a critical part of the tcache code.  Inline them to give tcache
+a 16% performance gain.  Since this improves multi-threaded cases
+as well, it helps offset any potential performance loss due to adding
+single-threaded fast paths.
+
+	* malloc/malloc.c (tcache_put): Inline.
+	(tcache_get): Inline.
+
+(cherry-picked from commit e4dd4ace56880d2f1064cd787e2bdb96ddacc3c4)
+
+diff --git a/ChangeLog b/ChangeLog
+index e17a716e53..192acbf7d5 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-10-17  Wilco Dijkstra  <wdijkstr@arm.com>
++
++	* malloc/malloc.c (tcache_put): Inline.
++	(tcache_get): Inline.
++
+ 2017-10-13  James Clarke  <jrtc27@jrtc27.com>
+ 
+ 	* sysdeps/powerpc/powerpc32/dl-machine.h (elf_machine_rela):
+diff --git a/malloc/malloc.c b/malloc/malloc.c
+index 01ec1571b9..546579bce4 100644
+--- a/malloc/malloc.c
++++ b/malloc/malloc.c
+@@ -2957,7 +2957,7 @@ static __thread tcache_perthread_struct *tcache = NULL;
+ 
+ /* Caller must ensure that we know tc_idx is valid and there's room
+    for more chunks.  */
+-static void
++static __always_inline void
+ tcache_put (mchunkptr chunk, size_t tc_idx)
+ {
+   tcache_entry *e = (tcache_entry *) chunk2mem (chunk);
+@@ -2969,7 +2969,7 @@ tcache_put (mchunkptr chunk, size_t tc_idx)
+ 
+ /* Caller must ensure that we know tc_idx is valid and there's
+    available chunks to remove.  */
+-static void *
++static __always_inline void *
+ tcache_get (size_t tc_idx)
+ {
+   tcache_entry *e = tcache->entries[tc_idx];
diff --git a/gnu/packages/patches/glibc-2-26-0083.patch b/gnu/packages/patches/glibc-2-26-0083.patch
new file mode 100644
index 000000000..d1ca35f7c
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0083.patch
@@ -0,0 +1,180 @@
+From aa5be982ea1f59ee1e479fe9a561aeafd91a2261 Mon Sep 17 00:00:00 2001
+From: Siddhesh Poyarekar <siddhesh@sourceware.org>
+Date: Thu, 16 Nov 2017 12:21:27 +0530
+Subject: [PATCH 83/90] Use relaxed atomics for malloc have_fastchunks
+
+Currently free typically uses 2 atomic operations per call.  The have_fastchunks
+flag indicates whether there are recently freed blocks in the fastbins.  This
+is purely an optimization to avoid calling malloc_consolidate too often and
+avoiding the overhead of walking all fast bins even if all are empty during a
+sequence of allocations.  However using catomic_or to update the flag is
+completely unnecessary since it can be changed into a simple boolean and
+accessed using relaxed atomics.  There is no change in multi-threaded behaviour
+given the flag is already approximate (it may be set when there are no blocks in
+any fast bins, or it may be clear when there are free blocks that could be
+consolidated).
+
+Performance of malloc/free improves by 27% on a simple benchmark on AArch64
+(both single and multithreaded). The number of load/store exclusive instructions
+is reduced by 33%. Bench-malloc-thread speeds up by ~3% in all cases.
+
+	* malloc/malloc.c (FASTCHUNKS_BIT): Remove.
+	(have_fastchunks): Remove.
+	(clear_fastchunks): Remove.
+	(set_fastchunks): Remove.
+	(malloc_state): Add have_fastchunks.
+	(malloc_init_state): Use have_fastchunks.
+	(do_check_malloc_state): Remove incorrect invariant checks.
+	(_int_malloc): Use have_fastchunks.
+	(_int_free): Likewise.
+	(malloc_consolidate): Likewise.
+
+(cherry-picked from e956075a5a2044d05ce48b905b10270ed4a63e87)
+
+diff --git a/ChangeLog b/ChangeLog
+index 192acbf7d5..67d3503afe 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,16 @@
++2017-10-17  Wilco Dijkstra  <wdijkstr@arm.com>
++
++	* malloc/malloc.c (FASTCHUNKS_BIT): Remove.
++	(have_fastchunks): Remove.
++	(clear_fastchunks): Remove.
++	(set_fastchunks): Remove.
++	(malloc_state): Add have_fastchunks.
++	(malloc_init_state): Use have_fastchunks.
++	(do_check_malloc_state): Remove incorrect invariant checks.
++	(_int_malloc): Use have_fastchunks.
++	(_int_free): Likewise.
++	(malloc_consolidate): Likewise.
++
+ 2017-10-17  Wilco Dijkstra  <wdijkstr@arm.com>
+ 
+ 	* malloc/malloc.c (tcache_put): Inline.
+diff --git a/malloc/malloc.c b/malloc/malloc.c
+index 546579bce4..37e3c44e72 100644
+--- a/malloc/malloc.c
++++ b/malloc/malloc.c
+@@ -1612,27 +1612,6 @@ typedef struct malloc_chunk *mfastbinptr;
+ 
+ #define FASTBIN_CONSOLIDATION_THRESHOLD  (65536UL)
+ 
+-/*
+-   Since the lowest 2 bits in max_fast don't matter in size comparisons,
+-   they are used as flags.
+- */
+-
+-/*
+-   FASTCHUNKS_BIT held in max_fast indicates that there are probably
+-   some fastbin chunks. It is set true on entering a chunk into any
+-   fastbin, and cleared only in malloc_consolidate.
+-
+-   The truth value is inverted so that have_fastchunks will be true
+-   upon startup (since statics are zero-filled), simplifying
+-   initialization checks.
+- */
+-
+-#define FASTCHUNKS_BIT        (1U)
+-
+-#define have_fastchunks(M)     (((M)->flags & FASTCHUNKS_BIT) == 0)
+-#define clear_fastchunks(M)    catomic_or (&(M)->flags, FASTCHUNKS_BIT)
+-#define set_fastchunks(M)      catomic_and (&(M)->flags, ~FASTCHUNKS_BIT)
+-
+ /*
+    NONCONTIGUOUS_BIT indicates that MORECORE does not return contiguous
+    regions.  Otherwise, contiguity is exploited in merging together,
+@@ -1690,6 +1669,17 @@ get_max_fast (void)
+    ----------- Internal state representation and initialization -----------
+  */
+ 
++/*
++   have_fastchunks indicates that there are probably some fastbin chunks.
++   It is set true on entering a chunk into any fastbin, and cleared early in
++   malloc_consolidate.  The value is approximate since it may be set when there
++   are no fastbin chunks, or it may be clear even if there are fastbin chunks
++   available.  Given it's sole purpose is to reduce number of redundant calls to
++   malloc_consolidate, it does not affect correctness.  As a result we can safely
++   use relaxed atomic accesses.
++ */
++
++
+ struct malloc_state
+ {
+   /* Serialize access.  */
+@@ -1698,6 +1688,9 @@ struct malloc_state
+   /* Flags (formerly in max_fast).  */
+   int flags;
+ 
++  /* Set if the fastbin chunks contain recently inserted free blocks.  */
++  bool have_fastchunks;
++
+   /* Fastbins */
+   mfastbinptr fastbinsY[NFASTBINS];
+ 
+@@ -1841,7 +1834,7 @@ malloc_init_state (mstate av)
+   set_noncontiguous (av);
+   if (av == &main_arena)
+     set_max_fast (DEFAULT_MXFAST);
+-  av->flags |= FASTCHUNKS_BIT;
++  atomic_store_relaxed (&av->have_fastchunks, false);
+ 
+   av->top = initial_top (av);
+ }
+@@ -2206,11 +2199,6 @@ do_check_malloc_state (mstate av)
+         }
+     }
+ 
+-  if (total != 0)
+-    assert (have_fastchunks (av));
+-  else if (!have_fastchunks (av))
+-    assert (total == 0);
+-
+   /* check normal bins */
+   for (i = 1; i < NBINS; ++i)
+     {
+@@ -3701,7 +3689,7 @@ _int_malloc (mstate av, size_t bytes)
+   else
+     {
+       idx = largebin_index (nb);
+-      if (have_fastchunks (av))
++      if (atomic_load_relaxed (&av->have_fastchunks))
+         malloc_consolidate (av);
+     }
+ 
+@@ -4116,7 +4104,7 @@ _int_malloc (mstate av, size_t bytes)
+ 
+       /* When we are using atomic ops to free fast chunks we can get
+          here for all block sizes.  */
+-      else if (have_fastchunks (av))
++      else if (atomic_load_relaxed (&av->have_fastchunks))
+         {
+           malloc_consolidate (av);
+           /* restore original bin index */
+@@ -4242,7 +4230,7 @@ _int_free (mstate av, mchunkptr p, int have_lock)
+ 
+     free_perturb (chunk2mem(p), size - 2 * SIZE_SZ);
+ 
+-    set_fastchunks(av);
++    atomic_store_relaxed (&av->have_fastchunks, true);
+     unsigned int idx = fastbin_index(size);
+     fb = &fastbin (av, idx);
+ 
+@@ -4393,7 +4381,7 @@ _int_free (mstate av, mchunkptr p, int have_lock)
+     */
+ 
+     if ((unsigned long)(size) >= FASTBIN_CONSOLIDATION_THRESHOLD) {
+-      if (have_fastchunks(av))
++      if (atomic_load_relaxed (&av->have_fastchunks))
+ 	malloc_consolidate(av);
+ 
+       if (av == &main_arena) {
+@@ -4464,7 +4452,7 @@ static void malloc_consolidate(mstate av)
+   */
+ 
+   if (get_max_fast () != 0) {
+-    clear_fastchunks(av);
++    atomic_store_relaxed (&av->have_fastchunks, false);
+ 
+     unsorted_bin = unsorted_chunks(av);
+ 
diff --git a/gnu/packages/patches/glibc-2-26-0084.patch b/gnu/packages/patches/glibc-2-26-0084.patch
new file mode 100644
index 000000000..aa7b3edf8
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0084.patch
@@ -0,0 +1,37 @@
+From a546080d517c8833ce1d6abdb86a9293c8d29bae Mon Sep 17 00:00:00 2001
+From: Wilco Dijkstra <wdijkstr@arm.com>
+Date: Wed, 18 Oct 2017 12:20:55 +0100
+Subject: [PATCH 84/90] Fix build failure on tilepro due to unsupported atomics
+
+        * malloc/malloc.c (malloc_state): Use int for have_fastchunks since
+        not all targets support atomics on bool.
+
+(cherry-picked from 2c2245b92ccf6344b324d17d8f94ccd3b8c559c6)
+
+diff --git a/ChangeLog b/ChangeLog
+index 67d3503afe..d67ad031bc 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-10-18  Wilco Dijkstra  <wdijkstr@arm.com>
++
++	* malloc/malloc.c (malloc_state): Use int for have_fastchunks since
++	not all targets support atomics on bool.
++
+ 2017-10-17  Wilco Dijkstra  <wdijkstr@arm.com>
+ 
+ 	* malloc/malloc.c (FASTCHUNKS_BIT): Remove.
+diff --git a/malloc/malloc.c b/malloc/malloc.c
+index 37e3c44e72..dd9f699d97 100644
+--- a/malloc/malloc.c
++++ b/malloc/malloc.c
+@@ -1689,7 +1689,8 @@ struct malloc_state
+   int flags;
+ 
+   /* Set if the fastbin chunks contain recently inserted free blocks.  */
+-  bool have_fastchunks;
++  /* Note this is a bool but not all targets support atomics on booleans.  */
++  int have_fastchunks;
+ 
+   /* Fastbins */
+   mfastbinptr fastbinsY[NFASTBINS];
diff --git a/gnu/packages/patches/glibc-2-26-0085.patch b/gnu/packages/patches/glibc-2-26-0085.patch
new file mode 100644
index 000000000..70c256ee5
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0085.patch
@@ -0,0 +1,114 @@
+From 82b166320262b105136eef99da7552474d5a046f Mon Sep 17 00:00:00 2001
+From: Guido Trentalancia <guido@trentalancia.net>
+Date: Sat, 18 Nov 2017 19:26:57 +0100
+Subject: [PATCH 85/90] crypt: Use NSPR header files in addition to NSS header
+ files [BZ #17956]
+
+When configuring and building GNU libc using the Mozilla NSS library
+for cryptography (--enable-nss-crypt option), also include the
+NSPR header files along with the Mozilla NSS library header files.
+
+Finally, when running the check-local-headers test, ignore the
+Mozilla NSPR library header files (used by the Mozilla NSS library).
+
+(cherry picked from commit 57b4af1955e28c1623c98397b8597847d16bdd8c)
+
+diff --git a/ChangeLog b/ChangeLog
+index d67ad031bc..0693e834dd 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,14 @@
++2017-10-04  Guido Trentalancia  <guido@trentalancia.net>
++
++	[BZ #17956]
++	* configure.ac (--enable-nss-crypt): Use NSPR include directory.
++	* configure: Regenerate.
++	* crypt/Makefile (nss-cpp-flags): New variable.
++	(CPPFLAGS-sha256-crypt.c, CPPFLAGS-sha512-crypt.c)
++	(CPPFLAGS-md5-crypt.c): Use it.
++	* scripts/check-local-headers.sh: Ignore nspr header file
++	directory.
++
+ 2017-10-18  Wilco Dijkstra  <wdijkstr@arm.com>
+ 
+ 	* malloc/malloc.c (malloc_state): Use int for have_fastchunks since
+diff --git a/NEWS b/NEWS
+index ea1c1f1c04..e7b62a8d46 100644
+--- a/NEWS
++++ b/NEWS
+@@ -23,6 +23,7 @@ Security related changes:
+ The following bugs are resolved with this release:
+ 
+   [16750] ldd: Never run file directly.
++  [17956] crypt: Use NSPR header files in addition to NSS header files
+   [21242] assert: Suppress pedantic warning caused by statement expression
+   [21265] x86-64: Use fxsave/xsave/xsavec in _dl_runtime_resolve
+   [21780] posix: Set p{read,write}v2 to return ENOTSUP
+diff --git a/configure b/configure
+index d8e1c50e11..47d8c75248 100755
+--- a/configure
++++ b/configure
+@@ -3547,8 +3547,12 @@ if test x$nss_crypt = xyes; then
+   if test $? -ne 0; then
+     as_fn_error $? "cannot find include directory with nss-config" "$LINENO" 5
+   fi
++  nspr_includes=-I$(nspr-config --includedir 2>/dev/null)
++  if test $? -ne 0; then
++    as_fn_error $? "cannot find include directory with nspr-config" "$LINENO" 5
++  fi
+   old_CFLAGS="$CFLAGS"
+-  CFLAGS="$CFLAGS $nss_includes"
++  CFLAGS="$CFLAGS $nss_includes $nspr_includes"
+ 
+ cat confdefs.h - <<_ACEOF >conftest.$ac_ext
+ /* end confdefs.h.  */
+diff --git a/configure.ac b/configure.ac
+index 77456aa8d9..e8a1ab3562 100644
+--- a/configure.ac
++++ b/configure.ac
+@@ -330,8 +330,12 @@ if test x$nss_crypt = xyes; then
+   if test $? -ne 0; then
+     AC_MSG_ERROR([cannot find include directory with nss-config])
+   fi
++  nspr_includes=-I$(nspr-config --includedir 2>/dev/null)
++  if test $? -ne 0; then
++    AC_MSG_ERROR([cannot find include directory with nspr-config])
++  fi
+   old_CFLAGS="$CFLAGS"
+-  CFLAGS="$CFLAGS $nss_includes"
++  CFLAGS="$CFLAGS $nss_includes $nspr_includes"
+   AC_COMPILE_IFELSE([AC_LANG_PROGRAM([typedef int PRBool;
+ #include <hasht.h>
+ #include <nsslowhash.h>
+diff --git a/crypt/Makefile b/crypt/Makefile
+index 0280fba8a7..8bbbf2a121 100644
+--- a/crypt/Makefile
++++ b/crypt/Makefile
+@@ -37,9 +37,11 @@ routines += $(libcrypt-routines)
+ endif
+ 
+ ifeq ($(nss-crypt),yes)
+-CPPFLAGS-sha256-crypt.c = -DUSE_NSS -I$(shell nss-config --includedir)
+-CPPFLAGS-sha512-crypt.c = -DUSE_NSS -I$(shell nss-config --includedir)
+-CPPFLAGS-md5-crypt.c = -DUSE_NSS -I$(shell nss-config --includedir)
++nss-cpp-flags := -DUSE_NSS \
++  -I$(shell nss-config --includedir) -I$(shell nspr-config --includedir)
++CPPFLAGS-sha256-crypt.c = $(nss-cpp-flags)
++CPPFLAGS-sha512-crypt.c = $(nss-cpp-flags)
++CPPFLAGS-md5-crypt.c = $(nss-cpp-flags)
+ LDLIBS-crypt.so = -lfreebl3
+ else
+ libcrypt-routines += md5 sha256 sha512
+diff --git a/scripts/check-local-headers.sh b/scripts/check-local-headers.sh
+index 7859f613b2..4692361686 100755
+--- a/scripts/check-local-headers.sh
++++ b/scripts/check-local-headers.sh
+@@ -33,7 +33,7 @@ exec ${AWK} -v includedir="$includedir" '
+ BEGIN {
+   status = 0
+   exclude = "^" includedir \
+-    "/(.*-.*-.*/|.*-.*/|)(asm[-/]|arch|linux/|selinux/|mach/|mach_debug/|device/|hurd/(((hurd|ioctl)_types|paths)\\.h|ioctls\\.defs|ihash\\.h)|cthreads\\.h|gd|nss3/|c\\+\\+/|sys/(capability|sdt(|-config))\\.h|libaudit\\.h)"
++    "/(.*-.*-.*/|.*-.*/|)(asm[-/]|arch|linux/|selinux/|mach/|mach_debug/|device/|hurd/(((hurd|ioctl)_types|paths)\\.h|ioctls\\.defs|ihash\\.h)|cthreads\\.h|gd|nss3/|nspr/|c\\+\\+/|sys/(capability|sdt(|-config))\\.h|libaudit\\.h)"
+ }
+ /^[^ ]/ && $1 ~ /.*:/ { obj = $1 }
+ {
diff --git a/gnu/packages/patches/glibc-2-26-0086.patch b/gnu/packages/patches/glibc-2-26-0086.patch
new file mode 100644
index 000000000..a1f7ba367
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0086.patch
@@ -0,0 +1,34 @@
+From 2767ebd8bc34c8b632ea737296200a86f57289ad Mon Sep 17 00:00:00 2001
+From: Florian Weimer <fweimer@redhat.com>
+Date: Wed, 4 Oct 2017 15:49:06 +0200
+Subject: [PATCH 86/90] crypt: Adjust check-local-headers.sh for nspr4 include
+ directory [BZ #17956]
+
+(cherry picked from commit 11c4f5010c58029e73e656d5df4f8f42c9b8e877)
+
+diff --git a/ChangeLog b/ChangeLog
+index 0693e834dd..eb9204d972 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-10-04  Florian Weimer  <fweimer@redhat.com>
++
++	* scripts/check-local-headers.sh: Ignore nspr4 header file
++	directory in addition to nspr.
++
+ 2017-10-04  Guido Trentalancia  <guido@trentalancia.net>
+ 
+ 	[BZ #17956]
+diff --git a/scripts/check-local-headers.sh b/scripts/check-local-headers.sh
+index 4692361686..0cde6e8e92 100755
+--- a/scripts/check-local-headers.sh
++++ b/scripts/check-local-headers.sh
+@@ -33,7 +33,7 @@ exec ${AWK} -v includedir="$includedir" '
+ BEGIN {
+   status = 0
+   exclude = "^" includedir \
+-    "/(.*-.*-.*/|.*-.*/|)(asm[-/]|arch|linux/|selinux/|mach/|mach_debug/|device/|hurd/(((hurd|ioctl)_types|paths)\\.h|ioctls\\.defs|ihash\\.h)|cthreads\\.h|gd|nss3/|nspr/|c\\+\\+/|sys/(capability|sdt(|-config))\\.h|libaudit\\.h)"
++    "/(.*-.*-.*/|.*-.*/|)(asm[-/]|arch|linux/|selinux/|mach/|mach_debug/|device/|hurd/(((hurd|ioctl)_types|paths)\\.h|ioctls\\.defs|ihash\\.h)|cthreads\\.h|gd|nss3/|nspr4?/|c\\+\\+/|sys/(capability|sdt(|-config))\\.h|libaudit\\.h)"
+ }
+ /^[^ ]/ && $1 ~ /.*:/ { obj = $1 }
+ {
diff --git a/gnu/packages/patches/glibc-2-26-0087.patch b/gnu/packages/patches/glibc-2-26-0087.patch
new file mode 100644
index 000000000..390bc5c3a
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0087.patch
@@ -0,0 +1,332 @@
+From 6850e9c6bad862a1b982f456096c54946c2aaeab Mon Sep 17 00:00:00 2001
+From: Rajalakshmi Srinivasaraghavan <raji@linux.vnet.ibm.com>
+Date: Tue, 21 Nov 2017 22:32:20 +0530
+Subject: [PATCH 87/90] powerpc: Replace lxvd2x/stxvd2x with lvx/stvx in P7's
+ memcpy/memmove
+
+POWER9 DD2.1 and earlier has an issue where some cache inhibited
+vector load traps to the kernel, causing a performance degradation.  To
+handle this in memcpy and memmove, lvx/stvx is used for aligned
+addresses instead of lxvd2x/stxvd2x.
+
+Reference: https://patchwork.ozlabs.org/patch/814059/
+
+	* sysdeps/powerpc/powerpc64/power7/memcpy.S: Replace
+	lxvd2x/stxvd2x with lvx/stvx.
+	* sysdeps/powerpc/powerpc64/power7/memmove.S: Likewise.
+
+Reviewed-by: Tulio Magno Quites Machado Filho <tuliom@linux.vnet.ibm.com>
+Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
+
+(cherry picked from commit 63da5cd4a097d089033d980c42254c3356fa723f)
+
+diff --git a/ChangeLog b/ChangeLog
+index eb9204d972..c72c239620 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-11-21  Rajalakshmi Srinivasaraghavan  <raji@linux.vnet.ibm.com>
++
++	* sysdeps/powerpc/powerpc64/power7/memcpy.S: Replace
++	lxvd2x/stxvd2x with lvx/stvx.
++	* sysdeps/powerpc/powerpc64/power7/memmove.S: Likewise.
++
+ 2017-10-04  Florian Weimer  <fweimer@redhat.com>
+ 
+ 	* scripts/check-local-headers.sh: Ignore nspr4 header file
+diff --git a/sysdeps/powerpc/powerpc64/power7/memcpy.S b/sysdeps/powerpc/powerpc64/power7/memcpy.S
+index 641c7e2118..c9b6507d1b 100644
+--- a/sysdeps/powerpc/powerpc64/power7/memcpy.S
++++ b/sysdeps/powerpc/powerpc64/power7/memcpy.S
+@@ -91,63 +91,63 @@ L(aligned_copy):
+ 	srdi	12,cnt,7
+ 	cmpdi	12,0
+ 	beq	L(aligned_tail)
+-	lxvd2x	6,0,src
+-	lxvd2x	7,src,6
++	lvx	6,0,src
++	lvx	7,src,6
+ 	mtctr	12
+ 	b	L(aligned_128loop)
+ 
+ 	.align  4
+ L(aligned_128head):
+ 	/* for the 2nd + iteration of this loop. */
+-	lxvd2x	6,0,src
+-	lxvd2x	7,src,6
++	lvx	6,0,src
++	lvx	7,src,6
+ L(aligned_128loop):
+-	lxvd2x	8,src,7
+-	lxvd2x	9,src,8
+-	stxvd2x	6,0,dst
++	lvx	8,src,7
++	lvx	9,src,8
++	stvx	6,0,dst
+ 	addi	src,src,64
+-	stxvd2x	7,dst,6
+-	stxvd2x	8,dst,7
+-	stxvd2x	9,dst,8
+-	lxvd2x	6,0,src
+-	lxvd2x	7,src,6
++	stvx	7,dst,6
++	stvx	8,dst,7
++	stvx	9,dst,8
++	lvx	6,0,src
++	lvx	7,src,6
+ 	addi	dst,dst,64
+-	lxvd2x	8,src,7
+-	lxvd2x	9,src,8
++	lvx	8,src,7
++	lvx	9,src,8
+ 	addi	src,src,64
+-	stxvd2x	6,0,dst
+-	stxvd2x	7,dst,6
+-	stxvd2x	8,dst,7
+-	stxvd2x	9,dst,8
++	stvx	6,0,dst
++	stvx	7,dst,6
++	stvx	8,dst,7
++	stvx	9,dst,8
+ 	addi	dst,dst,64
+ 	bdnz	L(aligned_128head)
+ 
+ L(aligned_tail):
+ 	mtocrf	0x01,cnt
+ 	bf	25,32f
+-	lxvd2x	6,0,src
+-	lxvd2x	7,src,6
+-	lxvd2x	8,src,7
+-	lxvd2x	9,src,8
++	lvx	6,0,src
++	lvx	7,src,6
++	lvx	8,src,7
++	lvx	9,src,8
+ 	addi	src,src,64
+-	stxvd2x	6,0,dst
+-	stxvd2x	7,dst,6
+-	stxvd2x	8,dst,7
+-	stxvd2x	9,dst,8
++	stvx	6,0,dst
++	stvx	7,dst,6
++	stvx	8,dst,7
++	stvx	9,dst,8
+ 	addi	dst,dst,64
+ 32:
+ 	bf	26,16f
+-	lxvd2x	6,0,src
+-	lxvd2x	7,src,6
++	lvx	6,0,src
++	lvx	7,src,6
+ 	addi	src,src,32
+-	stxvd2x	6,0,dst
+-	stxvd2x	7,dst,6
++	stvx	6,0,dst
++	stvx	7,dst,6
+ 	addi	dst,dst,32
+ 16:
+ 	bf	27,8f
+-	lxvd2x	6,0,src
++	lvx	6,0,src
+ 	addi	src,src,16
+-	stxvd2x	6,0,dst
++	stvx	6,0,dst
+ 	addi	dst,dst,16
+ 8:
+ 	bf	28,4f
+diff --git a/sysdeps/powerpc/powerpc64/power7/memmove.S b/sysdeps/powerpc/powerpc64/power7/memmove.S
+index 93baa69ee2..667c6e2092 100644
+--- a/sysdeps/powerpc/powerpc64/power7/memmove.S
++++ b/sysdeps/powerpc/powerpc64/power7/memmove.S
+@@ -92,63 +92,63 @@ L(aligned_copy):
+ 	srdi	12,r5,7
+ 	cmpdi	12,0
+ 	beq	L(aligned_tail)
+-	lxvd2x	6,0,r4
+-	lxvd2x	7,r4,6
++	lvx	6,0,r4
++	lvx	7,r4,6
+ 	mtctr	12
+ 	b	L(aligned_128loop)
+ 
+ 	.align  4
+ L(aligned_128head):
+ 	/* for the 2nd + iteration of this loop. */
+-	lxvd2x	6,0,r4
+-	lxvd2x	7,r4,6
++	lvx	6,0,r4
++	lvx	7,r4,6
+ L(aligned_128loop):
+-	lxvd2x	8,r4,7
+-	lxvd2x	9,r4,8
+-	stxvd2x	6,0,r11
++	lvx	8,r4,7
++	lvx	9,r4,8
++	stvx	6,0,r11
+ 	addi	r4,r4,64
+-	stxvd2x	7,r11,6
+-	stxvd2x	8,r11,7
+-	stxvd2x	9,r11,8
+-	lxvd2x	6,0,r4
+-	lxvd2x	7,r4,6
++	stvx	7,r11,6
++	stvx	8,r11,7
++	stvx	9,r11,8
++	lvx	6,0,r4
++	lvx	7,r4,6
+ 	addi	r11,r11,64
+-	lxvd2x	8,r4,7
+-	lxvd2x	9,r4,8
++	lvx	8,r4,7
++	lvx	9,r4,8
+ 	addi	r4,r4,64
+-	stxvd2x	6,0,r11
+-	stxvd2x	7,r11,6
+-	stxvd2x	8,r11,7
+-	stxvd2x	9,r11,8
++	stvx	6,0,r11
++	stvx	7,r11,6
++	stvx	8,r11,7
++	stvx	9,r11,8
+ 	addi	r11,r11,64
+ 	bdnz	L(aligned_128head)
+ 
+ L(aligned_tail):
+ 	mtocrf	0x01,r5
+ 	bf	25,32f
+-	lxvd2x	6,0,r4
+-	lxvd2x	7,r4,6
+-	lxvd2x	8,r4,7
+-	lxvd2x	9,r4,8
++	lvx	6,0,r4
++	lvx	7,r4,6
++	lvx	8,r4,7
++	lvx	9,r4,8
+ 	addi	r4,r4,64
+-	stxvd2x	6,0,r11
+-	stxvd2x	7,r11,6
+-	stxvd2x	8,r11,7
+-	stxvd2x	9,r11,8
++	stvx	6,0,r11
++	stvx	7,r11,6
++	stvx	8,r11,7
++	stvx	9,r11,8
+ 	addi	r11,r11,64
+ 32:
+ 	bf	26,16f
+-	lxvd2x	6,0,r4
+-	lxvd2x	7,r4,6
++	lvx	6,0,r4
++	lvx	7,r4,6
+ 	addi	r4,r4,32
+-	stxvd2x	6,0,r11
+-	stxvd2x	7,r11,6
++	stvx	6,0,r11
++	stvx	7,r11,6
+ 	addi	r11,r11,32
+ 16:
+ 	bf	27,8f
+-	lxvd2x	6,0,r4
++	lvx	6,0,r4
+ 	addi	r4,r4,16
+-	stxvd2x	6,0,r11
++	stvx	6,0,r11
+ 	addi	r11,r11,16
+ 8:
+ 	bf	28,4f
+@@ -488,63 +488,63 @@ L(aligned_copy_bwd):
+ 	srdi	r12,r5,7
+ 	cmpdi	r12,0
+ 	beq	L(aligned_tail_bwd)
+-	lxvd2x	v6,r4,r6
+-	lxvd2x	v7,r4,r7
++	lvx	v6,r4,r6
++	lvx	v7,r4,r7
+ 	mtctr	12
+ 	b	L(aligned_128loop_bwd)
+ 
+ 	.align  4
+ L(aligned_128head_bwd):
+ 	/* for the 2nd + iteration of this loop. */
+-	lxvd2x	v6,r4,r6
+-	lxvd2x	v7,r4,r7
++	lvx	v6,r4,r6
++	lvx	v7,r4,r7
+ L(aligned_128loop_bwd):
+-	lxvd2x	v8,r4,r8
+-	lxvd2x	v9,r4,r9
+-	stxvd2x	v6,r11,r6
++	lvx	v8,r4,r8
++	lvx	v9,r4,r9
++	stvx	v6,r11,r6
+ 	subi	r4,r4,64
+-	stxvd2x	v7,r11,r7
+-	stxvd2x	v8,r11,r8
+-	stxvd2x	v9,r11,r9
+-	lxvd2x	v6,r4,r6
+-	lxvd2x	v7,r4,7
++	stvx	v7,r11,r7
++	stvx	v8,r11,r8
++	stvx	v9,r11,r9
++	lvx	v6,r4,r6
++	lvx	v7,r4,7
+ 	subi	r11,r11,64
+-	lxvd2x	v8,r4,r8
+-	lxvd2x	v9,r4,r9
++	lvx	v8,r4,r8
++	lvx	v9,r4,r9
+ 	subi	r4,r4,64
+-	stxvd2x	v6,r11,r6
+-	stxvd2x	v7,r11,r7
+-	stxvd2x	v8,r11,r8
+-	stxvd2x	v9,r11,r9
++	stvx	v6,r11,r6
++	stvx	v7,r11,r7
++	stvx	v8,r11,r8
++	stvx	v9,r11,r9
+ 	subi	r11,r11,64
+ 	bdnz	L(aligned_128head_bwd)
+ 
+ L(aligned_tail_bwd):
+ 	mtocrf	0x01,r5
+ 	bf	25,32f
+-	lxvd2x	v6,r4,r6
+-	lxvd2x	v7,r4,r7
+-	lxvd2x	v8,r4,r8
+-	lxvd2x	v9,r4,r9
++	lvx	v6,r4,r6
++	lvx	v7,r4,r7
++	lvx	v8,r4,r8
++	lvx	v9,r4,r9
+ 	subi	r4,r4,64
+-	stxvd2x	v6,r11,r6
+-	stxvd2x	v7,r11,r7
+-	stxvd2x	v8,r11,r8
+-	stxvd2x	v9,r11,r9
++	stvx	v6,r11,r6
++	stvx	v7,r11,r7
++	stvx	v8,r11,r8
++	stvx	v9,r11,r9
+ 	subi	r11,r11,64
+ 32:
+ 	bf	26,16f
+-	lxvd2x	v6,r4,r6
+-	lxvd2x	v7,r4,r7
++	lvx	v6,r4,r6
++	lvx	v7,r4,r7
+ 	subi	r4,r4,32
+-	stxvd2x	v6,r11,r6
+-	stxvd2x	v7,r11,r7
++	stvx	v6,r11,r6
++	stvx	v7,r11,r7
+ 	subi	r11,r11,32
+ 16:
+ 	bf	27,8f
+-	lxvd2x	v6,r4,r6
++	lvx	v6,r4,r6
+ 	subi	r4,r4,16
+-	stxvd2x	v6,r11,r6
++	stvx	v6,r11,r6
+ 	subi	r11,r11,16
+ 8:
+ 	bf	28,4f
diff --git a/gnu/packages/patches/glibc-2-26-0088.patch b/gnu/packages/patches/glibc-2-26-0088.patch
new file mode 100644
index 000000000..f248d28a2
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0088.patch
@@ -0,0 +1,119 @@
+From 88758c4ad3f046d050bc2c3ae0f172b6524ca6c2 Mon Sep 17 00:00:00 2001
+From: Andreas Schwab <schwab@suse.de>
+Date: Tue, 8 Aug 2017 16:21:58 +0200
+Subject: [PATCH 88/90] Don't use IFUNC resolver for longjmp or system in
+ libpthread (bug 21041)
+
+Unlike the vfork forwarder and like the fork forwarder as in bug 19861,
+there won't be a problem when the compiler does not turn this into a tail
+call.
+
+(cherry picked from commit fc5ad7024c620cdfe9b76e94638aac83b99c5bf8)
+
+diff --git a/ChangeLog b/ChangeLog
+index c72c239620..e4b1d02672 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,9 @@
++2017-08-08  Andreas Schwab  <schwab@suse.de>
++
++	[BZ #21041]
++	* nptl/pt-longjmp.c (longjmp, siglongjmp): Don't use IFUNC resolver.
++	* nptl/pt-system.c (system): Likewise.
++
+ 2017-11-21  Rajalakshmi Srinivasaraghavan  <raji@linux.vnet.ibm.com>
+ 
+ 	* sysdeps/powerpc/powerpc64/power7/memcpy.S: Replace
+diff --git a/nptl/pt-longjmp.c b/nptl/pt-longjmp.c
+index 2ef757e687..8f3c6b3a09 100644
+--- a/nptl/pt-longjmp.c
++++ b/nptl/pt-longjmp.c
+@@ -25,21 +25,14 @@
+    symbol in libpthread, but the historical ABI requires it.  For static
+    linking, there is no need to provide anything here--the libc version
+    will be linked in.  For shared library ABI compatibility, there must be
+-   longjmp and siglongjmp symbols in libpthread.so; so we define them using
+-   IFUNC to redirect to the libc function.  */
++   longjmp and siglongjmp symbols in libpthread.so.
+ 
+-#if SHLIB_COMPAT (libpthread, GLIBC_2_0, GLIBC_2_22)
+-
+-# if HAVE_IFUNC
+-
+-#  undef INIT_ARCH
+-#  define INIT_ARCH()
+-#  define DEFINE_LONGJMP(name) libc_ifunc (name, &__libc_longjmp)
+-
+-extern __typeof(longjmp) longjmp_ifunc;
+-extern __typeof(siglongjmp) siglongjmp_ifunc;
++   With an IFUNC resolver, it would be possible to avoid the indirection,
++   but the IFUNC resolver might run before the __libc_longjmp symbol has
++   been relocated, in which case the IFUNC resolver would not be able to
++   provide the correct address.  */
+ 
+-# else  /* !HAVE_IFUNC */
++#if SHLIB_COMPAT (libpthread, GLIBC_2_0, GLIBC_2_22)
+ 
+ static void __attribute__ ((noreturn, used))
+ longjmp_compat (jmp_buf env, int val)
+@@ -47,14 +40,10 @@ longjmp_compat (jmp_buf env, int val)
+   __libc_longjmp (env, val);
+ }
+ 
+-# define DEFINE_LONGJMP(name) strong_alias (longjmp_compat, name)
+-
+-# endif  /* HAVE_IFUNC */
+-
+-DEFINE_LONGJMP (longjmp_ifunc)
+-compat_symbol (libpthread, longjmp_ifunc, longjmp, GLIBC_2_0);
++strong_alias (longjmp_compat, longjmp_alias)
++compat_symbol (libpthread, longjmp_alias, longjmp, GLIBC_2_0);
+ 
+-strong_alias (longjmp_ifunc, siglongjmp_ifunc)
+-compat_symbol (libpthread, siglongjmp_ifunc, siglongjmp, GLIBC_2_0);
++strong_alias (longjmp_alias, siglongjmp_alias)
++compat_symbol (libpthread, siglongjmp_alias, siglongjmp, GLIBC_2_0);
+ 
+ #endif
+diff --git a/nptl/pt-system.c b/nptl/pt-system.c
+index f8ca6ba0d9..b30ddf2b39 100644
+--- a/nptl/pt-system.c
++++ b/nptl/pt-system.c
+@@ -25,29 +25,21 @@
+    libpthread, but the historical ABI requires it.  For static linking,
+    there is no need to provide anything here--the libc version will be
+    linked in.  For shared library ABI compatibility, there must be a
+-   'system' symbol in libpthread.so; so we define it using IFUNC to
+-   redirect to the libc function.  */
++   'system' symbol in libpthread.so.
+ 
+-#if SHLIB_COMPAT (libpthread, GLIBC_2_0, GLIBC_2_22)
+-
+-# if HAVE_IFUNC
+-
+-extern __typeof(system) system_ifunc;
+-#  undef INIT_ARCH
+-#  define INIT_ARCH()
+-libc_ifunc (system_ifunc, &__libc_system)
++   With an IFUNC resolver, it would be possible to avoid the indirection,
++   but the IFUNC resolver might run before the __libc_system symbol has
++   been relocated, in which case the IFUNC resolver would not be able to
++   provide the correct address.  */
+ 
+-# else  /* !HAVE_IFUNC */
++#if SHLIB_COMPAT (libpthread, GLIBC_2_0, GLIBC_2_22)
+ 
+ static int __attribute__ ((used))
+ system_compat (const char *line)
+ {
+   return __libc_system (line);
+ }
+-strong_alias (system_compat, system_ifunc)
+-
+-# endif  /* HAVE_IFUNC */
+-
+-compat_symbol (libpthread, system_ifunc, system, GLIBC_2_0);
++strong_alias (system_compat, system_alias)
++compat_symbol (libpthread, system_alias, system, GLIBC_2_0);
+ 
+ #endif
diff --git a/gnu/packages/patches/glibc-2-26-0089.patch b/gnu/packages/patches/glibc-2-26-0089.patch
new file mode 100644
index 000000000..baae56ca8
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0089.patch
@@ -0,0 +1,35 @@
+From 4db8f362c13c7239311db95bd7f96d4bce0769f3 Mon Sep 17 00:00:00 2001
+From: Andreas Schwab <schwab@suse.de>
+Date: Wed, 9 Aug 2017 10:36:08 +0200
+Subject: [PATCH 89/90] Fix s390 version of pt-longjmp.c
+
+(cherry picked from commit 5797b410a87f6f6f6d3661d730fac320cbd5f270)
+
+diff --git a/ChangeLog b/ChangeLog
+index e4b1d02672..4c6f0d0aa2 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,8 @@
++2017-08-09  Andreas Schwab  <schwab@suse.de>
++
++	* sysdeps/unix/sysv/linux/s390/pt-longjmp.c: Update reference to
++	renamed alias.
++
+ 2017-08-08  Andreas Schwab  <schwab@suse.de>
+ 
+ 	[BZ #21041]
+diff --git a/sysdeps/unix/sysv/linux/s390/pt-longjmp.c b/sysdeps/unix/sysv/linux/s390/pt-longjmp.c
+index d324237edd..0221ac2cf5 100644
+--- a/sysdeps/unix/sysv/linux/s390/pt-longjmp.c
++++ b/sysdeps/unix/sysv/linux/s390/pt-longjmp.c
+@@ -26,8 +26,8 @@
+ /* In glibc release 2.19 new versions of longjmp-functions were introduced,
+    but were reverted before 2.20. Thus both versions are the same function.  */
+ 
+-strong_alias (longjmp_ifunc, __v2longjmp)
++strong_alias (longjmp_alias, __v2longjmp)
+ compat_symbol (libpthread, __v2longjmp, longjmp, GLIBC_2_19);
+-strong_alias (siglongjmp_ifunc, __v2siglongjmp)
++strong_alias (siglongjmp_alias, __v2siglongjmp)
+ compat_symbol (libpthread, __v2siglongjmp, siglongjmp, GLIBC_2_19);
+ #endif /* SHLIB_COMPAT (libpthread, GLIBC_2_19, GLIBC_2_20))  */
diff --git a/gnu/packages/patches/glibc-2-26-0090.patch b/gnu/packages/patches/glibc-2-26-0090.patch
new file mode 100644
index 000000000..bbe9548e5
--- /dev/null
+++ b/gnu/packages/patches/glibc-2-26-0090.patch
@@ -0,0 +1,131 @@
+From 71170eba2af41e08d51cf9d7b1ded5fd4b0b5c9c Mon Sep 17 00:00:00 2001
+From: Andreas Schwab <schwab@suse.de>
+Date: Tue, 8 Aug 2017 17:44:32 +0200
+Subject: [PATCH 90/90] Add test for bug 21041
+
+(cherry picked from commit 40c06a3d0450365e9675fe26f34fc56ce8497325)
+
+diff --git a/ChangeLog b/ChangeLog
+index 4c6f0d0aa2..0dcbe3bc69 100644
+--- a/ChangeLog
++++ b/ChangeLog
+@@ -1,3 +1,13 @@
++2017-08-09  Andreas Schwab  <schwab@suse.de>
++
++	* nptl/Makefile (tests) [$(build-shared) = yes]: Add
++	tst-compat-forwarder.
++	(modules-names): Add tst-compat-forwarder-mod.
++	($(objpfx)tst-compat-forwarder): Depend on
++	$(objpfx)tst-compat-forwarder-mod.so.
++	* nptl/tst-compat-forwarder.c: New file.
++	* nptl/tst-compat-forwarder-mod.c: New file.
++
+ 2017-08-09  Andreas Schwab  <schwab@suse.de>
+ 
+ 	* sysdeps/unix/sysv/linux/s390/pt-longjmp.c: Update reference to
+diff --git a/nptl/Makefile b/nptl/Makefile
+index 5cb1bb2c3d..9ca6d01b8c 100644
+--- a/nptl/Makefile
++++ b/nptl/Makefile
+@@ -367,7 +367,7 @@ tests += tst-cancelx2 tst-cancelx3 tst-cancelx4 tst-cancelx5 \
+ 	 tst-cleanupx0 tst-cleanupx1 tst-cleanupx2 tst-cleanupx3 tst-cleanupx4 \
+ 	 tst-oncex3 tst-oncex4
+ ifeq ($(build-shared),yes)
+-tests += tst-atfork2 tst-tls4 tst-_res1 tst-fini1
++tests += tst-atfork2 tst-tls4 tst-_res1 tst-fini1 tst-compat-forwarder
+ tests-internal += tst-tls3 tst-tls3-malloc tst-tls5 tst-stackguard1
+ tests-nolibpthread += tst-fini1
+ ifeq ($(have-z-execstack),yes)
+@@ -379,7 +379,7 @@ modules-names = tst-atfork2mod tst-tls3mod tst-tls4moda tst-tls4modb \
+ 		tst-tls5mod tst-tls5moda tst-tls5modb tst-tls5modc \
+ 		tst-tls5modd tst-tls5mode tst-tls5modf tst-stack4mod \
+ 		tst-_res1mod1 tst-_res1mod2 tst-execstack-mod tst-fini1mod \
+-		tst-join7mod
++		tst-join7mod tst-compat-forwarder-mod
+ extra-test-objs += $(addsuffix .os,$(strip $(modules-names))) \
+ 		   tst-cleanup4aux.o tst-cleanupx4aux.o
+ test-extras += tst-cleanup4aux tst-cleanupx4aux
+@@ -718,6 +718,8 @@ $(objpfx)tst-oddstacklimit.out: $(objpfx)tst-oddstacklimit $(objpfx)tst-basic1
+ 	$(evaluate-test)
+ endif
+ 
++$(objpfx)tst-compat-forwarder: $(objpfx)tst-compat-forwarder-mod.so
++
+ # The tests here better do not run in parallel
+ ifneq ($(filter %tests,$(MAKECMDGOALS)),)
+ .NOTPARALLEL:
+diff --git a/nptl/tst-compat-forwarder-mod.c b/nptl/tst-compat-forwarder-mod.c
+new file mode 100644
+index 0000000000..823bfa22de
+--- /dev/null
++++ b/nptl/tst-compat-forwarder-mod.c
+@@ -0,0 +1,28 @@
++/* Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++/* Call the function system through a statically initialized pointer.  */
++
++#include <stdlib.h>
++
++int (*system_function) (const char *) = system;
++
++void
++call_system (void)
++{
++  system_function (NULL);
++}
+diff --git a/nptl/tst-compat-forwarder.c b/nptl/tst-compat-forwarder.c
+new file mode 100644
+index 0000000000..f96806b7fe
+--- /dev/null
++++ b/nptl/tst-compat-forwarder.c
+@@ -0,0 +1,35 @@
++/* Copyright (C) 2017 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
++   <http://www.gnu.org/licenses/>.  */
++
++/* Test that the compat forwaders in libpthread work correctly.  */
++
++#include <support/test-driver.h>
++
++extern void call_system (void);
++
++int
++do_test (void)
++{
++  /* Calling the system function from a shared library that is not linked
++     against libpthread, when the main program is linked against
++     libpthread, should not crash.  */
++  call_system ();
++
++  return 0;
++}
++
++#include <support/test-driver.c>
-- 
2.15.0


[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

  reply	other threads:[~2017-11-24  5:34 UTC|newest]

Thread overview: 15+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-11-22 21:28 [bug#29406] [PATCH core-updates]: Add selected upstream fixes for glibc 2.26 Marius Bakke
2017-11-23 14:57 ` Leo Famulari
2017-11-24  1:12   ` Marius Bakke
2017-11-24  3:08     ` Marius Bakke [this message]
2017-11-27 21:30   ` Leo Famulari
2017-11-28  1:42     ` Marius Bakke
2017-11-28 10:45       ` Ludovic Courtès
2017-11-28 12:54         ` Marius Bakke
2017-11-28 16:03           ` bug#29406: " Ludovic Courtès
2017-11-28 17:16             ` [bug#29406] " Marius Bakke
2017-11-28 21:02               ` Ludovic Courtès
2017-11-28 21:42                 ` Leo Famulari
2017-11-29 16:40                   ` Ludovic Courtès
2017-11-28 18:26           ` Leo Famulari
2017-11-23 15:42 ` Ludovic Courtès

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://guix.gnu.org/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=87d148pe57.fsf@fastmail.com \
    --to=mbakke@fastmail.com \
    --cc=29406@debbugs.gnu.org \
    --cc=leo@famulari.name \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/guix.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).