X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;ds=inline;f=plugins%2Fnet.mograsim.logic.model.am2900%2Fsrc%2Fnet%2Fmograsim%2Flogic%2Fmodel%2Fam2900%2Fmachine%2FAbstractAm2900MachineDefinition.java;h=aed53563305e1d27e8dbaf520a25eed3d8f7a0a3;hb=30779f58b602f508ae3b8048bdb576191f7d9980;hp=20f7c58f621986f360833a7055d7fa9a1245c446;hpb=8a9f064aeddd93cfe69b984318157f27a8a5e2af;p=Mograsim.git diff --git a/plugins/net.mograsim.logic.model.am2900/src/net/mograsim/logic/model/am2900/machine/AbstractAm2900MachineDefinition.java b/plugins/net.mograsim.logic.model.am2900/src/net/mograsim/logic/model/am2900/machine/AbstractAm2900MachineDefinition.java index 20f7c58f..aed53563 100644 --- a/plugins/net.mograsim.logic.model.am2900/src/net/mograsim/logic/model/am2900/machine/AbstractAm2900MachineDefinition.java +++ b/plugins/net.mograsim.logic.model.am2900/src/net/mograsim/logic/model/am2900/machine/AbstractAm2900MachineDefinition.java @@ -1,16 +1,14 @@ package net.mograsim.logic.model.am2900.machine; +import java.util.ArrayList; import java.util.Collections; -import java.util.HashSet; -import java.util.Set; +import java.util.List; -import net.mograsim.logic.model.am2900.machine.registers.NumberedRegister; -import net.mograsim.logic.model.am2900.machine.registers.QRegister; import net.mograsim.logic.model.model.LogicModelModifiable; import net.mograsim.machine.ISASchema; import net.mograsim.machine.MachineDefinition; -import net.mograsim.machine.Register; -import net.mograsim.machine.RegisterGroup; +import net.mograsim.machine.registers.Register; +import net.mograsim.machine.registers.RegisterGroup; //we can't use the Singleton pattern here because a MachineDefinition needs a public parameterless constructor //(used for detecting installed machines in plugin.core) @@ -19,15 +17,17 @@ public class AbstractAm2900MachineDefinition implements MachineDefinition public static final String SIMPLE_AM2900_MACHINE_ID = "Am2900Simple"; public static final String STRICT_AM2900_MACHINE_ID = "Am2900Strict"; - public static final Set allRegisters; + public static final List unsortedRegisters; + public static final List registerGroups; static { - Set allRegistersModifiable = new HashSet<>(); - allRegistersModifiable.add(QRegister.instance); - allRegistersModifiable.addAll(NumberedRegister.instancesCorrectOrder); - // TODO MSR, muSR, MIR, IR, PC/BZ... - allRegisters = Collections.unmodifiableSet(allRegistersModifiable); + List unsortedRegistersModifiable = new ArrayList<>(); + // TODO MIR, IR, PC/BZ... + unsortedRegisters = Collections.unmodifiableList(unsortedRegistersModifiable); + List registerGroupsModifiable = new ArrayList<>(); + // TODO Am2901, Am2904, Am2910 + registerGroups = Collections.unmodifiableList(registerGroupsModifiable); } public final boolean strict; @@ -62,9 +62,15 @@ public class AbstractAm2900MachineDefinition implements MachineDefinition } @Override - public Set getRegisters() + public List getUnsortedRegisters() { - return allRegisters; + return unsortedRegisters; + } + + @Override + public List getRegisterGroups() + { + return registerGroups; } @Override @@ -98,10 +104,4 @@ public class AbstractAm2900MachineDefinition implements MachineDefinition return Am2900MicroInstructionMemoryDefinition.instance; } - @Override - public Set getRegisterGroups() - { - return null; // TODO create groups for am2904, am2901-asmUsable, am2901-internal, ... - } - }