aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTim Newsome <tim@sifive.com>2017-08-07 15:13:09 -0700
committerTim Newsome <tim@sifive.com>2017-08-28 12:16:39 -0700
commit5d6b15402a5402239dee9bad68e3d57d5c1e430e (patch)
treee561ad612b8997d36fd42bb3bb1add676592983e
parent3a44725d27f6b2c77f0ca912d792b6856fde6a17 (diff)
downloadriscv-tests-5d6b15402a5402239dee9bad68e3d57d5c1e430e.zip
riscv-tests-5d6b15402a5402239dee9bad68e3d57d5c1e430e.tar.gz
riscv-tests-5d6b15402a5402239dee9bad68e3d57d5c1e430e.tar.bz2
WIP towards multiple gdb instances.
-rw-r--r--debug/testlib.py18
1 files changed, 14 insertions, 4 deletions
diff --git a/debug/testlib.py b/debug/testlib.py
index d6c7f8a..856b903 100644
--- a/debug/testlib.py
+++ b/debug/testlib.py
@@ -218,7 +218,13 @@ class Openocd(object):
logfile = open(Openocd.logname, "w")
logfile.write("+ %s\n" % " ".join(cmd))
logfile.flush()
- self.process = subprocess.Popen(cmd, stdin=subprocess.PIPE,
+
+ self.ports = []
+ self.port = None
+ self.process = self.start(cmd, logfile)
+
+ def start(self, cmd, logfile):
+ process = subprocess.Popen(cmd, stdin=subprocess.PIPE,
stdout=logfile, stderr=logfile)
try:
@@ -233,10 +239,14 @@ class Openocd(object):
m = re.search(r"Listening on port (\d+) for gdb connections",
log)
if m:
- self.port = int(m.group(1))
+ if not self.ports:
+ self.port = int(m.group(1))
+ self.ports.append(int(m.group(1)))
+
+ if "telnet server disabled" in log:
break
- if not self.process.poll() is None:
+ if not process.poll() is None:
raise Exception(
"OpenOCD exited before completing riscv_examine()")
if not messaged and time.time() - start > 1:
@@ -245,7 +255,7 @@ class Openocd(object):
if (time.time() - start) > timeout:
raise Exception("ERROR: Timed out waiting for OpenOCD to "
"listen for gdb")
-
+ return process
except Exception:
header("OpenOCD log")
sys.stdout.write(log)