OSDN Git Service

* lib/target-supports.exp (check_avx_os_support_available): New.
authoruros <uros@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 21 Jul 2011 15:53:11 +0000 (15:53 +0000)
committeruros <uros@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 21 Jul 2011 15:53:11 +0000 (15:53 +0000)
(check_effective_target_avx_runtime): Use it.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@176576 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/testsuite/ChangeLog
gcc/testsuite/lib/target-supports.exp

index 334730c..c49e0b7 100644 (file)
@@ -1,3 +1,8 @@
+2011-07-21  Uros Bizjak  <ubizjak@gmail.com>
+
+       * lib/target-supports.exp (check_avx_os_support_available): New.
+       (check_effective_target_avx_runtime): Use it.
+
 2011-07-21  Richard Guenther  <rguenther@suse.de>
 
        PR tree-optimization/49770
@@ -13,7 +18,7 @@
        * gfortran.dg/coarray_lib_token_1.f90: New.
 
 2011-07-21  Georg-Johann Lay  <avr@gjlay.de>
-       
+
        * gcc.dg/pr32912-2.c: Skip for AVR.
        * gcc.dg/pr44674.c: Add dg-require-profiling.
 
index 2148f80..bec4d6f 100644 (file)
@@ -1070,8 +1070,8 @@ proc check_sse_os_support_available { } {
            check_runtime_nocache sse_os_support_available {
                int main ()
                {
-                   __asm__ volatile ("movaps %xmm0,%xmm0");
-                   return 0;
+                 asm volatile ("movaps %xmm0,%xmm0");
+                 return 0;
                }
            } "-msse"
        } else {
@@ -1080,6 +1080,29 @@ proc check_sse_os_support_available { } {
     }]
 }
 
+# Return 1 if the target OS supports running AVX executables, 0
+# otherwise.  Cache the result.
+
+proc check_avx_os_support_available { } {
+    return [check_cached_effective_target avx_os_support_available {
+       # If this is not the right target then we can skip the test.
+       if { !([istarget x86_64-*-*] || [istarget i?86-*-*]) } {
+           expr 0
+       } else {
+           # Check that OS has AVX and SSE saving enabled.
+           check_runtime_nocache avx_os_support_available {
+               int main ()
+               {
+                 unsigned int eax, edx;
+
+                 asm ("xgetbv" : "=a" (eax), "=d" (edx) : "c" (0));
+                 return (eax & 6) != 6;
+               }
+           } ""
+       }
+    }]
+}
+
 # Return 1 if the target supports executing SSE instructions, 0
 # otherwise.  Cache the result.
 
@@ -1176,7 +1199,8 @@ proc check_effective_target_sse2_runtime { } {
 
 proc check_effective_target_avx_runtime { } {
     if { [check_effective_target_avx]
-        && [check_avx_hw_available] } {
+        && [check_avx_hw_available]
+        && [check_avx_os_support_available] } {
        return 1
     }
     return 0