]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
target-supports.exp (check_avx_os_support_available): New.
authorUros Bizjak <ubizjak@gmail.com>
Thu, 21 Jul 2011 21:25:08 +0000 (23:25 +0200)
committerUros Bizjak <uros@gcc.gnu.org>
Thu, 21 Jul 2011 21:25:08 +0000 (23:25 +0200)
* lib/target-supports.exp (check_avx_os_support_available): New.
(check_effective_target_avx_runtime): Use it.

From-SVN: r176590

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

index b22da57f47266617c27b1340842d63da9908fa07..7ca92a4b14d8acec774aaa80bcb721631a260fcd 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-19  Jakub Jelinek  <jakub@redhat.com>
 
        Backport from mainline
index 013ba0bccc965653eb04172c398a296673d04c8c..68c0236ad9de0008ac182fec786061ae12996751 100644 (file)
@@ -960,8 +960,8 @@ proc check_sse_os_support_available { } {
            check_runtime_nocache sse_os_support_available {
                int main ()
                {
-                   __asm__ volatile ("movss %xmm2,%xmm1");
-                   return 0;
+                 asm volatile ("movss %xmm2,%xmm1");
+                 return 0;
                }
            } "-msse"
        } else {
@@ -970,6 +970,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.
 
@@ -1064,7 +1087,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