Use MSVC intrinsic sqrt() on x86 for XBRZ too.
Instead of the inline asm fsqrt instruction. Already being used on x64. Signed-off-by: Rafael Kitover <rkitover@gmail.com>
This commit is contained in:
parent
4af78f6482
commit
55a0a52a39
|
@ -69,13 +69,6 @@ inline double fastSqrt(double n)
|
||||||
#if (defined(__GNUC__) || defined(__clang__)) && (defined(__x86_64__) || defined(__i386__))
|
#if (defined(__GNUC__) || defined(__clang__)) && (defined(__x86_64__) || defined(__i386__))
|
||||||
__asm__ ("fsqrt" : "+t" (n));
|
__asm__ ("fsqrt" : "+t" (n));
|
||||||
return n;
|
return n;
|
||||||
#elif defined(_MSC_VER) && defined(_M_IX86)
|
|
||||||
// speeds up xBRZ by about 9% compared to std::sqrt which internally uses
|
|
||||||
// the same assembler instructions but adds some "fluff"
|
|
||||||
__asm {
|
|
||||||
fld n
|
|
||||||
fsqrt
|
|
||||||
}
|
|
||||||
#elif defined(_MSC_VER)
|
#elif defined(_MSC_VER)
|
||||||
// On MSVC x64 use intrinsic with /Oi and /fp:fast
|
// On MSVC x64 use intrinsic with /Oi and /fp:fast
|
||||||
return sqrt(n);
|
return sqrt(n);
|
||||||
|
|
Loading…
Reference in New Issue