Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
* [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