Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
From: Adam Fedor <fedor@doc.com>
To: "gdb-patches@sources.redhat.com" <gdb-patches@sources.redhat.com>
Cc: Elena Zannoni <ezannoni@redhat.com>, Andrew Cagney <cagney@gnu.org>
Subject: Re: [rfa/symtab] Move find_pc_section call to lookup_minimal_symbol_by_pc
Date: Fri, 30 Jan 2004 04:53:00 -0000	[thread overview]
Message-ID: <1075438401.29218.20.camel@localhost.localdomain> (raw)
In-Reply-To: <401994EE.9060306@gnu.org>

[-- Attachment #1: Type: text/plain, Size: 1321 bytes --]

On Thu, 2004-01-29 at 16:19, Andrew Cagney wrote:
> > Andrew Cagney writes:
> >  > Hello,
> >  > 
> >  > Ref: RFA symtab: Fix for PR c++/1267 ("next" and shared libraries)
> >  > http://sources.redhat.com/ml/gdb-patches/2003-07/msg00354.html
> >  > 
> >  > The change unfortunatly broke IRIX 6.5's host compiler which is using 
> >  > mdebugread :-(  That code was looking for a symbol in the absolute 
> >  > section "*ABS*" but the PR/1267 change was causing *ABS* symbols to be 
> >  > ignored (find_pc_section didn't return an absolute section).
> >  > 
> >  > Since the underlying problem with PR/1267 was with the frame code 
> >  > needing a minimal symbol that was in the same section as the frame's PC, 
> >  > and that code [indirectly] calls lookup_minimal_symbol_by_pc, I moved 
> >  > the find_pc_section call to that function.
> >  > 
> >  > Tested on i386 GNU/Linux (dwarf 2) with no regressions.
> >  > Tested on PPC NetBSD (stabs) with no regressions.
> >  > Tested on IRIX and all the warnings, and many failures, disappeared.
> >  > See gdb/1519 for how to exercise the bug.
> >  > 
> >  > ok?
> > 
> > ok. Does it still fix shlibs/1237 and shlibs/1280 too? Adam, could you
> > check please?
> 
> Isn't that covered by the testsuite?  Sigh.
> 


This is probably ugly, but it shows the basic idea...



[-- Attachment #2: sh1280test.patch --]
[-- Type: text/x-patch, Size: 4490 bytes --]

Index: ChangeLog
===================================================================
RCS file: /cvs/src/src/gdb/testsuite/ChangeLog,v
retrieving revision 1.769
diff -u -r1.769 ChangeLog
--- ChangeLog	29 Jan 2004 11:15:42 -0000	1.769
+++ ChangeLog	30 Jan 2004 04:50:33 -0000
@@ -1,3 +1,8 @@
+2004-01-29  Adam Fedor  <fedor@gnu.org>
+
+	* gdb.base/ppc-shared.exp: New file.
+	* gdb.base/ppc-main.c, gdb.base/ppc-shared.c: New files.
+
 2004-01-29  Paul N. Hilfinger  <Hilfinger@gnat.com>
 
 	* gdb.base/chng-syms.exp: New file.
Index: gdb.base/ppc-main.c
===================================================================
RCS file: gdb.base/ppc-main.c
diff -N gdb.base/ppc-main.c
--- /dev/null	1 Jan 1970 00:00:00 -0000
+++ gdb.base/ppc-main.c	30 Jan 2004 04:50:33 -0000
@@ -0,0 +1,8 @@
+extern int hithere2 ();
+
+int
+main()
+{
+  hithere2();
+  return 0;
+}
Index: gdb.base/ppc-shared.c
===================================================================
RCS file: gdb.base/ppc-shared.c
diff -N gdb.base/ppc-shared.c
--- /dev/null	1 Jan 1970 00:00:00 -0000
+++ gdb.base/ppc-shared.c	30 Jan 2004 04:50:33 -0000
@@ -0,0 +1,5 @@
+int hithere2()
+{
+  return 21;
+}
+
Index: gdb.base/ppc-shared.exp
===================================================================
RCS file: gdb.base/ppc-shared.exp
diff -N gdb.base/ppc-shared.exp
--- /dev/null	1 Jan 1970 00:00:00 -0000
+++ gdb.base/ppc-shared.exp	30 Jan 2004 04:50:33 -0000
@@ -0,0 +1,98 @@
+# 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
+# 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@prep.ai.mit.edu
+
+# ppc-shared.exp -- Test stepping into and continuing to a function in
+# a shared library (PR shlib/1280, shlib/1237).
+
+if $tracelevel then {
+    strace $tracelevel
+}
+
+set testfile ppc-main
+set libfile ppc-shared
+set srcfile ${testfile}.c
+set binfile ${objdir}/${subdir}/${testfile}
+
+remote_exec build "rm -f ${binfile}"
+
+# get the value of gcc_compiled
+if [get_compiler_info ${binfile}] {
+    return -1
+}
+
+if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}.o" object {debug}] != "" } {
+    return -1
+}
+
+# Build the shared libraries this test case needs.
+#
+
+if {$gcc_compiled == 0} {
+    if [istarget "hppa*-hp-hpux*"] then {
+        set additional_flags "additional_flags=+z"
+    } elseif { [istarget "mips-sgi-irix*"] } {
+        # Disable SGI compiler's implicit -Dsgi
+        set additional_flags "additional_flags=-Usgi"
+    } else {
+        # don't know what the compiler is...
+        set additional_flags ""
+    }
+} else {
+    if { ([istarget "powerpc*-*-aix*"]
+    || [istarget "rs6000*-*-aix*"]) } {
+        set additional_flags ""
+    } else {
+        set additional_flags "additional_flags=-fpic"
+    }
+}
+
+set additional_flags "$additional_flags -shared"
+if {[gdb_compile "${srcdir}/${subdir}/${libfile}.c" "${objdir}/${subdir}/${libfile}.so" executable [list debug $additional_flags "incdir=${objdir}"]] != ""} {
+    return -1
+}
+
+if { ($gcc_compiled 
+&&  ([istarget "powerpc*-*-aix*"]
+|| [istarget "rs6000*-*-aix*"] )) } {
+    set additional_flags "additional_flags=-L${objdir}/${subdir}"
+} elseif { [istarget "mips-sgi-irix*"] } {
+    set additional_flags "additional_flags=-rpath ${objdir}/${subdir}"
+} else {
+    set additional_flags ""
+}
+
+if {[gdb_compile "${objdir}/${subdir}/${testfile}.o ${objdir}/${subdir}/${libfile}.so" "${binfile}" executable [list debug $additional_flags]] != ""} {
+    return -1
+}
+
+
+gdb_exit
+gdb_start
+gdb_reinitialize_dir $srcdir/$subdir
+gdb_load ${binfile}
+
+if ![runto_main] then {
+    fail "Can't run to main"
+    return 0
+}
+
+gdb_test s \
+    "hithere2 \\(\\) at.*${libfile}.c:3\r\n3.*return 21.*" \
+    "Step into shared lib function"
+

  parent reply	other threads:[~2004-01-30  4:53 UTC|newest]

Thread overview: 24+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2004-01-27 22:23 Andrew Cagney
2004-01-27 22:52 ` Daniel Jacobowitz
2004-01-29 20:15 ` Elena Zannoni
2004-01-29 23:22   ` Andrew Cagney
2004-01-30  3:30     ` Adam Fedor
2004-01-30  4:53     ` Adam Fedor [this message]
2004-02-04 22:25       ` Elena Zannoni
2004-02-09  4:26         ` Adam Fedor
2004-02-09 15:31           ` Elena Zannoni
2004-01-30  3:29   ` Adam Fedor
2004-02-04 22:20     ` Elena Zannoni
2004-02-04 23:06       ` Andrew Cagney
2004-02-06 18:59         ` Andrew Cagney
2004-02-08  5:17           ` Adam Fedor
2004-02-09 15:35           ` Elena Zannoni
2004-02-09 16:40             ` Andrew Cagney
2004-02-09 17:54               ` Joel Brobecker
2004-02-09 21:58 Michael Elizabeth Chastain
2004-02-10 16:38 ` Adam Fedor
2004-02-16 18:11 ` Elena Zannoni
2004-02-17  4:47   ` Adam Fedor
2004-02-17  5:00     ` Daniel Jacobowitz
2004-02-17 14:23     ` Elena Zannoni
2004-02-18  3:40       ` Adam Fedor

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1075438401.29218.20.camel@localhost.localdomain \
    --to=fedor@doc.com \
    --cc=cagney@gnu.org \
    --cc=ezannoni@redhat.com \
    --cc=gdb-patches@sources.redhat.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox