Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDanny Smith <dannysmith@users.sourceforge.net>2003-07-03 15:24:18 +0400
committerDanny Smith <dannysmith@users.sourceforge.net>2003-07-03 15:24:18 +0400
commit235f653a53a46cf225a4c0e7276436e2822b67d8 (patch)
tree60281dd899821cf91ed91e48c52b442b0d779d59 /winsup/mingw/mingwex
parent78b8a13965e94dac60e4872f6fd6d10093322a2c (diff)
* mingwex/math/trunc.c (trunc): Provide lvalue for memory input constraint.
* mingwex/math/truncf.c (truncf): Likewise. * mingwex/math/truncl.c (truncl): Likewise. * mingwex/math/modff.c (modff): Likewise. * mingwex/math/modfl.c (modfl): Likewise.
Diffstat (limited to 'winsup/mingw/mingwex')
-rw-r--r--winsup/mingw/mingwex/math/modff.c5
-rw-r--r--winsup/mingw/mingwex/math/modfl.c5
-rw-r--r--winsup/mingw/mingwex/math/trunc.c11
-rw-r--r--winsup/mingw/mingwex/math/truncf.c14
-rw-r--r--winsup/mingw/mingwex/math/truncl.c11
5 files changed, 23 insertions, 23 deletions
diff --git a/winsup/mingw/mingwex/math/modff.c b/winsup/mingw/mingwex/math/modff.c
index 9e34c7c95..072faace0 100644
--- a/winsup/mingw/mingwex/math/modff.c
+++ b/winsup/mingw/mingwex/math/modff.c
@@ -9,10 +9,11 @@ modff (float value, float* iptr)
{
float int_part;
unsigned short saved_cw;
+ unsigned short tmp_cw;
/* truncate */
asm ("fnstcw %0;" : "=m" (saved_cw)); /* save control word */
- asm ("fldcw %0;" : : "m" ((saved_cw & ~FE_ROUNDING_MASK)
- | FE_TOWARDZERO));
+ tmp_cw = (saved_cw & ~FE_ROUNDING_MASK) | FE_TOWARDZERO;
+ asm ("fldcw %0;" : : "m" (tmp_cw));
asm ("frndint;" : "=t" (int_part) : "0" (value)); /* round */
asm ("fldcw %0;" : : "m" (saved_cw)); /* restore saved cw */
if (iptr)
diff --git a/winsup/mingw/mingwex/math/modfl.c b/winsup/mingw/mingwex/math/modfl.c
index 5663956f0..c7ea2cbce 100644
--- a/winsup/mingw/mingwex/math/modfl.c
+++ b/winsup/mingw/mingwex/math/modfl.c
@@ -9,10 +9,11 @@ modfl (long double value, long double* iptr)
{
long double int_part;
unsigned short saved_cw;
+ unsigned short tmp_cw;
/* truncate */
asm ("fnstcw %0;" : "=m" (saved_cw)); /* save control word */
- asm ("fldcw %0;" : : "m" ((saved_cw & ~FE_ROUNDING_MASK)
- | FE_TOWARDZERO));
+ tmp_cw = (saved_cw & ~FE_ROUNDING_MASK) | FE_TOWARDZERO;
+ asm ("fldcw %0;" : : "m" (tmp_cw));
asm ("frndint;" : "=t" (int_part) : "0" (value)); /* round */
asm ("fldcw %0;" : : "m" (saved_cw)); /* restore saved cw */
if (iptr)
diff --git a/winsup/mingw/mingwex/math/trunc.c b/winsup/mingw/mingwex/math/trunc.c
index 2b9931255..5c7dc68cb 100644
--- a/winsup/mingw/mingwex/math/trunc.c
+++ b/winsup/mingw/mingwex/math/trunc.c
@@ -5,12 +5,11 @@ double
trunc (double _x){
double retval;
unsigned short saved_cw;
- __asm__ ("fnstcw %0;": "=m" (saved_cw)); /* save FPU control word */
- __asm__ ("fldcw %0;"
- :
- : "m" ((saved_cw & ~(FE_TONEAREST | FE_DOWNWARD | FE_UPWARD
- | FE_TOWARDZERO)) | FE_TOWARDZERO)
- );
+ unsigned short tmp_cw;
+ __asm__ ("fnstcw %0;" : "=m" (saved_cw)); /* save FPU control word */
+ tmp_cw = (saved_cw & ~(FE_TONEAREST | FE_DOWNWARD | FE_UPWARD | FE_TOWARDZERO))
+ | FE_TOWARDZERO;
+ __asm__ ("fldcw %0;" : : "m" (tmp_cw));
__asm__ ("frndint;" : "=t" (retval) : "0" (_x)); /* round towards zero */
__asm__ ("fldcw %0;" : : "m" (saved_cw) ); /* restore saved control word */
return retval;
diff --git a/winsup/mingw/mingwex/math/truncf.c b/winsup/mingw/mingwex/math/truncf.c
index 53fccb153..8869e377f 100644
--- a/winsup/mingw/mingwex/math/truncf.c
+++ b/winsup/mingw/mingwex/math/truncf.c
@@ -2,15 +2,15 @@
#include <math.h>
float
-truncf (float _x){
+truncf (float _x)
+{
float retval;
unsigned short saved_cw;
- __asm__ ("fnstcw %0;": "=m" (saved_cw)); /* save FPU control word */
- __asm__ ("fldcw %0;"
- :
- : "m" ((saved_cw & ~(FE_TONEAREST | FE_DOWNWARD | FE_UPWARD
- | FE_TOWARDZERO)) | FE_TOWARDZERO)
- );
+ unsigned short tmp_cw;
+ __asm__ ("fnstcw %0;" : "=m" (saved_cw)); /* save FPU control word */
+ tmp_cw = (saved_cw & ~(FE_TONEAREST | FE_DOWNWARD | FE_UPWARD | FE_TOWARDZERO))
+ | FE_TOWARDZERO;
+ __asm__ ("fldcw %0;" : : "m" (tmp_cw));
__asm__ ("frndint;" : "=t" (retval) : "0" (_x)); /* round towards zero */
__asm__ ("fldcw %0;" : : "m" (saved_cw) ); /* restore saved control word */
return retval;
diff --git a/winsup/mingw/mingwex/math/truncl.c b/winsup/mingw/mingwex/math/truncl.c
index 908197acc..e34b21ba9 100644
--- a/winsup/mingw/mingwex/math/truncl.c
+++ b/winsup/mingw/mingwex/math/truncl.c
@@ -5,12 +5,11 @@ long double
truncl (long double _x){
long double retval;
unsigned short saved_cw;
- __asm__ ("fnstcw %0;": "=m" (saved_cw)); /* save FPU control word */
- __asm__ ("fldcw %0;"
- :
- : "m" ((saved_cw & ~(FE_TONEAREST | FE_DOWNWARD | FE_UPWARD
- | FE_TOWARDZERO)) | FE_TOWARDZERO)
- );
+ unsigned short tmp_cw;
+ __asm__ ("fnstcw %0;" : "=m" (saved_cw)); /* save FPU control word */
+ tmp_cw = (saved_cw & ~(FE_TONEAREST | FE_DOWNWARD | FE_UPWARD | FE_TOWARDZERO))
+ | FE_TOWARDZERO;
+ __asm__ ("fldcw %0;" : : "m" (tmp_cw));
__asm__ ("frndint;" : "=t" (retval) : "0" (_x)); /* round towards zero */
__asm__ ("fldcw %0;" : : "m" (saved_cw) ); /* restore saved control word */
return retval;