0

我正在 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,正如我已经解释的那样。

这里有什么我遗漏的东西吗——我的代码中有一些我看不到的错误?

4

1 回答 1

1
byte jumpOffset = Processor.ReadNextByte();

它应该sbyte给出 -5 而不是 0xFB。

于 2019-05-15T23:04:14.637 回答