Commit 67c7c403 authored by Piotr Caban's avatar Piotr Caban Committed by Alexandre Julliard

msvcrt: Don't set x87 control word in x86_64 fesetenv.

parent 5189d73b
...@@ -5873,6 +5873,7 @@ int CDECL fesetenv(const fenv_t *env) ...@@ -5873,6 +5873,7 @@ int CDECL fesetenv(const fenv_t *env)
{ {
#if (defined(__GNUC__) || defined(__clang__)) && (defined(__i386__) || defined(__x86_64__)) #if (defined(__GNUC__) || defined(__clang__)) && (defined(__i386__) || defined(__x86_64__))
unsigned int x87_cw, sse_cw, x87_stat, sse_stat; unsigned int x87_cw, sse_cw, x87_stat, sse_stat;
#ifdef __i386__
struct { struct {
WORD control_word; WORD control_word;
WORD unused1; WORD unused1;
...@@ -5887,6 +5888,7 @@ int CDECL fesetenv(const fenv_t *env) ...@@ -5887,6 +5888,7 @@ int CDECL fesetenv(const fenv_t *env)
WORD data_segment; WORD data_segment;
WORD unused5; WORD unused5;
} fenv; } fenv;
#endif
TRACE( "(%p)\n", env ); TRACE( "(%p)\n", env );
...@@ -5900,6 +5902,7 @@ int CDECL fesetenv(const fenv_t *env) ...@@ -5900,6 +5902,7 @@ int CDECL fesetenv(const fenv_t *env)
if (!fenv_decode(env->_Fe_stat, &x87_stat, &sse_stat)) if (!fenv_decode(env->_Fe_stat, &x87_stat, &sse_stat))
return 1; return 1;
#ifdef __i386__
__asm__ __volatile__( "fnstenv %0" : "=m" (fenv) ); __asm__ __volatile__( "fnstenv %0" : "=m" (fenv) );
fenv.control_word &= ~0xc3d; fenv.control_word &= ~0xc3d;
...@@ -5938,6 +5941,7 @@ int CDECL fesetenv(const fenv_t *env) ...@@ -5938,6 +5941,7 @@ int CDECL fesetenv(const fenv_t *env)
__asm__ __volatile__( "fldenv %0" : : "m" (fenv) : "st", "st(1)", __asm__ __volatile__( "fldenv %0" : : "m" (fenv) : "st", "st(1)",
"st(2)", "st(3)", "st(4)", "st(5)", "st(6)", "st(7)" ); "st(2)", "st(3)", "st(4)", "st(5)", "st(6)", "st(7)" );
#endif
if (sse2_supported) if (sse2_supported)
{ {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment