| Index: gdb/testsuite/gdb.arch/mips-octeon-bbit.exp
|
| diff --git a/gdb/testsuite/gdb.arch/mips-octeon-bbit.exp b/gdb/testsuite/gdb.arch/mips-octeon-bbit.exp
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..850b1544a0aa6966bed7c97fe946f06bb9bef705
|
| --- /dev/null
|
| +++ b/gdb/testsuite/gdb.arch/mips-octeon-bbit.exp
|
| @@ -0,0 +1,111 @@
|
| +# Copyright (C) 2012-2013 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, see <http://www.gnu.org/licenses/>.
|
| +
|
| +# Test single-step on bbit.
|
| +
|
| +if ![istarget "*octeon*"] {
|
| + return -1
|
| +}
|
| +
|
| +proc current_insn {} {
|
| + global gdb_prompt
|
| +
|
| + send_gdb "x/i \$pc\n"
|
| + gdb_expect {
|
| + -re ".*?:\\s+\(.*?\)\\s*$gdb_prompt $" {
|
| + set insn $expect_out(1,string)
|
| + return $insn
|
| + }
|
| + }
|
| + return ""
|
| +}
|
| +
|
| +proc single_step {} {
|
| + global gdb_prompt
|
| +
|
| + send_gdb "si\n"
|
| + gdb_expect {
|
| + -re "$gdb_prompt \$" {
|
| + return 1
|
| + }
|
| + }
|
| + return 0
|
| +}
|
| +
|
| +proc single_step_until { match } {
|
| + global timeout
|
| +
|
| + set insn [current_insn]
|
| + set start [timestamp]
|
| + while { $insn != "" && [timestamp] - $start < 3*$timeout } {
|
| + if [regexp $match $insn] {
|
| + return 1
|
| + }
|
| + if {![single_step]} {
|
| + return 0
|
| + }
|
| + set insn [current_insn]
|
| + }
|
| + return 0
|
| +}
|
| +
|
| +proc test_bbit { name taken } {
|
| + if {![single_step_until "bbit"]} {
|
| + fail "$name single-step until bbit"
|
| + return
|
| + }
|
| + pass "$name single-step until bbit"
|
| + gdb_test "si" "" "$name single-step on bbit"
|
| + if [regexp "li\\s+\[sv\]0,$taken" [current_insn]] {
|
| + pass "$name check insn after bbit"
|
| + } else {
|
| + send_log "expected: li\\s+\[sv\]0,$taken found [current_insn]\n"
|
| + fail "$name check insn after bbit"
|
| + }
|
| +}
|
| +
|
| +set testfile "mips-octeon-bbit"
|
| +set srcfile ${testfile}.c
|
| +set binfile ${objdir}/${subdir}/${testfile}
|
| +
|
| +if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable \
|
| + {debug nowarnings}] != "" } {
|
| + fail "compilation"
|
| + return
|
| +}
|
| +
|
| +pass "compilation"
|
| +
|
| +gdb_exit
|
| +gdb_start
|
| +gdb_reinitialize_dir $srcdir/$subdir
|
| +gdb_load ${binfile}
|
| +# Native needs run.
|
| +runto_main
|
| +
|
| +set tests ""
|
| +foreach n [list "0_10" "0_36" "1_20" "1_49"] {
|
| + lappend tests "bbit_is_taken_$n"
|
| +}
|
| +foreach func $tests {
|
| + gdb_test "break $func" "Breakpoint.*at.*" "set breakpoint on $func"
|
| +}
|
| +
|
| +foreach func $tests {
|
| + gdb_test "continue" "Continuing.*Breakpoint.*$func.*" "hit $func first"
|
| + test_bbit "$func branch taken" 1
|
| + gdb_test "continue" "Continuing.*Breakpoint.*$func.*" "hit $func second"
|
| + test_bbit "$func branch not taken" 0
|
| +}
|
|
|