diff options
| author | 2014-12-16 05:53:19 -0500 | |
|---|---|---|
| committer | 2014-12-16 05:54:00 -0500 | |
| commit | 2ed03c10e03bbd0f513d157c577f1c75ae9ede5b (patch) | |
| tree | 5ee827081e5366694d3b999f5e76b9d04bc17070 /src | |
| parent | Merge pull request #281 from lioncash/uxtb16 (diff) | |
| download | yuzu-2ed03c10e03bbd0f513d157c577f1c75ae9ede5b.tar.gz yuzu-2ed03c10e03bbd0f513d157c577f1c75ae9ede5b.tar.xz yuzu-2ed03c10e03bbd0f513d157c577f1c75ae9ede5b.zip | |
armemu: Fix FSUBS bug where NaN shouldn't be negated
Diffstat (limited to 'src')
| -rw-r--r-- | src/core/arm/skyeye_common/vfp/vfpsingle.cpp | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/src/core/arm/skyeye_common/vfp/vfpsingle.cpp b/src/core/arm/skyeye_common/vfp/vfpsingle.cpp index 871900497..f5410fd9a 100644 --- a/src/core/arm/skyeye_common/vfp/vfpsingle.cpp +++ b/src/core/arm/skyeye_common/vfp/vfpsingle.cpp | |||
| @@ -1148,7 +1148,10 @@ static u32 vfp_single_fsub(ARMul_State* state, int sd, int sn, s32 m, u32 fpscr) | |||
| 1148 | /* | 1148 | /* |
| 1149 | * Subtraction is addition with one sign inverted. | 1149 | * Subtraction is addition with one sign inverted. |
| 1150 | */ | 1150 | */ |
| 1151 | return vfp_single_fadd(state, sd, sn, vfp_single_packed_negate(m), fpscr); | 1151 | if (m != 0x7FC00000) // Only negate if m isn't NaN. |
| 1152 | m = vfp_single_packed_negate(m); | ||
| 1153 | |||
| 1154 | return vfp_single_fadd(state, sd, sn, m, fpscr); | ||
| 1152 | } | 1155 | } |
| 1153 | 1156 | ||
| 1154 | /* | 1157 | /* |