aboutsummaryrefslogtreecommitdiff
path: root/debug/openocd.py
diff options
context:
space:
mode:
authorTim Newsome <tim@sifive.com>2016-10-20 14:49:44 -0700
committerTim Newsome <tim@sifive.com>2016-10-20 14:49:44 -0700
commit30d113085a08b0cde585c7e0d8b19e0cc6cbc046 (patch)
tree5cee22b799bef59fc44a8fdd26aebe994cfb34b4 /debug/openocd.py
parentdf47c4655a50983d03db186f524f50af0dc828c8 (diff)
downloadriscv-tests-30d113085a08b0cde585c7e0d8b19e0cc6cbc046.zip
riscv-tests-30d113085a08b0cde585c7e0d8b19e0cc6cbc046.tar.gz
riscv-tests-30d113085a08b0cde585c7e0d8b19e0cc6cbc046.tar.bz2
Test OpenOCD step and resume.
Diffstat (limited to 'debug/openocd.py')
-rwxr-xr-xdebug/openocd.py39
1 files changed, 34 insertions, 5 deletions
diff --git a/debug/openocd.py b/debug/openocd.py
index 4a71035..3807210 100755
--- a/debug/openocd.py
+++ b/debug/openocd.py
@@ -7,7 +7,7 @@ import sys
import targets
import testlib
-from testlib import assertRegexpMatches
+from testlib import assertIn, assertEqual
class OpenOcdTest(testlib.BaseTest):
def __init__(self, target):
@@ -20,13 +20,42 @@ class OpenOcdTest(testlib.BaseTest):
def setup(self):
# pylint: disable=attribute-defined-outside-init
self.cli = testlib.OpenocdCli()
+ self.cli.command("halt")
class RegTest(OpenOcdTest):
def test(self):
- self.cli.command("halt")
- output = self.cli.command("reg")
- assertRegexpMatches(output, r"x18 \(/%d\): 0x[0-9A-F]+" %
- self.target.xlen)
+ regs = self.cli.reg()
+ assertIn("x18", regs)
+
+class StepTest(OpenOcdTest):
+ def test(self):
+ # 0x13 is nop
+ for address in range(self.target.ram, self.target.ram + 16, 4):
+ self.cli.command("mww 0x%x 0x13" % address)
+
+ self.cli.command("step 0x%x" % self.target.ram)
+ for i in range(4):
+ pc = self.cli.reg("pc")
+ assertEqual(pc, self.target.ram + 4 * (i+1))
+ self.cli.command("step")
+
+class ResumeTest(OpenOcdTest):
+ def test(self):
+ # 0x13 is nop
+ for address in range(self.target.ram, self.target.ram + 32, 4):
+ self.cli.command("mww 0x%x 0x13" % address)
+
+ self.cli.command("bp 0x%x 4" % (self.target.ram + 12))
+ self.cli.command("bp 0x%x 4" % (self.target.ram + 24))
+
+ self.cli.command("resume 0x%x" % self.target.ram)
+ assertEqual(self.cli.reg("pc"), self.target.ram + 12)
+
+ self.cli.command("resume")
+ assertEqual(self.cli.reg("pc"), self.target.ram + 24)
+
+ self.cli.command("resume 0x%x" % self.target.ram)
+ assertEqual(self.cli.reg("pc"), self.target.ram + 12)
def main():
parser = argparse.ArgumentParser(