diff options
Diffstat (limited to 'gcc/testsuite/gcc.target/i386/avx512vl-check.h')
-rw-r--r-- | gcc/testsuite/gcc.target/i386/avx512vl-check.h | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.target/i386/avx512vl-check.h b/gcc/testsuite/gcc.target/i386/avx512vl-check.h new file mode 100644 index 00000000000..c017ee28e47 --- /dev/null +++ b/gcc/testsuite/gcc.target/i386/avx512vl-check.h @@ -0,0 +1,49 @@ +#include <stdlib.h> +#include "cpuid.h" +#include "m512-check.h" +#include "avx512f-os-support.h" + +static void avx512vl_test (void); + +static void __attribute__ ((noinline)) do_test (void) +{ + avx512vl_test (); +} + +int +main () +{ + unsigned int eax, ebx, ecx, edx; + + if (!__get_cpuid (1, &eax, &ebx, &ecx, &edx)) + return 0; + + /* Run avx512vl test only if host has avx512vl support. */ + 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_AVX512F) == bit_AVX512F) + && ((ebx & bit_AVX512VL) == bit_AVX512VL)) + { + 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; +} |