Clean code and add extras instructions
This commit is contained in:
parent
ea840b6615
commit
679b25a874
4 changed files with 46 additions and 10 deletions
|
@ -22,3 +22,7 @@ ijvm=dict({
|
||||||
"SWAP":0x5F,
|
"SWAP":0x5F,
|
||||||
"WIDE":0xC4
|
"WIDE":0xC4
|
||||||
})
|
})
|
||||||
|
|
||||||
|
# Add extras instructions
|
||||||
|
ijvm["OUT"]=0x23 # Print next byte as char
|
||||||
|
ijvm["HALT"]=0x2F # Stop simulator
|
||||||
|
|
|
@ -4,31 +4,47 @@ from components.ijvm import ijvm
|
||||||
class Microprogram:
|
class Microprogram:
|
||||||
|
|
||||||
def __init__(self,components):
|
def __init__(self,components):
|
||||||
self.c=components
|
self.c=components # Link components to microprogram
|
||||||
if self.c["RAM"]==None:
|
if self.c["RAM"]==None: # Check if RAM is initialize
|
||||||
raise RuntimeError("Microprogram initialization fail, RAM is not initialized")
|
raise RuntimeError("Microprogram initialization fail, RAM is not initialized")
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
|
"""
|
||||||
|
Start microprogram
|
||||||
|
"""
|
||||||
self.c["LV"]=(1024)# Place stack to 1024
|
self.c["LV"]=(1024)# Place stack to 1024
|
||||||
self.c["SP"]=(1024-1) # Init SP to LV-1 (because otherwise first element of the stack will be enty because of BIPUSH impl
|
self.c["SP"]=(1024-1) # Init SP to LV-1 (because otherwise first element of the stack will be enty because of BIPUSH impl
|
||||||
|
|
||||||
for i in range(1,30): # Launche first 30 insctructions
|
for i in range(1,30): # Launche first 30 insctructions
|
||||||
self.fetch() # Fetch
|
self.fetch() # Fetch
|
||||||
self.c["PC"]+=1 # INC PC
|
self.c["PC"]+=1 # INC PC after fetch
|
||||||
self.exec() # Execute opcode
|
if self.exec()==1: # Execute opcode and halt if return code is 1
|
||||||
|
break;
|
||||||
|
|
||||||
def fetch(self):
|
def fetch(self):
|
||||||
|
"""
|
||||||
|
Fetch next byte from memory into MBR
|
||||||
|
"""
|
||||||
opcode=self.c["RAM"].fetch()
|
opcode=self.c["RAM"].fetch()
|
||||||
self.c["MBR"]=opcode # Opcode to MBR
|
self.c["MBR"]=opcode # Opcode to MBR
|
||||||
|
|
||||||
def rd(self):
|
def rd(self):
|
||||||
|
"""
|
||||||
|
Read data into memory
|
||||||
|
"""
|
||||||
data=self.c["RAM"].read()
|
data=self.c["RAM"].read()
|
||||||
self.c["MDR"]=data
|
self.c["MDR"]=data
|
||||||
|
|
||||||
def wr(self):
|
def wr(self):
|
||||||
|
"""
|
||||||
|
Write data into memory
|
||||||
|
"""
|
||||||
self.c["RAM"].write()
|
self.c["RAM"].write()
|
||||||
|
|
||||||
def exec(self):# link: https://users-cs.au.dk/bouvin/dComArk/2015/noter/Note_2/#Instructions
|
def exec(self):# link: https://users-cs.au.dk/bouvin/dComArk/2015/noter/Note_2/#Instructions
|
||||||
|
"""
|
||||||
|
Execute next opcode
|
||||||
|
"""
|
||||||
opcode=self.c["MBR"] # Get loaded OpCode
|
opcode=self.c["MBR"] # Get loaded OpCode
|
||||||
if opcode==ijvm["NOP"]: # NOP
|
if opcode==ijvm["NOP"]: # NOP
|
||||||
pass
|
pass
|
||||||
|
@ -91,13 +107,28 @@ class Microprogram:
|
||||||
self.c["MAR"]=self.c["SP"]-1
|
self.c["MAR"]=self.c["SP"]-1
|
||||||
self.wr()
|
self.wr()
|
||||||
self.c["TOS"]=self.c["H"]
|
self.c["TOS"]=self.c["H"]
|
||||||
|
elif opcode==ijvm["OUT"]:
|
||||||
|
self.fetch();self.c["PC"]+=1 # Fetch byte to push in MBR
|
||||||
|
print(str(chr(self.c["MBR"])),end="")
|
||||||
|
elif opcode==ijvm["HALT"]:
|
||||||
|
return(1)
|
||||||
else:
|
else:
|
||||||
if opcode in ijvm:
|
if opcode in ijvm:
|
||||||
print("Instruction {} not yet implemented.".format(ijvm[opcode]))
|
print("Instruction {} not yet implemented.".format(ijvm[opcode]))
|
||||||
else:
|
else:
|
||||||
raise RuntimeError("Instruction {} not found".format(opcode))
|
raise RuntimeError("Instruction {} not found".format(opcode))
|
||||||
|
return(0)
|
||||||
|
|
||||||
def dump(self):
|
def dump(self):
|
||||||
print("---------- Stack ----------")
|
"""
|
||||||
self.c["RAM"].dump(self.c["LV"],self.c["SP"])
|
Print RAM, stack and registers
|
||||||
print("---------------------------")
|
"""
|
||||||
|
print("-------------- RAM --------------")
|
||||||
|
self.c["RAM"].dump()
|
||||||
|
print("------------- Stack -------------")
|
||||||
|
self.c["RAM"].dumpRange(self.c["LV"],self.c["SP"])
|
||||||
|
print("----------- Registers -----------")
|
||||||
|
for key,value in self.c.items():
|
||||||
|
if key!="RAM":
|
||||||
|
print("{}={}".format(key,value))
|
||||||
|
print("---------------------------------")
|
||||||
|
|
|
@ -52,13 +52,11 @@ class Ram:
|
||||||
return(value)
|
return(value)
|
||||||
|
|
||||||
def dump(self):
|
def dump(self):
|
||||||
print("------- RAM --------")
|
|
||||||
for key,value in self.data.items():
|
for key,value in self.data.items():
|
||||||
#print("{}:{}".format(key,bin(value)[2:]))
|
#print("{}:{}".format(key,bin(value)[2:]))
|
||||||
print("{}:{}".format(key,value))
|
print("{}:{}".format(key,value))
|
||||||
print("--------------------")
|
|
||||||
|
|
||||||
def dump(self,start,end):
|
def dumpRange(self,start,end):
|
||||||
for i in range(start,end+1):
|
for i in range(start,end+1):
|
||||||
try:
|
try:
|
||||||
print("{}:{}".format(i,self.data[i]))
|
print("{}:{}".format(i,self.data[i]))
|
||||||
|
|
3
ram.txt
3
ram.txt
|
@ -6,3 +6,6 @@ IADD
|
||||||
BIPUSH
|
BIPUSH
|
||||||
10
|
10
|
||||||
POP
|
POP
|
||||||
|
HALT
|
||||||
|
OUT
|
||||||
|
65
|
||||||
|
|
Loading…
Add table
Reference in a new issue