re PR target/81193 (PowerPC GCC __builtin_cpu_is and __builtin_cpu_supports should warn about old libraries)
[gcc] 2017-07-12 Michael Meissner <meissner@linux.vnet.ibm.com> PR target/81193 * config/rs6000/rs6000-c.c (rs6000_cpu_cpp_builtins): If GLIBC provides the hardware capability bits, define the macro __BUILTIN_CPU_SUPPORTS__. * config/rs6000/rs6000.c (cpu_expand_builtin): Generate a warning if GLIBC does not provide the hardware capability bits. Add a gcc_unreachable call if the built-in cpu function is neither __builtin_cpu_is nor __builtin_cpu_supports. (rs6000_get_function_versions_dispatcher): Change the warning that an old GLIBC is used which does not export the capability bits to be an error. * doc/extend.texi (target_clones attribute): Document the restriction that GLIBC 2.23 or newer is needed on the PowerPC. (PowerPC built-in functions): Document that GLIBC 2.23 or newer is needed by __builtin_cpu_is and __builtin_cpu_supports. Document the macros defined by GCC if the newer GLIBC is available. [gcc/testsuite] 2017-07-12 Michael Meissner <meissner@linux.vnet.ibm.com> PR target/81193 * gcc.target/powerpc/bmi-andn-1.c: Add guard against using __builtin_cpu_supports with old GLIBC's. * gcc.target/powerpc/bmi-andn-2.c: Likewise. * gcc.target/powerpc/bmi-bextr-1.c: Likewise. * gcc.target/powerpc/bmi-bextr-2.c: Likewise. * gcc.target/powerpc/bmi-bextr-4.c: Likewise. * gcc.target/powerpc/bmi-bextr-5.c: Likewise. * gcc.target/powerpc/bmi-blsi-1.c: Likewise. * gcc.target/powerpc/bmi-blsi-2.c: Likewise. * gcc.target/powerpc/bmi-blsmsk-1.c: Likewise. * gcc.target/powerpc/bmi-blsmsk-2.c: Likewise. * gcc.target/powerpc/bmi-blsr-1.c: Likewise. * gcc.target/powerpc/bmi-blsr-2.c: Likewise. * gcc.target/powerpc/bmi-tzcnt-1.c: Likewise. * gcc.target/powerpc/bmi-tzcnt-2.c: Likewise. * gcc.target/powerpc/bmi2-bzhi32-1.c: Likewise. * gcc.target/powerpc/bmi2-bzhi64-1.c: Likewise. * gcc.target/powerpc/bmi2-mulx32-1.c: Likewise. * gcc.target/powerpc/bmi2-mulx32-2.c: Likewise. * gcc.target/powerpc/bmi2-mulx64-1.c: Likewise. * gcc.target/powerpc/bmi2-mulx64-2.c: Likewise. * gcc.target/powerpc/bmi2-pdep32-1.c: Likewise. * gcc.target/powerpc/bmi2-pdep64-1.c: Likewise. * gcc.target/powerpc/bmi2-pext32-1.c: Likewise. * gcc.target/powerpc/bmi2-pext64-1.c: Likewise. * gcc.target/powerpc/cpu-builtin-1.c: Likewise. [libgcc] 2017-07-12 Michael Meissner <meissner@linux.vnet.ibm.com> PR target/81193 * configure.ac (PowerPC float128 hardware support): Test whether we can use __builtin_cpu_supports before enabling the ifunc handler. * configure: Regenerate. From-SVN: r250165
This commit is contained in:
parent
1b68a156d6
commit
3787ee47fc
@ -1,3 +1,22 @@
|
|||||||
|
2017-07-12 Michael Meissner <meissner@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
PR target/81193
|
||||||
|
* config/rs6000/rs6000-c.c (rs6000_cpu_cpp_builtins): If GLIBC
|
||||||
|
provides the hardware capability bits, define the macro
|
||||||
|
__BUILTIN_CPU_SUPPORTS__.
|
||||||
|
* config/rs6000/rs6000.c (cpu_expand_builtin): Generate a warning
|
||||||
|
if GLIBC does not provide the hardware capability bits. Add a
|
||||||
|
gcc_unreachable call if the built-in cpu function is neither
|
||||||
|
__builtin_cpu_is nor __builtin_cpu_supports.
|
||||||
|
(rs6000_get_function_versions_dispatcher): Change the warning
|
||||||
|
that an old GLIBC is used which does not export the capability
|
||||||
|
bits to be an error.
|
||||||
|
* doc/extend.texi (target_clones attribute): Document the
|
||||||
|
restriction that GLIBC 2.23 or newer is needed on the PowerPC.
|
||||||
|
(PowerPC built-in functions): Document that GLIBC 2.23 or newer is
|
||||||
|
needed by __builtin_cpu_is and __builtin_cpu_supports. Document
|
||||||
|
the macros defined by GCC if the newer GLIBC is available.
|
||||||
|
|
||||||
2017-07-12 Jeff Law <law@redhat.com>
|
2017-07-12 Jeff Law <law@redhat.com>
|
||||||
|
|
||||||
* config/riscv/riscv.c: Remove unnecessary includes. Reorder
|
* config/riscv/riscv.c: Remove unnecessary includes. Reorder
|
||||||
|
@ -644,6 +644,9 @@ rs6000_cpu_cpp_builtins (cpp_reader *pfile)
|
|||||||
builtin_define ("__FLOAT128_HARDWARE__");
|
builtin_define ("__FLOAT128_HARDWARE__");
|
||||||
if (TARGET_LONG_DOUBLE_128 && FLOAT128_IBM_P (TFmode))
|
if (TARGET_LONG_DOUBLE_128 && FLOAT128_IBM_P (TFmode))
|
||||||
builtin_define ("__ibm128=long double");
|
builtin_define ("__ibm128=long double");
|
||||||
|
#ifdef TARGET_LIBC_PROVIDES_HWCAP_IN_TCB
|
||||||
|
builtin_define ("__BUILTIN_CPU_SUPPORTS__");
|
||||||
|
#endif
|
||||||
|
|
||||||
/* We needed to create a keyword if -mfloat128-type was used but not -mfloat,
|
/* We needed to create a keyword if -mfloat128-type was used but not -mfloat,
|
||||||
so we used __ieee128. If -mfloat128 was used, create a #define back to
|
so we used __ieee128. If -mfloat128 was used, create a #define back to
|
||||||
|
@ -15176,6 +15176,8 @@ cpu_expand_builtin (enum rs6000_builtins fcode, tree exp ATTRIBUTE_UNUSED,
|
|||||||
emit_insn (gen_eqsi3 (scratch2, scratch1, const0_rtx));
|
emit_insn (gen_eqsi3 (scratch2, scratch1, const0_rtx));
|
||||||
emit_insn (gen_rtx_SET (target, gen_rtx_XOR (SImode, scratch2, const1_rtx)));
|
emit_insn (gen_rtx_SET (target, gen_rtx_XOR (SImode, scratch2, const1_rtx)));
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
gcc_unreachable ();
|
||||||
|
|
||||||
/* Record that we have expanded a CPU builtin, so that we can later
|
/* Record that we have expanded a CPU builtin, so that we can later
|
||||||
emit a reference to the special symbol exported by LIBC to ensure we
|
emit a reference to the special symbol exported by LIBC to ensure we
|
||||||
@ -15183,6 +15185,9 @@ cpu_expand_builtin (enum rs6000_builtins fcode, tree exp ATTRIBUTE_UNUSED,
|
|||||||
cpu_builtin_p = true;
|
cpu_builtin_p = true;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
warning (0, "%s needs GLIBC (2.23 and newer) that exports hardware "
|
||||||
|
"capability bits", rs6000_builtin_info[(size_t) fcode].name);
|
||||||
|
|
||||||
/* For old LIBCs, always return FALSE. */
|
/* For old LIBCs, always return FALSE. */
|
||||||
emit_move_insn (target, GEN_INT (0));
|
emit_move_insn (target, GEN_INT (0));
|
||||||
#endif /* TARGET_LIBC_PROVIDES_HWCAP_IN_TCB */
|
#endif /* TARGET_LIBC_PROVIDES_HWCAP_IN_TCB */
|
||||||
@ -37284,10 +37289,10 @@ rs6000_get_function_versions_dispatcher (void *decl)
|
|||||||
default_node = default_version_info->this_node;
|
default_node = default_version_info->this_node;
|
||||||
|
|
||||||
#ifndef TARGET_LIBC_PROVIDES_HWCAP_IN_TCB
|
#ifndef TARGET_LIBC_PROVIDES_HWCAP_IN_TCB
|
||||||
warning_at (DECL_SOURCE_LOCATION (default_node->decl), 0,
|
error_at (DECL_SOURCE_LOCATION (default_node->decl),
|
||||||
"target_clone needs GLIBC (2.23 and newer) to export hardware "
|
"target_clones attribute needs GLIBC (2.23 and newer) that "
|
||||||
"capability bits");
|
"exports hardware capability bits");
|
||||||
#endif
|
#else
|
||||||
|
|
||||||
if (targetm.has_ifunc_p ())
|
if (targetm.has_ifunc_p ())
|
||||||
{
|
{
|
||||||
@ -37320,6 +37325,7 @@ rs6000_get_function_versions_dispatcher (void *decl)
|
|||||||
"multiversioning needs ifunc which is not supported "
|
"multiversioning needs ifunc which is not supported "
|
||||||
"on this target");
|
"on this target");
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
return dispatch_decl;
|
return dispatch_decl;
|
||||||
}
|
}
|
||||||
|
@ -3282,7 +3282,8 @@ one compiled with @option{-msse4.1} and another with @option{-mavx}.
|
|||||||
On a PowerPC, you can compile a function with
|
On a PowerPC, you can compile a function with
|
||||||
@code{target_clones("cpu=power9,default")}. GCC will create two
|
@code{target_clones("cpu=power9,default")}. GCC will create two
|
||||||
function clones, one compiled with @option{-mcpu=power9} and another
|
function clones, one compiled with @option{-mcpu=power9} and another
|
||||||
with the default options.
|
with the default options. GCC must be configured to use GLIBC 2.23 or
|
||||||
|
newer in order to use the @code{target_clones} attribute.
|
||||||
|
|
||||||
It also creates a resolver function (see
|
It also creates a resolver function (see
|
||||||
the @code{ifunc} attribute above) that dynamically selects a clone
|
the @code{ifunc} attribute above) that dynamically selects a clone
|
||||||
@ -14945,8 +14946,18 @@ to maintain API compatibility with the x86 builtins.
|
|||||||
|
|
||||||
@deftypefn {Built-in Function} int __builtin_cpu_is (const char *@var{cpuname})
|
@deftypefn {Built-in Function} int __builtin_cpu_is (const char *@var{cpuname})
|
||||||
This function returns a value of @code{1} if the run-time CPU is of type
|
This function returns a value of @code{1} if the run-time CPU is of type
|
||||||
@var{cpuname} and returns @code{0} otherwise. The following CPU names can be
|
@var{cpuname} and returns @code{0} otherwise
|
||||||
detected:
|
|
||||||
|
The @code{__builtin_cpu_is} function requires GLIBC 2.23 or newer
|
||||||
|
which exports the hardware capability bits. GCC defines the macro
|
||||||
|
@code{__BUILTIN_CPU_SUPPORTS__} if the @code{__builtin_cpu_supports}
|
||||||
|
built-in function is fully supported.
|
||||||
|
|
||||||
|
If GCC was configured to use a GLIBC before 2.23, the built-in
|
||||||
|
function @code{__builtin_cpu_is} always returns a 0 and the compiler
|
||||||
|
issues a warning.
|
||||||
|
|
||||||
|
The following CPU names can be detected:
|
||||||
|
|
||||||
@table @samp
|
@table @samp
|
||||||
@item power9
|
@item power9
|
||||||
@ -14983,20 +14994,33 @@ IBM PowerPC Cell Broadband Engine Architecture CPU.
|
|||||||
|
|
||||||
Here is an example:
|
Here is an example:
|
||||||
@smallexample
|
@smallexample
|
||||||
if (__builtin_cpu_is ("power8"))
|
#ifdef __BUILTIN_CPU_SUPPORTS__
|
||||||
@{
|
if (__builtin_cpu_is ("power8"))
|
||||||
do_power8 (); // POWER8 specific implementation.
|
@{
|
||||||
@}
|
do_power8 (); // POWER8 specific implementation.
|
||||||
else
|
@}
|
||||||
@{
|
else
|
||||||
do_generic (); // Generic implementation.
|
#endif
|
||||||
@}
|
@{
|
||||||
|
do_generic (); // Generic implementation.
|
||||||
|
@}
|
||||||
@end smallexample
|
@end smallexample
|
||||||
@end deftypefn
|
@end deftypefn
|
||||||
|
|
||||||
@deftypefn {Built-in Function} int __builtin_cpu_supports (const char *@var{feature})
|
@deftypefn {Built-in Function} int __builtin_cpu_supports (const char *@var{feature})
|
||||||
This function returns a value of @code{1} if the run-time CPU supports the HWCAP
|
This function returns a value of @code{1} if the run-time CPU supports the HWCAP
|
||||||
feature @var{feature} and returns @code{0} otherwise. The following features can be
|
feature @var{feature} and returns @code{0} otherwise.
|
||||||
|
|
||||||
|
The @code{__builtin_cpu_supports} function requires GLIBC 2.23 or
|
||||||
|
newer which exports the hardware capability bits. GCC defines the
|
||||||
|
macro @code{__BUILTIN_CPU_SUPPORTS__} if the
|
||||||
|
@code{__builtin_cpu_supports} built-in function is fully supported.
|
||||||
|
|
||||||
|
If GCC was configured to use a GLIBC before 2.23, the built-in
|
||||||
|
function @code{__builtin_cpu_suports} always returns a 0 and the
|
||||||
|
compiler issues a warning.
|
||||||
|
|
||||||
|
The following features can be
|
||||||
detected:
|
detected:
|
||||||
|
|
||||||
@table @samp
|
@table @samp
|
||||||
@ -15080,14 +15104,16 @@ CPU supports the vector-scalar extension.
|
|||||||
|
|
||||||
Here is an example:
|
Here is an example:
|
||||||
@smallexample
|
@smallexample
|
||||||
if (__builtin_cpu_supports ("fpu"))
|
#ifdef __BUILTIN_CPU_SUPPORTS__
|
||||||
@{
|
if (__builtin_cpu_supports ("fpu"))
|
||||||
asm("fadd %0,%1,%2" : "=d"(dst) : "d"(src1), "d"(src2));
|
@{
|
||||||
@}
|
asm("fadd %0,%1,%2" : "=d"(dst) : "d"(src1), "d"(src2));
|
||||||
else
|
@}
|
||||||
@{
|
else
|
||||||
dst = __fadd (src1, src2); // Software FP addition function.
|
#endif
|
||||||
@}
|
@{
|
||||||
|
dst = __fadd (src1, src2); // Software FP addition function.
|
||||||
|
@}
|
||||||
@end smallexample
|
@end smallexample
|
||||||
@end deftypefn
|
@end deftypefn
|
||||||
|
|
||||||
|
@ -1,3 +1,33 @@
|
|||||||
|
2017-07-12 Michael Meissner <meissner@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
PR target/81193
|
||||||
|
* gcc.target/powerpc/bmi-andn-1.c: Add guard against using
|
||||||
|
__builtin_cpu_supports with old GLIBC's.
|
||||||
|
* gcc.target/powerpc/bmi-andn-2.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi-bextr-1.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi-bextr-2.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi-bextr-4.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi-bextr-5.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi-blsi-1.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi-blsi-2.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi-blsmsk-1.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi-blsmsk-2.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi-blsr-1.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi-blsr-2.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi-tzcnt-1.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi-tzcnt-2.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi2-bzhi32-1.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi2-bzhi64-1.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi2-mulx32-1.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi2-mulx32-2.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi2-mulx64-1.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi2-mulx64-2.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi2-pdep32-1.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi2-pdep64-1.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi2-pext32-1.c: Likewise.
|
||||||
|
* gcc.target/powerpc/bmi2-pext64-1.c: Likewise.
|
||||||
|
* gcc.target/powerpc/cpu-builtin-1.c: Likewise.
|
||||||
|
|
||||||
2017-07-12 Carl Love <cel@us.ibm.com>
|
2017-07-12 Carl Love <cel@us.ibm.com>
|
||||||
|
|
||||||
* gcc.target/powerpc/p9-xxbr-1.c (rev_bool_char, rev_bool_short,
|
* gcc.target/powerpc/p9-xxbr-1.c (rev_bool_char, rev_bool_short,
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3" } */
|
/* { dg-options "-O3" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3" } */
|
/* { dg-options "-O3" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O2 -fno-inline" } */
|
/* { dg-options "-O2 -fno-inline" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3 -fno-inline" } */
|
/* { dg-options "-O3 -fno-inline" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3 -fno-inline" } */
|
/* { dg-options "-O3 -fno-inline" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3 -fno-inline" } */
|
/* { dg-options "-O3 -fno-inline" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3 -fno-inline" } */
|
/* { dg-options "-O3 -fno-inline" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3 -fno-inline" } */
|
/* { dg-options "-O3 -fno-inline" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3 -fno-inline" } */
|
/* { dg-options "-O3 -fno-inline" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3 -fno-inline" } */
|
/* { dg-options "-O3 -fno-inline" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3 -fno-inline" } */
|
/* { dg-options "-O3 -fno-inline" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3 -fno-inline" } */
|
/* { dg-options "-O3 -fno-inline" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3 -fno-inline" } */
|
/* { dg-options "-O3 -fno-inline" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3 -fno-inline" } */
|
/* { dg-options "-O3 -fno-inline" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3" } */
|
/* { dg-options "-O3" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3" } */
|
/* { dg-options "-O3" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3" } */
|
/* { dg-options "-O3" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include "bmi2-check.h"
|
#include "bmi2-check.h"
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3" } */
|
/* { dg-options "-O3" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3" } */
|
/* { dg-options "-O3" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include "bmi2-check.h"
|
#include "bmi2-check.h"
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* { dg-do run } */
|
/* { dg-do run } */
|
||||||
/* { dg-options "-O3" } */
|
/* { dg-options "-O3" } */
|
||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
/* { dg-require-effective-target vsx_hw } */
|
/* { dg-require-effective-target vsx_hw } */
|
||||||
/* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power7" } } */
|
/* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power7" } } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
/* { dg-require-effective-target vsx_hw } */
|
/* { dg-require-effective-target vsx_hw } */
|
||||||
/* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power7" } } */
|
/* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power7" } } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
/* { dg-require-effective-target vsx_hw } */
|
/* { dg-require-effective-target vsx_hw } */
|
||||||
/* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power7" } } */
|
/* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power7" } } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
/* { dg-require-effective-target lp64 } */
|
/* { dg-require-effective-target lp64 } */
|
||||||
/* { dg-require-effective-target vsx_hw } */
|
/* { dg-require-effective-target vsx_hw } */
|
||||||
/* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power7" } } */
|
/* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power7" } } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
#define NO_WARN_X86_INTRINSICS 1
|
#define NO_WARN_X86_INTRINSICS 1
|
||||||
#include <x86intrin.h>
|
#include <x86intrin.h>
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
/* { dg-do compile { target { powerpc*-*-* } } } */
|
/* { dg-do compile { target { powerpc*-*-* } } } */
|
||||||
/* { dg-skip-if "" { powerpc*-*-darwin* } } */
|
/* { dg-skip-if "" { powerpc*-*-darwin* } } */
|
||||||
|
/* { dg-require-effective-target ppc_cpu_supports_hw } */
|
||||||
|
|
||||||
void
|
void
|
||||||
use_cpu_is_builtins (unsigned int *p)
|
use_cpu_is_builtins (unsigned int *p)
|
||||||
|
@ -1,3 +1,11 @@
|
|||||||
|
2017-07-12 Michael Meissner <meissner@linux.vnet.ibm.com>
|
||||||
|
|
||||||
|
PR target/81193
|
||||||
|
* configure.ac (PowerPC float128 hardware support): Test whether
|
||||||
|
we can use __builtin_cpu_supports before enabling the ifunc
|
||||||
|
handler.
|
||||||
|
* configure: Regenerate.
|
||||||
|
|
||||||
2017-07-10 Vineet Gupta <vgupta@synopsys.com>
|
2017-07-10 Vineet Gupta <vgupta@synopsys.com>
|
||||||
|
|
||||||
* config.host: Remove uclibc from arc target spec.
|
* config.host: Remove uclibc from arc target spec.
|
||||||
|
11
libgcc/configure
vendored
11
libgcc/configure
vendored
@ -4975,10 +4975,10 @@ esac
|
|||||||
esac
|
esac
|
||||||
|
|
||||||
case ${host} in
|
case ${host} in
|
||||||
# At present, we cannot turn -mfloat128 on via #pragma GCC target,
|
# At present, we cannot turn -mfloat128 on via #pragma GCC target, so just
|
||||||
# so just check if we have VSX (ISA 2.06) support to build the
|
# check if we have VSX (ISA 2.06) support to build the software libraries, and
|
||||||
# software libraries, and whether the assembler can handle xsaddqp
|
# whether the assembler can handle xsaddqp for hardware support. Also check if
|
||||||
# for hardware support.
|
# a new glibc is being used so that __builtin_cpu_supports can be used.
|
||||||
powerpc*-*-linux*)
|
powerpc*-*-linux*)
|
||||||
saved_CFLAGS="$CFLAGS"
|
saved_CFLAGS="$CFLAGS"
|
||||||
CFLAGS="$CFLAGS -mabi=altivec -mvsx -mfloat128"
|
CFLAGS="$CFLAGS -mabi=altivec -mvsx -mfloat128"
|
||||||
@ -5013,6 +5013,9 @@ else
|
|||||||
#ifndef AT_PLATFORM
|
#ifndef AT_PLATFORM
|
||||||
#error "AT_PLATFORM is not defined"
|
#error "AT_PLATFORM is not defined"
|
||||||
#endif
|
#endif
|
||||||
|
#ifndef __BUILTIN_CPU_SUPPORTS__
|
||||||
|
#error "__builtin_cpu_supports is not available"
|
||||||
|
#endif
|
||||||
vector unsigned char add (vector unsigned char a, vector unsigned char b)
|
vector unsigned char add (vector unsigned char a, vector unsigned char b)
|
||||||
{
|
{
|
||||||
vector unsigned char ret;
|
vector unsigned char ret;
|
||||||
|
@ -376,10 +376,10 @@ esac
|
|||||||
esac
|
esac
|
||||||
|
|
||||||
case ${host} in
|
case ${host} in
|
||||||
# At present, we cannot turn -mfloat128 on via #pragma GCC target,
|
# At present, we cannot turn -mfloat128 on via #pragma GCC target, so just
|
||||||
# so just check if we have VSX (ISA 2.06) support to build the
|
# check if we have VSX (ISA 2.06) support to build the software libraries, and
|
||||||
# software libraries, and whether the assembler can handle xsaddqp
|
# whether the assembler can handle xsaddqp for hardware support. Also check if
|
||||||
# for hardware support.
|
# a new glibc is being used so that __builtin_cpu_supports can be used.
|
||||||
powerpc*-*-linux*)
|
powerpc*-*-linux*)
|
||||||
saved_CFLAGS="$CFLAGS"
|
saved_CFLAGS="$CFLAGS"
|
||||||
CFLAGS="$CFLAGS -mabi=altivec -mvsx -mfloat128"
|
CFLAGS="$CFLAGS -mabi=altivec -mvsx -mfloat128"
|
||||||
@ -398,6 +398,9 @@ powerpc*-*-linux*)
|
|||||||
#ifndef AT_PLATFORM
|
#ifndef AT_PLATFORM
|
||||||
#error "AT_PLATFORM is not defined"
|
#error "AT_PLATFORM is not defined"
|
||||||
#endif
|
#endif
|
||||||
|
#ifndef __BUILTIN_CPU_SUPPORTS__
|
||||||
|
#error "__builtin_cpu_supports is not available"
|
||||||
|
#endif
|
||||||
vector unsigned char add (vector unsigned char a, vector unsigned char b)
|
vector unsigned char add (vector unsigned char a, vector unsigned char b)
|
||||||
{
|
{
|
||||||
vector unsigned char ret;
|
vector unsigned char ret;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user