xref: /netbsd-src/external/gpl3/gdb.old/dist/gdb/testsuite/gdb.arch/aarch64-sighandler-regs.exp (revision 6db267571823ee3b0a1d61478df085a087f2e990)
1# Copyright 2018-2020 Free Software Foundation, Inc.
2#
3# This program is free software; you can redistribute it and/or modify
4# it under the terms of the GNU General Public License as published by
5# the Free Software Foundation; either version 3 of the License, or
6# (at your option) any later version.
7#
8# This program is distributed in the hope that it will be useful,
9# but WITHOUT ANY WARRANTY; without even the implied warranty of
10# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11# GNU General Public License for more details.
12#
13# You should have received a copy of the GNU General Public License
14# along with this program.  If not, see <http://www.gnu.org/licenses/>.
15#
16# This file is part of the gdb testsuite.
17
18if {![is_aarch64_target]} {
19    verbose "Skipping ${gdb_test_file_name}."
20    return -1
21}
22
23set compile_flags {debug}
24
25if { [skip_aarch64_sve_tests] } {
26    unsupported "target does not support SVE"
27    set sve_hw 0
28} else {
29    set sve_hw 1
30    lappend compile_flags "additional_flags=-DSVE"
31}
32
33standard_testfile
34if { [prepare_for_testing "failed to prepare" ${testfile} ${srcfile} ${compile_flags}] } {
35    return -1
36}
37
38if ![runto_main] {
39    untested "could not run to main"
40    return -1
41}
42
43set endianness [get_endianness]
44
45if {$endianness == "little"} {
46    set reg_handler_value_128 "0x5f5e5d5c5b5a59585756555453525150"
47    set reg_handler_value_64 "0x5756555453525150"
48    set reg_handler_value_32 "0x53525150"
49    set reg_handler_value_16 "0x5150"
50    set reg_handler_value_8 "0x50"
51    set reg_main_value_128 "0x1f1e1d1c1b1a19181716151413121110"
52    set reg_main_value_64 "0x1716151413121110"
53    set reg_main_value_32 "0x13121110"
54    set reg_main_value_16 "0x1110"
55    set reg_main_value_8 "0x10"
56} else {
57    set reg_handler_value_128 "0x505152535455565758595a5b5c5d5e5f"
58    set reg_handler_value_64 "0x5051525354555657"
59    set reg_handler_value_32 "0x50515253"
60    set reg_handler_value_16 "0x5051"
61    set reg_handler_value_8 "0x50"
62    set reg_main_value_128 "0x101112131415161718191a1b1c1d1e1f"
63    set reg_main_value_64 "0x1011121314151617"
64    set reg_main_value_32 "0x10111213"
65    set reg_main_value_16 "0x1011"
66    set reg_main_value_8 "0x10"
67}
68set zreg_handler_value "\\{0x5756555453525150, .*"
69set zreg_main_value "\\{0x1716151413121110, .*"
70set preg_handler_value "\\{0x11, .*"
71set preg_main_value "\\{0x1, 0x0, .*"
72
73#Ignore x0, and x29 to x31
74set xreg_nums [list 1 2 3 4 5 6 7 8 9 11 12 13 14 15 16 17 18 19 21 22 23 24 \
75		    25 26 27 28 ]
76set vreg_nums [list 0 1 2 3 4 5 6 7 8 9 11 12 13 14 15 16 17 18 19 21 22 23 \
77		    24 25 26 27 28 29 30 31]
78set preg_nums [list 0 1 2 3 4 5 6 7 8 9 11 12 13 14 15]
79
80proc check_regs {regtype regnums value postfix} {
81  foreach regnum $regnums {
82    gdb_test "print /x \$$regtype$regnum$postfix" \
83      ".* = {?$value}?" \
84      "check register \$$regtype$regnum has value $value"
85  }
86}
87
88# Run until end of signal handler
89
90gdb_test "continue" \
91    "Continuing.*Program received signal SIGILL.*" \
92    "continue until signal"
93
94gdb_breakpoint [gdb_get_line_number "exit(0)"]
95gdb_continue_to_breakpoint "exit" ".*exit.*"
96
97set handlerframe [get_current_frame_number]
98set mainframe [expr $handlerframe + 2]
99
100
101# Check register values
102
103with_test_prefix "handler frame 1st" {
104  check_regs x $xreg_nums $reg_handler_value_64 ""
105  check_regs v $vreg_nums $reg_handler_value_128 ".q.u"
106  check_regs q $vreg_nums $reg_handler_value_128 ".u"
107  check_regs d $vreg_nums $reg_handler_value_64 ".u"
108  check_regs s $vreg_nums $reg_handler_value_32 ".u"
109  check_regs h $vreg_nums $reg_handler_value_16 ".u"
110  check_regs b $vreg_nums $reg_handler_value_8 ".u"
111  if { $sve_hw } {
112    check_regs z $vreg_nums $zreg_handler_value ".d.u"
113    check_regs p $preg_nums $preg_handler_value ""
114  }
115}
116
117# Switch to the frame for main(), and check register values
118
119gdb_test "frame $mainframe" \
120      "#$mainframe.*in main ().*" \
121      "set to main frame"
122
123
124with_test_prefix "main frame" {
125  check_regs x $xreg_nums $reg_main_value_64 ""
126  check_regs v $vreg_nums $reg_main_value_128 ".q.u"
127  check_regs q $vreg_nums $reg_main_value_128 ".u"
128  check_regs d $vreg_nums $reg_main_value_64 ".u"
129  check_regs s $vreg_nums $reg_main_value_32 ".u"
130  check_regs h $vreg_nums $reg_main_value_16 ".u"
131  check_regs b $vreg_nums $reg_main_value_8 ".u"
132  if { $sve_hw } {
133    check_regs z $vreg_nums $zreg_main_value ".d.u"
134    check_regs p $preg_nums $preg_main_value ""
135  }
136}
137
138# Switch back to the signal handler frame, and check register values
139
140gdb_test "frame $handlerframe" \
141      "#$handlerframe.*handler \\\(sig=4\\\).*" \
142      "set to signal handler frame"
143
144with_test_prefix "handler frame 2nd" {
145  check_regs x $xreg_nums $reg_handler_value_64 ""
146  check_regs v $vreg_nums $reg_handler_value_128 ".q.u"
147  check_regs q $vreg_nums $reg_handler_value_128 ".u"
148  check_regs d $vreg_nums $reg_handler_value_64 ".u"
149  check_regs s $vreg_nums $reg_handler_value_32 ".u"
150  check_regs h $vreg_nums $reg_handler_value_16 ".u"
151  check_regs b $vreg_nums $reg_handler_value_8 ".u"
152  if { $sve_hw } {
153    check_regs z $vreg_nums $zreg_handler_value ".d.u"
154    check_regs p $preg_nums $preg_handler_value ""
155}
156}
157