X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=debug%2Fgdbserver.py;h=a56d4a1f8a84216ac63596f0acf5944adccb1bcd;hb=c0aa8a601202a5de0d3334cb74f75105df627eee;hp=e59c3554f0211d2d5491629c3943e29fdf4b26a3;hpb=51ec34e28541f8c89cd89a6a9c137bd32ba71c29;p=riscv-tests.git diff --git a/debug/gdbserver.py b/debug/gdbserver.py index e59c355..a56d4a1 100755 --- a/debug/gdbserver.py +++ b/debug/gdbserver.py @@ -633,6 +633,35 @@ class MulticoreRunAllHaltOne(GdbTest): time.sleep(1) self.gdb.p("buf", fmt="") +class MulticoreRtosSwitchActiveHartTest(GdbTest): + compile_args = ("programs/multicore.c", "-DMULTICORE") + + def early_applicable(self): + return len(self.target.harts) > 1 + + def setup(self): + self.gdb.select_hart(self.target.harts[0]) + self.gdb.load() + for hart in self.target.harts: + self.gdb.select_hart(hart) + self.gdb.p("$pc=_start") + + def test(self): + if self.gdb.one_hart_per_gdb(): + return 'not_applicable' + + # Set breakpoint near '_start' label to increase the chances of a + # situation when all harts hit breakpoint immediately and + # simultaneously. + self.gdb.b("set_trap_handler") + + # Check that all harts hit breakpoint one by one. + for _ in range(len(self.target.harts)): + output = self.gdb.c() + assertIn("hit Breakpoint", output) + assertIn("set_trap_handler", output) + assertNotIn("received signal SIGTRAP", output) + class StepTest(GdbSingleHartTest): compile_args = ("programs/step.S", )