Added Am2900 MainMemory and MicroInstructionMemory Core/Model Components
[Mograsim.git] / net.mograsim.logic.model.am2900 / src / net / mograsim / logic / model / am2900 / components / ModelAm2900MicroInstructionMemoryAdapter.java
1 package net.mograsim.logic.model.am2900.components;
2
3 import java.util.Map;
4
5 import net.mograsim.logic.core.timeline.Timeline;
6 import net.mograsim.logic.core.wires.CoreWire;
7 import net.mograsim.logic.core.wires.CoreWire.ReadEnd;
8 import net.mograsim.logic.core.wires.CoreWire.ReadWriteEnd;
9 import net.mograsim.logic.model.model.wires.Pin;
10 import net.mograsim.logic.model.modeladapter.CoreModelParameters;
11 import net.mograsim.logic.model.modeladapter.componentadapters.ComponentAdapter;
12 import net.mograsim.machine.mi.StandardMicroInstructionMemory;
13 import net.mograsim.machine.mi.components.CoreMicroInstructionMemory;
14
15 public class ModelAm2900MicroInstructionMemoryAdapter implements ComponentAdapter<ModelAm2900MicroInstructionMemory>
16 {
17
18         @Override
19         public Class<ModelAm2900MicroInstructionMemory> getSupportedClass()
20         {
21                 return ModelAm2900MicroInstructionMemory.class;
22         }
23
24         @Override
25         public void createAndLinkComponent(Timeline timeline, CoreModelParameters params, ModelAm2900MicroInstructionMemory modelComponent,
26                         Map<Pin, CoreWire> logicWiresPerPin)
27         {
28                 ReadWriteEnd data = logicWiresPerPin.get(modelComponent.getDataPin()).createReadWriteEnd();
29                 ReadEnd address = logicWiresPerPin.get(modelComponent.getAddressPin()).createReadOnlyEnd();
30                 ReadEnd clock = logicWiresPerPin.get(modelComponent.getClockPin()).createReadOnlyEnd();
31                 CoreMicroInstructionMemory mem = new CoreMicroInstructionMemory(timeline, 2,
32                                 new StandardMicroInstructionMemory(modelComponent.getDefinition()), data, address, clock);
33                 modelComponent.setCoreModelBinding(mem);
34         }
35
36 }