From 7a79ba9eb1e7cbee6386d8c8e019fdc4738228a4 Mon Sep 17 00:00:00 2001 From: Ian C Date: Mon, 5 Mar 2012 23:55:51 +0000 Subject: None compiling safe-keeping commit. Started on Z80 disassembler. --- .../Noddybox.Emulation.EightBit.Z80.Test.csproj | 4 ++++ native/Noddybox.Emulation.EightBit.Z80.Test/README | 2 +- .../TestMachine.cs | 21 ++++++++++++++++++++- 3 files changed, 25 insertions(+), 2 deletions(-) (limited to 'native/Noddybox.Emulation.EightBit.Z80.Test') diff --git a/native/Noddybox.Emulation.EightBit.Z80.Test/Noddybox.Emulation.EightBit.Z80.Test.csproj b/native/Noddybox.Emulation.EightBit.Z80.Test/Noddybox.Emulation.EightBit.Z80.Test.csproj index a162641..fe563c6 100644 --- a/native/Noddybox.Emulation.EightBit.Z80.Test/Noddybox.Emulation.EightBit.Z80.Test.csproj +++ b/native/Noddybox.Emulation.EightBit.Z80.Test/Noddybox.Emulation.EightBit.Z80.Test.csproj @@ -48,6 +48,10 @@ + + {80CF1B2D-CCC3-4830-801F-2CCA9C1EDA1C} + Noddybox.Emulation.EightBit.Z80.Disassembler + {1E0BEBC1-AB7A-4844-AC1E-B1A0239B63CF} Noddybox.Emulation.EightBit.Z80 diff --git a/native/Noddybox.Emulation.EightBit.Z80.Test/README b/native/Noddybox.Emulation.EightBit.Z80.Test/README index d260441..bd0321f 100644 --- a/native/Noddybox.Emulation.EightBit.Z80.Test/README +++ b/native/Noddybox.Emulation.EightBit.Z80.Test/README @@ -3,7 +3,7 @@ THESE TESTS ARE BASED ON THE TESTS FROM THE FUSE EMULATOR http://fuse-emulator.sourceforge.net/ -ANY MISTAKES ARE MINE +ANY MISTAKES IN USING IT ARE MINE ************************************* diff --git a/native/Noddybox.Emulation.EightBit.Z80.Test/TestMachine.cs b/native/Noddybox.Emulation.EightBit.Z80.Test/TestMachine.cs index b5d7810..a876826 100644 --- a/native/Noddybox.Emulation.EightBit.Z80.Test/TestMachine.cs +++ b/native/Noddybox.Emulation.EightBit.Z80.Test/TestMachine.cs @@ -19,6 +19,8 @@ using System; using System.Collections.Generic; using System.Linq; using System.Text; +using System.Diagnostics; +using Noddybox.Emulation.EightBit.Z80.Disassembler; namespace Noddybox.Emulation.EightBit.Z80.Test { @@ -26,6 +28,7 @@ namespace Noddybox.Emulation.EightBit.Z80.Test { private readonly byte[] mem = new byte[0x10000]; private readonly Z80Cpu z80 = new Z80Cpu(); + private readonly Z80Disassembler disassembler = new Z80Disassembler(); private readonly Clock clock = new Clock(uint.MaxValue, uint.MaxValue); private void Output(ConsoleColor pen, ConsoleColor paper, string format, params object[] p) @@ -115,16 +118,30 @@ namespace Noddybox.Emulation.EightBit.Z80.Test if (line.Count > 1) { + ushort start; ushort addr = line.Dequeue().reg; + start = addr; foreach (Register16 b in line) { mem[addr++] = b.low; } + + while(start < addr) + { + string a, b, c; + start = disassembler.Disassemble(start, out a, out b, out c); + Output(ConsoleColor.Yellow, ConsoleColor.Blue, "{0}: {1} ; {2}", a, b, c); + } } } - while(clock.Ticks < cyclesToRun) + if (Debugger.IsAttached && name == "09") + { + Debugger.Break(); + } + + while (clock.Ticks < cyclesToRun) { z80.Step(); } @@ -318,6 +335,8 @@ namespace Noddybox.Emulation.EightBit.Z80.Test public TestMachine() { z80.Initialise(this, this, clock); + z80.Reset(); + disassembler.Initialise(this); } } } -- cgit v1.3