void EmulateCyclesWith1541() { thread_running = true; while (!quit_thyself) { // The order of calls is important here if (TheVIC.EmulateCycle()) { TheSID.EmulateLine(); } TheCIA1.CheckIRQs(); TheCIA2.CheckIRQs(); TheCIA1.EmulateCycle(); TheCIA2.EmulateCycle(); TheCPU.EmulateCycle(); TheCPU1541.CountVIATimers(1); if (!TheCPU1541.Idle) { TheCPU1541.EmulateCycle(); } CycleCounter++; } }
void write_byte_io(UInt16 adr, byte abyte) { if (adr >= 0xe000) { ram[adr] = abyte; if (adr == 0xff00) { TheREU.FF00Trigger(); } } else if (io_in) { switch ((adr >> 8) & 0x0f) { case 0x0: // VIC case 0x1: case 0x2: case 0x3: TheVIC.WriteRegister((UInt16)(adr & 0x3f), abyte); return; case 0x4: // SID case 0x5: case 0x6: case 0x7: TheSID.WriteRegister((UInt16)(adr & 0x1f), abyte); return; case 0x8: // Color RAM case 0x9: case 0xa: case 0xb: color_ram[adr & 0x03ff] = (byte)(abyte & 0x0f); return; case 0xc: // CIA 1 TheCIA1.WriteRegister((UInt16)(adr & 0x0f), abyte); return; case 0xd: // CIA 2 TheCIA2.WriteRegister((UInt16)(adr & 0x0f), abyte); return; case 0xe: // REU/Open I/O case 0xf: if ((adr & 0xfff0) == 0xdf00) { TheREU.WriteRegister((UInt16)(adr & 0x0f), abyte); } return; } } else { ram[adr] = abyte; } }
public void Reset() { TheCPU.AsyncReset(); TheCPU1541.AsyncReset(); TheSID.Reset(); TheCIA1.Reset(); TheCIA2.Reset(); TheIEC.Reset(); }
void EmulateCyclesWithout1541() { #if TIMERS uint lc = CycleCounter; HiResTimer timer = new HiResTimer(); timer.Start(); const uint cycleCount = 4000000; #endif thread_running = true; while (!quit_thyself) { // The order of calls is important here if (TheVIC.EmulateCycle()) { TheSID.EmulateLine(); } TheCIA1.CheckIRQs(); TheCIA2.CheckIRQs(); TheCIA1.EmulateCycle(); TheCIA2.EmulateCycle(); TheCPU.EmulateCycle(); CycleCounter++; #if TIMERS if (CycleCounter - lc == cycleCount) { timer.Stop(); lc = CycleCounter; double elapsedSec = timer.ElapsedMilliseconds / 1000.0f; Console.WriteLine("------------------------------------"); Console.WriteLine("{0} ms elapsed for {1:N} cycles", timer.ElapsedMilliseconds, cycleCount); Console.WriteLine("CIA1: TA Interrupts: {0} -> int/s: {1}", TheCIA1.ta_interrupts, TheCIA1.ta_interrupts / elapsedSec); Console.WriteLine("CPU Instructions: {0} -> ins/s: {1}", TheCPU.ins_counter, TheCPU.ins_counter / elapsedSec); // reset counters TheCIA1.ta_interrupts = 0; TheCIA1.tb_interrupts = 0; TheCIA2.ta_interrupts = 0; TheCIA2.tb_interrupts = 0; TheCPU.ins_counter = 0; timer.Reset(); timer.Start(); //TheDisplay.Surface.Update(); } #endif } }
public void Run() { TheCPU.Reset(); TheSID.Reset(); TheCIA1.Reset(); TheCIA2.Reset(); TheCPU1541.Reset(); // Patch kernal IEC routines orig_kernal_1d84 = Kernal[0x1d84]; orig_kernal_1d85 = Kernal[0x1d85]; patch_kernel(GlobalPrefs.ThePrefs.FastReset, GlobalPrefs.ThePrefs.Emul1541Proc); Events.Quit += new QuitEventHandler(Events_Quit); // Start the machine main loop MainLoop(); }
public void NewPrefs(Prefs prefs) { open_close_joysticks(GlobalPrefs.ThePrefs.Joystick1On, GlobalPrefs.ThePrefs.Joystick2On, prefs.Joystick1On, prefs.Joystick2On); patch_kernel(prefs.FastReset, prefs.Emul1541Proc); TheDisplay.NewPrefs(prefs); TheIEC.NewPrefs(prefs); TheJob1541.NewPrefs(prefs); TheREU.NewPrefs(prefs); TheSID.NewPrefs(prefs); // Reset 1541 processor if turned on if (!GlobalPrefs.ThePrefs.Emul1541Proc && prefs.Emul1541Proc) { TheCPU1541.AsyncReset(); } }
byte read_byte_io(UInt16 adr) { switch (adr >> 12) { case 0xa: case 0xb: if (basic_in) { return(basic_rom[adr & 0x1fff]); } else { return(ram[adr]); } case 0xc: return(ram[adr]); case 0xd: if (io_in) { switch ((adr >> 8) & 0x0f) { case 0x0: // VIC case 0x1: case 0x2: case 0x3: return(TheVIC.ReadRegister((UInt16)(adr & 0x3f))); case 0x4: // SID case 0x5: case 0x6: case 0x7: return(TheSID.ReadRegister((UInt16)(adr & 0x1f))); case 0x8: // Color RAM case 0x9: case 0xa: case 0xb: return((byte)(color_ram[adr & 0x03ff] & 0x0f | TheVIC.LastVICByte & 0xf0)); case 0xc: // CIA 1 return(TheCIA1.ReadRegister((UInt16)(adr & 0x0f))); case 0xd: // CIA 2 return(TheCIA2.ReadRegister((UInt16)(adr & 0x0f))); case 0xe: // REU/Open I/O case 0xf: if ((adr & 0xfff0) == 0xdf00) { return(TheREU.ReadRegister((UInt16)(adr & 0x0f))); } else if (adr < 0xdfa0) { return(TheVIC.LastVICByte); } else { return(read_emulator_id((UInt16)(adr & 0x7f))); } } } else if (char_in) { return(char_rom[adr & 0x0fff]); } return(ram[adr]); case 0xe: case 0xf: if (kernal_in) { return(kernel_rom[adr & 0x1fff]); } else { return(ram[adr]); } default: // Can't happen return(0); } }
public void VBlank(bool draw_frame) { TheDisplay.PollKeyboard(TheCIA1.KeyMatrix, TheCIA1.RevMatrix, ref joykey); if (TheDisplay.QuitRequested) { quit_thyself = true; } // Poll the joysticks. TheCIA1.Joystick1 = poll_joystick(0); TheCIA1.Joystick2 = poll_joystick(1); if (GlobalPrefs.ThePrefs.JoystickSwap) { byte tmp = TheCIA1.Joystick1; TheCIA1.Joystick1 = TheCIA1.Joystick2; TheCIA1.Joystick2 = tmp; } // Joystick keyboard emulation. if (TheDisplay.SwapJoysticks) { TheCIA1.Joystick1 &= joykey; } else { TheCIA1.Joystick2 &= joykey; } // Count TOD clocks. TheCIA1.CountTOD(); TheCIA2.CountTOD(); // Output a frag. TheSID.VBlank(); if (have_a_break) { return; } // Update the window if needed. frame++; if (draw_frame) { // Perform the actual screen update exactly at the // beginning of an interval for the smoothest video. TheDisplay.Update(); frameTimer.Stop(); // Compute the speed index and show it in the speedometer. double elapsed_time = (double)frameTimer.ElapsedMicroseconds; double speed_index = 20000 / elapsed_time * 100; // Limit speed to 100% if desired if ((speed_index > 100) && GlobalPrefs.ThePrefs.LimitSpeed) { int sleeptime = (int)((20000 - elapsed_time) / 1000.0); Thread.Sleep(sleeptime); speed_index = 100; } frameTimer.Reset(); frameTimer.Start(); TheDisplay.Speedometer((int)speed_index); } }
public void Resume() { TheSID.ResumeSound(); have_a_break = false; }
public void Pause() { TheSID.PauseSound(); have_a_break = true; state_change = true; }