1 from __future__
import print_function
3 # A very simple smoke test for debugging the SHA1 userspace test on
6 # This is launched via tests/guest-debug/run-test.py
15 def report(cond
, msg
):
16 "Report success/fail of test"
18 print("PASS: %s" % (msg
))
20 print("FAIL: %s" % (msg
))
24 def check_break(sym_name
):
25 "Setup breakpoint, continue and check we stopped."
26 sym
, ok
= gdb
.lookup_symbol(sym_name
)
27 bp
= gdb
.Breakpoint(sym_name
)
31 # hopefully we came back
32 end_pc
= gdb
.parse_and_eval('$pc')
33 report(bp
.hit_count
== 1,
34 "break @ %s (%s %d hits)" % (end_pc
, sym
.value(), bp
.hit_count
))
39 "Run through the tests one by one"
41 check_break("SHA1Init")
43 # Check step and inspect values. We do a double next after the
44 # breakpoint as depending on the version of gdb we may step the
45 # preamble and not the first actual line of source.
48 val_ctx
= gdb
.parse_and_eval("context->state[0]")
50 report(int(val_ctx
) == exp_ctx
, "context->state[0] == %x" % exp_ctx
);
53 val_ctx
= gdb
.parse_and_eval("context->state[1]")
55 report(int(val_ctx
) == exp_ctx
, "context->state[1] == %x" % exp_ctx
);
57 # finally check we don't barf inspecting registers
58 gdb
.execute("info registers")
61 # This runs as the script it sourced (via -x, via run-test.py)
64 inferior
= gdb
.selected_inferior()
65 arch
= inferior
.architecture()
66 print("ATTACHED: %s" % arch
.name())
67 except (gdb
.error
, AttributeError):
68 print("SKIPPING (not connected)", file=sys
.stderr
)
71 if gdb
.parse_and_eval('$pc') == 0:
72 print("SKIP: PC not set")
76 # These are not very useful in scripts
77 gdb
.execute("set pagination off")
78 gdb
.execute("set confirm off")
80 # Run the actual tests
83 print ("GDB Exception: %s" % (sys
.exc_info()[0]))
87 print("All tests complete: %d failures" % failcount
)