1 # Copyright 2007 Cavium Networks, 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 2 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, write to the Free Software
15 # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
17 # Test single-step on bbit.
19 if ![istarget "*octeon*"] {
23 proc current_insn {} {
28 -re ".*?:\\s+\(.*?\)\\s*$gdb_prompt $" {
29 set insn $expect_out(1,string)
41 -re "$gdb_prompt \$" {
48 proc single_step_until { match } {
51 set insn [current_insn]
53 while { $insn != "" && [timestamp] - $start < 3*$timeout } {
54 if [regexp $match $insn] {
60 set insn [current_insn]
65 proc test_bbit { name taken } {
66 if {![single_step_until "bbit"]} {
67 fail "$name single-step until bbit"
70 pass "$name single-step until bbit"
71 gdb_test "si" "" "$name single-step on bbit"
72 if [regexp "li\\s+\[sv\]0,$taken" [current_insn]] {
73 pass "$name check insn after bbit"
75 send_log "expected: li\\s+\[sv\]0,$taken found [current_insn]\n"
76 fail "$name check insn after bbit"
80 set testfile "mips-octeon-bbit"
81 set srcfile ${testfile}.c
82 set binfile ${objdir}/${subdir}/${testfile}
84 if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable \
85 {debug nowarnings}] != "" } {
94 gdb_reinitialize_dir $srcdir/$subdir
100 foreach n [list "0_10" "0_36" "1_20" "1_49"] {
101 lappend tests "bbit_is_taken_$n"
103 foreach func $tests {
104 gdb_test "break $func" "Breakpoint.*at.*" "set breakpoint on $func"
107 foreach func $tests {
108 gdb_test "continue" "Continuing.*Breakpoint.*$func.*" "hit $func first"
109 test_bbit "$func branch taken" 1
110 gdb_test "continue" "Continuing.*Breakpoint.*$func.*" "hit $func second"
111 test_bbit "$func branch not taken" 0