From 1bc5aee63eb72b341f506ad058502cd0361f0d10 Mon Sep 17 00:00:00 2001 From: Ben Cheng Date: Tue, 25 Mar 2014 22:37:19 -0700 Subject: Initial checkin of GCC 4.9.0 from trunk (r208799). Change-Id: I48a3c08bb98542aa215912a75f03c0890e497dba --- .../gcc/testsuite/gcc.target/i386/avx512er-check.h | 46 ++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 gcc-4.9/gcc/testsuite/gcc.target/i386/avx512er-check.h (limited to 'gcc-4.9/gcc/testsuite/gcc.target/i386/avx512er-check.h') diff --git a/gcc-4.9/gcc/testsuite/gcc.target/i386/avx512er-check.h b/gcc-4.9/gcc/testsuite/gcc.target/i386/avx512er-check.h new file mode 100644 index 000000000..34440d346 --- /dev/null +++ b/gcc-4.9/gcc/testsuite/gcc.target/i386/avx512er-check.h @@ -0,0 +1,46 @@ +#include +#include "cpuid.h" +#include "m512-check.h" +#include "avx512f-os-support.h" + +static void avx512er_test (void); + +static void __attribute__ ((noinline)) do_test (void) +{ + avx512er_test (); +} + +int +main () +{ + unsigned int eax, ebx, ecx, edx; + + if (!__get_cpuid (1, &eax, &ebx, &ecx, &edx)) + return 0; + + if ((ecx & bit_OSXSAVE) == (bit_OSXSAVE)) + { + if (__get_cpuid_max (0, NULL) < 7) + return 0; + + __cpuid_count (7, 0, eax, ebx, ecx, edx); + + if ((avx512f_os_support ()) && ((ebx & bit_AVX512ER) == bit_AVX512ER)) + { + do_test (); +#ifdef DEBUG + printf ("PASSED\n"); +#endif + return 0; + } +#ifdef DEBUG + printf ("SKIPPED\n"); +#endif + } +#ifdef DEBUG + else + printf ("SKIPPED\n"); +#endif + + return 0; +} -- cgit v1.2.3