aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEvgeniy Naydanov <evgeniy.naydanov@syntacore.com>2023-06-30 11:59:37 +0300
committerEvgeniy Naydanov <evgeniy.naydanov@syntacore.com>2023-07-07 14:37:10 +0300
commit4b18e0781afed3e40e9b7d14cbd76b0063dc823d (patch)
tree94e67f0ebed6aa7f7f9f47dda00148c6c21fb9f1
parent247e2334ef60654ad53ca1dd0a688dc1f0fccd33 (diff)
downloadriscv-tests-4b18e0781afed3e40e9b7d14cbd76b0063dc823d.zip
riscv-tests-4b18e0781afed3e40e9b7d14cbd76b0063dc823d.tar.gz
riscv-tests-4b18e0781afed3e40e9b7d14cbd76b0063dc823d.tar.bz2
change warning check in RepeatReadTest
-rwxr-xr-xdebug/gdbserver.py17
1 files changed, 15 insertions, 2 deletions
diff --git a/debug/gdbserver.py b/debug/gdbserver.py
index 764d1d0..b4c62ee 100755
--- a/debug/gdbserver.py
+++ b/debug/gdbserver.py
@@ -9,6 +9,7 @@ import tempfile
import time
import os
import re
+import itertools
import targets
import testlib
@@ -904,6 +905,9 @@ class RepeatReadTest(DebugTest):
def early_applicable(self):
return self.target.supports_clint_mtime
+ warning_re = re.compile(r"\[(?P<target_name>[^\]]+)\] Re-reading memory "
+ r"from addresses 0x(?P<addr>[\da-f]+) and 0x(?P=addr)\.")
+
def test(self):
self.gdb.b("main:start")
self.gdb.c()
@@ -912,8 +916,17 @@ class RepeatReadTest(DebugTest):
output = self.gdb.command(
f"monitor riscv repeat_read {count} 0x{mtime_addr:x} 4")
values = []
- for line in output.splitlines():
- # Ignore warnings
+ def is_valid_warning(line):
+ match = self.warning_re.match(line)
+ if match is None:
+ return False
+ assertEqual(int(match["addr"], 16), mtime_addr,
+ "The repeat read is reading from the wrong address")
+ return True
+
+ for line in itertools.dropwhile(is_valid_warning, output.splitlines()):
+ # This `if` is to be removed after
+ # https://github.com/riscv/riscv-openocd/pull/871 is merged.
if line.startswith("Batch memory"):
continue
for v in line.split():