Clean code and add extras instructions

This commit is contained in:
Loic GUEGAN 2018-08-31 20:11:10 +02:00
parent ea840b6615
commit 679b25a874
4 changed files with 46 additions and 10 deletions

View file

@ -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

View file

@ -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("---------------------------------")

View file

@ -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]))

View file

@ -6,3 +6,6 @@ IADD
BIPUSH BIPUSH
10 10
POP POP
HALT
OUT
65