1
0
mirror of https://github.com/sethm/symon.git synced 2025-01-19 15:30:14 +00:00

Implement SimpleMachine

This commit is contained in:
Seth Morabito 2014-08-10 13:53:04 -07:00
parent 4bfc196b49
commit ccae8905b3
6 changed files with 142 additions and 22 deletions

View File

@ -26,6 +26,7 @@
package com.loomcom.symon; package com.loomcom.symon;
import com.loomcom.symon.machines.MulticompMachine; import com.loomcom.symon.machines.MulticompMachine;
import com.loomcom.symon.machines.SimpleMachine;
import com.loomcom.symon.machines.SymonMachine; import com.loomcom.symon.machines.SymonMachine;
import java.util.Locale; import java.util.Locale;
import javax.swing.JOptionPane; import javax.swing.JOptionPane;
@ -51,13 +52,15 @@ public class Main {
machineClass = SymonMachine.class; machineClass = SymonMachine.class;
} else if(machine.equals("multicomp")) { } else if(machine.equals("multicomp")) {
machineClass = MulticompMachine.class; machineClass = MulticompMachine.class;
} else if (machine.equals("simple")) {
machineClass = SimpleMachine.class;
} }
} }
} }
while(true) { while(true) {
if(machineClass == null) { if(machineClass == null) {
Object[] possibilities = {"Symon", "Multicomp"}; Object[] possibilities = {"Symon", "Multicomp", "Simple"};
String s = (String)JOptionPane.showInputDialog( String s = (String)JOptionPane.showInputDialog(
null, null,
"Please choose the machine type to be emulated:", "Please choose the machine type to be emulated:",
@ -68,12 +71,16 @@ public class Main {
"Symon"); "Symon");
if(s != null && s.equals("Multicomp")) { if (s != null) {
if (s.equals("Multicomp")) {
machineClass = MulticompMachine.class; machineClass = MulticompMachine.class;
} else if (s.equals("Simple")) {
machineClass = SimpleMachine.class;
} else { } else {
machineClass = SymonMachine.class; machineClass = SymonMachine.class;
} }
} }
}
final Simulator simulator = new Simulator(machineClass); final Simulator simulator = new Simulator(machineClass);

View File

@ -137,7 +137,7 @@ public class Simulator {
*/ */
public void createAndShowUi() throws IOException { public void createAndShowUi() throws IOException {
mainWindow = new JFrame(); mainWindow = new JFrame();
mainWindow.setTitle("Symon 6502 Simulator"); mainWindow.setTitle("6502 Simulator - " + machine.getName());
mainWindow.setResizable(false); mainWindow.setResizable(false);
mainWindow.getContentPane().setLayout(new BorderLayout()); mainWindow.getContentPane().setLayout(new BorderLayout());
@ -337,7 +337,7 @@ public class Simulator {
// Read from the ACIA and immediately update the console if there's // Read from the ACIA and immediately update the console if there's
// output ready. // output ready.
if (machine.getAcia().hasTxChar()) { if (machine.getAcia() != null && machine.getAcia().hasTxChar()) {
// This is thread-safe // This is thread-safe
console.print(Character.toString((char) machine.getAcia().txRead())); console.print(Character.toString((char) machine.getAcia().txRead()));
console.repaint(); console.repaint();
@ -346,7 +346,7 @@ public class Simulator {
// If a key has been pressed, fill the ACIA. // If a key has been pressed, fill the ACIA.
// TODO: Interrupt handling. // TODO: Interrupt handling.
try { try {
if (console.hasInput()) { if (machine.getAcia() != null && console.hasInput()) {
machine.getAcia().rxWrite((int) console.readInputChar()); machine.getAcia().rxWrite((int) console.readInputChar());
} }
} catch (FifoUnderrunException ex) { } catch (FifoUnderrunException ex) {
@ -703,16 +703,20 @@ public class Simulator {
*/ */
public void simulatorDidStart() { public void simulatorDidStart() {
loadProgramItem.setEnabled(false); loadProgramItem.setEnabled(false);
if (loadRomItem != null) {
loadRomItem.setEnabled(false); loadRomItem.setEnabled(false);
} }
}
/** /**
* Enable menu items that should be available while the simulator is stopped. * Enable menu items that should be available while the simulator is stopped.
*/ */
public void simulatorDidStop() { public void simulatorDidStop() {
loadProgramItem.setEnabled(true); loadProgramItem.setEnabled(true);
if (loadRomItem != null) {
loadRomItem.setEnabled(true); loadRomItem.setEnabled(true);
} }
}
private void initMenu() { private void initMenu() {
/* /*
@ -722,15 +726,22 @@ public class Simulator {
JMenu fileMenu = new JMenu("File"); JMenu fileMenu = new JMenu("File");
loadProgramItem = new JMenuItem(new LoadProgramAction()); loadProgramItem = new JMenuItem(new LoadProgramAction());
loadRomItem = new JMenuItem(new LoadRomAction());
JMenuItem prefsItem = new JMenuItem(new ShowPrefsAction());
JMenuItem selectMachineItem = new JMenuItem(new SelectMachineAction());
JMenuItem quitItem = new JMenuItem(new QuitAction());
fileMenu.add(loadProgramItem); fileMenu.add(loadProgramItem);
// Simple Machine does not implement a ROM, so it makes no sense to
// offer a ROM load option.
if (machine.getRom() != null) {
loadRomItem = new JMenuItem(new LoadRomAction());
fileMenu.add(loadRomItem); fileMenu.add(loadRomItem);
}
JMenuItem prefsItem = new JMenuItem(new ShowPrefsAction());
fileMenu.add(prefsItem); fileMenu.add(prefsItem);
JMenuItem selectMachineItem = new JMenuItem(new SelectMachineAction());
fileMenu.add(selectMachineItem); fileMenu.add(selectMachineItem);
JMenuItem quitItem = new JMenuItem(new QuitAction());
fileMenu.add(quitItem); fileMenu.add(quitItem);
add(fileMenu); add(fileMenu);

View File

@ -57,4 +57,5 @@ public interface Machine {
public int getMemorySize(); public int getMemorySize();
String getName();
} }

View File

@ -148,4 +148,9 @@ public class MulticompMachine implements Machine {
return MEMORY_SIZE; return MEMORY_SIZE;
} }
@Override
public String getName() {
return "Multicomp";
}
} }

View File

@ -0,0 +1,93 @@
package com.loomcom.symon.machines;
import com.loomcom.symon.Bus;
import com.loomcom.symon.Cpu;
import com.loomcom.symon.devices.Acia;
import com.loomcom.symon.devices.Crtc;
import com.loomcom.symon.devices.Memory;
import com.loomcom.symon.devices.Via;
import com.loomcom.symon.exceptions.MemoryRangeException;
/**
* A SimpleMachine is the simplest 6502 implementation possible - it
* consists solely of RAM and a CPU. This machine is primarily useful
* for running 6502 functional tests or debugging by hand.
*/
public class SimpleMachine implements Machine {
private static final int BUS_BOTTOM = 0x0000;
private static final int BUS_TOP = 0xffff;
private final Bus bus;
private final Memory ram;
private final Cpu cpu;
public SimpleMachine() throws MemoryRangeException {
this.bus = new Bus(BUS_BOTTOM, BUS_TOP);
this.ram = new Memory(BUS_BOTTOM, BUS_TOP, false);
this.cpu = new Cpu();
bus.addCpu(cpu);
bus.addDevice(ram);
}
@Override
public Bus getBus() {
return bus;
}
@Override
public Cpu getCpu() {
return cpu;
}
@Override
public Memory getRam() {
return ram;
}
@Override
public Acia getAcia() {
return null;
}
@Override
public Via getVia() {
return null;
}
@Override
public Crtc getCrtc() {
return null;
}
@Override
public Memory getRom() {
return null;
}
@Override
public void setRom(Memory rom) throws MemoryRangeException {
// No-op
}
@Override
public int getRomBase() {
return 0;
}
@Override
public int getRomSize() {
return 0;
}
@Override
public int getMemorySize() {
return BUS_TOP + 1;
}
@Override
public String getName() {
return "Simple";
}
}

View File

@ -161,7 +161,10 @@ public class SymonMachine implements Machine {
return MEMORY_SIZE; return MEMORY_SIZE;
} }
@Override
public String getName() {
return "Symon";
}
} }