ARM: Fix edge case with Thumb SBC flags (fixes #1818)

This commit is contained in:
Vicki Pfau 2020-07-12 14:26:13 -07:00
parent 27d08d4966
commit 189b697b89
2 changed files with 12 additions and 3 deletions

View File

@ -2,6 +2,7 @@
Emulation fixes: Emulation fixes:
- ARM: Fix LDM^ writeback to user-mode register - ARM: Fix LDM^ writeback to user-mode register
- ARM: Fix LDM^ {pc} differences (fixes mgba.io/i/1698) - ARM: Fix LDM^ {pc} differences (fixes mgba.io/i/1698)
- ARM: Fix edge case with Thumb SBC flags (fixes mgba.io/i/1818)
- GB Memory: Fix OAM DMA from top 8 kB - GB Memory: Fix OAM DMA from top 8 kB
- GB MBC: Fix MBC1 RAM enable bit selection - GB MBC: Fix MBC1 RAM enable bit selection
- GB MBC: Fix MBC2 bit selection - GB MBC: Fix MBC2 bit selection

View File

@ -25,6 +25,13 @@
cpu->cpsr.c = ARM_BORROW_FROM(M, N, D); \ cpu->cpsr.c = ARM_BORROW_FROM(M, N, D); \
cpu->cpsr.v = ARM_V_SUBTRACTION(M, N, D); cpu->cpsr.v = ARM_V_SUBTRACTION(M, N, D);
#define THUMB_SUBTRACTION_CARRY_S(M, N, D, C) \
cpu->cpsr.flags = 0; \
cpu->cpsr.n = ARM_SIGN(D); \
cpu->cpsr.z = !(D); \
cpu->cpsr.c = ARM_BORROW_FROM_CARRY(M, N, D, C); \
cpu->cpsr.v = ARM_V_SUBTRACTION(M, N, D);
#define THUMB_NEUTRAL_S(M, N, D) \ #define THUMB_NEUTRAL_S(M, N, D) \
cpu->cpsr.n = ARM_SIGN(D); \ cpu->cpsr.n = ARM_SIGN(D); \
cpu->cpsr.z = !(D); cpu->cpsr.z = !(D);
@ -203,10 +210,11 @@ DEFINE_DATA_FORM_5_INSTRUCTION_THUMB(ADC,
THUMB_ADDITION_S(d, n, cpu->gprs[rd]);) THUMB_ADDITION_S(d, n, cpu->gprs[rd]);)
DEFINE_DATA_FORM_5_INSTRUCTION_THUMB(SBC, DEFINE_DATA_FORM_5_INSTRUCTION_THUMB(SBC,
int n = cpu->gprs[rn] + !cpu->cpsr.c; int n = cpu->gprs[rn];
int d = cpu->gprs[rd]; int d = cpu->gprs[rd];
cpu->gprs[rd] = d - n; cpu->gprs[rd] = d - n - !cpu->cpsr.c;
THUMB_SUBTRACTION_S(d, n, cpu->gprs[rd]);) THUMB_SUBTRACTION_CARRY_S(d, n, cpu->gprs[rd], !cpu->cpsr.c);)
DEFINE_DATA_FORM_5_INSTRUCTION_THUMB(ROR, DEFINE_DATA_FORM_5_INSTRUCTION_THUMB(ROR,
int rs = cpu->gprs[rn] & 0xFF; int rs = cpu->gprs[rn] & 0xFF;
if (rs) { if (rs) {