]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
fpu-387.h (set_fpu): Use __builtin_ia32_stmxcsr and __builtin_ia32_ldmxcsr intrinsics.
authorUros Bizjak <ubizjak@gmail.com>
Wed, 5 Sep 2012 19:49:21 +0000 (21:49 +0200)
committerUros Bizjak <uros@gcc.gnu.org>
Wed, 5 Sep 2012 19:49:21 +0000 (21:49 +0200)
* config/fpu-387.h (set_fpu): Use __builtin_ia32_stmxcsr and
__builtin_ia32_ldmxcsr intrinsics.

From-SVN: r190992

libgfortran/ChangeLog
libgfortran/config/fpu-387.h

index 9f0ed3ec77ff639bcba2e19d8a2e5ea3bda1f24c..65830870d231c759d5201e95e7330f1eb343f90e 100644 (file)
@@ -1,3 +1,8 @@
+2012-03-30  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/fpu-387.h (set_fpu): Use __builtin_ia32_stmxcsr and
+       __builtin_ia32_ldmxcsr intrinsics.
+
 2012-07-25  Andreas Schwab  <schwab@linux-m68k.org>
 
        * io/list_read.c (list_formatted_read_scalar): Fix copying real
index 8bf55b28a618ad51c28493302e07691cc582b95e..0e87aab8b9d07ef0c06bbf84980bd66386b16933 100644 (file)
@@ -118,7 +118,7 @@ void set_fpu (void)
     {
       unsigned int cw_sse;
 
-      asm volatile ("stmxcsr %0" : "=m" (cw_sse));
+      cw_sse = __builtin_ia32_stmxcsr ();
 
       cw_sse &= 0xffff0000;
       cw_sse |= (_FPU_MASK_IM | _FPU_MASK_DM | _FPU_MASK_ZM | _FPU_MASK_OM
@@ -131,6 +131,6 @@ void set_fpu (void)
       if (options.fpe & GFC_FPE_UNDERFLOW) cw_sse &= ~(_FPU_MASK_UM << 7);
       if (options.fpe & GFC_FPE_INEXACT) cw_sse &= ~(_FPU_MASK_PM << 7);
 
-      asm volatile ("ldmxcsr %0" : : "m" (cw_sse));
+      __builtin_ia32_ldmxcsr (cw_sse);
     }
 }