744f1b0f68
This test seems flaky and reports attachment even when we failed to negotiate the architecture. However the fetching of the guest architecture will fail tripping up the gdb AttributeError which will trigger our early no error status exit from the test Signed-off-by: Alex Bennée <alex.bennee@linaro.org> Message-Id: <20200430190122.4592-5-alex.bennee@linaro.org>
81 lines
2.1 KiB
Python
81 lines
2.1 KiB
Python
from __future__ import print_function
|
|
#
|
|
# Test the SVE registers are visable and changeable via gdbstub
|
|
#
|
|
# This is launched via tests/guest-debug/run-test.py
|
|
#
|
|
|
|
import gdb
|
|
import sys
|
|
|
|
MAGIC = 0xDEADBEEF
|
|
|
|
failcount = 0
|
|
|
|
def report(cond, msg):
|
|
"Report success/fail of test"
|
|
if cond:
|
|
print ("PASS: %s" % (msg))
|
|
else:
|
|
print ("FAIL: %s" % (msg))
|
|
global failcount
|
|
failcount += 1
|
|
|
|
def run_test():
|
|
"Run through the tests one by one"
|
|
|
|
gdb.execute("info registers")
|
|
report(True, "info registers")
|
|
|
|
gdb.execute("info registers vector")
|
|
report(True, "info registers vector")
|
|
|
|
# Now all the zregs
|
|
frame = gdb.selected_frame()
|
|
for i in range(0, 32):
|
|
rname = "z%d" % (i)
|
|
zreg = frame.read_register(rname)
|
|
report(True, "Reading %s" % rname)
|
|
for j in range(0, 4):
|
|
cmd = "set $%s.q.u[%d] = 0x%x" % (rname, j, MAGIC)
|
|
gdb.execute(cmd)
|
|
report(True, "%s" % cmd)
|
|
for j in range(0, 4):
|
|
reg = "$%s.q.u[%d]" % (rname, j)
|
|
v = gdb.parse_and_eval(reg)
|
|
report(str(v.type) == "uint128_t", "size of %s" % (reg))
|
|
for j in range(0, 8):
|
|
cmd = "set $%s.d.u[%d] = 0x%x" % (rname, j, MAGIC)
|
|
gdb.execute(cmd)
|
|
report(True, "%s" % cmd)
|
|
for j in range(0, 8):
|
|
reg = "$%s.d.u[%d]" % (rname, j)
|
|
v = gdb.parse_and_eval(reg)
|
|
report(str(v.type) == "uint64_t", "size of %s" % (reg))
|
|
report(int(v) == MAGIC, "%s is 0x%x" % (reg, MAGIC))
|
|
|
|
#
|
|
# This runs as the script it sourced (via -x, via run-test.py)
|
|
#
|
|
try:
|
|
inferior = gdb.selected_inferior()
|
|
arch = inferior.architecture()
|
|
report(arch.name() == "aarch64", "connected to aarch64")
|
|
except (gdb.error, AttributeError):
|
|
print("SKIPPING (not connected)", file=sys.stderr)
|
|
exit(0)
|
|
|
|
try:
|
|
# These are not very useful in scripts
|
|
gdb.execute("set pagination off")
|
|
|
|
# Run the actual tests
|
|
run_test()
|
|
except:
|
|
print ("GDB Exception: %s" % (sys.exc_info()[0]))
|
|
failcount += 1
|
|
|
|
print("All tests complete: %d failures" % failcount)
|
|
|
|
exit(failcount)
|