ce426f
    Backport of the following patches:
ce426f
    
ce426f
    commit 4393fc119c34e97519b9b7a4fc94066b283be452
ce426f
    Author: Adhemerval Zanella <azanella@linux.vnet.ibm.com>
ce426f
    Date:   Thu Feb 27 09:45:41 2014 -0600
ce426f
    
ce426f
        PowerPC: Optimized isinf/isinff for POWER8
ce426f
    
ce426f
        This patch add a optimized isinf/isinff implementation for POWER8
ce426f
        using the new Move From VSR Doubleword instruction to gains some
ce426f
        cycles from FP to GRP register move.
ce426f
    
ce426f
        ChangeLog:
ce426f
    	2014-02-27  Adhemerval Zanella  <azanella@linux.vnet.ibm.com>
ce426f
    
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/Makefile: Add isinf power8
ce426f
    	implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf-power8.S: New file:
ce426f
    	POWER8 isinf ifunc implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf.c (__isinf): Add
ce426f
    	POWER8 implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinff.c (__isinff):
ce426f
    	Likewise.
ce426f
    	* sysdeps/powerpc/powerpc64/power8/fpu/s_isinf.S: New file:
ce426f
    	POWER8 isinf implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/power8/fpu/s_isinff.S: New file.
ce426f
    
ce426f
    commit cac626d60a863e48ab75417064984769e58c5719
ce426f
    Author: Adhemerval Zanella <azanella@linux.vnet.ibm.com>
ce426f
    Date:   Thu Feb 27 09:46:46 2014 -0600
ce426f
    
ce426f
        PowerPC: Optimized finite/finitef for POWER8
ce426f
    
ce426f
        This patch add a optimized finite/finitef implementation for POWER8
ce426f
        using the new Move From VSR Doubleword instruction to gains some
ce426f
        cycles from FP to GRP register move.
ce426f
    
ce426f
        ChangeLog:
ce426f
    	2014-02-27  Adhemerval Zanella  <azanella@linux.vnet.ibm.com>
ce426f
    
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/Makefile: Add finite power8
ce426f
    	implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite-power8.S: New file:
ce426f
    	POWER8 finite ifunc implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite.c (__finite): Add
ce426f
    	POWER8 implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_finitef.c (__finitef):
ce426f
    	Likewise.
ce426f
    	* sysdeps/powerpc/powerpc64/power8/fpu/s_finite.S: New file:
ce426f
    	POWER8 finite implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/power8/fpu/s_finitef.S: New file.
ce426f
    
ce426f
    commit 1ad8950a3ea4056ed343d681b5146f4b4aa27e10
ce426f
    Author: Adhemerval Zanella <azanella@linux.vnet.ibm.com>
ce426f
    Date:   Tue Feb 18 09:29:29 2014 -0500
ce426f
    
ce426f
        PowerPC: llrint/llrintf POWER8 optimization
ce426f
    
ce426f
        This patch add a optimized llrint/llrintf implementation for POWER8
ce426f
        using the new Move From VSR Doubleword instruction to gains some
ce426f
        cycles from FP to GRP register move.
ce426f
    
ce426f
        ChangeLog:
ce426f
    	2014-02-27  Adhemerval Zanella  <azanella@linux.vnet.ibm.com>
ce426f
    
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/Makefile: Add llrint power8
ce426f
    	implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_llrint-power8.S: New file:
ce426f
    	POWER8 llrint ifunc implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_llrint.c (__lllrint): Add
ce426f
    	POWER8 implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/power8/fpu/s_llrint.S: New file:
ce426f
    	POWER8 llrint implementation.
ce426f
    
ce426f
    commit fe13a20c37578f08ce393ccaeb45caeb48815ca5
ce426f
    Author: Adhemerval Zanella <azanella@linux.vnet.ibm.com>
ce426f
    Date:   Mon Feb 17 10:44:08 2014 -0600
ce426f
    
ce426f
        PowerPC: llround/llroundf POWER8 optimization
ce426f
    
ce426f
        This patch add a optimized llround/llroundf implementation for POWER8
ce426f
        using the new Move From VSR Doubleword instruction to gains some
ce426f
        cycles from FP to GRP register move.
ce426f
    
ce426f
        ChangeLog:
ce426f
    	2014-02-27  Adhemerval Zanella  <azanella@linux.vnet.ibm.com>
ce426f
    
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/Makefile: Add llround power8
ce426f
    	implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_llround-power8.S: New file:
ce426f
    	POWER8 llround ifunc implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/fpu/multiarch/s_llround.c (__lllround): Add
ce426f
    	POWER8 implementation.
ce426f
    	* sysdeps/powerpc/powerpc64/power8/fpu/s_llround.S: New file:
ce426f
    	POWER8 llround implementation.
ce426f
    
ce426f
    commit 757d9dd5c3efa56fac75965abc014faaae7b7895
ce426f
    Author: Adhemerval Zanella <azanella@linux.vnet.ibm.com>
ce426f
    Date:   Mon Mar 31 08:00:38 2014 -0500
ce426f
    
ce426f
        PowerPC: Fix little endian enconding for mfvsrd
ce426f
    
ce426f
        This patch fixes the MFVSRD_R3_V1 macro that encodes 'mfvsrd  r3,vs1'
ce426f
        (to support old binutils) for little endian.
ce426f
ce426f
diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/Makefile b/sysdeps/powerpc/powerpc64/fpu/multiarch/Makefile
ce426f
index 4cd1c5d..3e2127b 100644
ce426f
--- a/sysdeps/powerpc/powerpc64/fpu/multiarch/Makefile
ce426f
+++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/Makefile
ce426f
@@ -4,7 +4,8 @@ sysdep_routines += s_isnan-power7 s_isnan-power6x s_isnan-power6 \
ce426f
                   s_copysign-ppc64 s_finite-power7 s_finite-ppc64 \
ce426f
                   s_finitef-ppc64 s_isinff-ppc64 s_isinf-power7 \
ce426f
                   s_isinf-ppc64 s_modf-power5+ s_modf-ppc64 \
ce426f
-                  s_modff-power5+ s_modff-ppc64 s_isnan-power8
ce426f
+                  s_modff-power5+ s_modff-ppc64 s_isnan-power8 \
ce426f
+                  s_isinf-power8 s_finite-power8
ce426f
 
ce426f
 libm-sysdep_routines += s_isnan-power7 s_isnan-power6x s_isnan-power6 \
ce426f
                        s_isnan-power5 s_isnan-ppc64 s_llround-power6x \
ce426f
@@ -22,7 +23,8 @@ libm-sysdep_routines += s_isnan-power7 s_isnan-power6x s_isnan-power6 \
ce426f
                        s_logbl-ppc64 s_modf-power5+ s_modf-ppc64 \
ce426f
                        s_modff-power5+ s_modff-ppc64 e_hypot-ppc64 \
ce426f
                        e_hypot-power7 e_hypotf-ppc64 e_hypotf-power7 \
ce426f
-                       s_isnan-power8
ce426f
+                       s_isnan-power8 s_isinf-power8 s_finite-power8 \
ce426f
+                       s_llrint-power8 s_llround-power8
ce426f
 
ce426f
 CFLAGS-s_logbf-power7.c = -mcpu=power7
ce426f
 CFLAGS-s_logbl-power7.c = -mcpu=power7
ce426f
diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite-power8.S b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite-power8.S
ce426f
new file mode 100644
ce426f
index 0000000..3b9071f
ce426f
--- /dev/null
ce426f
+++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite-power8.S
ce426f
@@ -0,0 +1,33 @@
ce426f
+/* isnan().  PowerPC64/POWER7 version.
ce426f
+   Copyright (C) 2014 Free Software Foundation, Inc.
ce426f
+   This file is part of the GNU C Library.
ce426f
+
ce426f
+   The GNU C Library is free software; you can redistribute it and/or
ce426f
+   modify it under the terms of the GNU Lesser General Public
ce426f
+   License as published by the Free Software Foundation; either
ce426f
+   version 2.1 of the License, or (at your option) any later version.
ce426f
+
ce426f
+   The GNU C Library is distributed in the hope that it will be useful,
ce426f
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
ce426f
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
ce426f
+   Lesser General Public License for more details.
ce426f
+
ce426f
+   You should have received a copy of the GNU Lesser General Public
ce426f
+   License along with the GNU C Library; if not, see
ce426f
+   <http://www.gnu.org/licenses/>.  */
ce426f
+
ce426f
+#include <sysdep.h>
ce426f
+#include <math_ldbl_opt.h>
ce426f
+
ce426f
+#undef hidden_def
ce426f
+#define hidden_def(name)
ce426f
+#undef weak_alias
ce426f
+#define weak_alias(name, alias)
ce426f
+#undef strong_alias
ce426f
+#define strong_alias(name, alias)
ce426f
+#undef compat_symbol
ce426f
+#define compat_symbol(lib, name, symbol, ver)
ce426f
+
ce426f
+#define __finite __finite_power8
ce426f
+
ce426f
+#include <sysdeps/powerpc/powerpc64/power8/fpu/s_finite.S>
ce426f
diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite.c b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite.c
ce426f
index f79a93e..b9e908d 100644
ce426f
--- a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite.c
ce426f
+++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finite.c
ce426f
@@ -23,10 +23,13 @@
ce426f
 
ce426f
 extern __typeof (__finite) __finite_ppc64 attribute_hidden;
ce426f
 extern __typeof (__finite) __finite_power7 attribute_hidden;
ce426f
+extern __typeof (__finite) __finite_power8 attribute_hidden;
ce426f
 
ce426f
 libc_ifunc (__finite,
ce426f
-	    (hwcap & PPC_FEATURE_ARCH_2_06)
ce426f
-	    ? __finite_power7
ce426f
+	    (hwcap2 & PPC_FEATURE2_ARCH_2_07)
ce426f
+	    ? __finite_power8 :
ce426f
+	      (hwcap & PPC_FEATURE_ARCH_2_06)
ce426f
+	      ? __finite_power7
ce426f
             : __finite_ppc64);
ce426f
 
ce426f
 weak_alias (__finite, finite)
ce426f
diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finitef.c b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finitef.c
ce426f
index a7243b5..30b34bc 100644
ce426f
--- a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finitef.c
ce426f
+++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_finitef.c
ce426f
@@ -23,10 +23,13 @@
ce426f
 extern __typeof (__finitef) __finitef_ppc64 attribute_hidden;
ce426f
 /* The double-precision version also works for single-precision.  */
ce426f
 extern __typeof (__finitef) __finite_power7 attribute_hidden;
ce426f
+extern __typeof (__finitef) __finite_power8 attribute_hidden;
ce426f
 
ce426f
 libc_ifunc (__finitef,
ce426f
-	    (hwcap & PPC_FEATURE_ARCH_2_06)
ce426f
-	    ? __finite_power7
ce426f
+	    (hwcap2 & PPC_FEATURE2_ARCH_2_07)
ce426f
+	    ? __finite_power8 :
ce426f
+	      (hwcap & PPC_FEATURE_ARCH_2_06)
ce426f
+	      ? __finite_power7
ce426f
             : __finitef_ppc64);
ce426f
 
ce426f
 weak_alias (__finitef, finitef)
ce426f
diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf-power8.S b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf-power8.S
ce426f
new file mode 100644
ce426f
index 0000000..979816e
ce426f
--- /dev/null
ce426f
+++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf-power8.S
ce426f
@@ -0,0 +1,33 @@
ce426f
+/* isinf().  PowerPC64/POWER8 version.
ce426f
+   Copyright (C) 2014 Free Software Foundation, Inc.
ce426f
+   This file is part of the GNU C Library.
ce426f
+
ce426f
+   The GNU C Library is free software; you can redistribute it and/or
ce426f
+   modify it under the terms of the GNU Lesser General Public
ce426f
+   License as published by the Free Software Foundation; either
ce426f
+   version 2.1 of the License, or (at your option) any later version.
ce426f
+
ce426f
+   The GNU C Library is distributed in the hope that it will be useful,
ce426f
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
ce426f
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
ce426f
+   Lesser General Public License for more details.
ce426f
+
ce426f
+   You should have received a copy of the GNU Lesser General Public
ce426f
+   License along with the GNU C Library; if not, see
ce426f
+   <http://www.gnu.org/licenses/>.  */
ce426f
+
ce426f
+#include <sysdep.h>
ce426f
+#include <math_ldbl_opt.h>
ce426f
+
ce426f
+#undef hidden_def
ce426f
+#define hidden_def(name)
ce426f
+#undef weak_alias
ce426f
+#define weak_alias(name, alias)
ce426f
+#undef strong_alias
ce426f
+#define strong_alias(name, alias)
ce426f
+#undef compat_symbol
ce426f
+#define compat_symbol(lib, name, alias, ver)
ce426f
+
ce426f
+#define __isinf __isinf_power8
ce426f
+
ce426f
+#include <sysdeps/powerpc/powerpc64/power8/fpu/s_isinf.S>
ce426f
diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf.c b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf.c
ce426f
index 1ee230b..e349a06 100644
ce426f
--- a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf.c
ce426f
+++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinf.c
ce426f
@@ -23,10 +23,13 @@
ce426f
 
ce426f
 extern __typeof (__isinf) __isinf_ppc64 attribute_hidden;
ce426f
 extern __typeof (__isinf) __isinf_power7 attribute_hidden;
ce426f
+extern __typeof (__isinf) __isinf_power8 attribute_hidden;
ce426f
 
ce426f
 libc_ifunc (__isinf,
ce426f
-	    (hwcap & PPC_FEATURE_ARCH_2_06)
ce426f
-	    ? __isinf_power7
ce426f
+	    (hwcap2 & PPC_FEATURE2_ARCH_2_07)
ce426f
+	    ? __isinf_power8 :
ce426f
+	      (hwcap & PPC_FEATURE_ARCH_2_06)
ce426f
+	      ? __isinf_power7
ce426f
             : __isinf_ppc64);
ce426f
 
ce426f
 weak_alias (__isinf, isinf)
ce426f
diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinff.c b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinff.c
ce426f
index 1336feb..71da7a3 100644
ce426f
--- a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinff.c
ce426f
+++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_isinff.c
ce426f
@@ -24,10 +24,13 @@
ce426f
 extern __typeof (__isinff) __isinff_ppc64 attribute_hidden;
ce426f
 /* The double-precision version also works for single-precision.  */
ce426f
 extern __typeof (__isinff) __isinf_power7 attribute_hidden;
ce426f
+extern __typeof (__isinff) __isinf_power8 attribute_hidden;
ce426f
 
ce426f
 libc_ifunc (__isinff,
ce426f
-	    (hwcap & PPC_FEATURE_ARCH_2_06)
ce426f
-	    ? __isinf_power7
ce426f
+	    (hwcap2 & PPC_FEATURE2_ARCH_2_07)
ce426f
+	    ? __isinf_power8 :
ce426f
+	      (hwcap & PPC_FEATURE_ARCH_2_06)
ce426f
+	      ? __isinf_power7
ce426f
             : __isinff_ppc64);
ce426f
 
ce426f
 weak_alias (__isinff, isinff)
ce426f
diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llrint-power8.S b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llrint-power8.S
ce426f
new file mode 100644
ce426f
index 0000000..3962b7d
ce426f
--- /dev/null
ce426f
+++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llrint-power8.S
ce426f
@@ -0,0 +1,31 @@
ce426f
+/* Round double to long int.  PowerPC64/POWER6X default version.
ce426f
+   Copyright (C) 2014 Free Software Foundation, Inc.
ce426f
+   This file is part of the GNU C Library.
ce426f
+
ce426f
+   The GNU C Library is free software; you can redistribute it and/or
ce426f
+   modify it under the terms of the GNU Lesser General Public
ce426f
+   License as published by the Free Software Foundation; either
ce426f
+   version 2.1 of the License, or (at your option) any later version.
ce426f
+
ce426f
+   The GNU C Library is distributed in the hope that it will be useful,
ce426f
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
ce426f
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
ce426f
+   Lesser General Public License for more details.
ce426f
+
ce426f
+   You should have received a copy of the GNU Lesser General Public
ce426f
+   License along with the GNU C Library; if not, see
ce426f
+   <http://www.gnu.org/licenses/>.  */
ce426f
+
ce426f
+#include <sysdep.h>
ce426f
+#include <math_ldbl_opt.h>
ce426f
+
ce426f
+#undef weak_alias
ce426f
+#define weak_alias(a,b)
ce426f
+#undef strong_alias
ce426f
+#define strong_alias(a,b)
ce426f
+#undef compat_symbol
ce426f
+#define compat_symbol(a,b,c,d)
ce426f
+
ce426f
+#define __llrint __llrint_power8
ce426f
+
ce426f
+#include <sysdeps/powerpc/powerpc64/power8/fpu/s_llrint.S>
ce426f
diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llrint.c b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llrint.c
ce426f
index 5818b53..cf1b2e4 100644
ce426f
--- a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llrint.c
ce426f
+++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llrint.c
ce426f
@@ -30,10 +30,13 @@
ce426f
 
ce426f
 extern __typeof (__llrint) __llrint_ppc64 attribute_hidden;
ce426f
 extern __typeof (__llrint) __llrint_power6x attribute_hidden;
ce426f
+extern __typeof (__llrint) __llrint_power8 attribute_hidden;
ce426f
 
ce426f
 libc_ifunc (__llrint,
ce426f
-	    (hwcap & PPC_FEATURE_POWER6_EXT)
ce426f
-	    ? __llrint_power6x
ce426f
+	    (hwcap2 & PPC_FEATURE2_ARCH_2_07)
ce426f
+	    ? __llrint_power8 :
ce426f
+	      (hwcap & PPC_FEATURE_POWER6_EXT)
ce426f
+	      ? __llrint_power6x
ce426f
             : __llrint_ppc64);
ce426f
 
ce426f
 weak_alias (__llrint, llrint)
ce426f
diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llround-power8.S b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llround-power8.S
ce426f
new file mode 100644
ce426f
index 0000000..41c61a1
ce426f
--- /dev/null
ce426f
+++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llround-power8.S
ce426f
@@ -0,0 +1,31 @@
ce426f
+/* llround().  PowerPC64 default version.
ce426f
+   Copyright (C) 2014 Free Software Foundation, Inc.
ce426f
+   This file is part of the GNU C Library.
ce426f
+
ce426f
+   The GNU C Library is free software; you can redistribute it and/or
ce426f
+   modify it under the terms of the GNU Lesser General Public
ce426f
+   License as published by the Free Software Foundation; either
ce426f
+   version 2.1 of the License, or (at your option) any later version.
ce426f
+
ce426f
+   The GNU C Library is distributed in the hope that it will be useful,
ce426f
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
ce426f
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
ce426f
+   Lesser General Public License for more details.
ce426f
+
ce426f
+   You should have received a copy of the GNU Lesser General Public
ce426f
+   License along with the GNU C Library; if not, see
ce426f
+   <http://www.gnu.org/licenses/>.  */
ce426f
+
ce426f
+#include <sysdep.h>
ce426f
+#include <math_ldbl_opt.h>
ce426f
+
ce426f
+#undef weak_alias
ce426f
+#define weak_alias(name, alias)
ce426f
+#undef strong_alias
ce426f
+#define strong_alias(name, alias)
ce426f
+#undef compat_symbol
ce426f
+#define compat_symbol(lib, name, alias, ver)
ce426f
+
ce426f
+#define __llround __llround_power8
ce426f
+
ce426f
+#include <sysdeps/powerpc/powerpc64/power8/fpu/s_llround.S>
ce426f
diff --git a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llround.c b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llround.c
ce426f
index a4d1bf3..7dba17e 100644
ce426f
--- a/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llround.c
ce426f
+++ b/sysdeps/powerpc/powerpc64/fpu/multiarch/s_llround.c
ce426f
@@ -27,12 +27,15 @@
ce426f
 extern __typeof (__llround) __llround_ppc64 attribute_hidden;
ce426f
 extern __typeof (__llround) __llround_power5plus attribute_hidden;
ce426f
 extern __typeof (__llround) __llround_power6x attribute_hidden;
ce426f
+extern __typeof (__llround) __llround_power8 attribute_hidden;
ce426f
 
ce426f
 libc_ifunc (__llround,
ce426f
-	    (hwcap & PPC_FEATURE_POWER6_EXT)
ce426f
-	    ? __llround_power6x :
ce426f
-	      (hwcap & PPC_FEATURE_POWER5_PLUS)
ce426f
-	      ? __llround_power5plus
ce426f
+	    (hwcap2 & PPC_FEATURE2_ARCH_2_07)
ce426f
+	    ? __llround_power8 :
ce426f
+	      (hwcap & PPC_FEATURE_POWER6_EXT)
ce426f
+	      ? __llround_power6x :
ce426f
+		(hwcap & PPC_FEATURE_POWER5_PLUS)
ce426f
+		? __llround_power5plus
ce426f
             : __llround_ppc64);
ce426f
 
ce426f
 weak_alias (__llround, llround)
ce426f
diff --git a/sysdeps/powerpc/powerpc64/power8/fpu/s_finite.S b/sysdeps/powerpc/powerpc64/power8/fpu/s_finite.S
ce426f
new file mode 100644
ce426f
index 0000000..3e98126
ce426f
--- /dev/null
ce426f
+++ b/sysdeps/powerpc/powerpc64/power8/fpu/s_finite.S
ce426f
@@ -0,0 +1,56 @@
ce426f
+/* isfinite().  PowerPC64/POWER8 version.
ce426f
+   Copyright (C) 2014 Free Software Foundation, Inc.
ce426f
+   This file is part of the GNU C Library.
ce426f
+
ce426f
+   The GNU C Library is free software; you can redistribute it and/or
ce426f
+   modify it under the terms of the GNU Lesser General Public
ce426f
+   License as published by the Free Software Foundation; either
ce426f
+   version 2.1 of the License, or (at your option) any later version.
ce426f
+
ce426f
+   The GNU C Library is distributed in the hope that it will be useful,
ce426f
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
ce426f
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
ce426f
+   Lesser General Public License for more details.
ce426f
+
ce426f
+   You should have received a copy of the GNU Lesser General Public
ce426f
+   License along with the GNU C Library; if not, see
ce426f
+   <http://www.gnu.org/licenses/>.  */
ce426f
+
ce426f
+#include <sysdep.h>
ce426f
+#include <math_ldbl_opt.h>
ce426f
+
ce426f
+#define MFVSRD_R3_V1  .long 0x7c230066     /* mfvsrd  r3,vs1  */
ce426f
+
ce426f
+/* int [r3] __finite ([fp1] x)  */
ce426f
+
ce426f
+EALIGN (__finite, 4, 0)
ce426f
+	CALL_MCOUNT 0
ce426f
+	MFVSRD_R3_V1
ce426f
+	lis     r9,0x8010
ce426f
+	clrldi  r3,r3,1       /* r3 = r3 & 0x8000000000000000  */
ce426f
+	rldicr  r9,r9,32,31   /* r9 = (r9 << 32) & 0xffffffff  */
ce426f
+	add     r3,r3,r9
ce426f
+	rldicl  r3,r3,1,63
ce426f
+	blr
ce426f
+END (__finite)
ce426f
+
ce426f
+hidden_def (__finite)
ce426f
+weak_alias (__finite, finite)
ce426f
+
ce426f
+/* It turns out that the 'double' version will also always work for
ce426f
+   single-precision.  */
ce426f
+strong_alias (__finite, __finitef)
ce426f
+hidden_def (__finitef)
ce426f
+weak_alias (__finitef, finitef)
ce426f
+
ce426f
+#ifdef IS_IN_libm
ce426f
+# if LONG_DOUBLE_COMPAT (libm, GLIBC_2_0)
ce426f
+compat_symbol (libm, __finite, __finitel, GLIBC_2_0)
ce426f
+compat_symbol (libm, finite, finitel, GLIBC_2_0)
ce426f
+# endif
ce426f
+#else
ce426f
+# if LONG_DOUBLE_COMPAT (libc, GLIBC_2_0)
ce426f
+compat_symbol (libc, __finite, __finitel, GLIBC_2_0);
ce426f
+compat_symbol (libc, finite, finitel, GLIBC_2_0);
ce426f
+# endif
ce426f
+#endif
ce426f
diff --git a/sysdeps/powerpc/powerpc64/power8/fpu/s_finitef.S b/sysdeps/powerpc/powerpc64/power8/fpu/s_finitef.S
ce426f
new file mode 100644
ce426f
index 0000000..54bd941
ce426f
--- /dev/null
ce426f
+++ b/sysdeps/powerpc/powerpc64/power8/fpu/s_finitef.S
ce426f
@@ -0,0 +1 @@
ce426f
+/* This function uses the same code as s_finite.S.  */
ce426f
diff --git a/sysdeps/powerpc/powerpc64/power8/fpu/s_isinf.S b/sysdeps/powerpc/powerpc64/power8/fpu/s_isinf.S
ce426f
new file mode 100644
ce426f
index 0000000..125de39
ce426f
--- /dev/null
ce426f
+++ b/sysdeps/powerpc/powerpc64/power8/fpu/s_isinf.S
ce426f
@@ -0,0 +1,61 @@
ce426f
+/* isinf().  PowerPC64/POWER8 version.
ce426f
+   Copyright (C) 2014 Free Software Foundation, Inc.
ce426f
+   This file is part of the GNU C Library.
ce426f
+
ce426f
+   The GNU C Library is free software; you can redistribute it and/or
ce426f
+   modify it under the terms of the GNU Lesser General Public
ce426f
+   License as published by the Free Software Foundation; either
ce426f
+   version 2.1 of the License, or (at your option) any later version.
ce426f
+
ce426f
+   The GNU C Library is distributed in the hope that it will be useful,
ce426f
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
ce426f
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
ce426f
+   Lesser General Public License for more details.
ce426f
+
ce426f
+   You should have received a copy of the GNU Lesser General Public
ce426f
+   License along with the GNU C Library; if not, see
ce426f
+   <http://www.gnu.org/licenses/>.  */
ce426f
+
ce426f
+#include <sysdep.h>
ce426f
+#include <math_ldbl_opt.h>
ce426f
+
ce426f
+#define MFVSRD_R3_V1  .long 0x7c230066     /* mfvsrd  r3,vs1  */
ce426f
+
ce426f
+/* int [r3] __isinf([fp1] x)  */
ce426f
+
ce426f
+EALIGN (__isinf, 4, 0)
ce426f
+	CALL_MCOUNT 0
ce426f
+	MFVSRD_R3_V1
ce426f
+	lis     r9,0x7ff0     /* r9 = 0x7ff0  */
ce426f
+	rldicl  r10,r3,0,1    /* r10 = r3 & (0x8000000000000000)  */
ce426f
+	sldi    r9,r9,32      /* r9 = r9 << 52  */
ce426f
+	cmpd    cr7,r10,r9    /* fp1 & 0x7ff0000000000000 ?  */
ce426f
+	beq     cr7,L(inf)
ce426f
+	li      r3,0          /* Not inf  */
ce426f
+	blr
ce426f
+L(inf):
ce426f
+	sradi   r3,r3,63      /* r3 = r3 >> 63  */
ce426f
+	ori     r3,r3,1       /* r3 = r3 | 0x1  */
ce426f
+	blr
ce426f
+END (__isinf)
ce426f
+
ce426f
+hidden_def (__isinf)
ce426f
+weak_alias (__isinf, isinf)
ce426f
+
ce426f
+/* It turns out that the 'double' version will also always work for
ce426f
+   single-precision.  */
ce426f
+strong_alias (__isinf, __isinff)
ce426f
+hidden_def (__isinff)
ce426f
+weak_alias (__isinff, isinff)
ce426f
+
ce426f
+#ifdef NO_LONG_DOUBLE
ce426f
+strong_alias (__isinf, __isinfl)
ce426f
+weak_alias (__isinf, isinfl)
ce426f
+#endif
ce426f
+
ce426f
+#ifndef IS_IN_libm
ce426f
+# if LONG_DOUBLE_COMPAT(libc, GLIBC_2_0)
ce426f
+compat_symbol (libc, __isinf, __isinfl, GLIBC_2_0);
ce426f
+compat_symbol (libc, isinf, isinfl, GLIBC_2_0);
ce426f
+# endif
ce426f
+#endif
ce426f
diff --git a/sysdeps/powerpc/powerpc64/power8/fpu/s_isinff.S b/sysdeps/powerpc/powerpc64/power8/fpu/s_isinff.S
ce426f
new file mode 100644
ce426f
index 0000000..be759e0
ce426f
--- /dev/null
ce426f
+++ b/sysdeps/powerpc/powerpc64/power8/fpu/s_isinff.S
ce426f
@@ -0,0 +1 @@
ce426f
+/* This function uses the same code as s_isinf.S.  */
ce426f
diff --git a/sysdeps/powerpc/powerpc64/power8/fpu/s_isnan.S b/sysdeps/powerpc/powerpc64/power8/fpu/s_isnan.S
ce426f
index c1ca9a5..cb96d03 100644
ce426f
--- a/sysdeps/powerpc/powerpc64/power8/fpu/s_isnan.S
ce426f
+++ b/sysdeps/powerpc/powerpc64/power8/fpu/s_isnan.S
ce426f
@@ -19,8 +19,8 @@
ce426f
 #include <sysdep.h>
ce426f
 #include <math_ldbl_opt.h>
ce426f
 
ce426f
-#define MFVSRD_R3_V1  .byte 0x7c,0x23,0x00,0x66     /* mfvsrd  r3,vs1  */
ce426f
-
ce426f
+#define MFVSRD_R3_V1  .long 0x7c230066     /* mfvsrd  r3,vs1  */
ce426f
+        
ce426f
 /* int [r3] __isnan([f1] x)  */
ce426f
 
ce426f
 EALIGN (__isnan, 4, 0)
ce426f
diff --git a/sysdeps/powerpc/powerpc64/power8/fpu/s_llrint.S b/sysdeps/powerpc/powerpc64/power8/fpu/s_llrint.S
ce426f
new file mode 100644
ce426f
index 0000000..ce48d4e
ce426f
--- /dev/null
ce426f
+++ b/sysdeps/powerpc/powerpc64/power8/fpu/s_llrint.S
ce426f
@@ -0,0 +1,45 @@
ce426f
+/* Round double to long int.  POWER8 PowerPC64 version.
ce426f
+   Copyright (C) 2014 Free Software Foundation, Inc.
ce426f
+   This file is part of the GNU C Library.
ce426f
+
ce426f
+   The GNU C Library is free software; you can redistribute it and/or
ce426f
+   modify it under the terms of the GNU Lesser General Public
ce426f
+   License as published by the Free Software Foundation; either
ce426f
+   version 2.1 of the License, or (at your option) any later version.
ce426f
+
ce426f
+   The GNU C Library is distributed in the hope that it will be useful,
ce426f
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
ce426f
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
ce426f
+   Lesser General Public License for more details.
ce426f
+
ce426f
+   You should have received a copy of the GNU Lesser General Public
ce426f
+   License along with the GNU C Library; if not, see
ce426f
+   <http://www.gnu.org/licenses/>.  */
ce426f
+
ce426f
+#include <sysdep.h>
ce426f
+#include <math_ldbl_opt.h>
ce426f
+
ce426f
+#define MFVSRD_R3_V1  .long 0x7c230066     /* mfvsrd  r3,vs1  */
ce426f
+
ce426f
+/* long long int[r3] __llrint (double x[fp1])  */
ce426f
+ENTRY (__llrint)
ce426f
+	CALL_MCOUNT 0
ce426f
+	fctid	fp1,fp1
ce426f
+	MFVSRD_R3_V1
ce426f
+	blr
ce426f
+END (__llrint)
ce426f
+
ce426f
+strong_alias (__llrint, __lrint)
ce426f
+weak_alias (__llrint, llrint)
ce426f
+weak_alias (__lrint, lrint)
ce426f
+
ce426f
+#ifdef NO_LONG_DOUBLE
ce426f
+strong_alias (__llrint, __llrintl)
ce426f
+weak_alias (__llrint, llrintl)
ce426f
+strong_alias (__lrint, __lrintl)
ce426f
+weak_alias (__lrint, lrintl)
ce426f
+#endif
ce426f
+#if LONG_DOUBLE_COMPAT(libm, GLIBC_2_1)
ce426f
+compat_symbol (libm, __llrint, llrintl, GLIBC_2_1)
ce426f
+compat_symbol (libm, __lrint, lrintl, GLIBC_2_1)
ce426f
+#endif
ce426f
diff --git a/sysdeps/powerpc/powerpc64/power8/fpu/s_llround.S b/sysdeps/powerpc/powerpc64/power8/fpu/s_llround.S
ce426f
new file mode 100644
ce426f
index 0000000..2aea234
ce426f
--- /dev/null
ce426f
+++ b/sysdeps/powerpc/powerpc64/power8/fpu/s_llround.S
ce426f
@@ -0,0 +1,47 @@
ce426f
+/* llround function.  POWER8 PowerPC64 version.
ce426f
+   Copyright (C) 2014 Free Software Foundation, Inc.
ce426f
+   This file is part of the GNU C Library.
ce426f
+
ce426f
+   The GNU C Library is free software; you can redistribute it and/or
ce426f
+   modify it under the terms of the GNU Lesser General Public
ce426f
+   License as published by the Free Software Foundation; either
ce426f
+   version 2.1 of the License, or (at your option) any later version.
ce426f
+
ce426f
+   The GNU C Library is distributed in the hope that it will be useful,
ce426f
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
ce426f
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
ce426f
+   Lesser General Public License for more details.
ce426f
+
ce426f
+   You should have received a copy of the GNU Lesser General Public
ce426f
+   License along with the GNU C Library; if not, see
ce426f
+   <http://www.gnu.org/licenses/>.  */
ce426f
+
ce426f
+#include <sysdep.h>
ce426f
+#include <math_ldbl_opt.h>
ce426f
+
ce426f
+#define MFVSRD_R3_V1  .long 0x7c230066     /* mfvsrd  r3,vs1  */
ce426f
+
ce426f
+/* long long [r3] llround (float x [fp1])  */
ce426f
+
ce426f
+ENTRY (__llround)
ce426f
+	CALL_MCOUNT 0
ce426f
+	frin	fp1,fp1	/* Round to nearest +-0.5.  */
ce426f
+	fctidz	fp1,fp1	/* Convert To Integer DW round toward 0.  */
ce426f
+	MFVSRD_R3_V1
ce426f
+	blr
ce426f
+END (__llround)
ce426f
+
ce426f
+strong_alias (__llround, __lround)
ce426f
+weak_alias (__llround, llround)
ce426f
+weak_alias (__lround, lround)
ce426f
+
ce426f
+#ifdef NO_LONG_DOUBLE
ce426f
+weak_alias (__llround, llroundl)
ce426f
+strong_alias (__llround, __llroundl)
ce426f
+weak_alias (__lround, lroundl)
ce426f
+strong_alias (__lround, __lroundl)
ce426f
+#endif
ce426f
+#if LONG_DOUBLE_COMPAT(libm, GLIBC_2_1)
ce426f
+compat_symbol (libm, __llround, llroundl, GLIBC_2_1)
ce426f
+compat_symbol (libm, __lround, lroundl, GLIBC_2_1)
ce426f
+#endif