7f03bd92e3
The ppc64 displaced step code can't handle atomic sequences. Fallback to stepping over the breakpoint in-line if we detect one. gdb/ChangeLog: 2015-08-07 Pedro Alves <palves@redhat.com> * infrun.c (displaced_step_prepare_throw): Return -1 if gdbarch_displaced_step_copy_insn returns NULL. Update intro comment. * rs6000-tdep.c (LWARX_MASK, LWARX_INSTRUCTION, LDARX_INSTRUCTION) (STWCX_MASK, STWCX_INSTRUCTION, STDCX_INSTRUCTION): Move higher up in file. (ppc_displaced_step_copy_insn): New function. (ppc_displaced_step_fixup): Update comment. (rs6000_gdbarch_init): Install ppc_displaced_step_copy_insn as gdbarch_displaced_step_copy_insn hook. * gdbarch.sh (displaced_step_copy_insn): Document what happens on NULL return. * gdbarch.h: Regenerate. gdb/testsuite/ChangeLog: 2015-08-07 Pedro Alves <palves@redhat.com> * gdb.arch/ppc64-atomic-inst.exp (do_test): New procedure, move tests here. (top level): Run do_test with and without displaced stepping.
73 lines
2.2 KiB
Plaintext
73 lines
2.2 KiB
Plaintext
# Copyright 2008-2015 Free Software Foundation, Inc.
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
#
|
|
# This file is part of the gdb testsuite.
|
|
|
|
# Test single stepping through atomic sequences beginning with
|
|
# a lwarx/ldarx instruction and ending with a stwcx/stdcx
|
|
# instruction.
|
|
|
|
|
|
if {![istarget "powerpc*"] || ![is_lp64_target]} {
|
|
verbose "Skipping testing of powerpc64 single stepping over atomic sequences."
|
|
return
|
|
}
|
|
|
|
standard_testfile .S
|
|
|
|
if { [prepare_for_testing ${testfile}.exp ${testfile} ${srcfile} {debug quiet}] } {
|
|
return -1
|
|
}
|
|
|
|
# The test proper. DISPLACED is true if we should try with displaced
|
|
# stepping.
|
|
proc do_test { displaced } {
|
|
global decimal hex
|
|
|
|
if ![runto_main] then {
|
|
untested "could not run to main"
|
|
return -1
|
|
}
|
|
|
|
gdb_test_no_output "set displaced-stepping $displaced"
|
|
|
|
set bp1 [gdb_get_line_number "lwarx"]
|
|
gdb_breakpoint "$bp1" "Breakpoint $decimal at $hex" \
|
|
"Set the breakpoint at the start of the lwarx/stwcx sequence"
|
|
|
|
set bp2 [gdb_get_line_number "ldarx"]
|
|
gdb_breakpoint "$bp2" "Breakpoint $decimal at $hex" \
|
|
"Set the breakpoint at the start of the ldarx/stdcx sequence"
|
|
|
|
gdb_test continue "Continuing.*Breakpoint $decimal.*" \
|
|
"Continue until lwarx/stwcx start breakpoint"
|
|
|
|
gdb_test nexti "bne.*1b" \
|
|
"Step through the lwarx/stwcx sequence"
|
|
|
|
gdb_test continue "Continuing.*Breakpoint $decimal.*" \
|
|
"Continue until ldarx/stdcx start breakpoint"
|
|
|
|
gdb_test nexti "bne.*1b" \
|
|
"Step through the ldarx/stdcx sequence"
|
|
}
|
|
|
|
foreach displaced { "off" "on" } {
|
|
with_test_prefix "displaced=$displaced" {
|
|
do_test $displaced
|
|
}
|
|
}
|