1 package net.mograsim.logic.model.am2900.machine;
3 import net.mograsim.logic.core.components.Clock;
4 import net.mograsim.logic.core.timeline.Timeline;
5 import net.mograsim.logic.core.types.BitVector;
6 import net.mograsim.logic.model.model.ViewModel;
7 import net.mograsim.logic.model.model.ViewModelModifiable;
8 import net.mograsim.logic.model.modeladapter.LogicModelParameters;
9 import net.mograsim.logic.model.modeladapter.ViewLogicModelAdapter;
10 import net.mograsim.logic.model.serializing.IndirectGUIComponentCreator;
11 import net.mograsim.machine.Machine;
12 import net.mograsim.machine.MachineDefinition;
13 import net.mograsim.machine.MainMemory;
14 import net.mograsim.machine.Register;
15 import net.mograsim.machine.mi.MicroInstructionMemory;
16 import net.mograsim.machine.mi.StandardMicroInstructionMemory;
17 import net.mograsim.machine.standard.memory.WordAddressableMemory;
19 public class Am2900Machine implements Machine
21 private Am2900MachineDefinition machineDefinition;
22 private ViewModelModifiable viewModel;
23 private Timeline timeline;
25 private MainMemory mainMemory;
26 private MicroInstructionMemory instMemory;
28 public Am2900Machine(Am2900MachineDefinition am2900MachineDefinition)
30 this.machineDefinition = am2900MachineDefinition;
31 viewModel = new ViewModelModifiable();
32 IndirectGUIComponentCreator.createComponent(viewModel,
33 "resloader:Am2900Loader:jsonres:net/mograsim/logic/model/am2900/components/GUIAm2900.json");
34 LogicModelParameters params = new LogicModelParameters();
35 params.gateProcessTime = 50;
36 params.wireTravelTime = 10;
37 timeline = ViewLogicModelAdapter.convert(viewModel, params);
39 mainMemory = new WordAddressableMemory(am2900MachineDefinition.getMainMemoryDefinition());
40 instMemory = new StandardMicroInstructionMemory(am2900MachineDefinition.getMicroInstructionMemoryDefinition());
44 public MachineDefinition getDefinition()
46 return machineDefinition;
52 // TODO Auto-generated method stub
57 public ViewModel getModel()
63 public Timeline getTimeline()
69 public Clock getClock()
75 public BitVector getRegister(Register r)
77 // TODO Auto-generated method stub
82 public void setRegister(Register r, BitVector value)
84 // TODO Auto-generated method stub
89 public MainMemory getMainMemory()
95 public MicroInstructionMemory getMicroInstructionMemory()