From c9d0f651b6ec387056d67f098fbb322924a99c04 Mon Sep 17 00:00:00 2001 From: Jeffrey Pfau Date: Tue, 26 Jan 2016 02:25:26 -0800 Subject: [PATCH] LR35902: Fix IRQs and RST --- src/gb/gb.c | 1 - src/lr35902/isa-lr35902.c | 32 ++++++++++++++++++++++++-------- src/lr35902/lr35902.c | 1 + 3 files changed, 25 insertions(+), 9 deletions(-) diff --git a/src/gb/gb.c b/src/gb/gb.c index 0ef8c855f..377df10cb 100644 --- a/src/gb/gb.c +++ b/src/gb/gb.c @@ -163,7 +163,6 @@ void GBUpdateIRQs(struct GB* gb) { return; } - gb->cpu->irqh.setInterrupts(gb->cpu, false); if (irqs & (1 << GB_IRQ_VBLANK)) { LR35902RaiseIRQ(gb->cpu, GB_VECTOR_VBLANK); gb->memory.io[REG_IF] &= ~(1 << GB_IRQ_VBLANK); diff --git a/src/lr35902/isa-lr35902.c b/src/lr35902/isa-lr35902.c index eaad161d8..79548f284 100644 --- a/src/lr35902/isa-lr35902.c +++ b/src/lr35902/isa-lr35902.c @@ -732,14 +732,30 @@ DEFINE_INSTRUCTION_LR35902(DI, cpu->irqh.setInterrupts(cpu, false)); DEFINE_INSTRUCTION_LR35902(EI, cpu->irqh.setInterrupts(cpu, true)); DEFINE_INSTRUCTION_LR35902(HALT, cpu->irqh.halt(cpu)); -DEFINE_INSTRUCTION_LR35902(RST00, LR35902RaiseIRQ(cpu, 0x00)); -DEFINE_INSTRUCTION_LR35902(RST08, LR35902RaiseIRQ(cpu, 0x08)); -DEFINE_INSTRUCTION_LR35902(RST10, LR35902RaiseIRQ(cpu, 0x10)); -DEFINE_INSTRUCTION_LR35902(RST18, LR35902RaiseIRQ(cpu, 0x18)); -DEFINE_INSTRUCTION_LR35902(RST20, LR35902RaiseIRQ(cpu, 0x20)); -DEFINE_INSTRUCTION_LR35902(RST28, LR35902RaiseIRQ(cpu, 0x28)); -DEFINE_INSTRUCTION_LR35902(RST30, LR35902RaiseIRQ(cpu, 0x30)); -DEFINE_INSTRUCTION_LR35902(RST38, LR35902RaiseIRQ(cpu, 0x38)); +#define DEFINE_RST_INSTRUCTION_LR35902(VEC) \ + DEFINE_INSTRUCTION_LR35902(RST ## VEC ## UpdateSPL, \ + cpu->pc = 0x ## VEC; \ + cpu->executionState = LR35902_CORE_STALL;) \ + DEFINE_INSTRUCTION_LR35902(RST ## VEC ## UpdateSPH, \ + cpu->index = cpu->sp + 1; \ + cpu->bus = (cpu->pc + 2) >> 8; \ + cpu->executionState = LR35902_CORE_MEMORY_STORE; \ + cpu->instruction = _LR35902InstructionRST ## VEC ## UpdateSPL;) \ + DEFINE_INSTRUCTION_LR35902(RST ## VEC, \ + cpu->sp -= 2; /* TODO: Atomic incrementing? */ \ + cpu->index = cpu->sp; \ + cpu->bus = cpu->pc; \ + cpu->executionState = LR35902_CORE_MEMORY_STORE; \ + cpu->instruction = _LR35902InstructionRST ## VEC ## UpdateSPH;) + +DEFINE_RST_INSTRUCTION_LR35902(00); +DEFINE_RST_INSTRUCTION_LR35902(08); +DEFINE_RST_INSTRUCTION_LR35902(10); +DEFINE_RST_INSTRUCTION_LR35902(18); +DEFINE_RST_INSTRUCTION_LR35902(20); +DEFINE_RST_INSTRUCTION_LR35902(28); +DEFINE_RST_INSTRUCTION_LR35902(30); +DEFINE_RST_INSTRUCTION_LR35902(38); DEFINE_INSTRUCTION_LR35902(STUB, cpu->irqh.hitStub(cpu)); diff --git a/src/lr35902/lr35902.c b/src/lr35902/lr35902.c index f957218c7..5ddf028c2 100644 --- a/src/lr35902/lr35902.c +++ b/src/lr35902/lr35902.c @@ -90,6 +90,7 @@ static void _LR35902InstructionIRQ(struct LR35902Core* cpu) { cpu->bus = cpu->pc; cpu->executionState = LR35902_CORE_MEMORY_STORE; cpu->instruction = _LR35902InstructionIRQFinish; + cpu->irqh.setInterrupts(cpu, false); } void LR35902Tick(struct LR35902Core* cpu) {