1 # Copyright 2008-2022 Free Software Foundation, Inc.
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.
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.
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/>.
16 # This file is part of the gdb testsuite.
18 # Test single stepping through atomic sequences beginning with
19 # a lwarx/ldarx instruction and ending with a stwcx/stdcx
23 if {![istarget "powerpc*"] || ![is_lp64_target]} {
24 verbose "Skipping testing of powerpc64 single stepping over atomic sequences."
30 if { [prepare_for_testing "failed to prepare" ${testfile} ${srcfile} {debug quiet}] } {
34 # The test proper. DISPLACED is true if we should try with displaced
36 proc do_test { displaced } {
39 if ![runto_main] then {
43 gdb_test_no_output "set displaced-stepping $displaced"
45 set bp1 [gdb_get_line_number "lwarx"]
46 gdb_breakpoint "$bp1" "Breakpoint $decimal at $hex" \
47 "set the breakpoint at the start of the lwarx/stwcx sequence"
49 set bp2 [gdb_get_line_number "ldarx"]
50 gdb_breakpoint "$bp2" "Breakpoint $decimal at $hex" \
51 "set the breakpoint at the start of the ldarx/stdcx sequence"
53 gdb_test continue "Continuing.*Breakpoint $decimal.*" \
54 "continue until lwarx/stwcx start breakpoint"
56 gdb_test nexti "bne.*1b" \
57 "step through the lwarx/stwcx sequence"
59 gdb_test continue "Continuing.*Breakpoint $decimal.*" \
60 "continue until ldarx/stdcx start breakpoint"
62 gdb_test nexti "bne.*1b" \
63 "step through the ldarx/stdcx sequence"
66 foreach displaced { "off" "on" } {
67 with_test_prefix "displaced=$displaced" {