diff options
| author | 2014-12-18 17:45:25 -0500 | |
|---|---|---|
| committer | 2014-12-18 17:45:25 -0500 | |
| commit | 4959e3b2c064e3b26d2c90c130937b87465cb8cb (patch) | |
| tree | f1a1c5ab8c08bcc498615610f75b4508cc93d92b | |
| parent | Merge pull request #301 from Subv/more_savedata (diff) | |
| parent | armemu: Fix lower-bounds clamping for USAT16 (diff) | |
| download | yuzu-4959e3b2c064e3b26d2c90c130937b87465cb8cb.tar.gz yuzu-4959e3b2c064e3b26d2c90c130937b87465cb8cb.tar.xz yuzu-4959e3b2c064e3b26d2c90c130937b87465cb8cb.zip | |
Merge pull request #307 from lioncash/usat16
armemu: Fix USAT16.
Diffstat (limited to '')
| -rw-r--r-- | src/core/arm/interpreter/armemu.cpp | 31 |
1 files changed, 20 insertions, 11 deletions
diff --git a/src/core/arm/interpreter/armemu.cpp b/src/core/arm/interpreter/armemu.cpp index b9ac8b9ad..99fc6c45d 100644 --- a/src/core/arm/interpreter/armemu.cpp +++ b/src/core/arm/interpreter/armemu.cpp | |||
| @@ -6192,18 +6192,27 @@ L_stm_s_takeabort: | |||
| 6192 | //ichfly | 6192 | //ichfly |
| 6193 | //USAT16 | 6193 | //USAT16 |
| 6194 | { | 6194 | { |
| 6195 | u8 tar = BITS(12, 15); | 6195 | const u8 rd_idx = BITS(12, 15); |
| 6196 | u8 src = BITS(0, 3); | 6196 | const u8 rn_idx = BITS(0, 3); |
| 6197 | u8 val = BITS(16, 19); | 6197 | const u8 num_bits = BITS(16, 19); |
| 6198 | s16 a1 = (state->Reg[src]); | 6198 | const s16 max = 0xFFFF >> (16 - num_bits); |
| 6199 | s16 a2 = (state->Reg[src] >> 0x10); | 6199 | s16 rn_lo = (state->Reg[rn_idx]); |
| 6200 | s16 max = 0xFFFF >> (16 - val); | 6200 | s16 rn_hi = (state->Reg[rn_idx] >> 16); |
| 6201 | if (max < a1) a1 = max; | 6201 | |
| 6202 | if (max < a2) a2 = max; | 6202 | if (max < rn_lo) |
| 6203 | u32 temp2 = ((u32)(a2)) << 0x10; | 6203 | rn_lo = max; |
| 6204 | state->Reg[tar] = (a1 & 0xFFFF) | (temp2); | 6204 | else if (rn_lo < 0) |
| 6205 | rn_lo = 0; | ||
| 6206 | |||
| 6207 | if (max < rn_hi) | ||
| 6208 | rn_hi = max; | ||
| 6209 | else if (rn_hi < 0) | ||
| 6210 | rn_hi = 0; | ||
| 6211 | |||
| 6212 | state->Reg[rd_idx] = (rn_lo & 0xFFFF) | ((rn_hi << 16) & 0xFFFF); | ||
| 6213 | return 1; | ||
| 6205 | } | 6214 | } |
| 6206 | return 1; | 6215 | |
| 6207 | default: | 6216 | default: |
| 6208 | break; | 6217 | break; |
| 6209 | } | 6218 | } |