Clean code
This commit is contained in:
parent
10279426e5
commit
84de7cd481
4 changed files with 24 additions and 3 deletions
|
@ -9,10 +9,11 @@ class Caretaker:
|
|||
self.objects[reg]=0
|
||||
self.objects["RAM"]=None
|
||||
|
||||
def __getitem__(self,key):
|
||||
def __getitem__(self,key): # TODO: Allow MBRU key and adapt its return value
|
||||
return(self.objects[key])
|
||||
|
||||
def __setitem__(self,key,value):# TODO: Do special treatment for MBR
|
||||
def __setitem__(self,key,value):# TODO: Do special treatment for MBR (allow only 2^8 value)
|
||||
# TODO: Force data to be at most 32 bits longs (Mic-1 architecture constraint)
|
||||
self.objects[key]=value
|
||||
|
||||
def items(self):
|
||||
|
|
|
@ -1,4 +1,6 @@
|
|||
|
||||
# Quick link about opcode: https://users-cs.au.dk/bouvin/dComArk/2015/noter/Note_2/#Instructions
|
||||
|
||||
# Build IJVM
|
||||
ijvm=dict({
|
||||
"BIPUSH":0x10,
|
||||
|
|
|
@ -41,7 +41,7 @@ class Microprogram:
|
|||
"""
|
||||
self.c["RAM"].write()
|
||||
|
||||
def exec(self):# link: https://users-cs.au.dk/bouvin/dComArk/2015/noter/Note_2/#Instructions
|
||||
def exec(self): # TODO: Implement opcode
|
||||
"""
|
||||
Execute next opcode
|
||||
"""
|
||||
|
|
|
@ -8,6 +8,9 @@ class Ram:
|
|||
self.c=components
|
||||
|
||||
def loadRamFile(self,filepath):
|
||||
"""
|
||||
Load a Ram file into self.data
|
||||
"""
|
||||
data=dict()
|
||||
addr=0
|
||||
f=open(filepath,"r")
|
||||
|
@ -22,12 +25,18 @@ class Ram:
|
|||
self.data=data
|
||||
|
||||
def write(self):
|
||||
"""
|
||||
Write data to memory based Mic-1 architecture
|
||||
"""
|
||||
addr=self.c["MAR"]
|
||||
if addr>self.lastAddr:
|
||||
raise ValueError("You get out of the ram by trying to set a value at address {}, max address is {}".format(addr,self.lastAddr))
|
||||
self.data[addr]=self.c["MDR"]
|
||||
|
||||
def read(self):
|
||||
"""
|
||||
Read data from memory based Mic-1 architecture
|
||||
"""
|
||||
addr=self.c["MAR"]
|
||||
value=None
|
||||
try:
|
||||
|
@ -40,6 +49,9 @@ class Ram:
|
|||
return(value)
|
||||
|
||||
def fetch(self):
|
||||
"""
|
||||
Fetch next byte from memory based Mic-1 architecture
|
||||
"""
|
||||
addr=self.c["PC"]
|
||||
value=None
|
||||
try:
|
||||
|
@ -52,11 +64,17 @@ class Ram:
|
|||
return(value)
|
||||
|
||||
def dump(self):
|
||||
"""
|
||||
Simple dump helper
|
||||
"""
|
||||
for key,value in self.data.items():
|
||||
#print("{}:{}".format(key,bin(value)[2:]))
|
||||
print("{}:{}".format(key,value))
|
||||
|
||||
def dumpRange(self,start,end):
|
||||
"""
|
||||
Another dump helper
|
||||
"""
|
||||
for i in range(start,end+1):
|
||||
try:
|
||||
print("{}:{}".format(i,self.data[i]))
|
||||
|
|
Loading…
Add table
Reference in a new issue