summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Pavone <pavone@retrodev.com>2018-10-06 17:33:15 -0700
committerMichael Pavone <pavone@retrodev.com>2018-10-06 17:33:15 -0700
commit441349cc260c0d95807b4d7469c2be5b3b62fbbb (patch)
treef4ea6c488b85eb01f205e8d0e9a815fb1a9fd7f1
parent1dab348088655d41be46a1fa33f0e28c0695f86e (diff)
Implement program ROM reads
-rwxr-xr-xcpu_dsl.py11
-rw-r--r--svp.cpu6
-rw-r--r--svp_util.c5
3 files changed, 17 insertions, 5 deletions
diff --git a/cpu_dsl.py b/cpu_dsl.py
index 33ae62c..0788050 100755
--- a/cpu_dsl.py
+++ b/cpu_dsl.py
@@ -676,11 +676,15 @@ class If(ChildBlock):
class Registers:
def __init__(self):
self.regs = {}
+ self.pointers = {}
self.regArrays = {}
self.regToArray = {}
def addReg(self, name, size):
self.regs[name] = size
+
+ def addPointer(self, name, size):
+ self.pointers[name] = size
def addRegArray(self, name, size, regs):
self.regArrays[name] = (size, regs)
@@ -721,11 +725,16 @@ class Registers:
elif len(parts) > 2:
self.addRegArray(parts[0], int(parts[1]), parts[2:])
else:
- self.addReg(parts[0], int(parts[1]))
+ if parts[1].startswith('ptr'):
+ self.addPointer(parts[0], int(parts[1][3:]))
+ else:
+ self.addReg(parts[0], int(parts[1]))
return self
def writeHeader(self, otype, hFile):
fieldList = []
+ for pointer in self.pointers:
+ hFile.write('\n\tuint{sz}_t *{nm};'.format(nm=pointer, sz=self.pointers[pointer]))
for reg in self.regs:
if not self.isRegArrayMember(reg):
fieldList.append((self.regs[reg], 1, reg))
diff --git a/svp.cpu b/svp.cpu
index cb12210..43549d7 100644
--- a/svp.cpu
+++ b/svp.cpu
@@ -6,8 +6,10 @@ info
include svp_util.c
regs
- internal 16 scratch1 x y scratch2 st pad pc
+ internal 16 scratch2 x y pad0 st pad1 pc
a 32
+ scratch1 32
+ rom ptr16
stack 16 stack0 stack1 stack2 stack3 stack4 stack5
stackidx 8
p 32
@@ -622,7 +624,7 @@ svp_prog_ram_read
if >=U
add src src scratch1
- ocall read_16
+ ocall prog_read_16
else
mov iram.src scratch1
diff --git a/svp_util.c b/svp_util.c
index 362646f..fcb46c4 100644
--- a/svp_util.c
+++ b/svp_util.c
@@ -1,5 +1,6 @@
-void svp_read_16(svp_context *context)
+void svp_prog_read_16(svp_context *context)
{
- context->internal[0] = 0;
+ uint16_t address = context->scratch1 >> 1;
+ context->scratch1 = context->rom[address];
}