aboutsummaryrefslogtreecommitdiff
path: root/MicSim/components/caretaker.py
blob: cd6d913de06defe1f3fd13522ff13b7b1c02bdd0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#!/usr/bin/python

from components.ram import Ram

class Caretaker:
	
	def __init__(self,ramSize):
		self.objects=dict() # Create empty objects pool
		# Add registers to pool
		for reg in ["MAR","MDR", "PC", "MBR", "SP","LV","CPP","TOS","OPC","H"]:
			self.objects[reg]=0
		self.objects["RAM"]=Ram(self,ramSize)
	
	def __getitem__(self,key):
		if key=="MBRU": # If we ask for unsigned
			return(abs(self.objects["MBR"]))
		elif key== "MBR":
			if self.objects[key] < 0:
				return(self.objects[key])
			elif self.objects[key]>>7==1: # If it a negative number (2 complement)
				#return(-(self.objects[key]&0x7F)) 
				return(-((self.objects[key]-1)^0xFF)) # Reverse 2 complements to get an unsign nummber (for python is better)

			else:
				return(self.objects[key])
		return(self.objects[key])

	def __setitem__(self,key,value):
		if key!="RAM":
			if ((-(2**7-1))>value or value>(2**8)-1) and (key=="MBR" or key=="MBRU"):
				raise RuntimeError("Value {} cannot fit in {} register (-(2^7-1) minimum value and (2^7-1) maximum value)".format(value,key))
			elif (-(2**31-1)>value or value>(2**32)-1) and (key!="MBR" and key!="MBRU"):
				raise RuntimeError("Value {} cannot fit in {} register (2^32-1 maximum value)".format(value,key))
		self.objects[key]=value
		
	def items(self):
		return(self.objects.items())