Updated Am2900Machine and -Definition; Added MachineContext
[Mograsim.git] / net.mograsim.logic.model.am2900 / src / net / mograsim / logic / model / am2900 / machine / Am2900Machine.java
1 package net.mograsim.logic.model.am2900.machine;
2
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;
18
19 public class Am2900Machine implements Machine
20 {
21         private Am2900MachineDefinition machineDefinition;
22         private ViewModelModifiable viewModel;
23         private Timeline timeline;
24         private Clock clock;
25         private MainMemory mainMemory;
26         private MicroInstructionMemory instMemory;
27
28         public Am2900Machine(Am2900MachineDefinition am2900MachineDefinition)
29         {
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);
38
39                 mainMemory = new WordAddressableMemory(am2900MachineDefinition.getMainMemoryDefinition());
40                 instMemory = new StandardMicroInstructionMemory(am2900MachineDefinition.getMicroInstructionMemoryDefinition());
41         }
42
43         @Override
44         public MachineDefinition getDefinition()
45         {
46                 return machineDefinition;
47         }
48
49         @Override
50         public void reset()
51         {
52                 // TODO Auto-generated method stub
53
54         }
55
56         @Override
57         public ViewModel getModel()
58         {
59                 return viewModel;
60         }
61
62         @Override
63         public Timeline getTimeline()
64         {
65                 return timeline;
66         }
67
68         @Override
69         public Clock getClock()
70         {
71                 return clock;
72         }
73
74         @Override
75         public BitVector getRegister(Register r)
76         {
77                 // TODO Auto-generated method stub
78                 return null;
79         }
80
81         @Override
82         public void setRegister(Register r, BitVector value)
83         {
84                 // TODO Auto-generated method stub
85
86         }
87
88         @Override
89         public MainMemory getMainMemory()
90         {
91                 return mainMemory;
92         }
93
94         @Override
95         public MicroInstructionMemory getMicroInstructionMemory()
96         {
97                 return instMemory;
98         }
99
100 }