sfp-machine.h (FP_RND_NEAREST, [...]): Move to ...
authorUros Bizjak <ubizjak@gmail.com>
Wed, 10 Oct 2012 18:35:32 +0000 (20:35 +0200)
committerUros Bizjak <uros@gcc.gnu.org>
Wed, 10 Oct 2012 18:35:32 +0000 (20:35 +0200)
* config/i386/sfp-machine.h (FP_RND_NEAREST, FP_RND_ZERO, FP_RND_PINF,
FP_RND_MINF, FP_RND_MASK, FP_INIT_ROUNDMODE, _FP_DECL_EX): Move to ...
* config/i386/32/sfp-machine.h: ... here.
* config/i386/64/sfp-machine.h (FP_RND_NEAREST, FP_RND_ZERO,
FP_RND_PINF, FP_RND_MINF, FP_RND_MASK, FP_INIT_ROUNDMODE, _FP_DECL_EX):
New defines.

From-SVN: r192324

libgcc/ChangeLog
libgcc/config/i386/32/sfp-machine.h
libgcc/config/i386/64/sfp-machine.h
libgcc/config/i386/sfp-machine.h

index b09c22fe5f2a3d977d58c270749efbd6b451cc87..e521dfaf01d7776e061a8f3cce37bb2ef113e143 100644 (file)
@@ -1,3 +1,12 @@
+2012-10-10  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/sfp-machine.h (FP_RND_NEAREST, FP_RND_ZERO, FP_RND_PINF,
+       FP_RND_MINF, FP_RND_MASK, FP_INIT_ROUNDMODE, _FP_DECL_EX): Move to ...
+       * config/i386/32/sfp-machine.h: ... here.
+       * config/i386/64/sfp-machine.h (FP_RND_NEAREST, FP_RND_ZERO,
+       FP_RND_PINF, FP_RND_MINF, FP_RND_MASK, FP_INIT_ROUNDMODE, _FP_DECL_EX):
+       New defines.
+
 2012-10-07  Matthias Klose  <doko@ubuntu.com>
 
        * config/arm/unwind-arm.h (__gnu_unwind_24bit): Mark parameters
index 7f0c099414d8cc4aa7b3ca2b0f7076eb93f4956b..474ade0d5038c71d104e1b68b4d1a216daac06dd 100644 (file)
    16byte since soft-fp emulation is done in 16byte.  */
 #define _FP_NANFRAC_E          _FP_QNANBIT_E, 0, 0, 0
 #define _FP_NANFRAC_Q          _FP_QNANBIT_Q, 0, 0, 0
+
+#define FP_RND_NEAREST         0
+#define FP_RND_ZERO            0xc00
+#define FP_RND_PINF            0x800
+#define FP_RND_MINF            0x400
+
+#define FP_RND_MASK            0xc00
+
+#define _FP_DECL_EX \
+  unsigned short _fcw __attribute__ ((unused)) = FP_RND_NEAREST;
+
+#define FP_INIT_ROUNDMODE                              \
+  do {                                                 \
+    __asm__ __volatile__ ("fnstcw\t%0" : "=m" (_fcw)); \
+  } while (0)
index 8cc982ecc7975a538d2da32aed5851088fe10673..fc9a38af696be8987e4bbe15172d3cd789687510 100644 (file)
@@ -17,3 +17,18 @@ typedef unsigned int UTItype __attribute__ ((mode (TI)));
 #define _FP_NANFRAC_D          _FP_QNANBIT_D
 #define _FP_NANFRAC_E          _FP_QNANBIT_E, 0
 #define _FP_NANFRAC_Q          _FP_QNANBIT_Q, 0
+
+#define FP_RND_NEAREST         0
+#define FP_RND_ZERO            0x6000
+#define FP_RND_PINF            0x4000
+#define FP_RND_MINF            0x2000
+
+#define FP_RND_MASK            0x6000
+
+#define _FP_DECL_EX \
+  unsigned int _fcw __attribute__ ((unused)) = FP_RND_NEAREST;
+
+#define FP_INIT_ROUNDMODE                                      \
+  do {                                                         \
+    __asm__ __volatile__ ("%vstmxcsr\t%0" : "=m" (_fcw));      \
+  } while (0)
index 34b4ca10e14ff6aa7764220f12b7d1157dde1a82..01bf14ffbb04cff1facbe42e99485506d6fe8f13 100644 (file)
@@ -55,21 +55,6 @@ void __sfp_handle_exceptions (int);
       __sfp_handle_exceptions (_fex);          \
   } while (0);
 
-#define FP_RND_NEAREST         0
-#define FP_RND_ZERO            0xc00
-#define FP_RND_PINF            0x800
-#define FP_RND_MINF            0x400
-
-#define FP_RND_MASK            0xc00
-
-#define _FP_DECL_EX \
-  unsigned short _fcw __attribute__ ((unused)) = FP_RND_NEAREST
-
-#define FP_INIT_ROUNDMODE                              \
-  do {                                                 \
-    __asm__ __volatile__ ("fnstcw\t%0" : "=m" (_fcw)); \
-  } while (0)
-
 #define FP_ROUNDMODE           (_fcw & FP_RND_MASK)
 
 #define        __LITTLE_ENDIAN 1234