ARM: Fix an issue with clang generating wrong code.
Clang generated executables would enter the if condition when it wasn't supposted to, resulting in the wrong simulated behavior. Implementing the operation this way is a bit faster anyway.
This commit is contained in:
parent
7ae06a3b3b
commit
68495a0748
1 changed files with 2 additions and 4 deletions
|
@ -993,9 +993,8 @@ FpOp::binaryOp(FPSCR &fpscr, fpType op1, fpType op2,
|
|||
fpType dest = func(op1, op2);
|
||||
__asm__ __volatile__ ("" : "=m" (dest) : "m" (dest));
|
||||
|
||||
int fpClass = std::fpclassify(dest);
|
||||
// Get NAN behavior right. This varies between x86 and ARM.
|
||||
if (fpClass == FP_NAN) {
|
||||
if (std::isnan(dest)) {
|
||||
const bool single = (sizeof(fpType) == sizeof(float));
|
||||
const uint64_t qnan =
|
||||
single ? 0x7fc00000 : ULL(0x7ff8000000000000);
|
||||
|
@ -1065,9 +1064,8 @@ FpOp::unaryOp(FPSCR &fpscr, fpType op1, fpType (*func)(fpType),
|
|||
fpType dest = func(op1);
|
||||
__asm__ __volatile__ ("" : "=m" (dest) : "m" (dest));
|
||||
|
||||
int fpClass = std::fpclassify(dest);
|
||||
// Get NAN behavior right. This varies between x86 and ARM.
|
||||
if (fpClass == FP_NAN) {
|
||||
if (std::isnan(dest)) {
|
||||
const bool single = (sizeof(fpType) == sizeof(float));
|
||||
const uint64_t qnan =
|
||||
single ? 0x7fc00000 : ULL(0x7ff8000000000000);
|
||||
|
|
Loading…
Reference in a new issue