我正在 C# 上开发 GameBoy 模拟器,并使用 Blargg 的测试 ROM(来自此处的 cpu_instrs )对其进行测试。我正在单独进行测试,现在我正在使用07-jr
, jp
, call
, ret
, and rst
。我正在将我的结果与 bgb 的调试器进行比较。现在,当我到达0209
运行 opcode 的位置时0x20 (JR NZ)
,bgb 会跳转到0x206
,但我的模拟器会跳转到0x306
.
这是我当前对该指令的代码:
if (Processor.GetZeroFlag() == 0)
{
byte jumpOffset = Processor.ReadNextByte();
ushort targetAddr = (ushort)(Processor.GetPC() + 2 + jumpOffset);
Processor.SetPC(targetAddr);
Processor.FinishedIntruction(0, 8, 2);
break;
}
else
{
Console.WriteLine("Not taking the branch");
Processor.FinishedIntruction(2, 8, 2);
break;
}
ReadNextByte()
从内存返回下一个字节(从 PC + 1 读取),在这种情况下它是 FB(根据 bgb,它是正确的)。据我了解,我必须将 FB 添加到当前 PC,以及指令的长度 (2),但这样做我最终会得到 306,正如我已经解释的那样。
这里有什么我遗漏的东西吗——我的代码中有一些我看不到的错误?