aboutsummaryrefslogtreecommitdiff
path: root/debug
diff options
context:
space:
mode:
Diffstat (limited to 'debug')
-rwxr-xr-xdebug/gdbserver.py26
1 files changed, 26 insertions, 0 deletions
diff --git a/debug/gdbserver.py b/debug/gdbserver.py
index 1ffb15f..64554d3 100755
--- a/debug/gdbserver.py
+++ b/debug/gdbserver.py
@@ -1973,6 +1973,32 @@ class EtriggerTest(DebugTest):
assertIn("breakpoint", output)
assertIn("trap_entry", self.gdb.where())
+class ItriggerTest(GdbSingleHartTest):
+ compile_args = ("programs/interrupt.c",)
+
+ def early_applicable(self):
+ return self.target.supports_clint_mtime
+
+ def setup(self):
+ self.gdb.load()
+
+ def test(self):
+ self.gdb.command(f"monitor targets {self.hart.id}")
+ output = self.gdb.command("monitor riscv itrigger set 0x80")
+ assertIn("Doesn't make sense", output)
+ output = self.gdb.command("monitor riscv itrigger set m 0")
+ assertIn("Doesn't make sense", output)
+ output = self.gdb.command("monitor riscv itrigger clear")
+ assertIn("No itrigger is set", output)
+ self.gdb.command("monitor riscv itrigger set m 0x80")
+
+ self.gdb.c()
+ assertIn("trap_entry", self.gdb.where())
+
+ self.gdb.command("monitor riscv itrigger clear")
+ self.gdb.p("keep_running=0")
+ self.exit()
+
parsed = None
def main():
parser = argparse.ArgumentParser(