diff options
author | uros <uros@138bc75d-0d04-0410-961f-82ee72b054a4> | 2013-06-19 06:38:16 +0000 |
---|---|---|
committer | uros <uros@138bc75d-0d04-0410-961f-82ee72b054a4> | 2013-06-19 06:38:16 +0000 |
commit | 510b35b81b935fc5c16ce36a7ce575f698a3ad6f (patch) | |
tree | 3940cd146ec0b28544034fc074a229b3267eb864 | |
parent | caf122b741fb7d5f01ea4f77974e3daa5755aaeb (diff) | |
download | gcc-510b35b81b935fc5c16ce36a7ce575f698a3ad6f.tar.gz |
* config/fpu-387.h: Use __asm__ and __volatile__ consistently.
(get_fpu_except_flags): Initialize result.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@200187 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | libgfortran/ChangeLog | 5 | ||||
-rw-r--r-- | libgfortran/config/fpu-387.h | 37 |
2 files changed, 19 insertions, 23 deletions
diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog index de5cfdd1ed9..d5ffcd2f03e 100644 --- a/libgfortran/ChangeLog +++ b/libgfortran/ChangeLog @@ -1,3 +1,8 @@ +2012-06-19 Uros Bizjak <ubizjak@gmail.com> + + * config/fpu-387.h: Use __asm__ and __volatile__ consistently. + (get_fpu_except_flags): Initialize result. + 2013-06-17 Tobias Burnus <burnus@net-b.de> * libgfortran.h (compile_options_t) Add fpe_summary. diff --git a/libgfortran/config/fpu-387.h b/libgfortran/config/fpu-387.h index 608354d975a..6c42ab84524 100644 --- a/libgfortran/config/fpu-387.h +++ b/libgfortran/config/fpu-387.h @@ -73,7 +73,7 @@ has_sse (void) /* We need a single SSE instruction here so the handler can safely skip over it. */ - __asm__ volatile ("movaps %xmm0,%xmm0"); + __asm__ __volatile__ ("movaps\t%xmm0,%xmm0"); sigaction (SIGILL, &oact, NULL); @@ -100,7 +100,7 @@ void set_fpu (void) { unsigned short cw; - asm volatile ("fnstcw %0" : "=m" (cw)); + __asm__ __volatile__ ("fnstcw\t%0" : "=m" (cw)); cw |= (_FPU_MASK_IM | _FPU_MASK_DM | _FPU_MASK_ZM | _FPU_MASK_OM | _FPU_MASK_UM | _FPU_MASK_PM); @@ -112,13 +112,13 @@ void set_fpu (void) if (options.fpe & GFC_FPE_UNDERFLOW) cw &= ~_FPU_MASK_UM; if (options.fpe & GFC_FPE_INEXACT) cw &= ~_FPU_MASK_PM; - asm volatile ("fldcw %0" : : "m" (cw)); + __asm__ __volatile__ ("fldcw\t%0" : : "m" (cw)); if (has_sse()) { unsigned int cw_sse; - asm volatile ("%vstmxcsr %0" : "=m" (cw_sse)); + __asm__ __volatile__ ("%vstmxcsr\t%0" : "=m" (cw_sse)); cw_sse &= 0xffff0000; cw_sse |= (_FPU_MASK_IM | _FPU_MASK_DM | _FPU_MASK_ZM | _FPU_MASK_OM @@ -131,7 +131,7 @@ 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 ("%vldmxcsr %0" : : "m" (cw_sse)); + __asm__ __volatile__ ("%vldmxcsr\t%0" : : "m" (cw_sse)); } } @@ -139,7 +139,7 @@ void set_fpu (void) int get_fpu_except_flags (void) { - int result; + int result = 0; unsigned short cw; __asm__ __volatile__ ("fnstsw\t%0" : "=a" (cw)); @@ -147,27 +147,18 @@ get_fpu_except_flags (void) if (has_sse()) { unsigned int cw_sse; + __asm__ __volatile__ ("%vstmxcsr\t%0" : "=m" (cw_sse)); + cw |= cw_sse; } - if (cw & _FPU_MASK_IM) - result |= GFC_FPE_INVALID; - - if (cw & _FPU_MASK_ZM) - result |= GFC_FPE_ZERO; - - if (cw & _FPU_MASK_OM) - result |= GFC_FPE_OVERFLOW; - - if (cw & _FPU_MASK_UM) - result |= GFC_FPE_UNDERFLOW; - - if (cw & _FPU_MASK_DM) - result |= GFC_FPE_DENORMAL; - - if (cw & _FPU_MASK_PM) - result |= GFC_FPE_INEXACT; + if (cw & _FPU_MASK_IM) result |= GFC_FPE_INVALID; + if (cw & _FPU_MASK_DM) result |= GFC_FPE_DENORMAL; + if (cw & _FPU_MASK_ZM) result |= GFC_FPE_ZERO; + if (cw & _FPU_MASK_OM) result |= GFC_FPE_OVERFLOW; + if (cw & _FPU_MASK_UM) result |= GFC_FPE_UNDERFLOW; + if (cw & _FPU_MASK_PM) result |= GFC_FPE_INEXACT; return result; } |