* [RFA] Fix incorrect use of "until" command in gdb.arch/gdb1431
@ 2004-02-20 3:03 Fred Fish
2004-02-26 21:04 ` Andrew Cagney
0 siblings, 1 reply; 4+ messages in thread
From: Fred Fish @ 2004-02-20 3:03 UTC (permalink / raw)
To: gdb-patches; +Cc: fnf
The gdb.arch/gdb1431 command is using the "until" command incorrectly.
As currently defined, that command ONLY stops at a point within the
current frame or upon return from the current frame. You have to use
the "advance" command to stop at a frame called by the current frame
or a frame called by a caller of the current frame.
-Fred
2004-02-19 Fred Fish <fnf@redhat.com>
* gdb.arch/gdb1431.c: Remove.
* gdb.arch/gdb1431.exp: Reuse test file from PR 1291 and use
"advance" correctly instead of "until" incorrectly.
Index: gdb.arch/gdb1431.c
===================================================================
RCS file: gdb.arch/gdb1431.c
diff -N gdb.arch/gdb1431.c
*** gdb.arch/gdb1431.c 4 Feb 2004 14:41:20 -0000 1.2
--- /dev/null 1 Jan 1970 00:00:00 -0000
***************
*** 1,65 ****
- /* Copyright 2003, 2004 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 2 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.
-
- Please email any bugs, comments, and/or additions to this file to:
- bug-gdb@gnu.org
-
- This file is part of the gdb testsuite. */
-
- void sub1 (void);
- void sub2 (void);
-
- main()
- {
- sub1();
- sub2();
- }
-
- asm(".text\n"
- " .align 5\n"
- "sub1:\n"
- "_sub1:\n"
- " mov.l r14,@-r15\n"
- " add #-128,r15\n"
- " add #-128,r15\n"
- " mov r15,r14\n"
- " mov.w .STACK1,r7\n"
- " add r7,r14\n"
- " mov r14,r15\n"
- " mov.l @r15+,r14\n"
- " rts\n"
- " nop\n"
- " .align 1\n"
- ".STACK1:\n"
- " .short 256\n");
-
- asm(".text\n"
- " .align 5\n"
- "sub2:\n"
- "_sub2:\n"
- " mov.l r14,@-r15\n"
- " mov.w .STACK2,r3\n"
- " sub r3,r15\n"
- " mov r15,r14\n"
- " mov.w .STACK2,r7\n"
- " add r7,r14\n"
- " mov r14,r15\n"
- " mov.l @r15+,r14\n"
- " rts\n"
- " nop\n"
- " .align 1\n"
- ".STACK2:\n"
- " .short 260\n");
--- 0 ----
Index: gdb.arch/gdb1431.exp
===================================================================
RCS file: /cvs/src/src/gdb/testsuite/gdb.arch/gdb1431.exp,v
retrieving revision 1.1
diff -c -p -r1.1 gdb1431.exp
*** gdb.arch/gdb1431.exp 3 Nov 2003 17:42:52 -0000 1.1
--- gdb.arch/gdb1431.exp 20 Feb 2004 02:47:50 -0000
***************
*** 1,4 ****
! # Copyright 2003 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
--- 1,4 ----
! # Copyright 2004 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
***************
*** 20,25 ****
--- 20,28 ----
# This file is part of the gdb testsuite.
# Tests for PR:1431. Catch gdb not continuing to second function properly.
+ # Note that originally this bug was reported as a problem with the "until"
+ # command, which actually is behaving as currently defined. What apparently
+ # was expected was the behavior of the newer "advance" command.
if $tracelevel {
strace $tracelevel
*************** if ![istarget "sh-*-*"] then {
*** 35,44 ****
return
}
! set testfile "gdb1431"
! set srcfile ${testfile}.c
set binfile ${objdir}/${subdir}/${testfile}
! if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
}
--- 38,48 ----
return
}
! # Use the same file as PR 1291
! set testfile "gdb1291"
! set srcfile ${testfile}.s
set binfile ${objdir}/${subdir}/${testfile}
! if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable ""] != "" } {
gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
}
*************** if ![runto_main] then {
*** 55,66 ****
gdb_suppress_tests
}
! gdb_test "u sub1" "sub1*" "get to sub1"
! gdb_test "bt" "#0\[ \t\]*$hex \\(\\) at sh-bt.*\r\n#1\[ \t\]*$hex in main.*" \
! "backtrace in gdb1291"
!
! kfail "gdb/1431" "u sub2"
! # This is what we would expect to be able to do:
! #gdb_test "u sub2" "sub2*" "get to sub2"
! #gdb_test "bt" "#0\[ \t\]*$hex \\(\\) at sh-bt.*\r\n#1\[ \t\]*$hex in main.*" \
! # "backtrace in gdb1291"
--- 59,64 ----
gdb_suppress_tests
}
! gdb_test "advance sub1" "hello world\r\n$hex in sub1 \\(\\)" "get to sub1"
! gdb_test "advance sub2" "$hex in main \\(\\)" "advance returns from sub1 frame"
! gdb_test "advance sub2" "$hex in sub2 \\(\\)" "get to sub2"
^ permalink raw reply [flat|nested] 4+ messages in thread* Re: [RFA] Fix incorrect use of "until" command in gdb.arch/gdb1431 2004-02-20 3:03 [RFA] Fix incorrect use of "until" command in gdb.arch/gdb1431 Fred Fish @ 2004-02-26 21:04 ` Andrew Cagney 2004-02-26 22:29 ` Fred Fish 0 siblings, 1 reply; 4+ messages in thread From: Andrew Cagney @ 2004-02-26 21:04 UTC (permalink / raw) To: fnf; +Cc: gdb-patches > The gdb.arch/gdb1431 command is using the "until" command incorrectly. > As currently defined, that command ONLY stops at a point within the > current frame or upon return from the current frame. You have to use > the "advance" command to stop at a frame called by the current frame > or a frame called by a caller of the current frame. Hmm, "How did it ever work"? :-) I guess so, but keep the 1531.c specific test file - we've had our fingers burt when trying to use the one test source file on multiple tests. Andrew > 2004-02-19 Fred Fish <fnf@redhat.com> > > * gdb.arch/gdb1431.c: Remove. > * gdb.arch/gdb1431.exp: Reuse test file from PR 1291 and use > "advance" correctly instead of "until" incorrectly. > ^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [RFA] Fix incorrect use of "until" command in gdb.arch/gdb1431 2004-02-26 21:04 ` Andrew Cagney @ 2004-02-26 22:29 ` Fred Fish 2004-02-26 23:01 ` Andrew Cagney 0 siblings, 1 reply; 4+ messages in thread From: Fred Fish @ 2004-02-26 22:29 UTC (permalink / raw) To: Andrew Cagney, fnf; +Cc: gdb-patches On Thursday 26 February 2004 14:04, Andrew Cagney wrote: > Hmm, "How did it ever work"? :-) From what I could tell, at one time "until" did work like "advance". There is a pretty long thread about it on the gdb or gdb-patches list, though I can't seem to find it again with a quick search. > I guess so, but keep the 1431.c specific test file OK, I kept a distinct file for this test, but one that is cloned from the 1291 test to be all assembly instead of mixed C/assembly. There is a previously reported gcc bug that causes line numbers to be botched in the mix C/assembly case, obscuring what we are trying to test for here. I committed the following patch. -Fred 2004-02-26 Fred Fish <fnf@redhat.com> * gdb.arch/gdb1431.c: Remove. * gdb.arch/gdb1431.s: New file, copy of gdb1291.s * gdb.arch/gdb1431.exp: Use "advance" correctly instead of "until" incorrectly. Index: gdb.arch/gdb1431.c =================================================================== RCS file: gdb.arch/gdb1431.c diff -N gdb.arch/gdb1431.c *** gdb.arch/gdb1431.c 4 Feb 2004 14:41:20 -0000 1.2 --- /dev/null 1 Jan 1970 00:00:00 -0000 *************** *** 1,65 **** - /* Copyright 2003, 2004 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 2 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. - - Please email any bugs, comments, and/or additions to this file to: - bug-gdb@gnu.org - - This file is part of the gdb testsuite. */ - - void sub1 (void); - void sub2 (void); - - main() - { - sub1(); - sub2(); - } - - asm(".text\n" - " .align 5\n" - "sub1:\n" - "_sub1:\n" - " mov.l r14,@-r15\n" - " add #-128,r15\n" - " add #-128,r15\n" - " mov r15,r14\n" - " mov.w .STACK1,r7\n" - " add r7,r14\n" - " mov r14,r15\n" - " mov.l @r15+,r14\n" - " rts\n" - " nop\n" - " .align 1\n" - ".STACK1:\n" - " .short 256\n"); - - asm(".text\n" - " .align 5\n" - "sub2:\n" - "_sub2:\n" - " mov.l r14,@-r15\n" - " mov.w .STACK2,r3\n" - " sub r3,r15\n" - " mov r15,r14\n" - " mov.w .STACK2,r7\n" - " add r7,r14\n" - " mov r14,r15\n" - " mov.l @r15+,r14\n" - " rts\n" - " nop\n" - " .align 1\n" - ".STACK2:\n" - " .short 260\n"); --- 0 ---- Index: gdb.arch/gdb1431.exp =================================================================== RCS file: /cvs/src/src/gdb/testsuite/gdb.arch/gdb1431.exp,v retrieving revision 1.1 diff -c -p -r1.1 gdb1431.exp *** gdb.arch/gdb1431.exp 3 Nov 2003 17:42:52 -0000 1.1 --- gdb.arch/gdb1431.exp 26 Feb 2004 22:18:25 -0000 *************** *** 1,4 **** ! # Copyright 2003 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 --- 1,4 ---- ! # Copyright 2003, 2004 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 *************** *** 20,25 **** --- 20,28 ---- # This file is part of the gdb testsuite. # Tests for PR:1431. Catch gdb not continuing to second function properly. + # Note that originally this bug was reported as a problem with the "until" + # command, which actually is behaving as currently defined. What apparently + # was expected was the behavior of the newer "advance" command. if $tracelevel { strace $tracelevel *************** if ![istarget "sh-*-*"] then { *** 36,44 **** } set testfile "gdb1431" ! set srcfile ${testfile}.c set binfile ${objdir}/${subdir}/${testfile} ! if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } { gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail." } --- 39,47 ---- } set testfile "gdb1431" ! set srcfile ${testfile}.s set binfile ${objdir}/${subdir}/${testfile} ! if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable ""] != "" } { gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail." } *************** if ![runto_main] then { *** 55,66 **** gdb_suppress_tests } ! gdb_test "u sub1" "sub1*" "get to sub1" ! gdb_test "bt" "#0\[ \t\]*$hex \\(\\) at sh-bt.*\r\n#1\[ \t\]*$hex in main.*" \ ! "backtrace in gdb1291" ! ! kfail "gdb/1431" "u sub2" ! # This is what we would expect to be able to do: ! #gdb_test "u sub2" "sub2*" "get to sub2" ! #gdb_test "bt" "#0\[ \t\]*$hex \\(\\) at sh-bt.*\r\n#1\[ \t\]*$hex in main.*" \ ! # "backtrace in gdb1291" --- 58,63 ---- gdb_suppress_tests } ! gdb_test "advance sub1" "hello world\r\n$hex in sub1 \\(\\)" "get to sub1" ! gdb_test "advance sub2" "$hex in main \\(\\)" "advance returns from sub1 frame" ! gdb_test "advance sub2" "$hex in sub2 \\(\\)" "get to sub2" Index: gdb.arch/gdb1431.s =================================================================== RCS file: gdb.arch/gdb1431.s diff -N gdb.arch/gdb1431.s *** /dev/null 1 Jan 1970 00:00:00 -0000 --- gdb.arch/gdb1431.s 26 Feb 2004 22:18:25 -0000 *************** *** 0 **** --- 1,129 ---- + ! Copyright 2004 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 2 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. + ! + ! Please email any bugs, comments, and/or additions to this file to: + ! bug-gdb@gnu.org + ! + ! This file is part of the gdb testsuite. + ! + ! It was generated using "sh-elf-gcc -S gdb1431.c", using the following + ! source file: + ! + ! #include <stdio.h> + ! + ! main() + ! { + ! printf("hello world\n"); + ! sub1(); + ! sub2(); + ! } + ! sub1() + ! { + ! int buf[64]; + ! + ! } + ! + ! sub2() + ! { + ! int buf[65]; + ! + ! } + ! + ! We use a pregenerated assembly file as the test input to avoid possible + ! problems with future versions of gcc generating different code. + + .file "gdb1431.c" + .text + .section .rodata + .align 2 + .LC0: + .string "hello world\n" + .text + .align 1 + .global _main + .type _main, @function + _main: + mov.l r14,@-r15 + sts.l pr,@-r15 + mov r15,r14 + mov.l .L2,r1 + mov r1,r4 + mov.l .L3,r1 + jsr @r1 + nop + mov.l .L4,r1 + jsr @r1 + nop + mov.l .L5,r1 + jsr @r1 + nop + mov r14,r15 + lds.l @r15+,pr + mov.l @r15+,r14 + rts + nop + .L6: + .align 2 + .L2: + .long .LC0 + .L3: + .long _printf + .L4: + .long _sub1 + .L5: + .long _sub2 + .size _main, .-_main + .align 1 + .global _sub1 + .type _sub1, @function + _sub1: + mov.l r14,@-r15 + sts.l pr,@-r15 + add #-128,r15 + add #-128,r15 + mov r15,r14 + mov.w .L8,r7 + add r7,r14 + mov r14,r15 + lds.l @r15+,pr + mov.l @r15+,r14 + rts + nop + .align 1 + .L8: + .short 256 + .size _sub1, .-_sub1 + .align 1 + .global _sub2 + .type _sub2, @function + _sub2: + mov.l r14,@-r15 + sts.l pr,@-r15 + mov.w .L11,r1 + sub r1,r15 + mov r15,r14 + mov.w .L11,r7 + add r7,r14 + mov r14,r15 + lds.l @r15+,pr + mov.l @r15+,r14 + rts + nop + .align 1 + .L11: + .short 260 + .size _sub2, .-_sub2 + .ident "GCC: (GNU) 3.5.0 20040204 (experimental)" ^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [RFA] Fix incorrect use of "until" command in gdb.arch/gdb1431 2004-02-26 22:29 ` Fred Fish @ 2004-02-26 23:01 ` Andrew Cagney 0 siblings, 0 replies; 4+ messages in thread From: Andrew Cagney @ 2004-02-26 23:01 UTC (permalink / raw) To: fnf; +Cc: gdb-patches > On Thursday 26 February 2004 14:04, Andrew Cagney wrote: > >>> Hmm, "How did it ever work"? :-) > > > From what I could tell, at one time "until" did work like "advance". > There is a pretty long thread about it on the gdb or gdb-patches list, > though I can't seem to find it again with a quick search. Ah, that would explain it. The current "finish" behavior is the original "finish" behavior. There was a period (of several years) during which "finish" was broken. I guess the test was written during that period (or with such a broken GDB). "advance" came about because people wanted both the correct and broken behavior .... Andrew >>> I guess so, but keep the 1431.c specific test file > > > OK, I kept a distinct file for this test, but one that is cloned from > the 1291 test to be all assembly instead of mixed C/assembly. There > is a previously reported gcc bug that causes line numbers to be > botched in the mix C/assembly case, obscuring what we are trying to > test for here. > > I committed the following patch. ^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2004-02-26 23:01 UTC | newest] Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2004-02-20 3:03 [RFA] Fix incorrect use of "until" command in gdb.arch/gdb1431 Fred Fish 2004-02-26 21:04 ` Andrew Cagney 2004-02-26 22:29 ` Fred Fish 2004-02-26 23:01 ` Andrew Cagney
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox