diff options
author | Evgeniy Naydanov <evgeniy.naydanov@syntacore.com> | 2023-06-30 11:59:37 +0300 |
---|---|---|
committer | Evgeniy Naydanov <evgeniy.naydanov@syntacore.com> | 2023-07-07 14:37:10 +0300 |
commit | 4b18e0781afed3e40e9b7d14cbd76b0063dc823d (patch) | |
tree | 94e67f0ebed6aa7f7f9f47dda00148c6c21fb9f1 | |
parent | 247e2334ef60654ad53ca1dd0a688dc1f0fccd33 (diff) | |
download | riscv-tests-4b18e0781afed3e40e9b7d14cbd76b0063dc823d.zip riscv-tests-4b18e0781afed3e40e9b7d14cbd76b0063dc823d.tar.gz riscv-tests-4b18e0781afed3e40e9b7d14cbd76b0063dc823d.tar.bz2 |
change warning check in RepeatReadTest
-rwxr-xr-x | debug/gdbserver.py | 17 |
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(): |