This commit is contained in:
parent
11cccbc678
commit
ca95d1dab0
@ -1,11 +0,0 @@
|
|||||||
gdb
|
|
||||||
+/usr/bin/gdb -> /usr/bin/gdb<extension>
|
|
||||||
# kill package for i586 32bit
|
|
||||||
targetarch x86_64 block!
|
|
||||||
prereq -glibc-x86
|
|
||||||
gdbserver
|
|
||||||
+/usr/bin/gdbserver -> /usr/bin/gdbserver<extension>
|
|
||||||
provides "gdb-<targettype>:/usr/bin/gdbserver<extension>"
|
|
||||||
# kill package for i586 32bit
|
|
||||||
targetarch x86_64 block!
|
|
||||||
prereq -glibc-x86
|
|
5626
cell-combined.diff
5626
cell-combined.diff
File diff suppressed because it is too large
Load Diff
@ -1,26 +0,0 @@
|
|||||||
Index: gdb/breakpoint.c
|
|
||||||
===================================================================
|
|
||||||
RCS file: /cvs/src/src/gdb/breakpoint.c,v
|
|
||||||
retrieving revision 1.325
|
|
||||||
diff -u -a -p -u -p -a -r1.325 gdb/breakpoint.c
|
|
||||||
--- gdb/breakpoint.c 10 Jun 2008 09:29:15 -0000 1.325
|
|
||||||
+++ gdb/breakpoint.c 22 Jun 2008 23:51:37 -0000
|
|
||||||
@@ -5211,18 +5211,6 @@ expand_line_sal_maybe (struct symtab_and
|
|
||||||
return expanded;
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (original_pc)
|
|
||||||
- {
|
|
||||||
- found = 0;
|
|
||||||
- for (i = 0; i < expanded.nelts; ++i)
|
|
||||||
- if (expanded.sals[i].pc == original_pc)
|
|
||||||
- {
|
|
||||||
- found = 1;
|
|
||||||
- break;
|
|
||||||
- }
|
|
||||||
- gdb_assert (found);
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
return expanded;
|
|
||||||
}
|
|
||||||
|
|
@ -1,12 +0,0 @@
|
|||||||
--- gdb/symtab.c.~1.157.~ 2007-04-16 17:39:04.000000000 +0200
|
|
||||||
+++ gdb/symtab.c 2007-04-18 14:10:52.000000000 +0200
|
|
||||||
@@ -2252,6 +2252,9 @@ find_pc_sect_line (CORE_ADDR pc, struct
|
|
||||||
best_end = item->pc;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ if (notcurrent)
|
|
||||||
+ pc++;
|
|
||||||
+
|
|
||||||
if (!best_symtab)
|
|
||||||
{
|
|
||||||
/* If we didn't find any line number info, just return zeros.
|
|
@ -1,85 +0,0 @@
|
|||||||
Index: gdb/symfile.c
|
|
||||||
===================================================================
|
|
||||||
RCS file: /cvs/src/src/gdb/symfile.c,v
|
|
||||||
retrieving revision 1.205
|
|
||||||
diff -u -a -p -u -p -a -r1.205 gdb/symfile.c
|
|
||||||
--- gdb/symfile.c 5 Jun 2008 19:21:55 -0000 1.205
|
|
||||||
+++ gdb/symfile.c 10 Jun 2008 09:56:34 -0000
|
|
||||||
@@ -1414,12 +1414,13 @@ find_separate_debug_file (struct objfile
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
dir = xstrdup (objfile->name);
|
|
||||||
+ canon_name = lrealpath (dir);
|
|
||||||
|
|
||||||
/* Strip off the final filename part, leaving the directory name,
|
|
||||||
followed by a slash. Objfile names should always be absolute and
|
|
||||||
tilde-expanded, so there should always be a slash in there
|
|
||||||
somewhere. */
|
|
||||||
- for (i = strlen(dir) - 1; i >= 0; i--)
|
|
||||||
+ for (i = strlen (dir) - 1; i >= 0; i--)
|
|
||||||
{
|
|
||||||
if (IS_DIR_SEPARATOR (dir[i]))
|
|
||||||
break;
|
|
||||||
@@ -1427,8 +1428,20 @@ find_separate_debug_file (struct objfile
|
|
||||||
gdb_assert (i >= 0 && IS_DIR_SEPARATOR (dir[i]));
|
|
||||||
dir[i+1] = '\0';
|
|
||||||
|
|
||||||
+ if (canon_name)
|
|
||||||
+ {
|
|
||||||
+ for (i = strlen (canon_name) - 1; i >= 0; i--)
|
|
||||||
+ {
|
|
||||||
+ if (IS_DIR_SEPARATOR (canon_name[i]))
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+ gdb_assert (i >= 0 && IS_DIR_SEPARATOR (canon_name[i]));
|
|
||||||
+ canon_name[i+1] = '\0';
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
debugfile = alloca (strlen (debug_file_directory) + 1
|
|
||||||
- + strlen (dir)
|
|
||||||
+ + (canon_name != NULL && strlen (canon_name) > strlen (dir)
|
|
||||||
+ ? strlen (canon_name) : strlen (dir))
|
|
||||||
+ strlen (DEBUG_SUBDIRECTORY)
|
|
||||||
+ strlen ("/")
|
|
||||||
+ strlen (basename)
|
|
||||||
@@ -1440,6 +1453,8 @@ find_separate_debug_file (struct objfile
|
|
||||||
|
|
||||||
if (separate_debug_file_exists (debugfile, crc32))
|
|
||||||
{
|
|
||||||
+ if (canon_name)
|
|
||||||
+ xfree (canon_name);
|
|
||||||
xfree (basename);
|
|
||||||
xfree (dir);
|
|
||||||
return xstrdup (debugfile);
|
|
||||||
@@ -1453,6 +1468,8 @@ find_separate_debug_file (struct objfile
|
|
||||||
|
|
||||||
if (separate_debug_file_exists (debugfile, crc32))
|
|
||||||
{
|
|
||||||
+ if (canon_name)
|
|
||||||
+ xfree (canon_name);
|
|
||||||
xfree (basename);
|
|
||||||
xfree (dir);
|
|
||||||
return xstrdup (debugfile);
|
|
||||||
@@ -1461,11 +1478,13 @@ find_separate_debug_file (struct objfile
|
|
||||||
/* Then try in the global debugfile directory. */
|
|
||||||
strcpy (debugfile, debug_file_directory);
|
|
||||||
strcat (debugfile, "/");
|
|
||||||
- strcat (debugfile, dir);
|
|
||||||
+ strcat (debugfile, canon_name ? canon_name : dir);
|
|
||||||
strcat (debugfile, basename);
|
|
||||||
|
|
||||||
if (separate_debug_file_exists (debugfile, crc32))
|
|
||||||
{
|
|
||||||
+ if (canon_name)
|
|
||||||
+ xfree (canon_name);
|
|
||||||
xfree (basename);
|
|
||||||
xfree (dir);
|
|
||||||
return xstrdup (debugfile);
|
|
||||||
@@ -1473,7 +1492,6 @@ find_separate_debug_file (struct objfile
|
|
||||||
|
|
||||||
/* If the file is in the sysroot, try using its base path in the
|
|
||||||
global debugfile directory. */
|
|
||||||
- canon_name = lrealpath (dir);
|
|
||||||
if (canon_name
|
|
||||||
&& strncmp (canon_name, gdb_sysroot, strlen (gdb_sysroot)) == 0
|
|
||||||
&& IS_DIR_SEPARATOR (canon_name[strlen (gdb_sysroot)]))
|
|
@ -1,19 +0,0 @@
|
|||||||
Index: gdb/i386-tdep.c
|
|
||||||
===================================================================
|
|
||||||
--- gdb/i386-tdep.c.orig
|
|
||||||
+++ gdb/i386-tdep.c
|
|
||||||
@@ -1023,11 +1023,13 @@ i386_frame_cache (struct frame_info *nex
|
|
||||||
/* This will be added back below. */
|
|
||||||
cache->saved_regs[I386_EIP_REGNUM] -= cache->base;
|
|
||||||
}
|
|
||||||
- else
|
|
||||||
+ else if (cache->pc)
|
|
||||||
{
|
|
||||||
get_frame_register (this_frame, I386_ESP_REGNUM, buf);
|
|
||||||
cache->base = extract_unsigned_integer (buf, 4) + cache->sp_offset;
|
|
||||||
}
|
|
||||||
+ else
|
|
||||||
+ cache->saved_regs[I386_EBP_REGNUM] = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Now that we have the base address for the stack frame we can
|
|
110
gdb-6.3-attach-see-vdso-test.patch
Normal file
110
gdb-6.3-attach-see-vdso-test.patch
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.base/attach-see-vdso.c 6 Jul 2007 14:14:44 -0000
|
||||||
|
@@ -0,0 +1,25 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2007 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. */
|
||||||
|
+
|
||||||
|
+#include <unistd.h>
|
||||||
|
+
|
||||||
|
+int main ()
|
||||||
|
+{
|
||||||
|
+ pause ();
|
||||||
|
+ return 1;
|
||||||
|
+}
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.base/attach-see-vdso.exp 6 Jul 2007 14:14:44 -0000
|
||||||
|
@@ -0,0 +1,79 @@
|
||||||
|
+# Copyright 2007
|
||||||
|
+
|
||||||
|
+# 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.
|
||||||
|
+
|
||||||
|
+# This file was created by Jan Kratochvil <jan.kratochvil@redhat.com>.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+# This test only works on Linux
|
||||||
|
+if { ![istarget "*-*-linux-gnu*"] } {
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "attach-see-vdso"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+set escapedbinfile [string_to_regexp ${objdir}/${subdir}/${testfile}]
|
||||||
|
+
|
||||||
|
+# The kernel VDSO is used for the syscalls returns only on i386 (not x86_64).
|
||||||
|
+#
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug additional_flags=-m32}] != "" } {
|
||||||
|
+ gdb_suppress_entire_file "Testcase nonthraded compile failed, so all tests in this file will automatically fail."
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if [get_compiler_info ${binfile}] {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Start the program running and then wait for a bit, to be sure
|
||||||
|
+# that it can be attached to.
|
||||||
|
+
|
||||||
|
+set testpid [eval exec $binfile &]
|
||||||
|
+
|
||||||
|
+# Avoid some race:
|
||||||
|
+sleep 2
|
||||||
|
+
|
||||||
|
+# Start with clean gdb
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+# Never call: gdb_load ${binfile}
|
||||||
|
+# as the former problem would not reproduce otherwise.
|
||||||
|
+
|
||||||
|
+set test "attach"
|
||||||
|
+gdb_test_multiple "attach $testpid" "$test" {
|
||||||
|
+ -re "Attaching to process $testpid\r?\n.*$gdb_prompt $" {
|
||||||
|
+ pass "$test"
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_test "bt" "#0 *0x\[0-9a-f\]* in \[^?\].*" "backtrace decodes VDSO"
|
||||||
|
+
|
||||||
|
+# Exit and detach the process.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+
|
||||||
|
+# Make sure we don't leave a process around to confuse
|
||||||
|
+# the next test run (and prevent the compile by keeping
|
||||||
|
+# the text file busy), in case the "set should_exit" didn't
|
||||||
|
+# work.
|
||||||
|
+
|
||||||
|
+remote_exec build "kill -9 ${testpid}"
|
88
gdb-6.3-bt-past-zero-20051201.patch
Normal file
88
gdb-6.3-bt-past-zero-20051201.patch
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
2005-12-01 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* frame.c (backtrace_past_zero_pc): New static variable.
|
||||||
|
(get_prev_frame): Don't return NULL for zero pc value if
|
||||||
|
backtrace past-zero-frame option is turned on.
|
||||||
|
(_initialize_frame): Initialize new command to allow backtracing
|
||||||
|
past a zero pc value (set backtrace past-zero-pc).
|
||||||
|
|
||||||
|
testsuite/gdb.base:
|
||||||
|
2005-12-01 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* setshow.exp: Add testing of "set backtrace past-zero-pc" option.
|
||||||
|
|
||||||
|
2007-10-15 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7.
|
||||||
|
|
||||||
|
Index: gdb-6.7/gdb/testsuite/gdb.base/setshow.exp
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.7.orig/gdb/testsuite/gdb.base/setshow.exp 2007-08-23 20:14:17.000000000 +0200
|
||||||
|
+++ gdb-6.7/gdb/testsuite/gdb.base/setshow.exp 2007-10-15 21:34:52.000000000 +0200
|
||||||
|
@@ -106,6 +106,16 @@ if { ![target_info exists use_gdb_stub]
|
||||||
|
delete_breakpoints
|
||||||
|
gdb_test "run" "Starting program:.*foo bar blup baz bubble.*" "passing args"
|
||||||
|
}
|
||||||
|
+#test show backtrace past-zero-pc
|
||||||
|
+gdb_test "show backtrace past-zero-pc" "Whether backtraces should continue past a zero pc value is off." "default show backtrace past-zero-pc (off)"
|
||||||
|
+#test set backtrace past-zero-pc on
|
||||||
|
+gdb_test "set backtrace past-zero-pc on" "" "set backtrace past-zero-pc on"
|
||||||
|
+#test show backtrace past-zero-pc
|
||||||
|
+gdb_test "show backtrace past-zero-pc" "Whether backtraces should continue past a zero pc value is on." "show backtrace past-zero-pc (on)"
|
||||||
|
+#test set backtrace past-zero-pc off
|
||||||
|
+gdb_test "set backtrace past-zero-pc off" "" "set backtrace past-zero-pc off"
|
||||||
|
+#test show backtrace past-zero-pc
|
||||||
|
+gdb_test "show backtrace past-zero-pc" "Whether backtraces should continue past a zero pc value is off." "show backtrace past-zero-pc (off)"
|
||||||
|
#test set check range on
|
||||||
|
gdb_test "set check range on" "" "set check range on"
|
||||||
|
#test show check range on
|
||||||
|
Index: gdb-6.7/gdb/frame.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.7.orig/gdb/frame.c 2007-10-12 22:35:58.000000000 +0200
|
||||||
|
+++ gdb-6.7/gdb/frame.c 2007-10-15 21:34:52.000000000 +0200
|
||||||
|
@@ -133,6 +133,16 @@ Whether backtraces should continue past
|
||||||
|
value);
|
||||||
|
}
|
||||||
|
|
||||||
|
+static int backtrace_past_zero_pc;
|
||||||
|
+static void
|
||||||
|
+show_backtrace_past_zero_pc (struct ui_file *file, int from_tty,
|
||||||
|
+ struct cmd_list_element *c, const char *value)
|
||||||
|
+{
|
||||||
|
+ fprintf_filtered (file, _("\
|
||||||
|
+Whether backtraces should continue past a zero pc value is %s.\n"),
|
||||||
|
+ value);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
static int backtrace_past_entry;
|
||||||
|
static void
|
||||||
|
show_backtrace_past_entry (struct ui_file *file, int from_tty,
|
||||||
|
@@ -1483,9 +1493,7 @@ get_prev_frame (struct frame_info *this_
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this_frame->level > 0
|
||||||
|
-#if 0
|
||||||
|
- && backtrace_past_zero_pc
|
||||||
|
-#endif
|
||||||
|
+ && !backtrace_past_zero_pc
|
||||||
|
&& get_frame_type (this_frame) == NORMAL_FRAME
|
||||||
|
&& get_frame_type (get_next_frame (this_frame)) == NORMAL_FRAME
|
||||||
|
&& get_frame_pc (this_frame) == 0)
|
||||||
|
@@ -1850,6 +1858,17 @@ the rest of the stack trace."),
|
||||||
|
&set_backtrace_cmdlist,
|
||||||
|
&show_backtrace_cmdlist);
|
||||||
|
|
||||||
|
+ add_setshow_boolean_cmd ("past-zero-pc", class_obscure,
|
||||||
|
+ &backtrace_past_zero_pc, _("\
|
||||||
|
+Set whether backtraces should continue past a zero pc value."), _("\
|
||||||
|
+Show whether backtraces should continue past a zero pc value."), _("\
|
||||||
|
+Normally GDB stops backtracing when it finds a zero pc.\n\
|
||||||
|
+Set this variable if you need to see the rest of the stack trace."),
|
||||||
|
+ NULL,
|
||||||
|
+ show_backtrace_past_zero_pc,
|
||||||
|
+ &set_backtrace_cmdlist,
|
||||||
|
+ &show_backtrace_cmdlist);
|
||||||
|
+
|
||||||
|
add_setshow_integer_cmd ("limit", class_obscure,
|
||||||
|
&backtrace_limit, _("\
|
||||||
|
Set an upper bound on the number of backtrace levels."), _("\
|
317
gdb-6.3-bz140532-ppc-unwinding-test.patch
Normal file
317
gdb-6.3-bz140532-ppc-unwinding-test.patch
Normal file
@ -0,0 +1,317 @@
|
|||||||
|
diff -u -ruNp gdb-6.3-unpatched/gdb/testsuite/gdb.arch/powerpc-bcl-prologue-asm32.S gdb-6.3/gdb/testsuite/gdb.arch/powerpc-bcl-prologue-asm32.S
|
||||||
|
--- gdb-6.3-unpatched/gdb/testsuite/gdb.arch/powerpc-bcl-prologue-asm32.S 1969-12-31 19:00:00.000000000 -0500
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.arch/powerpc-bcl-prologue-asm32.S 2007-08-02 13:23:10.000000000 -0400
|
||||||
|
@@ -0,0 +1,78 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2007 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. */
|
||||||
|
+
|
||||||
|
+ .section ".text"
|
||||||
|
+ .align 2
|
||||||
|
+ .globl func0
|
||||||
|
+ .type func0, @function
|
||||||
|
+func0:
|
||||||
|
+ stwu 1,-16(1)
|
||||||
|
+ mflr 0
|
||||||
|
+ stw 31,12(1)
|
||||||
|
+ stw 0,20(1)
|
||||||
|
+ mr 31,1
|
||||||
|
+ bl abort
|
||||||
|
+ .size func0, .-func0
|
||||||
|
+ .align 2
|
||||||
|
+ .globl func1
|
||||||
|
+ .type func1, @function
|
||||||
|
+func1:
|
||||||
|
+ stwu 1,-16(1)
|
||||||
|
+ mflr 0
|
||||||
|
+/* 20 = BO = branch always
|
||||||
|
+ 31 = BI = CR bit (ignored) */
|
||||||
|
+ bcl 20,31,.Lpie
|
||||||
|
+.Lpie: stw 31,12(1)
|
||||||
|
+ stw 0,20(1)
|
||||||
|
+ mr 31,1
|
||||||
|
+ bl func0
|
||||||
|
+ mr 0,3
|
||||||
|
+ lis 9,var@ha
|
||||||
|
+ lwz 9,var@l(9)
|
||||||
|
+ add 0,0,9
|
||||||
|
+ mr 3,0
|
||||||
|
+ lwz 11,0(1)
|
||||||
|
+ lwz 0,4(11)
|
||||||
|
+ mtlr 0
|
||||||
|
+ lwz 31,-4(11)
|
||||||
|
+ mr 1,11
|
||||||
|
+ blr
|
||||||
|
+ .size func1, .-func1
|
||||||
|
+ .section .note.GNU-stack,"",@progbits
|
||||||
|
+ .ident "GCC: (GNU) 3.4.6 20060404 (Red Hat 3.4.6-8)"
|
||||||
|
+
|
||||||
|
+/* Original source file:
|
||||||
|
+
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+
|
||||||
|
+extern volatile int var;
|
||||||
|
+
|
||||||
|
+int func0 (void) __attribute__((__noinline__));
|
||||||
|
+int func0 (void)
|
||||||
|
+{
|
||||||
|
+ abort ();
|
||||||
|
+ return var;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int func1 (void) __attribute__((__noinline__));
|
||||||
|
+int func1 (void)
|
||||||
|
+{
|
||||||
|
+ return func0 () + var;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+*/
|
||||||
|
diff -u -ruNp gdb-6.3-unpatched/gdb/testsuite/gdb.arch/powerpc-bcl-prologue-asm64.S gdb-6.3/gdb/testsuite/gdb.arch/powerpc-bcl-prologue-asm64.S
|
||||||
|
--- gdb-6.3-unpatched/gdb/testsuite/gdb.arch/powerpc-bcl-prologue-asm64.S 1969-12-31 19:00:00.000000000 -0500
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.arch/powerpc-bcl-prologue-asm64.S 2007-08-02 14:28:56.000000000 -0400
|
||||||
|
@@ -0,0 +1,98 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2007 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. */
|
||||||
|
+
|
||||||
|
+ .section ".toc","aw"
|
||||||
|
+ .section ".text"
|
||||||
|
+ .align 2
|
||||||
|
+ .globl func0
|
||||||
|
+ .section ".opd","aw"
|
||||||
|
+ .align 3
|
||||||
|
+func0:
|
||||||
|
+ .quad .L.func0,.TOC.@tocbase
|
||||||
|
+ .previous
|
||||||
|
+ .type func0, @function
|
||||||
|
+.L.func0:
|
||||||
|
+ mflr 0
|
||||||
|
+ std 31,-8(1)
|
||||||
|
+ std 0,16(1)
|
||||||
|
+ stdu 1,-128(1)
|
||||||
|
+ mr 31,1
|
||||||
|
+ bl abort
|
||||||
|
+ nop
|
||||||
|
+ .long 0
|
||||||
|
+ .byte 0,0,0,1,128,1,0,1
|
||||||
|
+ .size func0,.-.L.func0
|
||||||
|
+ .section ".toc","aw"
|
||||||
|
+.LC1:
|
||||||
|
+ .tc var[TC],var
|
||||||
|
+ .section ".text"
|
||||||
|
+ .align 2
|
||||||
|
+ .globl func1
|
||||||
|
+ .section ".opd","aw"
|
||||||
|
+ .align 3
|
||||||
|
+func1:
|
||||||
|
+ .quad .L.func1,.TOC.@tocbase
|
||||||
|
+ .previous
|
||||||
|
+ .type func1, @function
|
||||||
|
+.L.func1:
|
||||||
|
+ mflr 0
|
||||||
|
+/* 20 = BO = branch always
|
||||||
|
+ 31 = BI = CR bit (ignored) */
|
||||||
|
+ bcl 20,31,.Lpie
|
||||||
|
+.Lpie: std 31,-8(1)
|
||||||
|
+ std 0,16(1)
|
||||||
|
+ stdu 1,-128(1)
|
||||||
|
+ mr 31,1
|
||||||
|
+ bl func0
|
||||||
|
+ mr 11,3
|
||||||
|
+ ld 9,.LC1@toc(2)
|
||||||
|
+ lwz 0,0(9)
|
||||||
|
+ add 0,11,0
|
||||||
|
+ extsw 0,0
|
||||||
|
+ mr 3,0
|
||||||
|
+ ld 1,0(1)
|
||||||
|
+ ld 0,16(1)
|
||||||
|
+ mtlr 0
|
||||||
|
+ ld 31,-8(1)
|
||||||
|
+ blr
|
||||||
|
+ .long 0
|
||||||
|
+ .byte 0,0,0,1,128,1,0,1
|
||||||
|
+ .size func1,.-.L.func1
|
||||||
|
+ .section .note.GNU-stack,"",@progbits
|
||||||
|
+ .ident "GCC: (GNU) 3.4.6 20060404 (Red Hat 3.4.6-8)"
|
||||||
|
+
|
||||||
|
+/* Original source file:
|
||||||
|
+
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+
|
||||||
|
+extern volatile int var;
|
||||||
|
+
|
||||||
|
+int func0 (void) __attribute__((__noinline__));
|
||||||
|
+int func0 (void)
|
||||||
|
+{
|
||||||
|
+ abort ();
|
||||||
|
+ return var;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int func1 (void) __attribute__((__noinline__));
|
||||||
|
+int func1 (void)
|
||||||
|
+{
|
||||||
|
+ return func0 () + var;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+*/
|
||||||
|
diff -u -ruNp gdb-6.3-unpatched/gdb/testsuite/gdb.arch/powerpc-bcl-prologue.c gdb-6.3/gdb/testsuite/gdb.arch/powerpc-bcl-prologue.c
|
||||||
|
--- gdb-6.3-unpatched/gdb/testsuite/gdb.arch/powerpc-bcl-prologue.c 1969-12-31 19:00:00.000000000 -0500
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.arch/powerpc-bcl-prologue.c 2007-08-02 13:25:10.000000000 -0400
|
||||||
|
@@ -0,0 +1,29 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2007 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. */
|
||||||
|
+
|
||||||
|
+/* Force `-fpie' double jump bl->blrl. */
|
||||||
|
+/* No longer used. */
|
||||||
|
+volatile int var;
|
||||||
|
+
|
||||||
|
+extern int func1 (void);
|
||||||
|
+
|
||||||
|
+int main (void)
|
||||||
|
+{
|
||||||
|
+ func1 ();
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
diff -u -ruNp gdb-6.3-unpatched/gdb/testsuite/gdb.arch/powerpc-bcl-prologue.exp gdb-6.3/gdb/testsuite/gdb.arch/powerpc-bcl-prologue.exp
|
||||||
|
--- gdb-6.3-unpatched/gdb/testsuite/gdb.arch/powerpc-bcl-prologue.exp 1969-12-31 19:00:00.000000000 -0500
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.arch/powerpc-bcl-prologue.exp 2007-08-02 14:21:29.000000000 -0400
|
||||||
|
@@ -0,0 +1,79 @@
|
||||||
|
+# Copyright 2006, 2007 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.
|
||||||
|
+
|
||||||
|
+# Test unwinding fixes of the PPC platform, specifically on the coping with BCL
|
||||||
|
+# jump of the PIE code.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+if ![istarget "powerpc*-*-linux*"] then {
|
||||||
|
+ verbose "Skipping powerpc-linux prologue tests."
|
||||||
|
+ return
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "powerpc-bcl-prologue"
|
||||||
|
+set srcfile1 ${testfile}.c
|
||||||
|
+set flags "debug"
|
||||||
|
+if [istarget "powerpc-*"] then {
|
||||||
|
+ set srcfile2 ${testfile}-asm32.S
|
||||||
|
+ set flags "$flags additional_flags=-m32"
|
||||||
|
+} elseif [istarget "powerpc64-*"] then {
|
||||||
|
+ set srcfile2 ${testfile}-asm64.S
|
||||||
|
+ set flags "$flags additional_flags=-m64"
|
||||||
|
+} else {
|
||||||
|
+ fail "powerpc arch test"
|
||||||
|
+ return
|
||||||
|
+}
|
||||||
|
+set objfile2 ${objdir}/${subdir}/${testfile}-asm.o
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile1} ${srcdir}/${subdir}/${srcfile2}" ${binfile} executable $flags] != ""} {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+# We should stop in abort(3).
|
||||||
|
+
|
||||||
|
+gdb_run_cmd
|
||||||
|
+
|
||||||
|
+gdb_test_multiple {} "continue to abort()" {
|
||||||
|
+ -re ".*Program received signal SIGABRT,.*$gdb_prompt $" {
|
||||||
|
+ pass "continue to abort()"
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Check backtrace:
|
||||||
|
+# #3 0x0804835f in func0 ()
|
||||||
|
+# #4 0x0804836a in func1 ()
|
||||||
|
+# #5 0x0804838c in main ()
|
||||||
|
+# (gdb)
|
||||||
|
+# `\\.?' prefixes are needed for ppc64 without `debug' (another bug).
|
||||||
|
+
|
||||||
|
+set test "matching unwind"
|
||||||
|
+gdb_test_multiple "backtrace" $test {
|
||||||
|
+ -re "\r\n#\[0-9\]\[^\r\n\]* in \\.?func0 \\(\[^\r\n\]*\r\n#\[0-9\]\[^\r\n\]* in \\.?func1 \\(\[^\r\n\]*\r\n#\[0-9\]\[^\r\n\]* in \\.?main \\(\[^\r\n\]*\r\n$gdb_prompt $" {
|
||||||
|
+ pass $test
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
|
||||||
|
Fixup the testcase for ppc64 biarch GDB.
|
||||||
|
|
||||||
|
--- ./gdb/testsuite/gdb.arch/powerpc-prologue.exp 2008-01-13 13:32:19.000000000 +0100
|
||||||
|
+++ ./gdb/testsuite/gdb.arch/powerpc-prologue.exp 2008-01-02 00:04:10.000000000 +0100
|
||||||
|
@@ -17,8 +17,9 @@
|
||||||
|
# Test PowerPC prologue analyzer.
|
||||||
|
|
||||||
|
# Do not run on AIX (where we won't be able to build the tests without
|
||||||
|
-# some surgery) or on PowerPC64 (ditto, dot symbols).
|
||||||
|
-if {[istarget *-*-aix*] || ![istarget "powerpc-*-*"]} then {
|
||||||
|
+# some surgery). PowerPC64 target would break due to dot symbols but we build
|
||||||
|
+# there PowerPC32 inferior.
|
||||||
|
+if {[istarget *-*-aix*] || ![istarget "powerpc*-*-*"]} then {
|
||||||
|
verbose "Skipping PowerPC prologue tests."
|
||||||
|
return
|
||||||
|
}
|
98
gdb-6.3-bz202689-exec-from-pthread-test.patch
Normal file
98
gdb-6.3-bz202689-exec-from-pthread-test.patch
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
2007-01-17 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.threads/threaded-exec.exp, gdb.threads/threaded-exec.c: New files.
|
||||||
|
|
||||||
|
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.threads/threaded-exec.c 17 Jan 2007 23:10:22 -0000
|
||||||
|
@@ -0,0 +1,46 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2007 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. */
|
||||||
|
+
|
||||||
|
+#include <stddef.h>
|
||||||
|
+#include <pthread.h>
|
||||||
|
+#include <assert.h>
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+static void *
|
||||||
|
+threader (void *arg)
|
||||||
|
+{
|
||||||
|
+ return NULL;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int
|
||||||
|
+main (void)
|
||||||
|
+{
|
||||||
|
+ pthread_t t1;
|
||||||
|
+ int i;
|
||||||
|
+
|
||||||
|
+ i = pthread_create (&t1, NULL, threader, (void *) NULL);
|
||||||
|
+ assert (i == 0);
|
||||||
|
+ i = pthread_join (t1, NULL);
|
||||||
|
+ assert (i == 0);
|
||||||
|
+
|
||||||
|
+ execl ("/bin/true", "/bin/true", NULL);
|
||||||
|
+ abort ();
|
||||||
|
+}
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.threads/threaded-exec.exp 17 Jan 2007 23:10:22 -0000
|
||||||
|
@@ -0,0 +1,41 @@
|
||||||
|
+# threaded-exec.exp -- Check reset of the tracked threads on exec*(2)
|
||||||
|
+# Copyright (C) 2007 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
|
||||||
|
+
|
||||||
|
+set testfile threaded-exec
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+if {[gdb_compile_pthreads "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable []] != "" } {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+gdb_run_cmd
|
||||||
|
+
|
||||||
|
+gdb_test_multiple {} "Program exited" {
|
||||||
|
+ -re "\r\nProgram exited normally.\r\n$gdb_prompt $" {
|
||||||
|
+ pass "Program exited"
|
||||||
|
+ }
|
||||||
|
+}
|
201
gdb-6.3-bz231832-obstack-2gb.patch
Normal file
201
gdb-6.3-bz231832-obstack-2gb.patch
Normal file
@ -0,0 +1,201 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=231832
|
||||||
|
|
||||||
|
|
||||||
|
Index: gdb-6.8/gdb/symmisc.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.orig/gdb/symmisc.c 2008-03-17 16:06:24.000000000 +0100
|
||||||
|
+++ gdb-6.8/gdb/symmisc.c 2008-07-14 10:27:50.000000000 +0200
|
||||||
|
@@ -230,8 +230,8 @@ print_objfile_statistics (void)
|
||||||
|
if (OBJSTAT (objfile, sz_strtab) > 0)
|
||||||
|
printf_filtered (_(" Space used by a.out string tables: %d\n"),
|
||||||
|
OBJSTAT (objfile, sz_strtab));
|
||||||
|
- printf_filtered (_(" Total memory used for objfile obstack: %d\n"),
|
||||||
|
- obstack_memory_used (&objfile->objfile_obstack));
|
||||||
|
+ printf_filtered (_(" Total memory used for objfile obstack: %ld\n"),
|
||||||
|
+ (long) obstack_memory_used (&objfile->objfile_obstack));
|
||||||
|
printf_filtered (_(" Total memory used for psymbol cache: %d\n"),
|
||||||
|
bcache_memory_used (objfile->psymbol_cache));
|
||||||
|
printf_filtered (_(" Total memory used for macro cache: %d\n"),
|
||||||
|
Index: gdb-6.8/include/obstack.h
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.orig/include/obstack.h 2005-05-10 12:21:08.000000000 +0200
|
||||||
|
+++ gdb-6.8/include/obstack.h 2008-07-14 10:27:50.000000000 +0200
|
||||||
|
@@ -188,31 +188,31 @@ struct obstack /* control current objec
|
||||||
|
|
||||||
|
/* Declare the external functions we use; they are in obstack.c. */
|
||||||
|
|
||||||
|
-extern void _obstack_newchunk (struct obstack *, int);
|
||||||
|
+extern void _obstack_newchunk (struct obstack *, PTR_INT_TYPE);
|
||||||
|
extern void _obstack_free (struct obstack *, void *);
|
||||||
|
-extern int _obstack_begin (struct obstack *, int, int,
|
||||||
|
+extern int _obstack_begin (struct obstack *, PTR_INT_TYPE, int,
|
||||||
|
void *(*) (long), void (*) (void *));
|
||||||
|
-extern int _obstack_begin_1 (struct obstack *, int, int,
|
||||||
|
+extern int _obstack_begin_1 (struct obstack *, PTR_INT_TYPE, int,
|
||||||
|
void *(*) (void *, long),
|
||||||
|
void (*) (void *, void *), void *);
|
||||||
|
-extern int _obstack_memory_used (struct obstack *);
|
||||||
|
+extern PTR_INT_TYPE _obstack_memory_used (struct obstack *);
|
||||||
|
|
||||||
|
/* Do the function-declarations after the structs
|
||||||
|
but before defining the macros. */
|
||||||
|
|
||||||
|
void obstack_init (struct obstack *obstack);
|
||||||
|
|
||||||
|
-void * obstack_alloc (struct obstack *obstack, int size);
|
||||||
|
+void * obstack_alloc (struct obstack *obstack, PTR_INT_TYPE size);
|
||||||
|
|
||||||
|
-void * obstack_copy (struct obstack *obstack, void *address, int size);
|
||||||
|
-void * obstack_copy0 (struct obstack *obstack, void *address, int size);
|
||||||
|
+void * obstack_copy (struct obstack *obstack, void *address, PTR_INT_TYPE size);
|
||||||
|
+void * obstack_copy0 (struct obstack *obstack, void *address, PTR_INT_TYPE size);
|
||||||
|
|
||||||
|
void obstack_free (struct obstack *obstack, void *block);
|
||||||
|
|
||||||
|
-void obstack_blank (struct obstack *obstack, int size);
|
||||||
|
+void obstack_blank (struct obstack *obstack, PTR_INT_TYPE size);
|
||||||
|
|
||||||
|
-void obstack_grow (struct obstack *obstack, void *data, int size);
|
||||||
|
-void obstack_grow0 (struct obstack *obstack, void *data, int size);
|
||||||
|
+void obstack_grow (struct obstack *obstack, void *data, PTR_INT_TYPE size);
|
||||||
|
+void obstack_grow0 (struct obstack *obstack, void *data, PTR_INT_TYPE size);
|
||||||
|
|
||||||
|
void obstack_1grow (struct obstack *obstack, int data_char);
|
||||||
|
void obstack_ptr_grow (struct obstack *obstack, void *data);
|
||||||
|
@@ -220,20 +220,20 @@ void obstack_int_grow (struct obstack *o
|
||||||
|
|
||||||
|
void * obstack_finish (struct obstack *obstack);
|
||||||
|
|
||||||
|
-int obstack_object_size (struct obstack *obstack);
|
||||||
|
+PTR_INT_TYPE obstack_object_size (struct obstack *obstack);
|
||||||
|
|
||||||
|
-int obstack_room (struct obstack *obstack);
|
||||||
|
-void obstack_make_room (struct obstack *obstack, int size);
|
||||||
|
+PTR_INT_TYPE obstack_room (struct obstack *obstack);
|
||||||
|
+void obstack_make_room (struct obstack *obstack, PTR_INT_TYPE size);
|
||||||
|
void obstack_1grow_fast (struct obstack *obstack, int data_char);
|
||||||
|
void obstack_ptr_grow_fast (struct obstack *obstack, void *data);
|
||||||
|
void obstack_int_grow_fast (struct obstack *obstack, int data);
|
||||||
|
-void obstack_blank_fast (struct obstack *obstack, int size);
|
||||||
|
+void obstack_blank_fast (struct obstack *obstack, PTR_INT_TYPE size);
|
||||||
|
|
||||||
|
void * obstack_base (struct obstack *obstack);
|
||||||
|
void * obstack_next_free (struct obstack *obstack);
|
||||||
|
int obstack_alignment_mask (struct obstack *obstack);
|
||||||
|
-int obstack_chunk_size (struct obstack *obstack);
|
||||||
|
-int obstack_memory_used (struct obstack *obstack);
|
||||||
|
+size_t obstack_chunk_size (struct obstack *obstack);
|
||||||
|
+size_t obstack_memory_used (struct obstack *obstack);
|
||||||
|
|
||||||
|
/* Error handler called when `obstack_chunk_alloc' failed to allocate
|
||||||
|
more memory. This can be set to a user defined function. The
|
||||||
|
@@ -318,7 +318,7 @@ extern int obstack_exit_failure;
|
||||||
|
# define obstack_make_room(OBSTACK,length) \
|
||||||
|
__extension__ \
|
||||||
|
({ struct obstack *__o = (OBSTACK); \
|
||||||
|
- int __len = (length); \
|
||||||
|
+ PTR_INT_TYPE __len = (length); \
|
||||||
|
if (__o->chunk_limit - __o->next_free < __len) \
|
||||||
|
_obstack_newchunk (__o, __len); \
|
||||||
|
(void) 0; })
|
||||||
|
@@ -331,7 +331,7 @@ __extension__ \
|
||||||
|
# define obstack_grow(OBSTACK,where,length) \
|
||||||
|
__extension__ \
|
||||||
|
({ struct obstack *__o = (OBSTACK); \
|
||||||
|
- int __len = (length); \
|
||||||
|
+ PTR_INT_TYPE __len = (length); \
|
||||||
|
if (__o->next_free + __len > __o->chunk_limit) \
|
||||||
|
_obstack_newchunk (__o, __len); \
|
||||||
|
_obstack_memcpy (__o->next_free, (where), __len); \
|
||||||
|
@@ -341,7 +341,7 @@ __extension__ \
|
||||||
|
# define obstack_grow0(OBSTACK,where,length) \
|
||||||
|
__extension__ \
|
||||||
|
({ struct obstack *__o = (OBSTACK); \
|
||||||
|
- int __len = (length); \
|
||||||
|
+ PTR_INT_TYPE __len = (length); \
|
||||||
|
if (__o->next_free + __len + 1 > __o->chunk_limit) \
|
||||||
|
_obstack_newchunk (__o, __len + 1); \
|
||||||
|
_obstack_memcpy (__o->next_free, (where), __len); \
|
||||||
|
@@ -392,7 +392,7 @@ __extension__ \
|
||||||
|
# define obstack_blank(OBSTACK,length) \
|
||||||
|
__extension__ \
|
||||||
|
({ struct obstack *__o = (OBSTACK); \
|
||||||
|
- int __len = (length); \
|
||||||
|
+ PTR_INT_TYPE __len = (length); \
|
||||||
|
if (__o->chunk_limit - __o->next_free < __len) \
|
||||||
|
_obstack_newchunk (__o, __len); \
|
||||||
|
obstack_blank_fast (__o, __len); \
|
||||||
|
@@ -532,7 +532,7 @@ __extension__ \
|
||||||
|
# define obstack_free(h,obj) \
|
||||||
|
( (h)->temp = (char *) (obj) - (char *) (h)->chunk, \
|
||||||
|
(((h)->temp > 0 && (h)->temp < (h)->chunk_limit - (char *) (h)->chunk)\
|
||||||
|
- ? (int) ((h)->next_free = (h)->object_base \
|
||||||
|
+ ? (PTR_INT_TYPE) ((h)->next_free = (h)->object_base \
|
||||||
|
= (h)->temp + (char *) (h)->chunk) \
|
||||||
|
: (((obstack_free) ((h), (h)->temp + (char *) (h)->chunk), 0), 0)))
|
||||||
|
|
||||||
|
Index: gdb-6.8/libiberty/obstack.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.orig/libiberty/obstack.c 2005-05-10 17:33:33.000000000 +0200
|
||||||
|
+++ gdb-6.8/libiberty/obstack.c 2008-07-14 10:27:50.000000000 +0200
|
||||||
|
@@ -44,9 +44,11 @@
|
||||||
|
#if !defined (_LIBC) && defined (__GNU_LIBRARY__) && __GNU_LIBRARY__ > 1
|
||||||
|
#include <gnu-versions.h>
|
||||||
|
#if _GNU_OBSTACK_INTERFACE_VERSION == OBSTACK_INTERFACE_VERSION
|
||||||
|
+#if 0 /* 64-bit obstack is not compatible with any glibc implementation. */
|
||||||
|
#define ELIDE_CODE
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
+#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef ELIDE_CODE
|
||||||
|
@@ -139,7 +141,7 @@ struct obstack *_obstack;
|
||||||
|
free up some memory, then call this again. */
|
||||||
|
|
||||||
|
int
|
||||||
|
-_obstack_begin (struct obstack *h, int size, int alignment,
|
||||||
|
+_obstack_begin (struct obstack *h, PTR_INT_TYPE size, int alignment,
|
||||||
|
POINTER (*chunkfun) (long), void (*freefun) (void *))
|
||||||
|
{
|
||||||
|
register struct _obstack_chunk *chunk; /* points to new chunk */
|
||||||
|
@@ -183,7 +185,7 @@ _obstack_begin (struct obstack *h, int s
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
-_obstack_begin_1 (struct obstack *h, int size, int alignment,
|
||||||
|
+_obstack_begin_1 (struct obstack *h, PTR_INT_TYPE size, int alignment,
|
||||||
|
POINTER (*chunkfun) (POINTER, long),
|
||||||
|
void (*freefun) (POINTER, POINTER), POINTER arg)
|
||||||
|
{
|
||||||
|
@@ -235,7 +237,7 @@ _obstack_begin_1 (struct obstack *h, int
|
||||||
|
to the beginning of the new one. */
|
||||||
|
|
||||||
|
void
|
||||||
|
-_obstack_newchunk (struct obstack *h, int length)
|
||||||
|
+_obstack_newchunk (struct obstack *h, PTR_INT_TYPE length)
|
||||||
|
{
|
||||||
|
register struct _obstack_chunk *old_chunk = h->chunk;
|
||||||
|
register struct _obstack_chunk *new_chunk;
|
||||||
|
@@ -388,11 +390,11 @@ obstack_free (struct obstack *h, POINTER
|
||||||
|
abort ();
|
||||||
|
}
|
||||||
|
|
||||||
|
-int
|
||||||
|
+PTR_INT_TYPE
|
||||||
|
_obstack_memory_used (struct obstack *h)
|
||||||
|
{
|
||||||
|
register struct _obstack_chunk* lp;
|
||||||
|
- register int nbytes = 0;
|
||||||
|
+ register PTR_INT_TYPE nbytes = 0;
|
||||||
|
|
||||||
|
for (lp = h->chunk; lp != 0; lp = lp->prev)
|
||||||
|
{
|
||||||
|
@@ -421,6 +423,7 @@ print_and_abort (void)
|
||||||
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
+/* These functions are now broken for 64-bit obstack! */
|
||||||
|
/* These are now turned off because the applications do not use it
|
||||||
|
and it uses bcopy via obstack_grow, which causes trouble on sysV. */
|
||||||
|
|
52
gdb-6.3-dtorfix-20050121.patch
Normal file
52
gdb-6.3-dtorfix-20050121.patch
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
2005-01-21 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* linespec.c (collect_methods): Don't do special processing for
|
||||||
|
destructors as this will be handled in find_methods.
|
||||||
|
(find_methods): Fix ctor check to also check for dtor.
|
||||||
|
|
||||||
|
2007-10-14 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7.
|
||||||
|
|
||||||
|
Index: gdb-6.7/gdb/linespec.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.7.orig/gdb/linespec.c 2007-10-13 05:26:33.000000000 +0200
|
||||||
|
+++ gdb-6.7/gdb/linespec.c 2007-10-14 23:31:03.000000000 +0200
|
||||||
|
@@ -398,12 +398,14 @@ add_matching_methods (int method_counter
|
||||||
|
|
||||||
|
/* Check for special case of looking for member that
|
||||||
|
doesn't have a mangled name provided. This will happen
|
||||||
|
- when we have in-charge and not-in-charge constructors.
|
||||||
|
+ when we have in-charge and not-in-charge ctors/dtors.
|
||||||
|
Since we don't have a mangled name to work with, if we
|
||||||
|
- look for the symbol, we can only find the class itself.
|
||||||
|
+ look for the symbol, we can at best find the class itself.
|
||||||
|
We can find the information we need in the minimal symbol
|
||||||
|
table which has the full member name information we need. */
|
||||||
|
- if (strlen (phys_name) <= strlen (class_name))
|
||||||
|
+ if (strlen (phys_name) <= strlen (class_name)
|
||||||
|
+ || (strlen (phys_name) == strlen (class_name) + 1
|
||||||
|
+ && phys_name[0] == '~'))
|
||||||
|
return add_minsym_members (class_name, phys_name, msym_arr);
|
||||||
|
|
||||||
|
/* Destructor is handled by caller, don't add it to
|
||||||
|
@@ -1731,6 +1733,11 @@ collect_methods (char *copy, struct type
|
||||||
|
{
|
||||||
|
int i1 = 0; /* Counter for the symbol array. */
|
||||||
|
|
||||||
|
+#if 0
|
||||||
|
+ /* Ignore this special method for getting destructors because
|
||||||
|
+ find_methods is more robust and can handle multiple
|
||||||
|
+ destructors which is the case when gcc generates a not-in-charge
|
||||||
|
+ vs an in-charge destructor. */
|
||||||
|
if (destructor_name_p (copy, t))
|
||||||
|
{
|
||||||
|
/* Destructors are a special case. */
|
||||||
|
@@ -1749,6 +1756,7 @@ collect_methods (char *copy, struct type
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
+#endif
|
||||||
|
i1 = find_methods (t, copy, SYMBOL_LANGUAGE (sym_class), sym_arr, msym_arr);
|
||||||
|
|
||||||
|
return i1;
|
28
gdb-6.3-focus-cmd-prev-test.patch
Normal file
28
gdb-6.3-focus-cmd-prev-test.patch
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
--- /dev/null 2008-03-23 13:41:46.072650180 +0100
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.base/focus-cmd-prev.exp 2008-03-23 23:46:45.000000000 +0100
|
||||||
|
@@ -0,0 +1,25 @@
|
||||||
|
+# Copyright 2008 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.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+
|
||||||
|
+gdb_test "focus cmd"
|
||||||
|
+gdb_test "focus prev"
|
28
gdb-6.3-framepczero-20040927.patch
Normal file
28
gdb-6.3-framepczero-20040927.patch
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
2004-09-27 Andrew Cagney <cagney@gnu.org>
|
||||||
|
|
||||||
|
* frame.c (get_prev_frame): Stop backtrace when a zero PC and
|
||||||
|
successive normal frames.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/frame.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/frame.c 2008-12-04 01:34:37.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/frame.c 2008-12-04 01:35:47.000000000 +0100
|
||||||
|
@@ -1566,6 +1566,18 @@ get_prev_frame (struct frame_info *this_
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ if (this_frame->level > 0
|
||||||
|
+#if 0
|
||||||
|
+ && backtrace_past_zero_pc
|
||||||
|
+#endif
|
||||||
|
+ && get_frame_type (this_frame) == NORMAL_FRAME
|
||||||
|
+ && get_frame_type (get_next_frame (this_frame)) == NORMAL_FRAME
|
||||||
|
+ && get_frame_pc (this_frame) == 0)
|
||||||
|
+ {
|
||||||
|
+ frame_debug_got_null_frame (this_frame, "zero PC");
|
||||||
|
+ return NULL;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
return get_prev_frame_1 (this_frame);
|
||||||
|
}
|
||||||
|
|
25
gdb-6.3-gcore-thread-20050204.patch
Normal file
25
gdb-6.3-gcore-thread-20050204.patch
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
2005-02-07 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* linux-nat.c (linux_nat_xfer_memory): Don't use
|
||||||
|
linux_proc_xfer_memory for ia64.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081209/gdb/linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081209.orig/gdb/linux-nat.c 2008-12-10 01:22:23.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081209/gdb/linux-nat.c 2008-12-10 01:25:26.000000000 +0100
|
||||||
|
@@ -4123,10 +4123,15 @@ linux_xfer_partial (struct target_ops *o
|
||||||
|
return linux_nat_xfer_osdata (ops, object, annex, readbuf, writebuf,
|
||||||
|
offset, len);
|
||||||
|
|
||||||
|
+#ifndef NATIVE_XFER_UNWIND_TABLE
|
||||||
|
+ /* FIXME: For ia64, we cannot currently use linux_proc_xfer_memory
|
||||||
|
+ for accessing thread storage. Revert when Bugzilla 147436
|
||||||
|
+ is fixed. */
|
||||||
|
xfer = linux_proc_xfer_partial (ops, object, annex, readbuf, writebuf,
|
||||||
|
offset, len);
|
||||||
|
if (xfer != 0)
|
||||||
|
return xfer;
|
||||||
|
+#endif
|
||||||
|
|
||||||
|
return super_xfer_partial (ops, object, annex, readbuf, writebuf,
|
||||||
|
offset, len);
|
@ -2,20 +2,22 @@
|
|||||||
|
|
||||||
* Makefile.in (uninstall-gstack, install-gstack): New rules, add
|
* Makefile.in (uninstall-gstack, install-gstack): New rules, add
|
||||||
to install and uninstall.
|
to install and uninstall.
|
||||||
* gstack.sh: New file.
|
* gstack.sh, gstack.1: New files.
|
||||||
|
|
||||||
--- gdb/Makefile.in 2004-11-23 13:31:03.000000000 -0500
|
Index: gdb-6.8.50.20090226/gdb/Makefile.in
|
||||||
+++ gdb/Makefile.in 2004-11-23 15:06:34.623389592 -0500
|
===================================================================
|
||||||
@@ -970,7 +970,7 @@
|
--- gdb-6.8.50.20090226.orig/gdb/Makefile.in 2009-02-26 22:09:59.000000000 +0100
|
||||||
# time it takes for make to check that all is up to date.
|
+++ gdb-6.8.50.20090226/gdb/Makefile.in 2009-02-26 22:10:22.000000000 +0100
|
||||||
# install-only is intended to address that need.
|
@@ -973,7 +973,7 @@ install: all install-only
|
||||||
install: all install-only
|
|
||||||
-install-only: $(CONFIG_INSTALL)
|
# The "install-only" target also installs the syscalls' XML files in
|
||||||
+install-only: install-gstack $(CONFIG_INSTALL)
|
# the system.
|
||||||
|
-install-only: $(CONFIG_INSTALL) xml-syscall-install
|
||||||
|
+install-only: install-gstack $(CONFIG_INSTALL) xml-syscall-install
|
||||||
transformed_name=`t='$(program_transform_name)'; \
|
transformed_name=`t='$(program_transform_name)'; \
|
||||||
echo gdb | sed -e "$$t"` ; \
|
echo gdb | sed -e "$$t"` ; \
|
||||||
if test "x$$transformed_name" = x; then \
|
if test "x$$transformed_name" = x; then \
|
||||||
@@ -1002,9 +1002,22 @@
|
@@ -1005,9 +1005,26 @@ install-tui:
|
||||||
$(DESTDIR)$(man1dir) ; \
|
$(DESTDIR)$(man1dir) ; \
|
||||||
$(INSTALL_DATA) $(srcdir)/gdb.1 \
|
$(INSTALL_DATA) $(srcdir)/gdb.1 \
|
||||||
$(DESTDIR)$(man1dir)/$$transformed_name.1
|
$(DESTDIR)$(man1dir)/$$transformed_name.1
|
||||||
@ -24,14 +26,18 @@
|
|||||||
+install-gstack:
|
+install-gstack:
|
||||||
+ transformed_name=`t='$(program_transform_name)'; \
|
+ transformed_name=`t='$(program_transform_name)'; \
|
||||||
+ echo $(GSTACK) | sed -e "$$t"` ; \
|
+ echo $(GSTACK) | sed -e "$$t"` ; \
|
||||||
+ if test "x$$transformed_name" = x; then \
|
+ if test "x$$transformed_name" = x; then \
|
||||||
+ transformed_name=$(GSTACK) ; \
|
+ transformed_name=$(GSTACK) ; \
|
||||||
+ else \
|
+ else \
|
||||||
+ true ; \
|
+ true ; \
|
||||||
+ fi ; \
|
+ fi ; \
|
||||||
+ $(SHELL) $(srcdir)/../mkinstalldirs $(DESTDIR)$(bindir) ; \
|
+ $(SHELL) $(srcdir)/../mkinstalldirs $(DESTDIR)$(bindir) ; \
|
||||||
+ $(INSTALL_PROGRAM) $(srcdir)/$(GSTACK).sh \
|
+ $(INSTALL_PROGRAM) $(srcdir)/$(GSTACK).sh \
|
||||||
+ $(DESTDIR)$(bindir)/$$transformed_name$(EXEEXT) ; \
|
+ $(DESTDIR)$(bindir)/$$transformed_name$(EXEEXT) ; \
|
||||||
|
+ : $(SHELL) $(srcdir)/../mkinstalldirs \
|
||||||
|
+ $(DESTDIR)$(man1dir) ; \
|
||||||
|
+ : $(INSTALL_DATA) $(srcdir)/gstack.1 \
|
||||||
|
+ $(DESTDIR)$(man1dir)/$$transformed_name.1
|
||||||
|
|
||||||
|
|
||||||
-uninstall: force $(CONFIG_UNINSTALL)
|
-uninstall: force $(CONFIG_UNINSTALL)
|
||||||
@ -39,7 +45,7 @@
|
|||||||
transformed_name=`t='$(program_transform_name)'; \
|
transformed_name=`t='$(program_transform_name)'; \
|
||||||
echo gdb | sed -e $$t` ; \
|
echo gdb | sed -e $$t` ; \
|
||||||
if test "x$$transformed_name" = x; then \
|
if test "x$$transformed_name" = x; then \
|
||||||
@@ -1026,6 +1043,16 @@
|
@@ -1029,6 +1046,17 @@ uninstall-tui:
|
||||||
fi ; \
|
fi ; \
|
||||||
rm -f $(DESTDIR)$(bindir)/$$transformed_name$(EXEEXT) \
|
rm -f $(DESTDIR)$(bindir)/$$transformed_name$(EXEEXT) \
|
||||||
$(DESTDIR)$(man1dir)/$$transformed_name.1
|
$(DESTDIR)$(man1dir)/$$transformed_name.1
|
||||||
@ -47,17 +53,20 @@
|
|||||||
+uninstall-gstack:
|
+uninstall-gstack:
|
||||||
+ transformed_name=`t='$(program_transform_name)'; \
|
+ transformed_name=`t='$(program_transform_name)'; \
|
||||||
+ echo $(GSTACK) | sed -e $$t` ; \
|
+ echo $(GSTACK) | sed -e $$t` ; \
|
||||||
+ if test "x$$transformed_name" = x; then \
|
+ if test "x$$transformed_name" = x; then \
|
||||||
+ transformed_name=$(GSTACK) ; \
|
+ transformed_name=$(GSTACK) ; \
|
||||||
+ else \
|
+ else \
|
||||||
+ true ; \
|
+ true ; \
|
||||||
+ fi ; \
|
+ fi ; \
|
||||||
+ rm -f $(DESTDIR)$(bindir)/$$transformed_name$(EXEEXT)
|
+ rm -f $(DESTDIR)$(bindir)/$$transformed_name$(EXEEXT) \
|
||||||
|
+ $(DESTDIR)$(man1dir)/$$transformed_name.1
|
||||||
|
|
||||||
# We do this by grepping through sources. If that turns out to be too slow,
|
# The C++ name parser can be built standalone for testing.
|
||||||
# maybe we could just require every .o file to have an initialization routine
|
test-cp-name-parser.o: cp-name-parser.c
|
||||||
--- /dev/null 2005-04-09 23:51:05.027867440 -0400
|
Index: gdb-6.8.50.20090226/gdb/gstack.sh
|
||||||
+++ gdb/gstack.sh 2005-04-08 18:00:49.000000000 -0400
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/gstack.sh 2009-02-26 22:10:05.000000000 +0100
|
||||||
@@ -0,0 +1,45 @@
|
@@ -0,0 +1,45 @@
|
||||||
+#!/bin/sh
|
+#!/bin/sh
|
||||||
+
|
+
|
34
gdb-6.3-gstack-without-path-20060414.patch
Normal file
34
gdb-6.3-gstack-without-path-20060414.patch
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
Index: gdb-6.3/gdb/gstack.sh
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.3.orig/gdb/gstack.sh 2006-02-14 17:21:05.000000000 -0200
|
||||||
|
+++ gdb-6.3/gdb/gstack.sh 2006-04-14 03:17:12.000000000 -0300
|
||||||
|
@@ -17,17 +17,17 @@ fi
|
||||||
|
backtrace="bt"
|
||||||
|
if test -d /proc/$1/task ; then
|
||||||
|
# Newer kernel; has a task/ directory.
|
||||||
|
- if test `ls /proc/$1/task | wc -l` -gt 1 2>/dev/null ; then
|
||||||
|
+ if test `/bin/ls /proc/$1/task | /usr/bin/wc -l` -gt 1 2>/dev/null ; then
|
||||||
|
backtrace="thread apply all bt"
|
||||||
|
fi
|
||||||
|
elif test -f /proc/$1/maps ; then
|
||||||
|
# Older kernel; go by it loading libpthread.
|
||||||
|
- if grep -e libpthread /proc/$1/maps > /dev/null 2>&1 ; then
|
||||||
|
+ if /bin/grep -e libpthread /proc/$1/maps > /dev/null 2>&1 ; then
|
||||||
|
backtrace="thread apply all bt"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
-GDB=${GDB:-gdb}
|
||||||
|
+GDB=${GDB:-/usr/bin/gdb}
|
||||||
|
|
||||||
|
if $GDB -nx --quiet --batch --readnever > /dev/null 2>&1; then
|
||||||
|
readnever=--readnever
|
||||||
|
@@ -39,7 +39,7 @@ fi
|
||||||
|
$GDB --quiet $readnever -nx /proc/$1/exe $1 <<EOF 2>&1 |
|
||||||
|
$backtrace
|
||||||
|
EOF
|
||||||
|
-sed -n \
|
||||||
|
+/bin/sed -n \
|
||||||
|
-e 's/^(gdb) //' \
|
||||||
|
-e '/^#/p' \
|
||||||
|
-e '/^Thread/p'
|
20
gdb-6.3-ia64-gcore-page0-20050421.patch
Normal file
20
gdb-6.3-ia64-gcore-page0-20050421.patch
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
Index: gdb-6.8.50.20081128/gdb/gcore.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/gcore.c 2008-09-11 16:27:34.000000000 +0200
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/gcore.c 2008-12-01 16:39:04.000000000 +0100
|
||||||
|
@@ -475,8 +475,14 @@ gcore_copy_callback (bfd *obfd, asection
|
||||||
|
if (size > total_size)
|
||||||
|
size = total_size;
|
||||||
|
|
||||||
|
+ /* Warn if read error occurs except if we were trying to read the
|
||||||
|
+ first page for ia64. The first page is marked readable, but it cannot
|
||||||
|
+ be read. */
|
||||||
|
if (target_read_memory (bfd_section_vma (obfd, osec) + offset,
|
||||||
|
- memhunk, size) != 0)
|
||||||
|
+ memhunk, size) != 0
|
||||||
|
+ && (strcmp (gdbarch_bfd_arch_info (current_gdbarch)->arch_name,
|
||||||
|
+ "ia64")
|
||||||
|
+ || bfd_section_vma (obfd, osec) != 0))
|
||||||
|
{
|
||||||
|
warning (_("Memory read failed for corefile section, %s bytes at 0x%s."),
|
||||||
|
plongest (size), paddr (bfd_section_vma (obfd, osec)));
|
126
gdb-6.3-ia64-gcore-speedup-20050714.patch
Normal file
126
gdb-6.3-ia64-gcore-speedup-20050714.patch
Normal file
@ -0,0 +1,126 @@
|
|||||||
|
2005-07-14 Jeff Johnsotn <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* linux-nat.c (linux_nat_xfer_memory): Incorporate Fujitsu
|
||||||
|
work-around to use /proc/mem for storage, but to fall-back
|
||||||
|
to PTRACE for ia64 rse register areas.
|
||||||
|
* ia64-linux-nat.c (ia64_rse_slot_num): New static function.
|
||||||
|
(ia64_rse_skip_regs): Ditto.
|
||||||
|
(ia64_linux_check_stack_region): New function.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/linux-nat.c 2009-02-27 07:51:44.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/linux-nat.c 2009-02-28 07:19:05.000000000 +0100
|
||||||
|
@@ -4386,15 +4386,38 @@ linux_xfer_partial (struct target_ops *o
|
||||||
|
return linux_nat_xfer_osdata (ops, object, annex, readbuf, writebuf,
|
||||||
|
offset, len);
|
||||||
|
|
||||||
|
-#ifndef NATIVE_XFER_UNWIND_TABLE
|
||||||
|
- /* FIXME: For ia64, we cannot currently use linux_proc_xfer_memory
|
||||||
|
- for accessing thread storage. Revert when Bugzilla 147436
|
||||||
|
- is fixed. */
|
||||||
|
xfer = linux_proc_xfer_partial (ops, object, annex, readbuf, writebuf,
|
||||||
|
offset, len);
|
||||||
|
if (xfer != 0)
|
||||||
|
- return xfer;
|
||||||
|
+ {
|
||||||
|
+#ifdef NATIVE_XFER_UNWIND_TABLE
|
||||||
|
+ struct mem_region range;
|
||||||
|
+ range.lo = memaddr;
|
||||||
|
+ range.hi = memaddr + len;
|
||||||
|
+
|
||||||
|
+ /* FIXME: For ia64, we cannot currently use
|
||||||
|
+ linux_proc_xfer_partial for accessing rse register storage.
|
||||||
|
+ Revert when Bugzilla 147436 is fixed. */
|
||||||
|
+#ifdef NATIVE_XFER_UNWIND_TABLE
|
||||||
|
+ extern int ia64_linux_check_stack_region (struct lwp_info *lwp,
|
||||||
|
+ void *range);
|
||||||
|
+#endif
|
||||||
|
+ if (iterate_over_lwps (ia64_linux_check_stack_region, &range) != NULL)
|
||||||
|
+ { /* This region contains ia64 rse registers, we have to re-read. */
|
||||||
|
+ int xxfer;
|
||||||
|
+
|
||||||
|
+ /* Re-read register stack area. */
|
||||||
|
+ xxfer = super_xfer_partial (ops, object, annex,
|
||||||
|
+ readbuf + (range.lo - memaddr),
|
||||||
|
+ writebuf + (range.lo - memaddr),
|
||||||
|
+ offset + (range.lo - memaddr),
|
||||||
|
+ range.hi - range.lo);
|
||||||
|
+ if (xxfer == 0)
|
||||||
|
+ xfer = 0;
|
||||||
|
+ }
|
||||||
|
#endif
|
||||||
|
+ return xfer;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
return super_xfer_partial (ops, object, annex, readbuf, writebuf,
|
||||||
|
offset, len);
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/ia64-linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/ia64-linux-nat.c 2009-02-23 01:03:49.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/ia64-linux-nat.c 2009-02-28 07:18:10.000000000 +0100
|
||||||
|
@@ -809,6 +809,64 @@ ia64_linux_xfer_partial (struct target_o
|
||||||
|
|
||||||
|
void _initialize_ia64_linux_nat (void);
|
||||||
|
|
||||||
|
+/*
|
||||||
|
+ * Note: taken from ia64_tdep.c
|
||||||
|
+ *
|
||||||
|
+ */
|
||||||
|
+
|
||||||
|
+static __inline__ unsigned long
|
||||||
|
+ia64_rse_slot_num (unsigned long addr)
|
||||||
|
+{
|
||||||
|
+ return (addr >> 3) & 0x3f;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+/* Skip over a designated number of registers in the backing
|
||||||
|
+ store, remembering every 64th position is for NAT. */
|
||||||
|
+static __inline__ unsigned long
|
||||||
|
+ia64_rse_skip_regs (unsigned long addr, long num_regs)
|
||||||
|
+{
|
||||||
|
+ long delta = ia64_rse_slot_num(addr) + num_regs;
|
||||||
|
+
|
||||||
|
+ if (num_regs < 0)
|
||||||
|
+ delta -= 0x3e;
|
||||||
|
+ return addr + ((num_regs + delta/0x3f) << 3);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+/*
|
||||||
|
+ * Check mem_region is stack or not. If stack, /proc/<pid>/mem cannot return
|
||||||
|
+ * expected value.
|
||||||
|
+ */
|
||||||
|
+int ia64_linux_check_stack_region(struct lwp_info *ti, struct mem_region *range)
|
||||||
|
+{
|
||||||
|
+ CORE_ADDR addr;
|
||||||
|
+ int error;
|
||||||
|
+ unsigned long bsp, cfm, bspstore;
|
||||||
|
+ long sof;
|
||||||
|
+ pid_t pid = ptid_get_lwp(ti->ptid);
|
||||||
|
+ bsp = ptrace(PTRACE_PEEKUSER, pid, PT_AR_BSP ,NULL);
|
||||||
|
+ if (bsp == (unsigned long)-1) {
|
||||||
|
+ return 1;
|
||||||
|
+ }
|
||||||
|
+ /* stack is allocated by one-segment, not separated into several segments.
|
||||||
|
+ So, we only have to check whether bsp is in *range* or not. */
|
||||||
|
+ if((range->lo <= bsp) && (bsp <= range->hi)) {
|
||||||
|
+ bspstore = ptrace(PTRACE_PEEKUSER, pid, PT_AR_BSPSTORE, NULL);
|
||||||
|
+ cfm = ptrace(PTRACE_PEEKUSER, pid, PT_CFM, NULL);
|
||||||
|
+ sof = cfm & 0x3f;
|
||||||
|
+ bsp = ia64_rse_skip_regs(bsp, -sof);
|
||||||
|
+ range->lo = bspstore;
|
||||||
|
+ range->hi = bsp;
|
||||||
|
+ /* we have to check the size of dirty register stack area */
|
||||||
|
+ /*
|
||||||
|
+ fprintf_unfiltered(gdb_stdlog, "<%d> <%p> <%lx> <%p> <%p>\n",
|
||||||
|
+ pid, bsp, sof, range->lo, range->hi);
|
||||||
|
+ */
|
||||||
|
+ return 1;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
void
|
||||||
|
_initialize_ia64_linux_nat (void)
|
||||||
|
{
|
110
gdb-6.3-ia64-info-frame-fix-20050725.patch
Normal file
110
gdb-6.3-ia64-info-frame-fix-20050725.patch
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
2005-07-25 Jeff Johnstno <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* libunwind-frame.c (libunwind_frame_prev_register): Check valuep
|
||||||
|
is not NULL before copying cursor address into it.
|
||||||
|
|
||||||
|
testsuite:
|
||||||
|
2005-07-25 Jeff Johnstno <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* gdb.arch/ia64-sigtramp.exp: New test.
|
||||||
|
* gdb.arch/ia64-sigtramp.c: Ditto.
|
||||||
|
|
||||||
|
2008-02-24 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.8pre. (Only the testcase has remained.)
|
||||||
|
|
||||||
|
--- gdb-6.3/gdb/testsuite/gdb.arch/ia64-sigtramp.c.fix 2005-07-25 16:42:46.000000000 -0400
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.arch/ia64-sigtramp.c 2005-07-25 16:42:08.000000000 -0400
|
||||||
|
@@ -0,0 +1,23 @@
|
||||||
|
+#include <stdio.h>
|
||||||
|
+#include <signal.h>
|
||||||
|
+
|
||||||
|
+int *l;
|
||||||
|
+
|
||||||
|
+void x (int sig)
|
||||||
|
+{
|
||||||
|
+ printf ("in signal handler for signal %d\n", sig);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int main()
|
||||||
|
+{
|
||||||
|
+ int k;
|
||||||
|
+
|
||||||
|
+ signal (SIGSEGV, &x);
|
||||||
|
+
|
||||||
|
+ k = *l;
|
||||||
|
+
|
||||||
|
+ printf ("k is %d\n", k);
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
--- gdb-6.3/gdb/testsuite/gdb.arch/ia64-sigtramp.exp.fix 2005-07-25 16:42:50.000000000 -0400
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.arch/ia64-sigtramp.exp 2005-07-25 16:42:01.000000000 -0400
|
||||||
|
@@ -0,0 +1,66 @@
|
||||||
|
+# Copyright 2005 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
|
||||||
|
+
|
||||||
|
+# This file was written by Jeff Johnston (jjohnstn@redhat.com)
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+#
|
||||||
|
+# test running programs
|
||||||
|
+#
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+if ![istarget "ia64-*-*"] then {
|
||||||
|
+ return
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "ia64-sigtramp"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug additional_flags=-w}] != "" } {
|
||||||
|
+ gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if [get_compiler_info ${binfile}] {
|
||||||
|
+ 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 "handle SIGSEGV" "SIGSEGV.*Yes.*Yes.*Yes.*Segmentation fault"
|
||||||
|
+gdb_test "next" "" "first next"
|
||||||
|
+gdb_test "next" "Program received signal SIGSEGV.*" "getting SIGSEGV"
|
||||||
|
+gdb_breakpoint "x"
|
||||||
|
+gdb_test "continue" "Breakpoint.*x.*" "continue to x"
|
||||||
|
+
|
||||||
|
+gdb_test "f 1" ".*signal handler called.*" "frame 1"
|
||||||
|
+gdb_test "info frame" "Stack level 1.*p63 at .*" "info sigtramp frame"
|
||||||
|
+
|
116
gdb-6.3-ia64-sigill-20051115.patch
Normal file
116
gdb-6.3-ia64-sigill-20051115.patch
Normal file
@ -0,0 +1,116 @@
|
|||||||
|
2005-11-15 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* linux-thread-db.c (thread_db_wait): Don't bother continuing if
|
||||||
|
the wait result indicates the program terminated with a signal.
|
||||||
|
* linux-nat.c (linux_nat_wait): For SIGILL and SIGTRAP, don't
|
||||||
|
throw away the event if the user has specified nostop noprint.
|
||||||
|
|
||||||
|
gdb/testsuite:
|
||||||
|
|
||||||
|
2005-11-15 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* gdb.arch/ia64-sigill.c: New test.
|
||||||
|
* gdb.arch/ia64-sigill.exp: Ditto.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.arch/ia64-sigill.exp
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.arch/ia64-sigill.exp 2008-12-02 21:10:57.000000000 +0100
|
||||||
|
@@ -0,0 +1,59 @@
|
||||||
|
+# Copyright 2005 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
|
||||||
|
+
|
||||||
|
+# This file was written by Jeff Johnston (jjohnstn@redhat.com)
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+#
|
||||||
|
+# test running programs
|
||||||
|
+#
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+if ![istarget "ia64-*-*"] then {
|
||||||
|
+ return
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "ia64-sigill"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+# Deliberately compile with pthreads, even though test is single-threaded.
|
||||||
|
+# We want to force gdb thread code to be exercised.
|
||||||
|
+if { [gdb_compile_pthreads "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug additional_flags=-w}] != "" } {
|
||||||
|
+ gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if [get_compiler_info ${binfile}] {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+# We set up SIGILL nostop, noprint, pass and then run the program.
|
||||||
|
+# We expect to just see a normal run.
|
||||||
|
+gdb_test "handle SIGILL nostop noprint" "SIGILL.*No.*No.*Yes.*" "handle sigill"
|
||||||
|
+gdb_test "run" "Starting program.*ia64-sigill.*\[New thread.*\].*hello world.*Program exited normally." "run to exit"
|
||||||
|
+
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.arch/ia64-sigill.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.arch/ia64-sigill.c 2008-12-02 21:10:57.000000000 +0100
|
||||||
|
@@ -0,0 +1,8 @@
|
||||||
|
+#include <stdio.h>
|
||||||
|
+
|
||||||
|
+int main()
|
||||||
|
+{
|
||||||
|
+ printf ("hello world\n");
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/linux-nat.c 2008-12-02 19:04:38.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/linux-nat.c 2008-12-02 21:11:11.000000000 +0100
|
||||||
|
@@ -2974,7 +2974,8 @@ retry:
|
||||||
|
threads can be a bit time-consuming so if we want decent
|
||||||
|
performance with heavily multi-threaded programs, especially when
|
||||||
|
they're using a high frequency timer, we'd better avoid it if we
|
||||||
|
- can. */
|
||||||
|
+ can. For possible trap signals like SIGTRAP and SIGILL, don't
|
||||||
|
+ avoid reporting. */
|
||||||
|
|
||||||
|
if (WIFSTOPPED (status))
|
||||||
|
{
|
||||||
|
@@ -2992,7 +2993,9 @@ retry:
|
||||||
|
&& inf->stop_soon == NO_STOP_QUIETLY
|
||||||
|
&& signal_stop_state (signo) == 0
|
||||||
|
&& signal_print_state (signo) == 0
|
||||||
|
- && signal_pass_state (signo) == 1)
|
||||||
|
+ && signal_pass_state (signo) == 1
|
||||||
|
+ && signo != TARGET_SIGNAL_ILL
|
||||||
|
+ && signo != TARGET_SIGNAL_TRAP)
|
||||||
|
{
|
||||||
|
/* FIMXE: kettenis/2001-06-06: Should we resume all threads
|
||||||
|
here? It is not clear we should. GDB may not expect
|
163
gdb-6.3-ia64-sigtramp-fp-20050926.patch
Normal file
163
gdb-6.3-ia64-sigtramp-fp-20050926.patch
Normal file
@ -0,0 +1,163 @@
|
|||||||
|
2005-09-27 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* libunwind-frame.c (libunwind_frame_cache): Save the current
|
||||||
|
stack pointer in the cache.
|
||||||
|
(libunwind_sigtramp_frame_this_id): New function.
|
||||||
|
(libunwind_sigtramp_frame_unwind): New unwinder.
|
||||||
|
(libunwind_sigtramp_frame_sniffer): Return
|
||||||
|
libunwind_sigtramp_frame_unwind address.
|
||||||
|
* libunwind-frame.h (libunwind_sigtramp_frame_this_id): New
|
||||||
|
prototype.
|
||||||
|
* ia64-tdep.c (ia64_libunwind_sigtramp_frame_this_id): Calculate
|
||||||
|
the base address using the current stack pointer plus a fixed
|
||||||
|
offset.
|
||||||
|
|
||||||
|
2007-10-14 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7.
|
||||||
|
|
||||||
|
2008-02-24 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.8pre.
|
||||||
|
|
||||||
|
2008-04-16 Yi Zhan <yi.zhan@intel.com>
|
||||||
|
|
||||||
|
Fix a compilation error on a typo.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/libunwind-frame.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/libunwind-frame.c 2008-05-06 20:37:46.000000000 +0200
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/libunwind-frame.c 2008-12-02 19:46:26.000000000 +0100
|
||||||
|
@@ -61,6 +61,7 @@ static unw_word_t (*unw_find_dyn_list_p)
|
||||||
|
struct libunwind_frame_cache
|
||||||
|
{
|
||||||
|
CORE_ADDR base;
|
||||||
|
+ CORE_ADDR sp;
|
||||||
|
CORE_ADDR func_addr;
|
||||||
|
unw_cursor_t cursor;
|
||||||
|
unw_addr_space_t as;
|
||||||
|
@@ -133,6 +134,7 @@ libunwind_frame_cache (struct frame_info
|
||||||
|
unw_accessors_t *acc;
|
||||||
|
unw_addr_space_t as;
|
||||||
|
unw_word_t fp;
|
||||||
|
+ unw_word_t sp;
|
||||||
|
unw_regnum_t uw_sp_regnum;
|
||||||
|
struct libunwind_frame_cache *cache;
|
||||||
|
struct libunwind_descr *descr;
|
||||||
|
@@ -174,14 +176,30 @@ libunwind_frame_cache (struct frame_info
|
||||||
|
: __LITTLE_ENDIAN);
|
||||||
|
|
||||||
|
unw_init_remote_p (&cache->cursor, as, this_frame);
|
||||||
|
+
|
||||||
|
+ /* For the base address, we have a small problem. The majority
|
||||||
|
+ of the time, we can get the stack pointer of the previous
|
||||||
|
+ frame to use as a frame pointer. In the case where we have
|
||||||
|
+ a signal trampoline, the stack may change due to a sigaltstack
|
||||||
|
+ being set up. In that case, the normal mechanism will give us
|
||||||
|
+ an address in the regular stack which is not at the end of the
|
||||||
|
+ sigaltstack as we want. To handle this, we record the stack
|
||||||
|
+ address so the caller may calculate a more correct base address
|
||||||
|
+ to use. */
|
||||||
|
+ uw_sp_regnum = descr->gdb2uw (gdbarch_sp_regnum (gdbarch));
|
||||||
|
+ ret = unw_get_reg_p (&cache->cursor, uw_sp_regnum, &sp);
|
||||||
|
+ if (ret < 0)
|
||||||
|
+ {
|
||||||
|
+ unw_destroy_addr_space_p (as);
|
||||||
|
+ error (_("Can't get libunwind sp register."));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
if (unw_step_p (&cache->cursor) < 0)
|
||||||
|
{
|
||||||
|
unw_destroy_addr_space_p (as);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
- /* To get base address, get sp from previous frame. */
|
||||||
|
- uw_sp_regnum = descr->gdb2uw (gdbarch_sp_regnum (gdbarch));
|
||||||
|
ret = unw_get_reg_p (&cache->cursor, uw_sp_regnum, &fp);
|
||||||
|
if (ret < 0)
|
||||||
|
{
|
||||||
|
@@ -189,6 +207,7 @@ libunwind_frame_cache (struct frame_info
|
||||||
|
error (_("Can't get libunwind sp register."));
|
||||||
|
}
|
||||||
|
|
||||||
|
+ cache->sp = (CORE_ADDR)sp;
|
||||||
|
cache->base = (CORE_ADDR)fp;
|
||||||
|
cache->as = as;
|
||||||
|
|
||||||
|
@@ -376,6 +395,31 @@ libunwind_search_unwind_table (void *as,
|
||||||
|
di, pi, need_unwind_info, args);
|
||||||
|
}
|
||||||
|
|
||||||
|
+void
|
||||||
|
+libunwind_sigtramp_frame_this_id (struct frame_info *this_frame,
|
||||||
|
+ void **this_cache,
|
||||||
|
+ struct frame_id *this_id)
|
||||||
|
+{
|
||||||
|
+ struct libunwind_frame_cache *cache =
|
||||||
|
+ libunwind_frame_cache (this_frame, this_cache);
|
||||||
|
+
|
||||||
|
+ /* Unlike a regular frame, we can't use the normal frame pointer
|
||||||
|
+ mechanism because a sigaltstack may have been used. Instead,
|
||||||
|
+ we return the current stack pointer for the caller to use
|
||||||
|
+ to calculate the base address. */
|
||||||
|
+ if (cache != NULL)
|
||||||
|
+ (*this_id) = frame_id_build (cache->sp, cache->func_addr);
|
||||||
|
+ else
|
||||||
|
+ (*this_id) = null_frame_id;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static const struct frame_unwind libunwind_sigtramp_frame_unwind =
|
||||||
|
+{
|
||||||
|
+ SIGTRAMP_FRAME,
|
||||||
|
+ libunwind_sigtramp_frame_this_id,
|
||||||
|
+ libunwind_frame_prev_register
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
/* Verify if we are in a sigtramp frame and we can use libunwind to unwind. */
|
||||||
|
int
|
||||||
|
libunwind_sigtramp_frame_sniffer (const struct frame_unwind *self,
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/libunwind-frame.h
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/libunwind-frame.h 2008-05-06 20:37:46.000000000 +0200
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/libunwind-frame.h 2008-12-02 19:38:55.000000000 +0100
|
||||||
|
@@ -52,6 +52,9 @@ void libunwind_frame_set_descr (struct g
|
||||||
|
|
||||||
|
void libunwind_frame_this_id (struct frame_info *this_frame, void **this_cache,
|
||||||
|
struct frame_id *this_id);
|
||||||
|
+void libunwind_sigtramp_frame_this_id (struct frame_info *this_frame,
|
||||||
|
+ void **this_cache,
|
||||||
|
+ struct frame_id *this_id);
|
||||||
|
struct value *libunwind_frame_prev_register (struct frame_info *this_frame,
|
||||||
|
void **this_cache, int regnum);
|
||||||
|
void libunwind_frame_dealloc_cache (struct frame_info *self, void *cache);
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/ia64-tdep.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/ia64-tdep.c 2008-12-02 19:04:32.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/ia64-tdep.c 2008-12-02 21:09:46.000000000 +0100
|
||||||
|
@@ -2964,7 +2964,7 @@ ia64_libunwind_sigtramp_frame_this_id (s
|
||||||
|
struct frame_id id;
|
||||||
|
CORE_ADDR prev_ip;
|
||||||
|
|
||||||
|
- libunwind_frame_this_id (this_frame, this_cache, &id);
|
||||||
|
+ libunwind_sigtramp_frame_this_id (this_frame, this_cache, &id);
|
||||||
|
if (frame_id_eq (id, null_frame_id))
|
||||||
|
{
|
||||||
|
(*this_id) = null_frame_id;
|
||||||
|
@@ -2976,8 +2976,14 @@ ia64_libunwind_sigtramp_frame_this_id (s
|
||||||
|
get_frame_register (this_frame, IA64_BSP_REGNUM, buf);
|
||||||
|
bsp = extract_unsigned_integer (buf, 8);
|
||||||
|
|
||||||
|
- /* For a sigtramp frame, we don't make the check for previous ip being 0. */
|
||||||
|
- (*this_id) = frame_id_build_special (id.stack_addr, id.code_addr, bsp);
|
||||||
|
+ /* For a sigtramp frame, we don't make the check for previous ip being 0.
|
||||||
|
+ We also must calculate the frame pointer because libunwind will give
|
||||||
|
+ us back the current stack pointer instead of the frame pointer since
|
||||||
|
+ it cannot figure this out when in a sigaltstack. We make a basic
|
||||||
|
+ assumption of 16 (default size) + 8 bytes for sigcontext address.
|
||||||
|
+ FIXME: if libunwind were to export the frame pointer address, we
|
||||||
|
+ could eliminate the assumption and get the actual value. */
|
||||||
|
+ (*this_id) = frame_id_build_special (id.stack_addr + 24, id.code_addr, bsp);
|
||||||
|
|
||||||
|
if (gdbarch_debug >= 1)
|
||||||
|
fprintf_unfiltered (gdb_stdlog,
|
158
gdb-6.3-ia64-sigtramp-frame-20050708.patch
Normal file
158
gdb-6.3-ia64-sigtramp-frame-20050708.patch
Normal file
@ -0,0 +1,158 @@
|
|||||||
|
2005-07-08 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* ia64-tdep.c (ia64_sigtramp_frame_prev_register): Build
|
||||||
|
pseudo-registers the same as ia64_pseudo_register_read.
|
||||||
|
|
||||||
|
2008-04-16 Yi Zhan <yi.zhan@intel.com>
|
||||||
|
|
||||||
|
* ia64-tdep.c (ia64_sigtramp_frame_prev_register): Fix an
|
||||||
|
ISO C compliance compilation error.
|
||||||
|
|
||||||
|
2008-02-12 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to gdb-6.8.50.20081128, follow the upstream change:
|
||||||
|
http://sourceware.org/cgi-bin/cvsweb.cgi/src/gdb/ia64-tdep.c.diff?cvsroot=src&r1=1.176&r2=1.177
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/ia64-tdep.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/ia64-tdep.c 2008-11-26 06:27:48.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/ia64-tdep.c 2008-12-02 19:04:32.000000000 +0100
|
||||||
|
@@ -2107,6 +2107,94 @@ ia64_sigtramp_frame_prev_register (struc
|
||||||
|
return frame_unwind_got_constant (this_frame, regnum, pc);
|
||||||
|
}
|
||||||
|
|
||||||
|
+ /* Red Hat patch begin. */
|
||||||
|
+ else if (IA64_NAT0_REGNUM <= regnum && regnum <= IA64_NAT31_REGNUM)
|
||||||
|
+ {
|
||||||
|
+ /* NAT pseudo registers 0-31: get them from UNAT.
|
||||||
|
+ * "copied" from ia64_pseudo_register_read() */
|
||||||
|
+ ULONGEST unatN_val;
|
||||||
|
+ ULONGEST unat;
|
||||||
|
+ read_memory (cache->saved_regs[IA64_UNAT_REGNUM], (char *) &unat,
|
||||||
|
+ register_size (current_gdbarch, IA64_UNAT_REGNUM));
|
||||||
|
+ unatN_val = (unat & (1LL << (regnum - IA64_NAT0_REGNUM))) != 0;
|
||||||
|
+ return frame_unwind_got_constant (this_frame, regnum, unatN_val);
|
||||||
|
+ }
|
||||||
|
+ else if (IA64_NAT32_REGNUM <= regnum && regnum <= IA64_NAT127_REGNUM)
|
||||||
|
+ {
|
||||||
|
+ /* NAT pseudo registers 32-127.
|
||||||
|
+ * "copied" from ia64_pseudo_register_read()
|
||||||
|
+ * FIXME: Not currently tested -- cannot get the frame to include
|
||||||
|
+ * NAT32-NAT127. */
|
||||||
|
+ ULONGEST bsp;
|
||||||
|
+ ULONGEST cfm;
|
||||||
|
+ ULONGEST natN_val = 0;
|
||||||
|
+ CORE_ADDR gr_addr = 0, nat_addr = 0;
|
||||||
|
+
|
||||||
|
+ read_memory (cache->saved_regs[IA64_BSP_REGNUM], (char *) &bsp,
|
||||||
|
+ register_size (current_gdbarch, IA64_BSP_REGNUM));
|
||||||
|
+ read_memory (cache->saved_regs[IA64_CFM_REGNUM], (char *) &cfm,
|
||||||
|
+ register_size (current_gdbarch, IA64_CFM_REGNUM));
|
||||||
|
+
|
||||||
|
+ /* The bsp points at the end of the register frame so we
|
||||||
|
+ subtract the size of frame from it to get start of register frame. */
|
||||||
|
+ bsp = rse_address_add (bsp, -(cfm & 0x7f));
|
||||||
|
+
|
||||||
|
+ if ((cfm & 0x7f) > regnum - V32_REGNUM)
|
||||||
|
+ gr_addr = rse_address_add (bsp, (regnum - V32_REGNUM));
|
||||||
|
+
|
||||||
|
+ if (gr_addr != 0)
|
||||||
|
+ {
|
||||||
|
+ /* Compute address of nat collection bits */
|
||||||
|
+ CORE_ADDR nat_collection;
|
||||||
|
+ int nat_bit;
|
||||||
|
+ nat_addr = gr_addr | 0x1f8;
|
||||||
|
+ /* If our nat collection address is bigger than bsp, we have to get
|
||||||
|
+ the nat collection from rnat. Otherwise, we fetch the nat
|
||||||
|
+ collection from the computed address. FIXME: Do not know if
|
||||||
|
+ RNAT can be not stored in the frame--being extra cautious. */
|
||||||
|
+ if (nat_addr >= bsp)
|
||||||
|
+ {
|
||||||
|
+ nat_addr = cache->saved_regs[IA64_RNAT_REGNUM];
|
||||||
|
+ if (nat_addr != 0)
|
||||||
|
+ read_memory (nat_addr, (char *) &nat_collection,
|
||||||
|
+ register_size (current_gdbarch, IA64_RNAT_REGNUM));
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ nat_collection = read_memory_integer (nat_addr, 8);
|
||||||
|
+ if (nat_addr != 0)
|
||||||
|
+ {
|
||||||
|
+ nat_bit = (gr_addr >> 3) & 0x3f;
|
||||||
|
+ natN_val = (nat_collection >> nat_bit) & 1;
|
||||||
|
+ return frame_unwind_got_constant (this_frame, regnum, natN_val);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ warning (_("ia64_sigtramp_frame_prev_register: unhandled register %d"),
|
||||||
|
+ regnum);
|
||||||
|
+ }
|
||||||
|
+ else if (regnum == VBOF_REGNUM)
|
||||||
|
+ {
|
||||||
|
+ /* BOF pseudo register.
|
||||||
|
+ * "copied" from ia64_pseudo_register_read()
|
||||||
|
+ *
|
||||||
|
+ * A virtual register frame start is provided for user convenience.
|
||||||
|
+ * It can be calculated as the bsp - sof (sizeof frame). */
|
||||||
|
+ ULONGEST bsp;
|
||||||
|
+ ULONGEST cfm;
|
||||||
|
+ ULONGEST bof;
|
||||||
|
+
|
||||||
|
+ read_memory (cache->saved_regs[IA64_BSP_REGNUM], (char *) &bsp,
|
||||||
|
+ register_size (current_gdbarch, IA64_BSP_REGNUM));
|
||||||
|
+ read_memory (cache->saved_regs[IA64_CFM_REGNUM], (char *) &cfm,
|
||||||
|
+ register_size (current_gdbarch, IA64_CFM_REGNUM));
|
||||||
|
+
|
||||||
|
+ /* The bsp points at the end of the register frame so we
|
||||||
|
+ subtract the size of frame from it to get beginning of frame. */
|
||||||
|
+ bof = rse_address_add (bsp, -(cfm & 0x7f));
|
||||||
|
+
|
||||||
|
+ return frame_unwind_got_constant (this_frame, regnum, bof);
|
||||||
|
+ }
|
||||||
|
+ /* Red Hat patch end. */
|
||||||
|
+
|
||||||
|
else if ((regnum >= IA64_GR32_REGNUM && regnum <= IA64_GR127_REGNUM)
|
||||||
|
|| (regnum >= V32_REGNUM && regnum <= V127_REGNUM))
|
||||||
|
{
|
||||||
|
@@ -2121,7 +2209,42 @@ ia64_sigtramp_frame_prev_register (struc
|
||||||
|
return frame_unwind_got_constant (this_frame, regnum, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
- else /* All other registers not listed above. */
|
||||||
|
+ /* Red Hat patch begin. */
|
||||||
|
+ else if (VP0_REGNUM <= regnum && regnum <= VP63_REGNUM)
|
||||||
|
+ {
|
||||||
|
+ /* VP 0-63.
|
||||||
|
+ * "copied" from ia64_pseudo_register_read()
|
||||||
|
+ *
|
||||||
|
+ * FIXME: Not currently tested--cannot get the frame to include PR. */
|
||||||
|
+ CORE_ADDR pr_addr = 0;
|
||||||
|
+
|
||||||
|
+ pr_addr = cache->saved_regs[IA64_PR_REGNUM];
|
||||||
|
+ if (pr_addr != 0)
|
||||||
|
+ {
|
||||||
|
+ ULONGEST pr;
|
||||||
|
+ ULONGEST cfm;
|
||||||
|
+ ULONGEST prN_val;
|
||||||
|
+ read_memory (pr_addr, (char *) &pr,
|
||||||
|
+ register_size (current_gdbarch, IA64_PR_REGNUM));
|
||||||
|
+ read_memory (cache->saved_regs[IA64_CFM_REGNUM], (char *) &cfm,
|
||||||
|
+ register_size (current_gdbarch, IA64_CFM_REGNUM));
|
||||||
|
+
|
||||||
|
+ /* Get the register rename base for this frame and adjust the
|
||||||
|
+ * register name to take rotation into account. */
|
||||||
|
+ if (VP16_REGNUM <= regnum && regnum <= VP63_REGNUM)
|
||||||
|
+ {
|
||||||
|
+ int rrb_pr = (cfm >> 32) & 0x3f;
|
||||||
|
+ regnum = VP16_REGNUM + ((regnum - VP16_REGNUM) + rrb_pr) % 48;
|
||||||
|
+ }
|
||||||
|
+ prN_val = (pr & (1LL << (regnum - VP0_REGNUM))) != 0;
|
||||||
|
+ return frame_unwind_got_constant (this_frame, regnum, prN_val);
|
||||||
|
+ }
|
||||||
|
+ warning (_("ia64_sigtramp_frame_prev_register: unhandled register %d"),
|
||||||
|
+ regnum);
|
||||||
|
+ }
|
||||||
|
+ /* Red Hat patch end. */
|
||||||
|
+
|
||||||
|
+ /* All other registers not listed above. */
|
||||||
|
{
|
||||||
|
CORE_ADDR addr = cache->saved_regs[regnum];
|
||||||
|
|
322
gdb-6.3-inferior-notification-20050721.patch
Normal file
322
gdb-6.3-inferior-notification-20050721.patch
Normal file
@ -0,0 +1,322 @@
|
|||||||
|
2005-07-21 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* gdb.base/attach-32.exp: New test for attaching in 32-bit
|
||||||
|
mode on 64-bit systems.
|
||||||
|
* gdb.base/attach-32.c: Ditto.
|
||||||
|
* gdb.base/attach-32b.c: Ditto.
|
||||||
|
|
||||||
|
2007-12-26 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.base/attach-32.exp: Fix forgotten $GDBFLAGS as set.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.base/attach-32.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.base/attach-32.c 2008-12-07 10:06:03.000000000 +0100
|
||||||
|
@@ -0,0 +1,20 @@
|
||||||
|
+/* This program is intended to be started outside of gdb, and then
|
||||||
|
+ attached to by gdb. Thus, it simply spins in a loop. The loop
|
||||||
|
+ is exited when & if the variable 'should_exit' is non-zero. (It
|
||||||
|
+ is initialized to zero in this program, so the loop will never
|
||||||
|
+ exit unless/until gdb sets the variable to non-zero.)
|
||||||
|
+ */
|
||||||
|
+#include <stdio.h>
|
||||||
|
+
|
||||||
|
+int should_exit = 0;
|
||||||
|
+
|
||||||
|
+int main ()
|
||||||
|
+{
|
||||||
|
+ int local_i = 0;
|
||||||
|
+
|
||||||
|
+ while (! should_exit)
|
||||||
|
+ {
|
||||||
|
+ local_i++;
|
||||||
|
+ }
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.base/attach-32.exp
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.base/attach-32.exp 2008-12-07 10:08:52.000000000 +0100
|
||||||
|
@@ -0,0 +1,252 @@
|
||||||
|
+# Copyright 2005 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.
|
||||||
|
+#
|
||||||
|
+# This test was based on attach.exp and modified for 32/64 bit Linux systems. */
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+# On HP-UX 11.0, this test is causing a process running the program
|
||||||
|
+# "attach" to be left around spinning. Until we figure out why, I am
|
||||||
|
+# commenting out the test to avoid polluting tiamat (our 11.0 nightly
|
||||||
|
+# test machine) with these processes. RT
|
||||||
|
+#
|
||||||
|
+# Setting the magic bit in the target app should work. I added a
|
||||||
|
+# "kill", and also a test for the R3 register warning. JB
|
||||||
|
+if { ![istarget "x86_64*-*linux*"]
|
||||||
|
+ && ![istarget "powerpc64*-*linux*"]} {
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# are we on a target board
|
||||||
|
+if [is_remote target] then {
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "attach-32"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set srcfile2 ${testfile}b.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+set binfile2 ${objdir}/${subdir}/${testfile}b
|
||||||
|
+set escapedbinfile [string_to_regexp ${objdir}/${subdir}/${testfile}]
|
||||||
|
+
|
||||||
|
+#execute_anywhere "rm -f ${binfile} ${binfile2}"
|
||||||
|
+remote_exec build "rm -f ${binfile} ${binfile2}"
|
||||||
|
+# For debugging this test
|
||||||
|
+#
|
||||||
|
+#log_user 1
|
||||||
|
+
|
||||||
|
+# build the first test case
|
||||||
|
+#
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable [list debug "additional_flags=-m32"]] != "" } {
|
||||||
|
+ gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Build the in-system-call test
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile2}" "${binfile2}" executable [list debug "additional_flags=-m32"]] != "" } {
|
||||||
|
+ gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if [get_compiler_info ${binfile}] {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+proc do_attach_tests {} {
|
||||||
|
+ global gdb_prompt
|
||||||
|
+ global binfile
|
||||||
|
+ global escapedbinfile
|
||||||
|
+ global srcfile
|
||||||
|
+ global testfile
|
||||||
|
+ global objdir
|
||||||
|
+ global subdir
|
||||||
|
+ global timeout
|
||||||
|
+ global testpid
|
||||||
|
+
|
||||||
|
+ # Verify that we can "see" the variable "should_exit" in the
|
||||||
|
+ # program, and that it is zero.
|
||||||
|
+
|
||||||
|
+ gdb_test "print should_exit" " = 0" "after attach-32, print should_exit"
|
||||||
|
+
|
||||||
|
+ # Verify that we can modify the variable "should_exit" in the
|
||||||
|
+ # program.
|
||||||
|
+
|
||||||
|
+ gdb_test "set should_exit=1" "" "after attach-32, set should_exit"
|
||||||
|
+
|
||||||
|
+ # Verify that the modification really happened.
|
||||||
|
+
|
||||||
|
+ send_gdb "tbreak 19\n"
|
||||||
|
+ gdb_expect {
|
||||||
|
+ -re "reakpoint .*at.*$srcfile, line 19.*$gdb_prompt $" {
|
||||||
|
+ pass "after attach-32, set tbreak postloop"
|
||||||
|
+ }
|
||||||
|
+ -re "$gdb_prompt $" {
|
||||||
|
+ fail "after attach-32, set tbreak postloop"
|
||||||
|
+ }
|
||||||
|
+ timeout {
|
||||||
|
+ fail "(timeout) after attach-32, set tbreak postloop"
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ send_gdb "continue\n"
|
||||||
|
+ gdb_expect {
|
||||||
|
+ -re "main.*at.*$srcfile:19.*$gdb_prompt $" {
|
||||||
|
+ pass "after attach-32, reach tbreak postloop"
|
||||||
|
+ }
|
||||||
|
+ -re "$gdb_prompt $" {
|
||||||
|
+ fail "after attach-32, reach tbreak postloop"
|
||||||
|
+ }
|
||||||
|
+ timeout {
|
||||||
|
+ fail "(timeout) after attach-32, reach tbreak postloop"
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ # Allow the test process to exit, to cleanup after ourselves.
|
||||||
|
+
|
||||||
|
+ gdb_test "continue" "Program exited normally." "after attach-32, exit"
|
||||||
|
+
|
||||||
|
+ # Make sure we don't leave a process around to confuse
|
||||||
|
+ # the next test run (and prevent the compile by keeping
|
||||||
|
+ # the text file busy), in case the "set should_exit" didn't
|
||||||
|
+ # work.
|
||||||
|
+
|
||||||
|
+ remote_exec build "kill -9 ${testpid}"
|
||||||
|
+
|
||||||
|
+ # Start the program running and then wait for a bit, to be sure
|
||||||
|
+ # that it can be attached to.
|
||||||
|
+
|
||||||
|
+ set testpid [eval exec $binfile &]
|
||||||
|
+ exec sleep 2
|
||||||
|
+ if { [istarget "*-*-cygwin*"] } {
|
||||||
|
+ # testpid is the Cygwin PID, GDB uses the Windows PID, which might be
|
||||||
|
+ # different due to the way fork/exec works.
|
||||||
|
+ set testpid [ exec ps -e | gawk "{ if (\$1 == $testpid) print \$4; }" ]
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ # Verify that we can attach to the process, and find its a.out
|
||||||
|
+ # when we're cd'd to some directory that doesn't contain the
|
||||||
|
+ # a.out. (We use the source path set by the "dir" command.)
|
||||||
|
+
|
||||||
|
+ gdb_test "dir ${objdir}/${subdir}" "Source directories searched: .*" \
|
||||||
|
+ "set source path"
|
||||||
|
+
|
||||||
|
+ gdb_test "cd /tmp" "Working directory /tmp." \
|
||||||
|
+ "cd away from process working directory"
|
||||||
|
+
|
||||||
|
+ # Explicitly flush out any knowledge of the previous attachment.
|
||||||
|
+
|
||||||
|
+ set test "before attach-32-3, flush symbols"
|
||||||
|
+ gdb_test_multiple "symbol" "$test" {
|
||||||
|
+ -re "Discard symbol table from.*y or n. $" {
|
||||||
|
+ gdb_test "y" "No symbol file now." \
|
||||||
|
+ "$test"
|
||||||
|
+ }
|
||||||
|
+ -re "No symbol file now.*$gdb_prompt $" {
|
||||||
|
+ pass "$test"
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ gdb_test "exec" "No executable file now." \
|
||||||
|
+ "before attach-32-3, flush exec"
|
||||||
|
+
|
||||||
|
+ gdb_test "attach $testpid" \
|
||||||
|
+ "Attaching to process $testpid.*Reading symbols from $escapedbinfile.*main.*at .*" \
|
||||||
|
+ "attach-32 when process' a.out not in cwd"
|
||||||
|
+
|
||||||
|
+ set test "after attach-32-3, exit"
|
||||||
|
+ gdb_test_multiple "kill" "$test" {
|
||||||
|
+ -re "Kill the program being debugged.*y or n. $" {
|
||||||
|
+ gdb_test "y" "" "$test"
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ # Another "don't leave a process around"
|
||||||
|
+ remote_exec build "kill -9 ${testpid}"
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+proc do_call_attach_tests {} {
|
||||||
|
+ global gdb_prompt
|
||||||
|
+ global binfile2
|
||||||
|
+ global testpid
|
||||||
|
+
|
||||||
|
+ # See if other registers are problems
|
||||||
|
+
|
||||||
|
+ set test "info other register"
|
||||||
|
+ gdb_test_multiple "i r r3" "$test" {
|
||||||
|
+ -re "warning: reading register.*$gdb_prompt $" {
|
||||||
|
+ fail "$test"
|
||||||
|
+ }
|
||||||
|
+ -re "r3.*$gdb_prompt $" {
|
||||||
|
+ pass "$test"
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ # Get rid of the process
|
||||||
|
+
|
||||||
|
+ gdb_test "p should_exit = 1"
|
||||||
|
+ gdb_test "c" "Program exited normally."
|
||||||
|
+
|
||||||
|
+ # Be paranoid
|
||||||
|
+
|
||||||
|
+ remote_exec build "kill -9 ${testpid}"
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+# Start with a fresh gdb
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+set testpid [eval exec $binfile &]
|
||||||
|
+exec sleep 3
|
||||||
|
+if { [istarget "*-*-cygwin*"] } {
|
||||||
|
+ # testpid is the Cygwin PID, GDB uses the Windows PID, which might be
|
||||||
|
+ # different due to the way fork/exec works.
|
||||||
|
+ set testpid [ exec ps -e | gawk "{ if (\$1 == $testpid) print \$4; }" ]
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set GDBFLAGS_orig $GDBFLAGS
|
||||||
|
+set GDBFLAGS "--pid=$testpid"
|
||||||
|
+gdb_start
|
||||||
|
+set GDBFLAGS $GDBFLAGS_orig
|
||||||
|
+
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+
|
||||||
|
+# This is a test of gdb's ability to attach to a running process.
|
||||||
|
+
|
||||||
|
+do_attach_tests
|
||||||
|
+
|
||||||
|
+# Test attaching when the target is inside a system call
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+set testpid [eval exec $binfile2 &]
|
||||||
|
+exec sleep 3
|
||||||
|
+if { [istarget "*-*-cygwin*"] } {
|
||||||
|
+ # testpid is the Cygwin PID, GDB uses the Windows PID, which might be
|
||||||
|
+ # different due to the way fork/exec works.
|
||||||
|
+ set testpid [ exec ps -e | gawk "{ if (\$1 == $testpid) print \$4; }" ]
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set GDBFLAGS_orig $GDBFLAGS
|
||||||
|
+set GDBFLAGS "--pid=$testpid"
|
||||||
|
+gdb_start
|
||||||
|
+set GDBFLAGS $GDBFLAGS_orig
|
||||||
|
+
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+do_call_attach_tests
|
||||||
|
+
|
||||||
|
+return 0
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.base/attach-32b.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.base/attach-32b.c 2008-12-07 10:06:03.000000000 +0100
|
||||||
|
@@ -0,0 +1,24 @@
|
||||||
|
+/* This program is intended to be started outside of gdb, and then
|
||||||
|
+ attached to by gdb. Thus, it simply spins in a loop. The loop
|
||||||
|
+ is exited when & if the variable 'should_exit' is non-zero. (It
|
||||||
|
+ is initialized to zero in this program, so the loop will never
|
||||||
|
+ exit unless/until gdb sets the variable to non-zero.)
|
||||||
|
+ */
|
||||||
|
+#include <stdio.h>
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
+
|
||||||
|
+int should_exit = 0;
|
||||||
|
+
|
||||||
|
+int main ()
|
||||||
|
+{
|
||||||
|
+ int local_i = 0;
|
||||||
|
+
|
||||||
|
+ sleep( 10 ); /* System call causes register fetch to fail */
|
||||||
|
+ /* This is a known HPUX "feature" */
|
||||||
|
+ while (! should_exit)
|
||||||
|
+ {
|
||||||
|
+ local_i++;
|
||||||
|
+ }
|
||||||
|
+ return (0);
|
||||||
|
+}
|
26
gdb-6.3-inheritance-20050324.patch
Normal file
26
gdb-6.3-inheritance-20050324.patch
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
2005-03-24 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* valops.c (check_field_in): Use check_typedef for base classes
|
||||||
|
to avoid problems with opaque type references.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/valops.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/valops.c 2008-12-08 10:56:11.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/valops.c 2008-12-08 10:59:14.000000000 +0100
|
||||||
|
@@ -2484,8 +2484,14 @@ check_field (struct type *type, const ch
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = TYPE_N_BASECLASSES (type) - 1; i >= 0; i--)
|
||||||
|
- if (check_field (TYPE_BASECLASS (type, i), name))
|
||||||
|
- return 1;
|
||||||
|
+ {
|
||||||
|
+ /* Check the base classes. Make sure we have the real type for
|
||||||
|
+ each base class as opposed to an opaque declaration. */
|
||||||
|
+ struct type *baseclass = check_typedef (TYPE_BASECLASS (type, i));
|
||||||
|
+
|
||||||
|
+ if (check_field (baseclass, name))
|
||||||
|
+ return 1;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
153
gdb-6.3-inheritancetest-20050726.patch
Normal file
153
gdb-6.3-inheritancetest-20050726.patch
Normal file
@ -0,0 +1,153 @@
|
|||||||
|
2005-07-26 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* gdb.cp/b146835.exp: New testcase.
|
||||||
|
* gdb.cp/b146835.cc: Ditto.
|
||||||
|
* gdb.cp/b146835b.cc: Ditto.
|
||||||
|
* gdb.cp/b146835.h: Ditto.
|
||||||
|
|
||||||
|
--- gdb-6.3/gdb/testsuite/gdb.cp/b146835b.cc.fix3 2005-07-26 16:47:12.000000000 -0400
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.cp/b146835b.cc 2005-07-26 16:53:31.000000000 -0400
|
||||||
|
@@ -0,0 +1,11 @@
|
||||||
|
+#include "b146835.h"
|
||||||
|
+
|
||||||
|
+C::C() { d = 0; x = 3; }
|
||||||
|
+
|
||||||
|
+int C::z (char *s) { return 0; }
|
||||||
|
+
|
||||||
|
+C::~C() {}
|
||||||
|
+
|
||||||
|
+void A::funcD (class E *e, class D *d) {}
|
||||||
|
+void A::funcE (E *e, D *d) {}
|
||||||
|
+void A::funcF (unsigned long x, D *d) {}
|
||||||
|
--- gdb-6.3/gdb/testsuite/gdb.cp/b146835.cc.fix3 2005-07-26 16:47:20.000000000 -0400
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.cp/b146835.cc 2005-07-26 16:46:50.000000000 -0400
|
||||||
|
@@ -0,0 +1,32 @@
|
||||||
|
+#include "b146835.h"
|
||||||
|
+#include <iostream>
|
||||||
|
+
|
||||||
|
+class F : public C {
|
||||||
|
+
|
||||||
|
+protected:
|
||||||
|
+
|
||||||
|
+ virtual void funcA (unsigned long a, B *b);
|
||||||
|
+ virtual void funcB (E *e);
|
||||||
|
+ virtual void funcC (unsigned long x, bool y);
|
||||||
|
+
|
||||||
|
+ char *s1, *s2;
|
||||||
|
+ bool b1;
|
||||||
|
+ int k;
|
||||||
|
+
|
||||||
|
+public:
|
||||||
|
+ void foo() {
|
||||||
|
+ std::cout << "foo" << std::endl;
|
||||||
|
+ }
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+void F::funcA (unsigned long a, B *b) {}
|
||||||
|
+void F::funcB (E *e) {}
|
||||||
|
+void F::funcC (unsigned long x, bool y) {}
|
||||||
|
+
|
||||||
|
+int main()
|
||||||
|
+{
|
||||||
|
+ F f;
|
||||||
|
+ f.foo();
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
--- gdb-6.3/gdb/testsuite/gdb.cp/b146835.exp.fix3 2005-07-26 16:47:26.000000000 -0400
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.cp/b146835.exp 2005-07-26 16:46:50.000000000 -0400
|
||||||
|
@@ -0,0 +1,55 @@
|
||||||
|
+# This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+# Copyright 2005 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.
|
||||||
|
+
|
||||||
|
+# Check that GDB can properly print an inherited member variable
|
||||||
|
+# (Bugzilla 146835)
|
||||||
|
+
|
||||||
|
+if $tracelevel {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+set testfile "b146835"
|
||||||
|
+set srcfile ${testfile}.cc
|
||||||
|
+set srcfile2 ${testfile}b.cc
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+if {[gdb_compile "${srcdir}/${subdir}/${srcfile} ${srcdir}/${subdir}/${srcfile2}" "${binfile}" executable {debug c++}] != "" } {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+#
|
||||||
|
+# Run to `main' where we begin our tests.
|
||||||
|
+#
|
||||||
|
+
|
||||||
|
+if ![runto_main] then {
|
||||||
|
+ gdb_suppress_tests
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_test "break 'F::foo()'" ""
|
||||||
|
+gdb_continue_to_breakpoint "First line foo"
|
||||||
|
+
|
||||||
|
+# Verify that we can access the inherited member d
|
||||||
|
+gdb_test "p d" ".*(struct D \*.).*0x0" "Verify inherited member d accessible"
|
||||||
|
+
|
||||||
|
--- gdb-6.3/gdb/testsuite/gdb.cp/b146835.h.fix3 2005-07-26 16:47:36.000000000 -0400
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.cp/b146835.h 2005-07-26 16:53:18.000000000 -0400
|
||||||
|
@@ -0,0 +1,36 @@
|
||||||
|
+
|
||||||
|
+class A {
|
||||||
|
+
|
||||||
|
+protected:
|
||||||
|
+
|
||||||
|
+ virtual void funcA (unsigned long a, class B *b) = 0;
|
||||||
|
+ virtual void funcB (class E *e) = 0;
|
||||||
|
+ virtual void funcC (unsigned long x, bool y) = 0;
|
||||||
|
+
|
||||||
|
+ void funcD (class E *e, class D* d);
|
||||||
|
+ virtual void funcE (E *e, D *d);
|
||||||
|
+ virtual void funcF (unsigned long x, D *d);
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+class C : public A {
|
||||||
|
+
|
||||||
|
+protected:
|
||||||
|
+
|
||||||
|
+ int x;
|
||||||
|
+ class K *k;
|
||||||
|
+ class H *h;
|
||||||
|
+
|
||||||
|
+ D *d;
|
||||||
|
+
|
||||||
|
+ class W *w;
|
||||||
|
+ class N *n;
|
||||||
|
+ class L *l;
|
||||||
|
+ unsigned long *r;
|
||||||
|
+
|
||||||
|
+public:
|
||||||
|
+
|
||||||
|
+ C();
|
||||||
|
+ int z (char *s);
|
||||||
|
+ virtual ~C();
|
||||||
|
+};
|
316
gdb-6.3-large-core-20051206.patch
Normal file
316
gdb-6.3-large-core-20051206.patch
Normal file
@ -0,0 +1,316 @@
|
|||||||
|
2005-12-14 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* symfile-mem.c (read_memory): New static read callback function.
|
||||||
|
(symfile_add_from_memory): Pass read_memory to bfd instead of
|
||||||
|
target_read_memory.
|
||||||
|
* target.c (target_xfer_memory): Add support for LONGEST len and
|
||||||
|
change all callers.
|
||||||
|
(deprecated_debug_xfer_memory, target_read_memory): Ditto.
|
||||||
|
(target_write_memory, do_xfer_memory): Ditto.
|
||||||
|
(target_xfer_memory_partial, target_read_memory_partial): Ditto.
|
||||||
|
(target_write_memory_partial): Ditto.
|
||||||
|
* infptrace.c (child_xfer_memory): Ditto.
|
||||||
|
* linux-nat.c (linux_nat_xfer_memory): Ditto.
|
||||||
|
(linux_nat_proc_xfer_memory): Ditto.
|
||||||
|
* dcache.c (dcache_xfer_memory): Ditto.
|
||||||
|
* exec.c (xfer_memory): Ditto.
|
||||||
|
* remote.c (remote_xfer_memory): Ditto.
|
||||||
|
* remote-sim.c (gdbsim_xfer_interior_memory): Ditto.
|
||||||
|
* target.h: Change prototypes for functions changed above.
|
||||||
|
* linux-nat.h: Ditto.
|
||||||
|
* remote.h: Ditto.
|
||||||
|
* dcache.h: Ditto.
|
||||||
|
|
||||||
|
2007-10-15 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/symfile-mem.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/symfile-mem.c 2009-02-21 17:14:49.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/symfile-mem.c 2009-02-28 07:22:09.000000000 +0100
|
||||||
|
@@ -56,6 +56,14 @@
|
||||||
|
#include "elf/common.h"
|
||||||
|
|
||||||
|
|
||||||
|
+/* Local callback routine to pass to bfd to read from target memory,
|
||||||
|
+ using a len constrained to INT_MAX. */
|
||||||
|
+static int
|
||||||
|
+read_target_memory (bfd_vma addr, bfd_byte *buf, int len)
|
||||||
|
+{
|
||||||
|
+ return target_read_memory (addr, buf, (LONGEST)len);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
/* Read inferior memory at ADDR to find the header of a loaded object file
|
||||||
|
and read its in-core symbols out of inferior memory. TEMPL is a bfd
|
||||||
|
representing the target's format. NAME is the name to use for this
|
||||||
|
@@ -76,7 +84,7 @@ symbol_file_add_from_memory (struct bfd
|
||||||
|
error (_("add-symbol-file-from-memory not supported for this target"));
|
||||||
|
|
||||||
|
nbfd = bfd_elf_bfd_from_remote_memory (templ, addr, &loadbase,
|
||||||
|
- target_read_memory);
|
||||||
|
+ read_target_memory);
|
||||||
|
if (nbfd == NULL)
|
||||||
|
error (_("Failed to read a valid object file image from memory."));
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/target.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/target.c 2009-02-27 00:04:32.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/target.c 2009-02-28 07:22:09.000000000 +0100
|
||||||
|
@@ -57,7 +57,7 @@ static int nosymbol (char *, CORE_ADDR *
|
||||||
|
|
||||||
|
static void tcomplain (void) ATTR_NORETURN;
|
||||||
|
|
||||||
|
-static int nomemory (CORE_ADDR, char *, int, int, struct target_ops *);
|
||||||
|
+static LONGEST nomemory (CORE_ADDR, char *, int, int, struct target_ops *);
|
||||||
|
|
||||||
|
static int return_zero (void);
|
||||||
|
|
||||||
|
@@ -286,7 +286,7 @@ target_create_inferior (char *exec_file,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
-static int
|
||||||
|
+static LONGEST
|
||||||
|
nomemory (CORE_ADDR memaddr, char *myaddr, int len, int write,
|
||||||
|
struct target_ops *t)
|
||||||
|
{
|
||||||
|
@@ -507,7 +507,7 @@ update_current_target (void)
|
||||||
|
(void (*) (struct regcache *))
|
||||||
|
noprocess);
|
||||||
|
de_fault (deprecated_xfer_memory,
|
||||||
|
- (int (*) (CORE_ADDR, gdb_byte *, int, int, struct mem_attrib *, struct target_ops *))
|
||||||
|
+ (LONGEST (*) (CORE_ADDR, gdb_byte *, LONGEST, int, struct mem_attrib *, struct target_ops *))
|
||||||
|
nomemory);
|
||||||
|
de_fault (to_files_info,
|
||||||
|
(void (*) (struct target_ops *))
|
||||||
|
@@ -1237,7 +1237,7 @@ target_xfer_partial (struct target_ops *
|
||||||
|
it makes no progress, and then return how much was transferred). */
|
||||||
|
|
||||||
|
int
|
||||||
|
-target_read_memory (CORE_ADDR memaddr, gdb_byte *myaddr, int len)
|
||||||
|
+target_read_memory (CORE_ADDR memaddr, gdb_byte *myaddr, LONGEST len)
|
||||||
|
{
|
||||||
|
if (target_read (¤t_target, TARGET_OBJECT_MEMORY, NULL,
|
||||||
|
myaddr, memaddr, len) == len)
|
||||||
|
@@ -1247,7 +1247,7 @@ target_read_memory (CORE_ADDR memaddr, g
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
-target_write_memory (CORE_ADDR memaddr, const gdb_byte *myaddr, int len)
|
||||||
|
+target_write_memory (CORE_ADDR memaddr, const gdb_byte *myaddr, LONGEST len)
|
||||||
|
{
|
||||||
|
if (target_write (¤t_target, TARGET_OBJECT_MEMORY, NULL,
|
||||||
|
myaddr, memaddr, len) == len)
|
||||||
|
@@ -2777,8 +2777,8 @@ debug_to_prepare_to_store (struct regcac
|
||||||
|
fprintf_unfiltered (gdb_stdlog, "target_prepare_to_store ()\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
-static int
|
||||||
|
-deprecated_debug_xfer_memory (CORE_ADDR memaddr, bfd_byte *myaddr, int len,
|
||||||
|
+static LONGEST
|
||||||
|
+deprecated_debug_xfer_memory (CORE_ADDR memaddr, bfd_byte *myaddr, LONGEST len,
|
||||||
|
int write, struct mem_attrib *attrib,
|
||||||
|
struct target_ops *target)
|
||||||
|
{
|
||||||
|
@@ -2788,8 +2788,8 @@ deprecated_debug_xfer_memory (CORE_ADDR
|
||||||
|
attrib, target);
|
||||||
|
|
||||||
|
fprintf_unfiltered (gdb_stdlog,
|
||||||
|
- "target_xfer_memory (%s, xxx, %d, %s, xxx) = %d",
|
||||||
|
- paddress (memaddr), len, write ? "write" : "read",
|
||||||
|
+ "target_xfer_memory (%s, xxx, %ld, %s, xxx) = %d",
|
||||||
|
+ paddress (memaddr), (long) len, write ? "write" : "read",
|
||||||
|
retval);
|
||||||
|
|
||||||
|
if (retval > 0)
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/target.h
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/target.h 2009-02-27 00:04:32.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/target.h 2009-02-28 07:22:09.000000000 +0100
|
||||||
|
@@ -376,10 +376,10 @@ struct target_ops
|
||||||
|
NOTE: cagney/2004-10-01: This has been entirely superseeded by
|
||||||
|
to_xfer_partial and inferior inheritance. */
|
||||||
|
|
||||||
|
- int (*deprecated_xfer_memory) (CORE_ADDR memaddr, gdb_byte *myaddr,
|
||||||
|
- int len, int write,
|
||||||
|
- struct mem_attrib *attrib,
|
||||||
|
- struct target_ops *target);
|
||||||
|
+ LONGEST (*deprecated_xfer_memory) (CORE_ADDR memaddr, gdb_byte *myaddr,
|
||||||
|
+ LONGEST len, int write,
|
||||||
|
+ struct mem_attrib *attrib,
|
||||||
|
+ struct target_ops *target);
|
||||||
|
|
||||||
|
void (*to_files_info) (struct target_ops *);
|
||||||
|
int (*to_insert_breakpoint) (struct bp_target_info *);
|
||||||
|
@@ -679,13 +679,14 @@ extern DCACHE *target_dcache;
|
||||||
|
|
||||||
|
extern int target_read_string (CORE_ADDR, char **, int, int *);
|
||||||
|
|
||||||
|
-extern int target_read_memory (CORE_ADDR memaddr, gdb_byte *myaddr, int len);
|
||||||
|
+extern int target_read_memory (CORE_ADDR memaddr, gdb_byte *myaddr,
|
||||||
|
+ LONGEST len);
|
||||||
|
|
||||||
|
extern int target_write_memory (CORE_ADDR memaddr, const gdb_byte *myaddr,
|
||||||
|
- int len);
|
||||||
|
+ LONGEST len);
|
||||||
|
|
||||||
|
-extern int xfer_memory (CORE_ADDR, gdb_byte *, int, int,
|
||||||
|
- struct mem_attrib *, struct target_ops *);
|
||||||
|
+extern LONGEST xfer_memory (CORE_ADDR, gdb_byte *, LONGEST, int,
|
||||||
|
+ struct mem_attrib *, struct target_ops *);
|
||||||
|
|
||||||
|
/* Fetches the target's memory map. If one is found it is sorted
|
||||||
|
and returned, after some consistency checking. Otherwise, NULL
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/dcache.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/dcache.c 2009-01-03 06:57:51.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/dcache.c 2009-02-28 07:22:09.000000000 +0100
|
||||||
|
@@ -524,9 +524,9 @@ dcache_free (DCACHE *dcache)
|
||||||
|
|
||||||
|
This routine is indended to be called by remote_xfer_ functions. */
|
||||||
|
|
||||||
|
-int
|
||||||
|
+LONGEST
|
||||||
|
dcache_xfer_memory (DCACHE *dcache, CORE_ADDR memaddr, gdb_byte *myaddr,
|
||||||
|
- int len, int should_write)
|
||||||
|
+ LONGEST len, int should_write)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
int (*xfunc) (DCACHE *dcache, CORE_ADDR addr, gdb_byte *ptr);
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/dcache.h
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/dcache.h 2009-01-03 06:57:51.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/dcache.h 2009-02-28 07:22:09.000000000 +0100
|
||||||
|
@@ -35,7 +35,7 @@ void dcache_free (DCACHE *);
|
||||||
|
|
||||||
|
/* Simple to call from <remote>_xfer_memory */
|
||||||
|
|
||||||
|
-int dcache_xfer_memory (DCACHE *cache, CORE_ADDR mem, gdb_byte *my,
|
||||||
|
- int len, int should_write);
|
||||||
|
+LONGEST dcache_xfer_memory (DCACHE *cache, CORE_ADDR mem, gdb_byte *my,
|
||||||
|
+ LONGEST len, int should_write);
|
||||||
|
|
||||||
|
#endif /* DCACHE_H */
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/exec.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/exec.c 2009-02-22 20:35:47.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/exec.c 2009-02-28 07:22:09.000000000 +0100
|
||||||
|
@@ -464,8 +464,8 @@ map_vmap (bfd *abfd, bfd *arch)
|
||||||
|
The same routine is used to handle both core and exec files;
|
||||||
|
we just tail-call it with more arguments to select between them. */
|
||||||
|
|
||||||
|
-int
|
||||||
|
-xfer_memory (CORE_ADDR memaddr, gdb_byte *myaddr, int len, int write,
|
||||||
|
+LONGEST
|
||||||
|
+xfer_memory (CORE_ADDR memaddr, gdb_byte *myaddr, LONGEST len, int write,
|
||||||
|
struct mem_attrib *attrib, struct target_ops *target)
|
||||||
|
{
|
||||||
|
int res;
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/linux-nat.c 2009-02-28 07:22:02.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/linux-nat.c 2009-02-28 07:22:32.000000000 +0100
|
||||||
|
@@ -4407,7 +4407,7 @@ linux_xfer_partial (struct target_ops *o
|
||||||
|
#endif
|
||||||
|
if (iterate_over_lwps (ia64_linux_check_stack_region, &range) != NULL)
|
||||||
|
{ /* This region contains ia64 rse registers, we have to re-read. */
|
||||||
|
- int xxfer;
|
||||||
|
+ LONGEST xxfer;
|
||||||
|
|
||||||
|
/* Re-read register stack area. */
|
||||||
|
xxfer = super_xfer_partial (ops, object, annex,
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/remote.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/remote.c 2009-02-25 03:14:22.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/remote.c 2009-02-28 07:22:09.000000000 +0100
|
||||||
|
@@ -25,6 +25,7 @@
|
||||||
|
#include "gdb_string.h"
|
||||||
|
#include <ctype.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
+#include <limits.h>
|
||||||
|
#include "inferior.h"
|
||||||
|
#include "bfd.h"
|
||||||
|
#include "symfile.h"
|
||||||
|
@@ -5683,12 +5684,19 @@ handle_notification (char *buf, size_t l
|
||||||
|
if SHOULD_WRITE is nonzero. Returns length of data written or
|
||||||
|
read; 0 for error. TARGET is unused. */
|
||||||
|
|
||||||
|
-static int
|
||||||
|
-remote_xfer_memory (CORE_ADDR mem_addr, gdb_byte *buffer, int mem_len,
|
||||||
|
+static LONGEST
|
||||||
|
+remote_xfer_memory (CORE_ADDR mem_addr, gdb_byte *buffer, LONGEST mem_len,
|
||||||
|
int should_write, struct mem_attrib *attrib,
|
||||||
|
struct target_ops *target)
|
||||||
|
{
|
||||||
|
int res;
|
||||||
|
+ int len;
|
||||||
|
+
|
||||||
|
+ /* This routine is not set up to handle > INT_MAX bytes. */
|
||||||
|
+ if (mem_len >= (LONGEST)INT_MAX)
|
||||||
|
+ return 0;
|
||||||
|
+
|
||||||
|
+ len = (int)mem_len;
|
||||||
|
|
||||||
|
set_general_thread (inferior_ptid);
|
||||||
|
|
||||||
|
@@ -5697,7 +5705,7 @@ remote_xfer_memory (CORE_ADDR mem_addr,
|
||||||
|
else
|
||||||
|
res = remote_read_bytes (mem_addr, buffer, mem_len);
|
||||||
|
|
||||||
|
- return res;
|
||||||
|
+ return (LONGEST)res;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Sends a packet with content determined by the printf format string
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/remote-sim.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/remote-sim.c 2009-02-23 19:31:23.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/remote-sim.c 2009-02-28 07:22:09.000000000 +0100
|
||||||
|
@@ -754,11 +754,14 @@ gdbsim_prepare_to_store (struct regcache
|
||||||
|
|
||||||
|
Returns the number of bytes transferred. */
|
||||||
|
|
||||||
|
-static int
|
||||||
|
-gdbsim_xfer_inferior_memory (CORE_ADDR memaddr, gdb_byte *myaddr, int len,
|
||||||
|
+static LONGEST
|
||||||
|
+gdbsim_xfer_inferior_memory (CORE_ADDR memaddr, gdb_byte *myaddr, LONGEST len,
|
||||||
|
int write, struct mem_attrib *attrib,
|
||||||
|
struct target_ops *target)
|
||||||
|
{
|
||||||
|
+ /* Convert to len type that sim_read and sim_write can handle. */
|
||||||
|
+ int xfer_len = (int)len;
|
||||||
|
+
|
||||||
|
/* If no program is running yet, then ignore the simulator for
|
||||||
|
memory. Pass the request down to the next target, hopefully
|
||||||
|
an exec file. */
|
||||||
|
@@ -774,22 +777,22 @@ gdbsim_xfer_inferior_memory (CORE_ADDR m
|
||||||
|
printf_filtered ("gdbsim_xfer_inferior_memory: myaddr 0x");
|
||||||
|
gdb_print_host_address (myaddr, gdb_stdout);
|
||||||
|
printf_filtered (", memaddr 0x%s, len %d, write %d\n",
|
||||||
|
- paddr_nz (memaddr), len, write);
|
||||||
|
+ paddr_nz (memaddr), xfer_len, write);
|
||||||
|
if (remote_debug && write)
|
||||||
|
- dump_mem (myaddr, len);
|
||||||
|
+ dump_mem (myaddr, xfer_len);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (write)
|
||||||
|
{
|
||||||
|
- len = sim_write (gdbsim_desc, memaddr, myaddr, len);
|
||||||
|
+ xfer_len = sim_write (gdbsim_desc, memaddr, myaddr, xfer_len);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
- len = sim_read (gdbsim_desc, memaddr, myaddr, len);
|
||||||
|
- if (remote_debug && len > 0)
|
||||||
|
- dump_mem (myaddr, len);
|
||||||
|
+ xfer_len = sim_read (gdbsim_desc, memaddr, myaddr, xfer_len);
|
||||||
|
+ if (remote_debug && xfer_len > 0)
|
||||||
|
+ dump_mem (myaddr, xfer_len);
|
||||||
|
}
|
||||||
|
- return len;
|
||||||
|
+ return (LONGEST)xfer_len;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
464
gdb-6.3-linespec-20041213.patch
Normal file
464
gdb-6.3-linespec-20041213.patch
Normal file
@ -0,0 +1,464 @@
|
|||||||
|
[base]
|
||||||
|
|
||||||
|
2007-09-21 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* linespec.c (add_minsym_members): Support also the `$allocate' and
|
||||||
|
`$delete' variants.
|
||||||
|
|
||||||
|
2007-10-05 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* linespec.c (add_minsym_members): Support also the `$allocate' and
|
||||||
|
`$delete' variants.
|
||||||
|
(decode_variable): Renamed to ...
|
||||||
|
(decode_variable_1) ... here, its parameter NOT_FOUND_PTR and its
|
||||||
|
exception throwing was moved to ...
|
||||||
|
(decode_variable_not_found): ... a new function here.
|
||||||
|
(decode_variable): New function.
|
||||||
|
|
||||||
|
2007-10-31 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7.
|
||||||
|
|
||||||
|
[ Remove decode_variable* for GDB-6.8+ as no longer needed. ]
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/linespec.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/linespec.c 2008-09-05 13:37:17.000000000 +0200
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/linespec.c 2008-12-04 01:43:36.000000000 +0100
|
||||||
|
@@ -39,6 +39,7 @@
|
||||||
|
#include "interps.h"
|
||||||
|
#include "mi/mi-cmds.h"
|
||||||
|
#include "target.h"
|
||||||
|
+#include "gdb_assert.h"
|
||||||
|
|
||||||
|
/* We share this one with symtab.c, but it is not exported widely. */
|
||||||
|
|
||||||
|
@@ -78,7 +79,8 @@ static struct symtabs_and_lines find_met
|
||||||
|
|
||||||
|
static int collect_methods (char *copy, struct type *t,
|
||||||
|
struct symbol *sym_class,
|
||||||
|
- struct symbol **sym_arr);
|
||||||
|
+ struct symbol **sym_arr,
|
||||||
|
+ struct minimal_symbol **msym_arr);
|
||||||
|
|
||||||
|
static NORETURN void cplusplus_error (const char *name,
|
||||||
|
const char *fmt, ...)
|
||||||
|
@@ -87,11 +89,13 @@ static NORETURN void cplusplus_error (co
|
||||||
|
static int total_number_of_methods (struct type *type);
|
||||||
|
|
||||||
|
static int find_methods (struct type *, char *,
|
||||||
|
- enum language, struct symbol **);
|
||||||
|
+ enum language, struct symbol **,
|
||||||
|
+ struct minimal_symbol **);
|
||||||
|
|
||||||
|
static int add_matching_methods (int method_counter, struct type *t,
|
||||||
|
enum language language,
|
||||||
|
- struct symbol **sym_arr);
|
||||||
|
+ struct symbol **sym_arr,
|
||||||
|
+ struct minimal_symbol **msym_arr);
|
||||||
|
|
||||||
|
static int add_constructors (int method_counter, struct type *t,
|
||||||
|
enum language language,
|
||||||
|
@@ -107,6 +111,9 @@ static int is_objc_method_format (const
|
||||||
|
static struct symtabs_and_lines decode_line_2 (struct symbol *[],
|
||||||
|
int, int, char ***);
|
||||||
|
|
||||||
|
+static struct symtabs_and_lines decode_line_3 (struct minimal_symbol *[],
|
||||||
|
+ int, int, char ***);
|
||||||
|
+
|
||||||
|
static struct symtab *symtab_from_filename (char **argptr,
|
||||||
|
char *p, int is_quote_enclosed,
|
||||||
|
int *not_found_ptr);
|
||||||
|
@@ -196,13 +203,18 @@ total_number_of_methods (struct type *ty
|
||||||
|
/* Recursive helper function for decode_line_1.
|
||||||
|
Look for methods named NAME in type T.
|
||||||
|
Return number of matches.
|
||||||
|
- Put matches in SYM_ARR, which should have been allocated with
|
||||||
|
+ Put symbol matches in SYM_ARR, which should have been allocated with
|
||||||
|
a size of total_number_of_methods (T) * sizeof (struct symbol *).
|
||||||
|
+ In a special case where we are looking for constructors, we may
|
||||||
|
+ have to return minimal symbols in the array: MSYM_ARR. This occurs
|
||||||
|
+ when the compiler does not generate mangled names for the constructor's
|
||||||
|
+ debug info because there are multiple versions of the constructor
|
||||||
|
+ (in-charge vs not-in-charge).
|
||||||
|
Note that this function is g++ specific. */
|
||||||
|
|
||||||
|
static int
|
||||||
|
find_methods (struct type *t, char *name, enum language language,
|
||||||
|
- struct symbol **sym_arr)
|
||||||
|
+ struct symbol **sym_arr, struct minimal_symbol **msym_arr)
|
||||||
|
{
|
||||||
|
int i1 = 0;
|
||||||
|
int ibase;
|
||||||
|
@@ -244,7 +256,7 @@ find_methods (struct type *t, char *name
|
||||||
|
if (strcmp_iw (name, method_name) == 0)
|
||||||
|
/* Find all the overloaded methods with that name. */
|
||||||
|
i1 += add_matching_methods (method_counter, t, language,
|
||||||
|
- sym_arr + i1);
|
||||||
|
+ sym_arr + i1, msym_arr);
|
||||||
|
else if (strncmp (class_name, name, name_len) == 0
|
||||||
|
&& (class_name[name_len] == '\0'
|
||||||
|
|| class_name[name_len] == '<'))
|
||||||
|
@@ -267,21 +279,100 @@ find_methods (struct type *t, char *name
|
||||||
|
if (i1 == 0)
|
||||||
|
for (ibase = 0; ibase < TYPE_N_BASECLASSES (t); ibase++)
|
||||||
|
i1 += find_methods (TYPE_BASECLASS (t, ibase), name,
|
||||||
|
- language, sym_arr + i1);
|
||||||
|
+ language, sym_arr + i1, msym_arr);
|
||||||
|
|
||||||
|
return i1;
|
||||||
|
}
|
||||||
|
|
||||||
|
+static int
|
||||||
|
+add_minsym_members (const char *class_name,
|
||||||
|
+ const char *member_name,
|
||||||
|
+ struct minimal_symbol **msym_arr)
|
||||||
|
+{
|
||||||
|
+ char *completion_name;
|
||||||
|
+ char **list;
|
||||||
|
+ int i;
|
||||||
|
+ int comp_len;
|
||||||
|
+ int counter = 0;
|
||||||
|
+
|
||||||
|
+ /* To find the member, we first cheat and use symbol completion.
|
||||||
|
+ This will give us a list of all the member names including
|
||||||
|
+ the function signature. */
|
||||||
|
+ completion_name = xmalloc (strlen (class_name) +
|
||||||
|
+ strlen (member_name) + 9);
|
||||||
|
+ completion_name[0] = '\'';
|
||||||
|
+ strcpy (completion_name+1, class_name);
|
||||||
|
+ /* FIXME: make this the language class separator. */
|
||||||
|
+ strcat (completion_name, "::");
|
||||||
|
+ strcat (completion_name, member_name);
|
||||||
|
+ strcat (completion_name, "(");
|
||||||
|
+ list = make_symbol_completion_list (completion_name,
|
||||||
|
+ completion_name+1);
|
||||||
|
+
|
||||||
|
+ /* Now that we have the list, we generate an array of their
|
||||||
|
+ corresponding minimal symbols. */
|
||||||
|
+ counter = 0;
|
||||||
|
+ while (list && list[counter] != NULL)
|
||||||
|
+ {
|
||||||
|
+ msym_arr[counter] = lookup_minimal_symbol (list[counter], NULL, NULL);
|
||||||
|
+ ++counter;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ xfree (list);
|
||||||
|
+
|
||||||
|
+ /* In the case of constructors, there may be in-charge vs not-in-charge
|
||||||
|
+ constructors. Check for names with $base which indicates not-in-charge
|
||||||
|
+ constructors. */
|
||||||
|
+ comp_len = strlen (completion_name);
|
||||||
|
+ strcpy (completion_name + comp_len - 1, "$base(");
|
||||||
|
+ list = make_symbol_completion_list (completion_name,
|
||||||
|
+ completion_name+1);
|
||||||
|
+
|
||||||
|
+ /* Again we have a list. Add their minimal symbols to the array. */
|
||||||
|
+ i = 0;
|
||||||
|
+ while (list && list[i] != NULL)
|
||||||
|
+ {
|
||||||
|
+ msym_arr[counter] = lookup_minimal_symbol (list[i++], NULL, NULL);
|
||||||
|
+ ++counter;
|
||||||
|
+ }
|
||||||
|
+ xfree (list);
|
||||||
|
+
|
||||||
|
+ /* Target also the allocating/deleting variants. */
|
||||||
|
+ if (member_name[0] == '~')
|
||||||
|
+ strcpy (completion_name + comp_len - 1, "$delete(");
|
||||||
|
+ else
|
||||||
|
+ strcpy (completion_name + comp_len - 1, "$allocate(");
|
||||||
|
+ list = make_symbol_completion_list (completion_name,
|
||||||
|
+ completion_name+1);
|
||||||
|
+
|
||||||
|
+ /* Again we have a list. Add their minimal symbols to the array. */
|
||||||
|
+ i = 0;
|
||||||
|
+ while (list && list[i] != NULL)
|
||||||
|
+ {
|
||||||
|
+ msym_arr[counter] = lookup_minimal_symbol (list[i++], NULL, NULL);
|
||||||
|
+ ++counter;
|
||||||
|
+ }
|
||||||
|
+ xfree (list);
|
||||||
|
+
|
||||||
|
+ xfree (completion_name);
|
||||||
|
+
|
||||||
|
+ return counter;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
/* Add the symbols associated to methods of the class whose type is T
|
||||||
|
and whose name matches the method indexed by METHOD_COUNTER in the
|
||||||
|
array SYM_ARR. Return the number of methods added. */
|
||||||
|
|
||||||
|
static int
|
||||||
|
add_matching_methods (int method_counter, struct type *t,
|
||||||
|
- enum language language, struct symbol **sym_arr)
|
||||||
|
+ enum language language, struct symbol **sym_arr,
|
||||||
|
+ struct minimal_symbol **msym_arr)
|
||||||
|
{
|
||||||
|
int field_counter;
|
||||||
|
int i1 = 0;
|
||||||
|
+ int cons_index = 0;
|
||||||
|
+ char *class_name = type_name_no_tag (t);
|
||||||
|
+ char **list = NULL;
|
||||||
|
|
||||||
|
for (field_counter = TYPE_FN_FIELDLIST_LENGTH (t, method_counter) - 1;
|
||||||
|
field_counter >= 0;
|
||||||
|
@@ -306,6 +397,16 @@ add_matching_methods (int method_counter
|
||||||
|
else
|
||||||
|
phys_name = TYPE_FN_FIELD_PHYSNAME (f, field_counter);
|
||||||
|
|
||||||
|
+ /* Check for special case of looking for member that
|
||||||
|
+ doesn't have a mangled name provided. This will happen
|
||||||
|
+ when we have in-charge and not-in-charge constructors.
|
||||||
|
+ Since we don't have a mangled name to work with, if we
|
||||||
|
+ look for the symbol, we can only find the class itself.
|
||||||
|
+ We can find the information we need in the minimal symbol
|
||||||
|
+ table which has the full member name information we need. */
|
||||||
|
+ if (strlen (phys_name) <= strlen (class_name))
|
||||||
|
+ return add_minsym_members (class_name, phys_name, msym_arr);
|
||||||
|
+
|
||||||
|
/* Destructor is handled by caller, don't add it to
|
||||||
|
the list. */
|
||||||
|
if (is_destructor_name (phys_name) != 0)
|
||||||
|
@@ -330,6 +431,9 @@ add_matching_methods (int method_counter
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
+ if (list)
|
||||||
|
+ xfree (list);
|
||||||
|
+
|
||||||
|
return i1;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -630,6 +734,146 @@ See set/show multiple-symbol."));
|
||||||
|
discard_cleanups (old_chain);
|
||||||
|
return return_values;
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+/* Given a list of NELTS minimal symbols in MSYM_ARR, return a list of lines to
|
||||||
|
+ operate on (ask user if necessary).
|
||||||
|
+ If CANONICAL is non-NULL return a corresponding array of mangled names
|
||||||
|
+ as canonical line specs there. */
|
||||||
|
+
|
||||||
|
+static struct symtabs_and_lines
|
||||||
|
+decode_line_3 (struct minimal_symbol *msym_arr[],
|
||||||
|
+ int nelts, int funfirstline,
|
||||||
|
+ char ***canonical)
|
||||||
|
+{
|
||||||
|
+ struct symtabs_and_lines values, return_values;
|
||||||
|
+ char *args, *arg1;
|
||||||
|
+ int i;
|
||||||
|
+ char *prompt;
|
||||||
|
+ char *symname;
|
||||||
|
+ struct cleanup *old_chain;
|
||||||
|
+ char **canonical_arr = (char **) NULL;
|
||||||
|
+
|
||||||
|
+ values.sals = (struct symtab_and_line *)
|
||||||
|
+ alloca (nelts * sizeof (struct symtab_and_line));
|
||||||
|
+ return_values.sals = (struct symtab_and_line *)
|
||||||
|
+ xmalloc (nelts * sizeof (struct symtab_and_line));
|
||||||
|
+ old_chain = make_cleanup (xfree, return_values.sals);
|
||||||
|
+
|
||||||
|
+ if (canonical)
|
||||||
|
+ {
|
||||||
|
+ canonical_arr = (char **) xmalloc (nelts * sizeof (char *));
|
||||||
|
+ make_cleanup (xfree, canonical_arr);
|
||||||
|
+ memset (canonical_arr, 0, nelts * sizeof (char *));
|
||||||
|
+ *canonical = canonical_arr;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ i = 0;
|
||||||
|
+ printf_unfiltered ("[0] cancel\n[1] all\n");
|
||||||
|
+ while (i < nelts)
|
||||||
|
+ {
|
||||||
|
+ init_sal (&return_values.sals[i]); /* Initialize to zeroes. */
|
||||||
|
+ init_sal (&values.sals[i]);
|
||||||
|
+ if (msym_arr[i])
|
||||||
|
+ {
|
||||||
|
+ struct symtabs_and_lines msal = minsym_found (funfirstline,
|
||||||
|
+ msym_arr[i]);
|
||||||
|
+ memcpy (&values.sals[i], &msal.sals[0],
|
||||||
|
+ sizeof (struct symtab_and_line));
|
||||||
|
+ if (values.sals[i].symtab)
|
||||||
|
+ printf_unfiltered ("[%d] %s at %s:%d\n",
|
||||||
|
+ (i + 2),
|
||||||
|
+ SYMBOL_PRINT_NAME (msym_arr[i]),
|
||||||
|
+ values.sals[i].symtab->filename,
|
||||||
|
+ values.sals[i].line);
|
||||||
|
+ else
|
||||||
|
+ printf_unfiltered ("[%d] %s at ?FILE:%d [No symtab? Probably broken debug info...]\n",
|
||||||
|
+ (i + 2),
|
||||||
|
+ SYMBOL_PRINT_NAME (msym_arr[i]),
|
||||||
|
+ values.sals[i].line);
|
||||||
|
+
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ printf_unfiltered ("?HERE\n");
|
||||||
|
+ i++;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ prompt = getenv ("PS2");
|
||||||
|
+ if (prompt == NULL)
|
||||||
|
+ {
|
||||||
|
+ prompt = "> ";
|
||||||
|
+ }
|
||||||
|
+ args = command_line_input (prompt, 0, "overload-choice");
|
||||||
|
+
|
||||||
|
+ if (args == 0 || *args == 0)
|
||||||
|
+ error_no_arg ("one or more choice numbers");
|
||||||
|
+
|
||||||
|
+ i = 0;
|
||||||
|
+ while (*args)
|
||||||
|
+ {
|
||||||
|
+ int num;
|
||||||
|
+
|
||||||
|
+ arg1 = args;
|
||||||
|
+ while (*arg1 >= '0' && *arg1 <= '9')
|
||||||
|
+ arg1++;
|
||||||
|
+ if (*arg1 && *arg1 != ' ' && *arg1 != '\t')
|
||||||
|
+ error ("Arguments must be choice numbers.");
|
||||||
|
+
|
||||||
|
+ num = atoi (args);
|
||||||
|
+
|
||||||
|
+ if (num == 0)
|
||||||
|
+ error ("canceled");
|
||||||
|
+ else if (num == 1)
|
||||||
|
+ {
|
||||||
|
+ if (canonical_arr)
|
||||||
|
+ {
|
||||||
|
+ for (i = 0; i < nelts; i++)
|
||||||
|
+ {
|
||||||
|
+ if (canonical_arr[i] == NULL)
|
||||||
|
+ {
|
||||||
|
+ symname = SYMBOL_LINKAGE_NAME (msym_arr[i]);
|
||||||
|
+ canonical_arr[i] = savestring (symname, strlen (symname));
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ memcpy (return_values.sals, values.sals,
|
||||||
|
+ (nelts * sizeof (struct symtab_and_line)));
|
||||||
|
+ return_values.nelts = nelts;
|
||||||
|
+ discard_cleanups (old_chain);
|
||||||
|
+ return return_values;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (num >= nelts + 2)
|
||||||
|
+ {
|
||||||
|
+ printf_unfiltered ("No choice number %d.\n", num);
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ {
|
||||||
|
+ num -= 2;
|
||||||
|
+ if (values.sals[num].pc)
|
||||||
|
+ {
|
||||||
|
+ if (canonical_arr)
|
||||||
|
+ {
|
||||||
|
+ symname = SYMBOL_LINKAGE_NAME (msym_arr[num]);
|
||||||
|
+ make_cleanup (xfree, symname);
|
||||||
|
+ canonical_arr[i] = savestring (symname, strlen (symname));
|
||||||
|
+ }
|
||||||
|
+ return_values.sals[i++] = values.sals[num];
|
||||||
|
+ values.sals[num].pc = 0;
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ {
|
||||||
|
+ printf_unfiltered ("duplicate request for %d ignored.\n", num);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ args = arg1;
|
||||||
|
+ while (*args == ' ' || *args == '\t')
|
||||||
|
+ args++;
|
||||||
|
+ }
|
||||||
|
+ return_values.nelts = i;
|
||||||
|
+ discard_cleanups (old_chain);
|
||||||
|
+ return return_values;
|
||||||
|
+}
|
||||||
|
|
||||||
|
/* The parser of linespec itself. */
|
||||||
|
|
||||||
|
@@ -1438,35 +1682,47 @@ find_method (int funfirstline, char ***c
|
||||||
|
struct symbol **sym_arr = alloca (total_number_of_methods (t)
|
||||||
|
* sizeof (struct symbol *));
|
||||||
|
|
||||||
|
+ struct minimal_symbol **msym_arr = alloca (total_number_of_methods (t)
|
||||||
|
+ * sizeof (struct minimal_symbol *));
|
||||||
|
+
|
||||||
|
+ msym_arr[0] = NULL;
|
||||||
|
+
|
||||||
|
/* Find all methods with a matching name, and put them in
|
||||||
|
sym_arr. */
|
||||||
|
|
||||||
|
- i1 = collect_methods (copy, t, sym_class, sym_arr);
|
||||||
|
+ i1 = collect_methods (copy, t, sym_class, sym_arr, msym_arr);
|
||||||
|
|
||||||
|
if (i1 == 1)
|
||||||
|
{
|
||||||
|
/* There is exactly one field with that name. */
|
||||||
|
- sym = sym_arr[0];
|
||||||
|
-
|
||||||
|
- if (sym && SYMBOL_CLASS (sym) == LOC_BLOCK)
|
||||||
|
- {
|
||||||
|
- values.sals = (struct symtab_and_line *)
|
||||||
|
- xmalloc (sizeof (struct symtab_and_line));
|
||||||
|
- values.nelts = 1;
|
||||||
|
- values.sals[0] = find_function_start_sal (sym,
|
||||||
|
- funfirstline);
|
||||||
|
- }
|
||||||
|
+ if (msym_arr[0] != NULL)
|
||||||
|
+ return minsym_found (funfirstline, msym_arr[0]);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
- values.sals = NULL;
|
||||||
|
- values.nelts = 0;
|
||||||
|
+ sym = sym_arr[0];
|
||||||
|
+
|
||||||
|
+ if (sym && SYMBOL_CLASS (sym) == LOC_BLOCK)
|
||||||
|
+ {
|
||||||
|
+ values.sals = (struct symtab_and_line *)
|
||||||
|
+ xmalloc (sizeof (struct symtab_and_line));
|
||||||
|
+ values.nelts = 1;
|
||||||
|
+ values.sals[0] = find_function_start_sal (sym,
|
||||||
|
+ funfirstline);
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ {
|
||||||
|
+ values.sals = NULL;
|
||||||
|
+ values.nelts = 0;
|
||||||
|
+ }
|
||||||
|
+ return values;
|
||||||
|
}
|
||||||
|
- return values;
|
||||||
|
}
|
||||||
|
if (i1 > 0)
|
||||||
|
{
|
||||||
|
/* There is more than one field with that name
|
||||||
|
(overloaded). Ask the user which one to use. */
|
||||||
|
+ if (msym_arr[0] != NULL)
|
||||||
|
+ return decode_line_3 (msym_arr, i1, funfirstline, canonical);
|
||||||
|
return decode_line_2 (sym_arr, i1, funfirstline, canonical);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
@@ -1493,11 +1748,12 @@ find_method (int funfirstline, char ***c
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Find all methods named COPY in the class whose type is T, and put
|
||||||
|
- them in SYM_ARR. Return the number of methods found. */
|
||||||
|
+ them in SYM_ARR or MSYM_ARR. Return the number of methods found. */
|
||||||
|
|
||||||
|
static int
|
||||||
|
collect_methods (char *copy, struct type *t,
|
||||||
|
- struct symbol *sym_class, struct symbol **sym_arr)
|
||||||
|
+ struct symbol *sym_class, struct symbol **sym_arr,
|
||||||
|
+ struct minimal_symbol **msym_arr)
|
||||||
|
{
|
||||||
|
int i1 = 0; /* Counter for the symbol array. */
|
||||||
|
|
||||||
|
@@ -1518,7 +1774,7 @@ collect_methods (char *copy, struct type
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
- i1 = find_methods (t, copy, SYMBOL_LANGUAGE (sym_class), sym_arr);
|
||||||
|
+ i1 = find_methods (t, copy, SYMBOL_LANGUAGE (sym_class), sym_arr, msym_arr);
|
||||||
|
|
||||||
|
return i1;
|
||||||
|
}
|
221
gdb-6.3-mapping-zero-inode-test.patch
Normal file
221
gdb-6.3-mapping-zero-inode-test.patch
Normal file
@ -0,0 +1,221 @@
|
|||||||
|
--- /dev/null 2008-05-02 23:36:22.370004160 +0200
|
||||||
|
+++ gdb-6.8/gdb/testsuite/gdb.base/gcore-shmid0.exp 2008-05-03 22:36:56.000000000 +0200
|
||||||
|
@@ -0,0 +1,120 @@
|
||||||
|
+# Copyright 2007 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
|
||||||
|
+
|
||||||
|
+# Test GDB's handling of gcore for mapping with a name but zero inode.
|
||||||
|
+
|
||||||
|
+set testfile "gcore-shmid0"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
+ untested gcore.exp
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Start with a fresh gdb.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+# Does this gdb support gcore?
|
||||||
|
+send_gdb "help gcore\n"
|
||||||
|
+gdb_expect {
|
||||||
|
+ -re "Undefined command: .gcore.*$gdb_prompt $" {
|
||||||
|
+ # gcore command not supported -- nothing to test here.
|
||||||
|
+ unsupported "gdb does not support gcore on this target"
|
||||||
|
+ return -1;
|
||||||
|
+ }
|
||||||
|
+ -re "Save a core file .*$gdb_prompt $" {
|
||||||
|
+ pass "help gcore"
|
||||||
|
+ }
|
||||||
|
+ -re ".*$gdb_prompt $" {
|
||||||
|
+ fail "help gcore"
|
||||||
|
+ }
|
||||||
|
+ timeout {
|
||||||
|
+ fail "help gcore (timeout)"
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if { ! [ runto_main ] } then {
|
||||||
|
+ untested gcore-shmid0.exp
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_breakpoint "initialized"
|
||||||
|
+gdb_breakpoint "unresolved"
|
||||||
|
+
|
||||||
|
+set test "Continue to initialized."
|
||||||
|
+gdb_test_multiple "continue" $test {
|
||||||
|
+ -re "Breakpoint .*, initialized .* at .*\r\n$gdb_prompt $" {
|
||||||
|
+ pass $test
|
||||||
|
+ }
|
||||||
|
+ -re "Breakpoint .*, unresolved .* at .*\r\n$gdb_prompt $" {
|
||||||
|
+ unsupported $test
|
||||||
|
+ return -1
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set escapedfilename [string_to_regexp ${objdir}/${subdir}/gcore-shmid0.test]
|
||||||
|
+
|
||||||
|
+set test "save a corefile"
|
||||||
|
+gdb_test_multiple "gcore ${objdir}/${subdir}/gcore-shmid0.test" $test {
|
||||||
|
+ -re "Saved corefile ${escapedfilename}\[\r\n\]+$gdb_prompt $" {
|
||||||
|
+ pass $test
|
||||||
|
+ }
|
||||||
|
+ -re "Can't create a corefile\[\r\n\]+$gdb_prompt $" {
|
||||||
|
+ unsupported $test
|
||||||
|
+ }
|
||||||
|
+ eof {
|
||||||
|
+ fail $test
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Be sure to remove the handle first.
|
||||||
|
+# But it would get removed even on a kill by GDB as the handle is already
|
||||||
|
+# deleted, just it is still attached.
|
||||||
|
+gdb_continue_to_end "finish"
|
||||||
|
+
|
||||||
|
+set test "core-file command"
|
||||||
|
+gdb_test_multiple "core-file $objdir/$subdir/gcore-shmid0.test" $test {
|
||||||
|
+ -re ".* program is being debugged already.*y or n. $" {
|
||||||
|
+ # gdb_load may connect us to a gdbserver.
|
||||||
|
+ send_gdb "y\n"
|
||||||
|
+ exp_continue;
|
||||||
|
+ }
|
||||||
|
+ -re "Core was generated by .*\r\n\#0 .*\\\(\\\).*\r\n$gdb_prompt $" {
|
||||||
|
+ # The filename does not fit there anyway so do not check it.
|
||||||
|
+ pass $test
|
||||||
|
+ }
|
||||||
|
+ -re ".*registers from core file: File in wrong format.* $" {
|
||||||
|
+ fail "core-file command (could not read registers from core file)"
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set test "backtrace"
|
||||||
|
+gdb_test_multiple "bt" $test {
|
||||||
|
+ -re "#0 *initialized \\\(\\\) at .*#1 .* main \\\(.*$gdb_prompt $" {
|
||||||
|
+ pass $test
|
||||||
|
+ }
|
||||||
|
+ -re "#0 *initialized \\\(\\\) at .*Cannot access memory at address .*$gdb_prompt $" {
|
||||||
|
+ fail $test
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
--- /dev/null 2008-05-02 23:36:22.370004160 +0200
|
||||||
|
+++ gdb-6.8/gdb/testsuite/gdb.base/gcore-shmid0.c 2008-05-03 22:39:10.000000000 +0200
|
||||||
|
@@ -0,0 +1,95 @@
|
||||||
|
+/* Copyright 2007 Free Software Foundation, Inc.
|
||||||
|
+
|
||||||
|
+ This file is part of GDB.
|
||||||
|
+
|
||||||
|
+ 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. */
|
||||||
|
+
|
||||||
|
+/*
|
||||||
|
+ * Test GDB's handling of gcore for mapping with a name but zero inode.
|
||||||
|
+ */
|
||||||
|
+
|
||||||
|
+#include <sys/ipc.h>
|
||||||
|
+#include <sys/shm.h>
|
||||||
|
+#include <stdio.h>
|
||||||
|
+#include <errno.h>
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
+#include <assert.h>
|
||||||
|
+
|
||||||
|
+/* We need a backtrace through the stack. */
|
||||||
|
+
|
||||||
|
+static void
|
||||||
|
+initialized (void)
|
||||||
|
+{
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void
|
||||||
|
+unresolved (void)
|
||||||
|
+{
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int
|
||||||
|
+main (void)
|
||||||
|
+{
|
||||||
|
+ int sid;
|
||||||
|
+ unsigned int *addr = (void *) -1L;
|
||||||
|
+ int try;
|
||||||
|
+
|
||||||
|
+ /* The generated SID will cycle with an increment of 32768, try until it
|
||||||
|
+ * wraps to 0. */
|
||||||
|
+
|
||||||
|
+ for (try = 0; addr == (void *) -1L; try++)
|
||||||
|
+ {
|
||||||
|
+ /* At least kernel-2.6.25-8.fc9.x86_64 just never returns the value 0 by
|
||||||
|
+ shmget(2). */
|
||||||
|
+ if (try > 0x10000)
|
||||||
|
+ {
|
||||||
|
+ printf ("Problem no longer reproducible on this kernel (try %d)\n",
|
||||||
|
+ try);
|
||||||
|
+ unresolved ();
|
||||||
|
+ exit (1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ sid = shmget ((key_t) rand (), 0x1000, IPC_CREAT | IPC_EXCL | 0777);
|
||||||
|
+ if (sid == -1)
|
||||||
|
+ {
|
||||||
|
+ printf ("shmget (%d, 0x1000, IPC_CREAT): errno %d\n", 0, errno);
|
||||||
|
+ exit (1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /* Use SID only if it is 0, retry it otherwise. */
|
||||||
|
+
|
||||||
|
+ if (sid == 0)
|
||||||
|
+ {
|
||||||
|
+ addr = shmat (sid, NULL, SHM_RND);
|
||||||
|
+ if (addr == (void *) -1L)
|
||||||
|
+ {
|
||||||
|
+ printf ("shmat (%d, NULL, SHM_RND): errno %d\n", sid,
|
||||||
|
+ errno);
|
||||||
|
+ exit (1);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ if (shmctl (sid, IPC_RMID, NULL) != 0)
|
||||||
|
+ {
|
||||||
|
+ printf ("shmctl (%d, IPC_RMID, NULL): errno %d\n", sid, errno);
|
||||||
|
+ exit (1);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ initialized ();
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
119
gdb-6.3-nonthreaded-wp-20050117.patch
Normal file
119
gdb-6.3-nonthreaded-wp-20050117.patch
Normal file
@ -0,0 +1,119 @@
|
|||||||
|
[base]
|
||||||
|
|
||||||
|
2007-10-13 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* linux-nat.c (iterate_over_lwps): Fixed missing LWP initialization for
|
||||||
|
current INFERIOR_PTID.
|
||||||
|
|
||||||
|
2007-10-13 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.base/follow-child.exp, gdb.base/follow-child.c: New files.
|
||||||
|
|
||||||
|
2007-10-16 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7.
|
||||||
|
|
||||||
|
2008-02-24 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.8pre.
|
||||||
|
|
||||||
|
2008-08-25 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Remove the fix as causing an assertion failure for
|
||||||
|
gdb.base/checkpoint.exp and it is no longer needed for
|
||||||
|
gdb.base/follow-child.exp .
|
||||||
|
|
||||||
|
Index: gdb-6.8cvs20080219/gdb/testsuite/gdb.base/follow-child.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8cvs20080219/gdb/testsuite/gdb.base/follow-child.c 2008-02-22 08:14:04.000000000 +0100
|
||||||
|
@@ -0,0 +1,29 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2007 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 */
|
||||||
|
+
|
||||||
|
+#include <unistd.h>
|
||||||
|
+
|
||||||
|
+int main()
|
||||||
|
+{
|
||||||
|
+ fork ();
|
||||||
|
+ sleep (60);
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
Index: gdb-6.8cvs20080219/gdb/testsuite/gdb.base/follow-child.exp
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8cvs20080219/gdb/testsuite/gdb.base/follow-child.exp 2008-02-22 08:14:17.000000000 +0100
|
||||||
|
@@ -0,0 +1,55 @@
|
||||||
|
+# Copyright 2007 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.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+set testfile follow-child
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
+ untested "Couldn't compile test program"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Get things started.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+# For C programs, "start" should stop in main().
|
||||||
|
+
|
||||||
|
+gdb_test "set follow-fork-mode child" ""
|
||||||
|
+set test "started"
|
||||||
|
+# GDB_RUN_CMD already checks for `Starting program:'.
|
||||||
|
+gdb_run_cmd
|
||||||
|
+sleep 5
|
||||||
|
+send_gdb "\003"
|
||||||
|
+set test "break"
|
||||||
|
+gdb_test_multiple "" $test {
|
||||||
|
+ -re "Program received signal SIGINT.*$gdb_prompt $" {
|
||||||
|
+ pass $test
|
||||||
|
+ }
|
||||||
|
+ -re "\\\[New process \[0-9\]+\\\]" {
|
||||||
|
+ fail $test
|
||||||
|
+ }
|
||||||
|
+}
|
1441
gdb-6.3-pie-20050110.patch
Normal file
1441
gdb-6.3-pie-20050110.patch
Normal file
File diff suppressed because it is too large
Load Diff
24
gdb-6.3-ppc64displaysymbol-20041124.patch
Normal file
24
gdb-6.3-ppc64displaysymbol-20041124.patch
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
2004-11-24 Andrew Cagney <cagney@gnu.org>
|
||||||
|
|
||||||
|
* printcmd.c (build_address_symbolic): Find a section for the
|
||||||
|
address.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/printcmd.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/printcmd.c 2008-12-04 01:36:05.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/printcmd.c 2008-12-04 01:37:18.000000000 +0100
|
||||||
|
@@ -616,6 +616,14 @@ build_address_symbolic (CORE_ADDR addr,
|
||||||
|
addr = overlay_mapped_address (addr, section);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
+ /* To ensure that the symbol returned belongs to the correct setion
|
||||||
|
+ (and that the last [random] symbol from the previous section
|
||||||
|
+ isn't returned) try to find the section containing PC. First try
|
||||||
|
+ the overlay code (which by default returns NULL); and second try
|
||||||
|
+ the normal section code (which almost always succeeds). */
|
||||||
|
+ section = find_pc_overlay (addr);
|
||||||
|
+ if (section == NULL)
|
||||||
|
+ section = find_pc_section (addr);
|
||||||
|
|
||||||
|
/* First try to find the address in the symbol table, then
|
||||||
|
in the minsyms. Take the closest one. */
|
110
gdb-6.3-ppc64syscall-20040622.patch
Normal file
110
gdb-6.3-ppc64syscall-20040622.patch
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
2004-06-22 Andrew Cagney <cagney@gnu.org>
|
||||||
|
|
||||||
|
* rs6000-tdep.c (struct rs6000_framedata): Add field "func_start".
|
||||||
|
(skip_prologue): Delete local variable "orig_pc", use
|
||||||
|
"func_start". Add local variable "num_skip_linux_syscall_insn",
|
||||||
|
use to skip over first half of a GNU/Linux syscall and update
|
||||||
|
"func_start".
|
||||||
|
|
||||||
|
Index: gdb-6.8/gdb/rs6000-tdep.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.orig/gdb/rs6000-tdep.c 2008-02-20 15:34:43.000000000 +0100
|
||||||
|
+++ gdb-6.8/gdb/rs6000-tdep.c 2008-07-14 10:25:29.000000000 +0200
|
||||||
|
@@ -124,6 +124,7 @@ static const char *powerpc_vector_abi_st
|
||||||
|
|
||||||
|
struct rs6000_framedata
|
||||||
|
{
|
||||||
|
+ CORE_ADDR func_start; /* True function start. */
|
||||||
|
int offset; /* total size of frame --- the distance
|
||||||
|
by which we decrement sp to allocate
|
||||||
|
the frame */
|
||||||
|
@@ -1262,7 +1263,6 @@ static CORE_ADDR
|
||||||
|
skip_prologue (struct gdbarch *gdbarch, CORE_ADDR pc, CORE_ADDR lim_pc,
|
||||||
|
struct rs6000_framedata *fdata)
|
||||||
|
{
|
||||||
|
- CORE_ADDR orig_pc = pc;
|
||||||
|
CORE_ADDR last_prologue_pc = pc;
|
||||||
|
CORE_ADDR li_found_pc = 0;
|
||||||
|
gdb_byte buf[4];
|
||||||
|
@@ -1280,11 +1280,13 @@ skip_prologue (struct gdbarch *gdbarch,
|
||||||
|
int minimal_toc_loaded = 0;
|
||||||
|
int prev_insn_was_prologue_insn = 1;
|
||||||
|
int num_skip_non_prologue_insns = 0;
|
||||||
|
+ int num_skip_ppc64_gnu_linux_syscall_insn = 0;
|
||||||
|
int r0_contains_arg = 0;
|
||||||
|
const struct bfd_arch_info *arch_info = gdbarch_bfd_arch_info (gdbarch);
|
||||||
|
struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
|
||||||
|
|
||||||
|
memset (fdata, 0, sizeof (struct rs6000_framedata));
|
||||||
|
+ fdata->func_start = pc;
|
||||||
|
fdata->saved_gpr = -1;
|
||||||
|
fdata->saved_fpr = -1;
|
||||||
|
fdata->saved_vr = -1;
|
||||||
|
@@ -1313,6 +1315,55 @@ skip_prologue (struct gdbarch *gdbarch,
|
||||||
|
break;
|
||||||
|
op = extract_unsigned_integer (buf, 4);
|
||||||
|
|
||||||
|
+ /* A PPC64 GNU/Linux system call function is split into two
|
||||||
|
+ sub-functions: a non-threaded fast-path (__NAME_nocancel)
|
||||||
|
+ which does not use a frame; and a threaded slow-path
|
||||||
|
+ (Lpseudo_cancel) that does create a frame. Ref:
|
||||||
|
+ nptl/sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h
|
||||||
|
+
|
||||||
|
+ *INDENT-OFF*
|
||||||
|
+ NAME:
|
||||||
|
+ SINGLE_THREAD_P
|
||||||
|
+ bne- .Lpseudo_cancel
|
||||||
|
+ __NAME_nocancel:
|
||||||
|
+ li r0,162
|
||||||
|
+ sc
|
||||||
|
+ bnslr+
|
||||||
|
+ b 0x7fe014ef64 <.__syscall_error>
|
||||||
|
+ Lpseudo_cancel:
|
||||||
|
+ stdu r1,-128(r1)
|
||||||
|
+ ...
|
||||||
|
+ *INDENT-ON*
|
||||||
|
+
|
||||||
|
+ Unfortunatly, because the latter case uses a local label (not
|
||||||
|
+ in the symbol table) a PC in "Lpseudo_cancel" appears to be
|
||||||
|
+ in "__NAME_nocancel". The following code recognizes this,
|
||||||
|
+ adjusting FUNC_START to point to where "Lpseudo_cancel"
|
||||||
|
+ should be, and parsing the prologue sequence as if
|
||||||
|
+ "Lpseudo_cancel" was the entry point. */
|
||||||
|
+
|
||||||
|
+ if (((op & 0xffff0000) == 0x38000000 /* li r0,N */
|
||||||
|
+ && pc == fdata->func_start + 0
|
||||||
|
+ && num_skip_ppc64_gnu_linux_syscall_insn == 0)
|
||||||
|
+ || (op == 0x44000002 /* sc */
|
||||||
|
+ && pc == fdata->func_start + 4
|
||||||
|
+ && num_skip_ppc64_gnu_linux_syscall_insn == 1)
|
||||||
|
+ || (op == 0x4ca30020 /* bnslr+ */
|
||||||
|
+ && pc == fdata->func_start + 8
|
||||||
|
+ && num_skip_ppc64_gnu_linux_syscall_insn == 2))
|
||||||
|
+ {
|
||||||
|
+ num_skip_ppc64_gnu_linux_syscall_insn++;
|
||||||
|
+ continue;
|
||||||
|
+ }
|
||||||
|
+ else if ((op & 0xfc000003) == 0x48000000 /* b __syscall_error */
|
||||||
|
+ && pc == fdata->func_start + 12
|
||||||
|
+ && num_skip_ppc64_gnu_linux_syscall_insn == 3)
|
||||||
|
+ {
|
||||||
|
+ num_skip_ppc64_gnu_linux_syscall_insn = -1;
|
||||||
|
+ fdata->func_start = pc;
|
||||||
|
+ continue;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
if ((op & 0xfc1fffff) == 0x7c0802a6)
|
||||||
|
{ /* mflr Rx */
|
||||||
|
/* Since shared library / PIC code, which needs to get its
|
||||||
|
@@ -1486,9 +1537,9 @@ skip_prologue (struct gdbarch *gdbarch,
|
||||||
|
we have no line table information or the line info tells
|
||||||
|
us that the subroutine call is not part of the line
|
||||||
|
associated with the prologue. */
|
||||||
|
- if ((pc - orig_pc) > 8)
|
||||||
|
+ if ((pc - fdata->func_start) > 8)
|
||||||
|
{
|
||||||
|
- struct symtab_and_line prologue_sal = find_pc_line (orig_pc, 0);
|
||||||
|
+ struct symtab_and_line prologue_sal = find_pc_line (fdata->func_start, 0);
|
||||||
|
struct symtab_and_line this_sal = find_pc_line (pc, 0);
|
||||||
|
|
||||||
|
if ((prologue_sal.line == 0) || (prologue_sal.line != this_sal.line))
|
31
gdb-6.3-ppcdotsolib-20041022.patch
Normal file
31
gdb-6.3-ppcdotsolib-20041022.patch
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
2004-10-22 Andrew Cagney <cagney@gnu.org>
|
||||||
|
|
||||||
|
* solib-svr4.c (enable_break): Convert a symbol descriptor into
|
||||||
|
the corresponding function entry point.
|
||||||
|
(solib_break_names): Delete "._dl_debug_state", no longer needed.
|
||||||
|
|
||||||
|
2007-10-12 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7.
|
||||||
|
|
||||||
|
Index: gdb-6.7/gdb/solib-svr4.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.7.orig/gdb/solib-svr4.c 2007-10-09 20:03:30.000000000 +0200
|
||||||
|
+++ gdb-6.7/gdb/solib-svr4.c 2007-10-12 22:34:03.000000000 +0200
|
||||||
|
@@ -1089,7 +1089,15 @@ enable_break (void)
|
||||||
|
{
|
||||||
|
sym_addr = bfd_lookup_symbol (tmp_bfd, *bkpt_namep);
|
||||||
|
if (sym_addr != 0)
|
||||||
|
- break;
|
||||||
|
+ {
|
||||||
|
+ /* The symbol might be a descriptor, convert to into the
|
||||||
|
+ corresponding code address. */
|
||||||
|
+ sym_addr = gdbarch_convert_from_func_ptr_addr (current_gdbarch,
|
||||||
|
+ sym_addr,
|
||||||
|
+ tmp_bfd_target);
|
||||||
|
+ if (sym_addr != 0)
|
||||||
|
+ break;
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sym_addr != 0)
|
96
gdb-6.3-readnever-20050907.patch
Normal file
96
gdb-6.3-readnever-20050907.patch
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
2004-11-18 Andrew Cagney <cagney@gnu.org>
|
||||||
|
|
||||||
|
* dwarf2read.c: Include "top.c".
|
||||||
|
(dwarf2_has_info): Check for readnever_symbol_files.
|
||||||
|
* symfile.c (readnever_symbol_files): Define.
|
||||||
|
* top.h (readnever_symbol_files): Declare.
|
||||||
|
* main.c (captured_main): Add --readnever option.
|
||||||
|
(print_gdb_help): Ditto.
|
||||||
|
|
||||||
|
2004-11-18 Andrew Cagney <cagney@gnu.org>
|
||||||
|
|
||||||
|
* gdb.texinfo (File Options): Document --readnever.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20090228/gdb/doc/gdb.texinfo
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090228.orig/gdb/doc/gdb.texinfo 2009-03-02 01:01:15.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090228/gdb/doc/gdb.texinfo 2009-03-02 01:01:23.000000000 +0100
|
||||||
|
@@ -988,6 +988,12 @@ Read each symbol file's entire symbol ta
|
||||||
|
the default, which is to read it incrementally as it is needed.
|
||||||
|
This makes startup slower, but makes future operations faster.
|
||||||
|
|
||||||
|
+@item --readnever
|
||||||
|
+@cindex @code{--readnever}
|
||||||
|
+Do not read each symbol file's symbolic debug information. This makes
|
||||||
|
+startup faster but at the expense of not being able to perform
|
||||||
|
+symbolic debugging.
|
||||||
|
+
|
||||||
|
@end table
|
||||||
|
|
||||||
|
@node Mode Options
|
||||||
|
Index: gdb-6.8.50.20090228/gdb/main.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090228.orig/gdb/main.c 2009-03-02 01:01:17.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090228/gdb/main.c 2009-03-02 01:01:23.000000000 +0100
|
||||||
|
@@ -427,6 +427,7 @@ captured_main (void *data)
|
||||||
|
{"xdb", no_argument, &xdb_commands, 1},
|
||||||
|
{"dbx", no_argument, &dbx_commands, 1},
|
||||||
|
{"readnow", no_argument, &readnow_symbol_files, 1},
|
||||||
|
+ {"readnever", no_argument, &readnever_symbol_files, 1},
|
||||||
|
{"r", no_argument, &readnow_symbol_files, 1},
|
||||||
|
{"quiet", no_argument, &quiet, 1},
|
||||||
|
{"q", no_argument, &quiet, 1},
|
||||||
|
@@ -1070,6 +1071,7 @@ Options:\n\n\
|
||||||
|
fputs_unfiltered (_("\
|
||||||
|
--quiet Do not print version number on startup.\n\
|
||||||
|
--readnow Fully read symbol files on first access.\n\
|
||||||
|
+ --readnever Do not read symbol files.\n\
|
||||||
|
"), stream);
|
||||||
|
fputs_unfiltered (_("\
|
||||||
|
--se=FILE Use FILE as symbol file and executable file.\n\
|
||||||
|
Index: gdb-6.8.50.20090228/gdb/symfile.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090228.orig/gdb/symfile.c 2009-03-02 01:01:17.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090228/gdb/symfile.c 2009-03-02 01:01:23.000000000 +0100
|
||||||
|
@@ -77,6 +77,7 @@ static void clear_symtab_users_cleanup (
|
||||||
|
|
||||||
|
/* Global variables owned by this file */
|
||||||
|
int readnow_symbol_files; /* Read full symbols immediately */
|
||||||
|
+int readnever_symbol_files; /* Never read full symbols. */
|
||||||
|
|
||||||
|
/* External variables and functions referenced. */
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20090228/gdb/dwarf2read.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090228.orig/gdb/dwarf2read.c 2009-03-02 01:01:15.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090228/gdb/dwarf2read.c 2009-03-02 01:01:36.000000000 +0100
|
||||||
|
@@ -49,6 +49,7 @@
|
||||||
|
#include "f-lang.h"
|
||||||
|
#include "c-lang.h"
|
||||||
|
#include "typeprint.h"
|
||||||
|
+#include "top.h"
|
||||||
|
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include "gdb_string.h"
|
||||||
|
@@ -1161,7 +1162,8 @@ dwarf2_has_info (struct objfile *objfile
|
||||||
|
dwarf_aranges_section = 0;
|
||||||
|
|
||||||
|
bfd_map_over_sections (objfile->obfd, dwarf2_locate_sections, &update_sizes);
|
||||||
|
- return (dwarf_info_section != NULL && dwarf_abbrev_section != NULL);
|
||||||
|
+ return !readnever_symbol_files
|
||||||
|
+ && dwarf_info_section != NULL && dwarf_abbrev_section != NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* When loading sections, we can either look for ".<name>", or for
|
||||||
|
Index: gdb-6.8.50.20090228/gdb/top.h
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090228.orig/gdb/top.h 2009-01-03 06:57:53.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090228/gdb/top.h 2009-03-02 01:01:23.000000000 +0100
|
||||||
|
@@ -59,6 +59,7 @@ extern void set_prompt (char *);
|
||||||
|
|
||||||
|
/* From random places. */
|
||||||
|
extern int readnow_symbol_files;
|
||||||
|
+extern int readnever_symbol_files;
|
||||||
|
|
||||||
|
/* Perform _initialize initialization */
|
||||||
|
extern void gdb_init (char *);
|
29
gdb-6.3-removebp-20041130.patch
Normal file
29
gdb-6.3-removebp-20041130.patch
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
2004-11-30 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* breakpoint.c (remove_breakpoints): Continue removing breakpoints
|
||||||
|
even if an error occurs. Remove a failure code for the last failure
|
||||||
|
only.
|
||||||
|
|
||||||
|
--- gdb+dejagnu-20040607/gdb/breakpoint.c.fix2 Tue Nov 30 18:01:33 2004
|
||||||
|
+++ gdb+dejagnu-20040607/gdb/breakpoint.c Tue Nov 30 18:06:01 2004
|
||||||
|
@@ -1297,6 +1297,7 @@ remove_breakpoints (void)
|
||||||
|
{
|
||||||
|
struct bp_location *b;
|
||||||
|
int val;
|
||||||
|
+ int return_val = 0;
|
||||||
|
|
||||||
|
ALL_BP_LOCATIONS (b)
|
||||||
|
{
|
||||||
|
@@ -1304,10 +1305,10 @@ remove_breakpoints (void)
|
||||||
|
{
|
||||||
|
val = remove_breakpoint (b, mark_uninserted);
|
||||||
|
if (val != 0)
|
||||||
|
- return val;
|
||||||
|
+ return_val = val;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
- return 0;
|
||||||
|
+ return return_val;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
22
gdb-6.3-rh-dummykfail-20041202.patch
Normal file
22
gdb-6.3-rh-dummykfail-20041202.patch
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
2003-07-11 Elena Zannoni <ezannoni@redhat.com>
|
||||||
|
|
||||||
|
* lib/gdb.exp (setup_kfail, kfail): Redefine procedures.
|
||||||
|
|
||||||
|
--- ./gdb/testsuite/lib/gdb.exp.1 2004-11-24 15:59:46.131394720 -0500
|
||||||
|
+++ ./gdb/testsuite/lib/gdb.exp 2004-11-24 16:01:06.304206600 -0500
|
||||||
|
@@ -63,6 +63,15 @@
|
||||||
|
|
||||||
|
### Only procedures should come after this point.
|
||||||
|
|
||||||
|
+if {![llength [info procs kfail]]} {
|
||||||
|
+ proc setup_kfail { args } {
|
||||||
|
+ #setup_xfail args
|
||||||
|
+ }
|
||||||
|
+ proc kfail { bugid message } {
|
||||||
|
+ fail $message
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
#
|
||||||
|
# gdb_version -- extract and print the version number of GDB
|
||||||
|
#
|
76
gdb-6.3-rh-testlibunwind-20041202.patch
Normal file
76
gdb-6.3-rh-testlibunwind-20041202.patch
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
2003-11-17 Elena Zannoni <ezannoni@redhat.com>
|
||||||
|
|
||||||
|
From Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
* gdb.arch/ia64-libunwind.exp: New file.
|
||||||
|
* gdb.arch/ia64-libunwind.c: New file.
|
||||||
|
|
||||||
|
--- /dev/null Thu Apr 11 10:25:15 2002
|
||||||
|
+++ gdb+dejagnu-20040223/gdb/testsuite/gdb.arch/ia64-libunwind.exp Mon Nov 17 15:57:04 2003
|
||||||
|
@@ -0,0 +1,55 @@
|
||||||
|
+# 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
|
||||||
|
+
|
||||||
|
+# This file was written by Jeff Johnston (jjohnstn@redhat.com)
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+#
|
||||||
|
+# test running programs
|
||||||
|
+#
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+if ![istarget "ia64-*-*"] then {
|
||||||
|
+ return
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "ia64-libunwind"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug additional_flags=-w}] != "" } {
|
||||||
|
+ gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if [get_compiler_info ${binfile}] {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+send_gdb "set debug arch 1\n"
|
||||||
|
+send_gdb "break main\n"
|
||||||
|
+gdb_test "run" ".*acquire_unwind_info.*"
|
||||||
|
+
|
||||||
|
--- /dev/null Thu Apr 11 10:25:15 2002
|
||||||
|
+++ gdb+dejagnu-20040223/gdb/testsuite/gdb.arch/ia64-libunwind.c Mon Nov 17 15:58:27 2003
|
||||||
|
@@ -0,0 +1,9 @@
|
||||||
|
+#include <stdio.h>
|
||||||
|
+
|
||||||
|
+int main()
|
||||||
|
+{
|
||||||
|
+ printf ("hello world\n");
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
14
gdb-6.3-rh-testlibunwind1fix-20041202.patch
Normal file
14
gdb-6.3-rh-testlibunwind1fix-20041202.patch
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
2004-08-03 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* gdb.arch/ia64-libunwind.exp: Fix test string to match
|
||||||
|
current code base.
|
||||||
|
|
||||||
|
--- gdb+dejagnu-20040607/gdb/testsuite/gdb.arch/ia64-libunwind.exp.fix Tue Aug 3 18:29:22 2004
|
||||||
|
+++ gdb+dejagnu-20040607/gdb/testsuite/gdb.arch/ia64-libunwind.exp Tue Aug 3 18:41:01 2004
|
||||||
|
@@ -51,5 +51,5 @@ gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
gdb_load ${binfile}
|
||||||
|
send_gdb "set debug arch 1\n"
|
||||||
|
send_gdb "break main\n"
|
||||||
|
-gdb_test "run" ".*acquire_unwind_info.*"
|
||||||
|
+gdb_test "run" ".*ia64_find_proc_info_x.*"
|
||||||
|
|
19
gdb-6.3-rh-testversion-20041202.patch
Normal file
19
gdb-6.3-rh-testversion-20041202.patch
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
2003-02-24 Elena Zannoni <ezannoni@redhat.com>
|
||||||
|
|
||||||
|
* gdb.gdb/selftest.exp: Add matching on specific Red Hat only version
|
||||||
|
string.
|
||||||
|
|
||||||
|
Index: gdb-6.8/gdb/testsuite/gdb.gdb/selftest.exp
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.orig/gdb/testsuite/gdb.gdb/selftest.exp 2008-01-26 14:56:37.000000000 +0100
|
||||||
|
+++ gdb-6.8/gdb/testsuite/gdb.gdb/selftest.exp 2008-07-14 10:23:50.000000000 +0200
|
||||||
|
@@ -354,6 +354,9 @@ proc test_with_self { executable } {
|
||||||
|
-re ".\[0-9\]+ = +.+ +0x.*\[0-9.\]+.*$gdb_prompt $" {
|
||||||
|
pass "printed version with cast"
|
||||||
|
}
|
||||||
|
+ -re ".\[0-9\]+ = .Fedora \[\\(\\)0-9.a-z\\-\]+.*$gdb_prompt $" {
|
||||||
|
+ pass "printed version Fedora only"
|
||||||
|
+ }
|
||||||
|
-re ".*$gdb_prompt $" { fail "printed version" }
|
||||||
|
timeout { fail "(timeout) printed version" }
|
||||||
|
}
|
211
gdb-6.3-security-errata-20050610.patch
Normal file
211
gdb-6.3-security-errata-20050610.patch
Normal file
@ -0,0 +1,211 @@
|
|||||||
|
http://sourceware.org/ml/gdb-patches/2005-05/threads.html#00637
|
||||||
|
Proposed upstream but never committed upstream.
|
||||||
|
|
||||||
|
2005-06-09 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* gdb.base/gdbinit.exp: New testcase.
|
||||||
|
* gdb.base/gdbinit.sample: Sample .gdbinit for gdbinit.exp.
|
||||||
|
|
||||||
|
2005-06-08 Daniel Jacobowitz <dan@codesourcery.com>
|
||||||
|
Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* Makefile.in (cli-cmds.o): Update.
|
||||||
|
* configure.in: Add check for getuid.
|
||||||
|
* configure: Regenerated.
|
||||||
|
* config.in: Ditto.
|
||||||
|
* main.c (captured_main): Pass -1 to source_command when loading
|
||||||
|
gdbinit files.
|
||||||
|
* cli/cli-cmds.c: Include "gdb_stat.h" and <fcntl.h>.
|
||||||
|
(source_command): Update documentation. Check permissions if
|
||||||
|
FROM_TTY is -1.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/cli/cli-cmds.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/cli/cli-cmds.c 2009-02-27 00:04:32.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/cli/cli-cmds.c 2009-02-28 07:17:49.000000000 +0100
|
||||||
|
@@ -36,6 +36,7 @@
|
||||||
|
#include "objfiles.h"
|
||||||
|
#include "source.h"
|
||||||
|
#include "disasm.h"
|
||||||
|
+#include "gdb_stat.h"
|
||||||
|
|
||||||
|
#include "ui-out.h"
|
||||||
|
|
||||||
|
@@ -466,7 +467,7 @@ source_script (char *file, int from_tty)
|
||||||
|
|
||||||
|
if (fd == -1)
|
||||||
|
{
|
||||||
|
- if (from_tty)
|
||||||
|
+ if (from_tty > 0)
|
||||||
|
perror_with_name (file);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
@@ -475,6 +476,29 @@ source_script (char *file, int from_tty)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
+#ifdef HAVE_GETUID
|
||||||
|
+ if (from_tty == -1)
|
||||||
|
+ {
|
||||||
|
+ struct stat statbuf;
|
||||||
|
+
|
||||||
|
+ if (fstat (fd, &statbuf) < 0)
|
||||||
|
+ {
|
||||||
|
+ close (fd);
|
||||||
|
+ /* Do not do_cleanups (old_cleanups) as FILE is allocated there.
|
||||||
|
+ perror_with_name calls error which should call the cleanups. */
|
||||||
|
+ perror_with_name (file);
|
||||||
|
+ }
|
||||||
|
+ if (statbuf.st_uid != getuid () || (statbuf.st_mode & S_IWOTH))
|
||||||
|
+ {
|
||||||
|
+ /* FILE gets freed by do_cleanups (old_cleanups). */
|
||||||
|
+ warning (_("not using untrusted file \"%s\""), file);
|
||||||
|
+ close (fd);
|
||||||
|
+ do_cleanups (old_cleanups);
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
is_python = source_python;
|
||||||
|
if (strlen (file) > 3 && !strcmp (&file[strlen (file) - 3], ".py"))
|
||||||
|
is_python = 1;
|
||||||
|
@@ -486,6 +510,7 @@ source_script (char *file, int from_tty)
|
||||||
|
else
|
||||||
|
script_from_file (stream, file);
|
||||||
|
|
||||||
|
+ /* FILE gets freed by do_cleanups (old_cleanups). */
|
||||||
|
do_cleanups (old_cleanups);
|
||||||
|
}
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/testsuite/gdb.base/gdbinit.exp
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/testsuite/gdb.base/gdbinit.exp 2009-02-28 07:15:57.000000000 +0100
|
||||||
|
@@ -0,0 +1,98 @@
|
||||||
|
+# Copyright 2005
|
||||||
|
+# 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
|
||||||
|
+
|
||||||
|
+# This file was written by Jeff Johnston <jjohnstn@redhat.com>.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+# are we on a target board
|
||||||
|
+if [is_remote target] {
|
||||||
|
+ return
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+global verbose
|
||||||
|
+global GDB
|
||||||
|
+global GDBFLAGS
|
||||||
|
+global gdb_prompt
|
||||||
|
+global timeout
|
||||||
|
+global gdb_spawn_id;
|
||||||
|
+
|
||||||
|
+gdb_stop_suppressing_tests;
|
||||||
|
+
|
||||||
|
+verbose "Spawning $GDB -nw"
|
||||||
|
+
|
||||||
|
+if [info exists gdb_spawn_id] {
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if ![is_remote host] {
|
||||||
|
+ if { [which $GDB] == 0 } then {
|
||||||
|
+ perror "$GDB does not exist."
|
||||||
|
+ exit 1
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set env(HOME) [pwd]
|
||||||
|
+remote_exec build "rm .gdbinit"
|
||||||
|
+remote_exec build "cp ${srcdir}/${subdir}/gdbinit.sample .gdbinit"
|
||||||
|
+remote_exec build "chmod 646 .gdbinit"
|
||||||
|
+
|
||||||
|
+set res [remote_spawn host "$GDB -nw [host_info gdb_opts]"];
|
||||||
|
+if { $res < 0 || $res == "" } {
|
||||||
|
+ perror "Spawning $GDB failed."
|
||||||
|
+ return 1;
|
||||||
|
+}
|
||||||
|
+gdb_expect 360 {
|
||||||
|
+ -re "warning: not using untrusted file.*\.gdbinit.*\[\r\n\]$gdb_prompt $" {
|
||||||
|
+ pass "untrusted .gdbinit caught."
|
||||||
|
+ }
|
||||||
|
+ -re "$gdb_prompt $" {
|
||||||
|
+ fail "untrusted .gdbinit caught."
|
||||||
|
+ }
|
||||||
|
+ timeout {
|
||||||
|
+ fail "(timeout) untrusted .gdbinit caught."
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+remote_exec build "chmod 644 .gdbinit"
|
||||||
|
+set res [remote_spawn host "$GDB -nw [host_info gdb_opts]"];
|
||||||
|
+if { $res < 0 || $res == "" } {
|
||||||
|
+ perror "Spawning $GDB failed."
|
||||||
|
+ return 1;
|
||||||
|
+}
|
||||||
|
+gdb_expect 360 {
|
||||||
|
+ -re "warning: not using untrusted file.*\.gdbinit.*\[\r\n\]$gdb_prompt $" {
|
||||||
|
+ fail "trusted .gdbinit allowed."
|
||||||
|
+ }
|
||||||
|
+ -re "in gdbinit.*$gdb_prompt $" {
|
||||||
|
+ pass "trusted .gdbinit allowed."
|
||||||
|
+ }
|
||||||
|
+ timeout {
|
||||||
|
+ fail "(timeout) trusted .gdbinit allowed."
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+remote_exec build "rm .gdbinit"
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/testsuite/gdb.base/gdbinit.sample
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/testsuite/gdb.base/gdbinit.sample 2009-02-28 07:15:57.000000000 +0100
|
||||||
|
@@ -0,0 +1 @@
|
||||||
|
+echo "\nin gdbinit"
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/main.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/main.c 2009-02-27 00:04:32.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/main.c 2009-02-28 07:15:57.000000000 +0100
|
||||||
|
@@ -855,7 +855,7 @@ Excess command line arguments ignored. (
|
||||||
|
debugging or what directory you are in. */
|
||||||
|
|
||||||
|
if (home_gdbinit && !inhibit_gdbinit)
|
||||||
|
- catch_command_errors (source_script, home_gdbinit, 0, RETURN_MASK_ALL);
|
||||||
|
+ catch_command_errors (source_script, home_gdbinit, -1, RETURN_MASK_ALL);
|
||||||
|
|
||||||
|
/* Now perform all the actions indicated by the arguments. */
|
||||||
|
if (cdarg != NULL)
|
||||||
|
@@ -924,7 +924,7 @@ Can't attach to process and specify a co
|
||||||
|
/* Read the .gdbinit file in the current directory, *if* it isn't
|
||||||
|
the same as the $HOME/.gdbinit file (it should exist, also). */
|
||||||
|
if (local_gdbinit && !inhibit_gdbinit)
|
||||||
|
- catch_command_errors (source_script, local_gdbinit, 0, RETURN_MASK_ALL);
|
||||||
|
+ catch_command_errors (source_script, local_gdbinit, -1, RETURN_MASK_ALL);
|
||||||
|
|
||||||
|
for (i = 0; i < ncmd; i++)
|
||||||
|
{
|
82
gdb-6.3-sepcrc-20050402.patch
Normal file
82
gdb-6.3-sepcrc-20050402.patch
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
2005-04-02 Andrew Cagney <cagney@gnu.org>
|
||||||
|
|
||||||
|
* symfile.c (separate_debug_file_exists): When the CRCs mismatch
|
||||||
|
print a warning.
|
||||||
|
(find_separate_debug_file): Pass in the objfile's name.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/symfile.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/symfile.c 2008-10-03 18:36:10.000000000 +0200
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/symfile.c 2008-12-01 16:34:36.000000000 +0100
|
||||||
|
@@ -1296,7 +1296,8 @@ get_debug_link_info (struct objfile *obj
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
-separate_debug_file_exists (const char *name, unsigned long crc)
|
||||||
|
+separate_debug_file_exists (const char *name, unsigned long crc,
|
||||||
|
+ const char *parent_name)
|
||||||
|
{
|
||||||
|
unsigned long file_crc = 0;
|
||||||
|
bfd *abfd;
|
||||||
|
@@ -1316,7 +1317,15 @@ separate_debug_file_exists (const char *
|
||||||
|
|
||||||
|
bfd_close (abfd);
|
||||||
|
|
||||||
|
- return crc == file_crc;
|
||||||
|
+ if (crc != file_crc)
|
||||||
|
+ {
|
||||||
|
+ warning (_("the debug information found in \"%s\""
|
||||||
|
+ " does not match \"%s\" (CRC mismatch).\n"),
|
||||||
|
+ name, parent_name);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *debug_file_directory = NULL;
|
||||||
|
@@ -1368,6 +1377,8 @@ find_separate_debug_file (struct objfile
|
||||||
|
basename = get_debug_link_info (objfile, &crc32);
|
||||||
|
|
||||||
|
if (basename == NULL)
|
||||||
|
+ /* There's no separate debug info, hence there's no way we could
|
||||||
|
+ load it => no warning. */
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
dir = xstrdup (objfile->name);
|
||||||
|
@@ -1395,7 +1406,7 @@ find_separate_debug_file (struct objfile
|
||||||
|
strcpy (debugfile, dir);
|
||||||
|
strcat (debugfile, basename);
|
||||||
|
|
||||||
|
- if (separate_debug_file_exists (debugfile, crc32))
|
||||||
|
+ if (separate_debug_file_exists (debugfile, crc32, objfile->name))
|
||||||
|
{
|
||||||
|
xfree (basename);
|
||||||
|
xfree (dir);
|
||||||
|
@@ -1408,7 +1419,7 @@ find_separate_debug_file (struct objfile
|
||||||
|
strcat (debugfile, "/");
|
||||||
|
strcat (debugfile, basename);
|
||||||
|
|
||||||
|
- if (separate_debug_file_exists (debugfile, crc32))
|
||||||
|
+ if (separate_debug_file_exists (debugfile, crc32, objfile->name))
|
||||||
|
{
|
||||||
|
xfree (basename);
|
||||||
|
xfree (dir);
|
||||||
|
@@ -1421,7 +1432,7 @@ find_separate_debug_file (struct objfile
|
||||||
|
strcat (debugfile, dir);
|
||||||
|
strcat (debugfile, basename);
|
||||||
|
|
||||||
|
- if (separate_debug_file_exists (debugfile, crc32))
|
||||||
|
+ if (separate_debug_file_exists (debugfile, crc32, objfile->name))
|
||||||
|
{
|
||||||
|
xfree (basename);
|
||||||
|
xfree (dir);
|
||||||
|
@@ -1440,7 +1451,7 @@ find_separate_debug_file (struct objfile
|
||||||
|
strcat (debugfile, "/");
|
||||||
|
strcat (debugfile, basename);
|
||||||
|
|
||||||
|
- if (separate_debug_file_exists (debugfile, crc32))
|
||||||
|
+ if (separate_debug_file_exists (debugfile, crc32, objfile->name))
|
||||||
|
{
|
||||||
|
xfree (canon_name);
|
||||||
|
xfree (basename);
|
195
gdb-6.3-step-thread-exit-20050211-test.patch
Normal file
195
gdb-6.3-step-thread-exit-20050211-test.patch
Normal file
@ -0,0 +1,195 @@
|
|||||||
|
2005-02-11 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* testsuite/gdb.threads/step-thread-exit.c: New testcase.
|
||||||
|
* testsuite/gdb.threads/step-thread-exit.exp: Ditto.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.threads/step-thread-exit.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.threads/step-thread-exit.c 2008-12-08 22:21:26.000000000 +0100
|
||||||
|
@@ -0,0 +1,50 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2005 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. */
|
||||||
|
+
|
||||||
|
+#include <pthread.h>
|
||||||
|
+#include <stdio.h>
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
+
|
||||||
|
+void *thread_function (void *ptr)
|
||||||
|
+{
|
||||||
|
+ int *x = (int *)ptr;
|
||||||
|
+ printf("In thread_function, *x is %d\n", *x);
|
||||||
|
+} /* thread_function_end */
|
||||||
|
+
|
||||||
|
+volatile int repeat = 0;
|
||||||
|
+
|
||||||
|
+main()
|
||||||
|
+{
|
||||||
|
+ int ret;
|
||||||
|
+ pthread_t th;
|
||||||
|
+ int i = 3;
|
||||||
|
+
|
||||||
|
+ ret = pthread_create (&th, NULL, thread_function, &i);
|
||||||
|
+ do
|
||||||
|
+ {
|
||||||
|
+ repeat = 0;
|
||||||
|
+ sleep (3); /* sleep */
|
||||||
|
+ }
|
||||||
|
+ while (repeat);
|
||||||
|
+ pthread_join (th, NULL);
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.threads/step-thread-exit.exp
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.threads/step-thread-exit.exp 2008-12-08 22:22:14.000000000 +0100
|
||||||
|
@@ -0,0 +1,130 @@
|
||||||
|
+# This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+# Copyright 2005 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.
|
||||||
|
+
|
||||||
|
+# Check that GDB can step over a thread exit.
|
||||||
|
+
|
||||||
|
+if $tracelevel {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+set testfile "step-thread-exit"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+if {[gdb_compile_pthreads "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable [list debug "incdir=${objdir}"]] != "" } {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+# Reset the debug file directory so we can't debug within the C library
|
||||||
|
+gdb_test "set debug-file-directory ." "" ""
|
||||||
|
+
|
||||||
|
+#
|
||||||
|
+# Run to `main' where we begin our tests.
|
||||||
|
+#
|
||||||
|
+
|
||||||
|
+if ![runto_main] then {
|
||||||
|
+ gdb_suppress_tests
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# FIXME: Currently the main thread will escape/exit before our thread finishes
|
||||||
|
+# without this setting.
|
||||||
|
+gdb_test "set scheduler-locking step"
|
||||||
|
+gdb_test "show scheduler-locking" "Mode for locking scheduler during execution is \"step\"." "check scheduler-locking first"
|
||||||
|
+
|
||||||
|
+set sleep_line [expr [gdb_get_line_number "sleep"]]
|
||||||
|
+set end_line [expr [gdb_get_line_number "thread_function_end"]]
|
||||||
|
+
|
||||||
|
+gdb_breakpoint "$end_line"
|
||||||
|
+gdb_test "continue" "Break.*thread_function.*" "continue to thread_function 1"
|
||||||
|
+
|
||||||
|
+# Keep nexting until we cause the thread to exit. We expect the main
|
||||||
|
+# thread to be stopped and a message printed to tell us we have stepped
|
||||||
|
+# over the thread exit.
|
||||||
|
+set test "step over thread exit 1"
|
||||||
|
+gdb_test_multiple "next" "$test" {
|
||||||
|
+ -re "\}.*$gdb_prompt $" {
|
||||||
|
+ send_gdb "next\n"
|
||||||
|
+ exp_continue
|
||||||
|
+ }
|
||||||
|
+ -re "\[Thread .* exited\].*Program received signal SIGSTOP.*$gdb_prompt $" {
|
||||||
|
+ pass "$test"
|
||||||
|
+ }
|
||||||
|
+ -re "start_thread.*$gdb_prompt $" {
|
||||||
|
+ send_gdb "next\n"
|
||||||
|
+ exp_continue
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Without this fixup we could end up in:
|
||||||
|
+# #0 0x00110416 in __kernel_vsyscall ()
|
||||||
|
+# #1 0x0011de26 in __lll_unlock_wake_private () from /lib/libpthread.so.0
|
||||||
|
+# #2 0x001179f4 in _L_unlock_3164 () from /lib/libpthread.so.0
|
||||||
|
+# #3 0x00116f01 in pthread_create@@GLIBC_2.1 () from /lib/libpthread.so.0
|
||||||
|
+# #4 0x08048531 in main () at ../.././gdb/testsuite/gdb.threads/step-thread-exit.c:39
|
||||||
|
+gdb_breakpoint "$sleep_line"
|
||||||
|
+gdb_test "set repeat=1" "" "Get to the sleep function prepare 1"
|
||||||
|
+gdb_test "continue" "Break.*$sleep_line.*" "Get to the sleep function 1"
|
||||||
|
+
|
||||||
|
+gdb_test "bt" "main.*$sleep_line.*" "backtrace after step 1"
|
||||||
|
+
|
||||||
|
+runto_main
|
||||||
|
+gdb_test "show scheduler-locking" "Mode for locking scheduler during execution is \"step\"." "check scheduler-locking second"
|
||||||
|
+
|
||||||
|
+gdb_breakpoint "$sleep_line"
|
||||||
|
+gdb_breakpoint "$end_line"
|
||||||
|
+set test "continue to thread_function 2"
|
||||||
|
+gdb_test_multiple "continue" "$test" {
|
||||||
|
+ -re "Break.*thread_function.*$gdb_prompt $" {
|
||||||
|
+ pass $test
|
||||||
|
+ }
|
||||||
|
+ -re "Break.*$sleep_line.*$gdb_prompt $" {
|
||||||
|
+ gdb_test "set repeat=1" "" ""
|
||||||
|
+ send_gdb "continue\n"
|
||||||
|
+ exp_continue
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Keep nexting until we cause the thread to exit. In this case, we
|
||||||
|
+# expect the breakpoint in the main thread to have already triggered
|
||||||
|
+# and so we should stop there with a message that we stepped over
|
||||||
|
+# the thread exit.
|
||||||
|
+set test "step over thread exit 2"
|
||||||
|
+gdb_test_multiple "next" "$test" {
|
||||||
|
+ -re "\}.*$gdb_prompt $" {
|
||||||
|
+ send_gdb "next\n"
|
||||||
|
+ exp_continue
|
||||||
|
+ }
|
||||||
|
+ -re "\[Thread .* exited\].*Break.*$sleep_line.*$gdb_prompt $" {
|
||||||
|
+ pass "$test (breakpoint hit)"
|
||||||
|
+ }
|
||||||
|
+ -re "\[Thread .* exited\].*$gdb_prompt $" {
|
||||||
|
+ pass "$test (breakpoint not hit)"
|
||||||
|
+ }
|
||||||
|
+ -re "start_thread.*$gdb_prompt $" {
|
||||||
|
+ send_gdb "next\n"
|
||||||
|
+ exp_continue
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
28
gdb-6.3-terminal-fix-20050214.patch
Normal file
28
gdb-6.3-terminal-fix-20050214.patch
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
2005-02-14 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* top.c (gdb_readline_wrapper): Ensure terminal is gdb's before calling
|
||||||
|
readline.
|
||||||
|
|
||||||
|
2007-10-14 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7.
|
||||||
|
|
||||||
|
Index: gdb-6.7/gdb/top.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.7.orig/gdb/top.c 2007-09-02 23:13:56.000000000 +0200
|
||||||
|
+++ gdb-6.7/gdb/top.c 2007-10-14 23:38:27.000000000 +0200
|
||||||
|
@@ -795,6 +795,14 @@ gdb_readline_wrapper (char *prompt)
|
||||||
|
|
||||||
|
back_to = make_cleanup (gdb_readline_wrapper_cleanup, cleanup);
|
||||||
|
|
||||||
|
+ /* Before calling readline, ensure we have the terminal. If we don't
|
||||||
|
+ have the terminal and call readline, we risk the possibility of
|
||||||
|
+ gdb being thrown into the background. This problem occurs when
|
||||||
|
+ we attach to a background process on the same terminal the background
|
||||||
|
+ process was started from and then perform some action which requires
|
||||||
|
+ a page break prompt. */
|
||||||
|
+ terminal_ours ();
|
||||||
|
+
|
||||||
|
/* Display our prompt and prevent double prompt display. */
|
||||||
|
display_gdb_prompt (prompt);
|
||||||
|
rl_already_prompted = 1;
|
263
gdb-6.3-test-dtorfix-20050121.patch
Normal file
263
gdb-6.3-test-dtorfix-20050121.patch
Normal file
@ -0,0 +1,263 @@
|
|||||||
|
Index: gdb/testsuite/ChangeLog
|
||||||
|
2005-01-21 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* gdb.cp/constructortest.exp: New test.
|
||||||
|
* gdb.cp/constructortest.cc: Ditto.
|
||||||
|
* gdb.cp/templates.exp: Change break of dtor to be fully quoted.
|
||||||
|
|
||||||
|
2007-09-22 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.cp/constructortest.exp, gdb.cp/constructortest.cc: Test also the
|
||||||
|
`$delete' destructor variant.
|
||||||
|
|
||||||
|
2007-09-25 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.cp/constructortest.exp: Delete the FIXME workaround of restarting
|
||||||
|
the whole GDB.
|
||||||
|
|
||||||
|
2007-10-05 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.cp/constructortest.exp: Test BREAKPOINT_RE_SET for multiple PCs
|
||||||
|
by PIE.
|
||||||
|
* gdb.cp/constructortest.exp: Handle the change of settings breakpoints
|
||||||
|
always at all the ctor/dtor variants.
|
||||||
|
|
||||||
|
[ Removed the `gdb.cp/templates.exp' patch. ]
|
||||||
|
[ Updated the patch for "(X location") of GDB-6.8+. ]
|
||||||
|
|
||||||
|
--- gdb-6.3/gdb/testsuite/gdb.cp/constructortest.cc.fix Fri Jan 21 17:06:56 2005
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.cp/constructortest.cc Fri Jan 21 17:05:18 2005
|
||||||
|
@@ -0,0 +1,99 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2005 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. */
|
||||||
|
+
|
||||||
|
+class A
|
||||||
|
+{
|
||||||
|
+ public:
|
||||||
|
+ A();
|
||||||
|
+ ~A();
|
||||||
|
+ int k;
|
||||||
|
+ private:
|
||||||
|
+ int x;
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+class B: public A
|
||||||
|
+{
|
||||||
|
+ public:
|
||||||
|
+ B();
|
||||||
|
+ private:
|
||||||
|
+ int y;
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+/* C and D are for the $delete destructor. */
|
||||||
|
+
|
||||||
|
+class C
|
||||||
|
+{
|
||||||
|
+ public:
|
||||||
|
+ C();
|
||||||
|
+ virtual ~C();
|
||||||
|
+ private:
|
||||||
|
+ int x;
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+class D: public C
|
||||||
|
+{
|
||||||
|
+ public:
|
||||||
|
+ D();
|
||||||
|
+ private:
|
||||||
|
+ int y;
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+int main(int argc, char *argv[])
|
||||||
|
+{
|
||||||
|
+ A* a = new A;
|
||||||
|
+ B* b = new B;
|
||||||
|
+ D* d = new D;
|
||||||
|
+ delete a;
|
||||||
|
+ delete b;
|
||||||
|
+ delete d;
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+A::A() /* Constructor A */
|
||||||
|
+{
|
||||||
|
+ x = 1; /* First line A */
|
||||||
|
+ k = 4; /* Second line A */
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+A::~A() /* Destructor A */
|
||||||
|
+{
|
||||||
|
+ x = 3; /* First line ~A */
|
||||||
|
+ k = 6; /* Second line ~A */
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+B::B()
|
||||||
|
+{
|
||||||
|
+ y = 2; /* First line B */
|
||||||
|
+ k = 5;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+C::C() /* Constructor C */
|
||||||
|
+{
|
||||||
|
+ x = 1; /* First line C */
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+C::~C() /* Destructor C */
|
||||||
|
+{
|
||||||
|
+ x = 3; /* First line ~C */
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+D::D()
|
||||||
|
+{
|
||||||
|
+ y = 2; /* First line D */
|
||||||
|
+}
|
||||||
|
--- gdb-6.3/gdb/testsuite/gdb.cp/constructortest.exp.fix Fri Jan 21 17:07:02 2005
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.cp/constructortest.exp Fri Jan 21 17:05:29 2005
|
||||||
|
@@ -0,0 +1,131 @@
|
||||||
|
+# This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+# Copyright 2005, 2007 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.
|
||||||
|
+
|
||||||
|
+# Check that GDB can break at multiple forms of constructors.
|
||||||
|
+
|
||||||
|
+if $tracelevel {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+set testfile "constructortest"
|
||||||
|
+set srcfile ${testfile}.cc
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+# PIE is required for testing proper BREAKPOINT_RE_SET of the multiple-PC
|
||||||
|
+# breakpoints.
|
||||||
|
+if {[gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug c++ "additional_flags=-fpie -pie"}] != "" } {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+#
|
||||||
|
+# Run to `main' where we begin our tests.
|
||||||
|
+#
|
||||||
|
+
|
||||||
|
+if ![runto_main] then {
|
||||||
|
+ gdb_suppress_tests
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Break on the various forms of the A::A constructor
|
||||||
|
+gdb_test "break A\:\:A" "Breakpoint 2 at .* \\(2 locations\\)" "breaking on A::A"
|
||||||
|
+
|
||||||
|
+# Verify that we break for the A constructor two times
|
||||||
|
+# Once for new A and once for new B
|
||||||
|
+gdb_continue_to_breakpoint "First line A"
|
||||||
|
+gdb_test "bt" "#0.*A.*#1.*main.*" "Verify in in-charge A::A"
|
||||||
|
+gdb_continue_to_breakpoint "First line A"
|
||||||
|
+gdb_test "bt" "#0.*A.*#1.*B.*#2.*main.*" "Verify in not-in-charge A::A"
|
||||||
|
+
|
||||||
|
+# Now do the same for destructors
|
||||||
|
+gdb_test "break 'A::~A()'" ""
|
||||||
|
+
|
||||||
|
+# Verify that we break for the A destructor two times
|
||||||
|
+# Once for delete a and once for delete b
|
||||||
|
+gdb_continue_to_breakpoint "First line ~A"
|
||||||
|
+gdb_test "bt" "#0.*~A.*#1.*main.*" "Verify in in-charge A::~A"
|
||||||
|
+gdb_continue_to_breakpoint "First line ~A"
|
||||||
|
+gdb_test "bt" "#0.*~A.*#1.*~B.*#2.*main.*" "Verify in not-in-charge A::~A"
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+# Verify that we can break by line number in a constructor and find
|
||||||
|
+# both occurrences
|
||||||
|
+runto_main
|
||||||
|
+gdb_test "break 'A::A()'" "" "break in constructor A 2"
|
||||||
|
+gdb_continue_to_breakpoint "First line A"
|
||||||
|
+set second_line [gdb_get_line_number "Second line A"]
|
||||||
|
+gdb_test "break $second_line" "Breakpoint .*, line $second_line. \\(2 locations\\)" "break by line in constructor"
|
||||||
|
+gdb_continue_to_breakpoint "Second line A"
|
||||||
|
+gdb_test "bt" "#0.*A.*#1.*main.*" "Verify in in-charge A::A second line"
|
||||||
|
+gdb_continue_to_breakpoint "Second line A"
|
||||||
|
+gdb_test "bt" "#0.*A.*#1.*B.*#2.*main.*" "Verify in not-in-charge A::A second line"
|
||||||
|
+
|
||||||
|
+# Verify that we can break by line number in a destructor and find
|
||||||
|
+# both occurrences
|
||||||
|
+gdb_test "break 'A::~A()'" "" "break in constructor ~A 2"
|
||||||
|
+gdb_continue_to_breakpoint "First line ~A"
|
||||||
|
+set second_line_dtor [gdb_get_line_number "Second line ~A"]
|
||||||
|
+gdb_test "break $second_line_dtor" "Breakpoint .*, line $second_line_dtor. \\(2 locations\\)" "break by line in destructor"
|
||||||
|
+gdb_continue_to_breakpoint "Second line ~A"
|
||||||
|
+gdb_test "bt" "#0.*A.*#1.*main.*" "Verify in in-charge A::~A second line"
|
||||||
|
+# FIXME: Analyse this case better.
|
||||||
|
+gdb_continue_to_breakpoint "Second line ~A"
|
||||||
|
+gdb_test "bt" "#0.*A.*#1.*main.*" "Verify in A::~A second line #2"
|
||||||
|
+gdb_continue_to_breakpoint "Second line ~A"
|
||||||
|
+gdb_test "bt" "#0.*A.*#1.*B.*#2.*main.*" "Verify in not-in-charge A::~A second line"
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+# Test now the $delete destructors.
|
||||||
|
+
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+runto_main
|
||||||
|
+
|
||||||
|
+# Break on the various forms of the C::~C destructor
|
||||||
|
+gdb_test "break C\:\:~C" "Breakpoint .* \\(3 locations\\)" "breaking on C::~C"
|
||||||
|
+gdb_continue_to_breakpoint "First line ~C"
|
||||||
|
+
|
||||||
|
+# Verify that we can break by line number in a destructor and find
|
||||||
|
+# the $delete occurence
|
||||||
|
+
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+delete_breakpoints
|
||||||
|
+
|
||||||
|
+set first_line_dtor [gdb_get_line_number "First line ~C"]
|
||||||
|
+gdb_test "break $first_line_dtor" "Breakpoint .*, line $first_line_dtor. \\(3 locations\\)" "break by line in destructor"
|
||||||
|
+
|
||||||
|
+# Run to `main' where we begin our tests.
|
||||||
|
+# Set the breakpoints first to test PIE multiple-PC BREAKPOINT_RE_SET.
|
||||||
|
+# RUNTO_MAIN or RUNTO MAIN are not usable here as it runs DELETE_BREAKPOINTS.
|
||||||
|
+
|
||||||
|
+if ![gdb_breakpoint main] {
|
||||||
|
+ gdb_suppress_tests
|
||||||
|
+}
|
||||||
|
+gdb_run_cmd
|
||||||
|
+set test "running to main"
|
||||||
|
+gdb_test_multiple "" $test {
|
||||||
|
+ -re "Breakpoint \[0-9\]*, main .*$gdb_prompt $" {
|
||||||
|
+ pass $test
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_continue_to_breakpoint "First line ~C"
|
105
gdb-6.3-test-movedir-20050125.patch
Normal file
105
gdb-6.3-test-movedir-20050125.patch
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
2005-01-25 Elena Zannoni <ezannoni@redhat.com>
|
||||||
|
|
||||||
|
* gdb.base/move-dir.exp: New test.
|
||||||
|
* gdb.base/move-dir.c: Ditto.
|
||||||
|
* gdb.base/move-dir.h: Ditto.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.base/move-dir.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.base/move-dir.c 2008-12-07 23:57:41.000000000 +0100
|
||||||
|
@@ -0,0 +1,10 @@
|
||||||
|
+#include <stdio.h>
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+#include "move-dir.h"
|
||||||
|
+
|
||||||
|
+int main() {
|
||||||
|
+ const char* hw = "hello world.";
|
||||||
|
+ printf ("%s\n", hw);;
|
||||||
|
+ other();
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.base/move-dir.exp
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.base/move-dir.exp 2008-12-07 10:13:01.000000000 +0100
|
||||||
|
@@ -0,0 +1,67 @@
|
||||||
|
+# Copyright 2005
|
||||||
|
+# 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
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+set testfile "move-dir"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set incfile ${testfile}.h
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+set testdir "${objdir}/${subdir}/incdir"
|
||||||
|
+
|
||||||
|
+remote_exec build "mkdir $testdir"
|
||||||
|
+remote_exec build "cp ${srcdir}/${subdir}/${srcfile} ${objdir}/${subdir}"
|
||||||
|
+remote_exec build "cp ${srcdir}/${subdir}/${incfile} ${testdir}"
|
||||||
|
+
|
||||||
|
+set additional_flags "additional_flags=-I${subdir}/incdir"
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${objdir}/${subdir}/${srcfile}" "${binfile}" executable [list debug $additional_flags]] != "" } {
|
||||||
|
+ gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Create and source the file that provides information about the compiler
|
||||||
|
+# used to compile the test case.
|
||||||
|
+
|
||||||
|
+if [get_compiler_info ${binfile}] {
|
||||||
|
+ return -1;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+set oldtimeout $timeout
|
||||||
|
+set timeout [expr "$timeout + 60"]
|
||||||
|
+
|
||||||
|
+# Start with a fresh gdb.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_test "cd ../.." "" ""
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+gdb_test "list main" ".*hw.*other.*" "found main"
|
||||||
|
+gdb_test "list other" ".*ostring.*" "found include file"
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+set timeout $oldtimeout
|
||||||
|
+return 0
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.base/move-dir.h
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.base/move-dir.h 2008-12-07 10:13:01.000000000 +0100
|
||||||
|
@@ -0,0 +1,7 @@
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+
|
||||||
|
+void other() {
|
||||||
|
+ const char* ostring = "other";
|
||||||
|
+ printf ("%s\n", ostring);;
|
||||||
|
+}
|
||||||
|
+
|
2121
gdb-6.3-test-pie-20050107.patch
Normal file
2121
gdb-6.3-test-pie-20050107.patch
Normal file
File diff suppressed because it is too large
Load Diff
101
gdb-6.3-test-self-20050110.patch
Normal file
101
gdb-6.3-test-self-20050110.patch
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
2004-02-23 Elena Zannoni <ezannoni@redhat.com>
|
||||||
|
|
||||||
|
* gdb.gdb/selftest.exp: Make sure that the debug directory is
|
||||||
|
set up properly.
|
||||||
|
* gdb.gdb/complaints.exp: Ditto.
|
||||||
|
* gdb.gdb/xfullpath.exp: Ditto.
|
||||||
|
* gdb.gdb/observer.exp: Ditto.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/testsuite/gdb.gdb/complaints.exp
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/testsuite/gdb.gdb/complaints.exp 2009-01-03 06:58:04.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/testsuite/gdb.gdb/complaints.exp 2009-02-26 22:10:48.000000000 +0100
|
||||||
|
@@ -302,13 +302,13 @@ proc find_gdb { arg } {
|
||||||
|
set GDB_FULLPATH [find_gdb $GDB]
|
||||||
|
|
||||||
|
# Remove any old copy lying around.
|
||||||
|
-remote_file host delete x$tool
|
||||||
|
+#remote_file host delete x$tool
|
||||||
|
|
||||||
|
gdb_start
|
||||||
|
|
||||||
|
-set file [remote_download host $GDB_FULLPATH x$tool]
|
||||||
|
+#set file [remote_download host $GDB_FULLPATH x$tool]
|
||||||
|
|
||||||
|
-set setup_result [setup_test $file ]
|
||||||
|
+set setup_result [setup_test $GDB_FULLPATH ]
|
||||||
|
if {$setup_result <0} then {
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
@@ -319,4 +319,4 @@ test_short_complaints
|
||||||
|
test_empty_complaints
|
||||||
|
|
||||||
|
gdb_exit;
|
||||||
|
-catch "remote_file host delete $file";
|
||||||
|
+#catch "remote_file host delete $file";
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/testsuite/gdb.gdb/observer.exp
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/testsuite/gdb.gdb/observer.exp 2009-02-17 20:52:27.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/testsuite/gdb.gdb/observer.exp 2009-02-26 22:11:40.000000000 +0100
|
||||||
|
@@ -258,13 +258,13 @@ proc find_gdb { arg } {
|
||||||
|
set GDB_FULLPATH [find_gdb $GDB]
|
||||||
|
|
||||||
|
# Remove any old copy lying around.
|
||||||
|
-remote_file host delete x$tool
|
||||||
|
+#remote_file host delete x$tool
|
||||||
|
|
||||||
|
gdb_start
|
||||||
|
-set file [remote_download host $GDB_FULLPATH x$tool]
|
||||||
|
-set result [test_observer $file];
|
||||||
|
+#set file [remote_download host $GDB_FULLPATH x$tool]
|
||||||
|
+set result [test_observer $GDB_FULLPATH];
|
||||||
|
gdb_exit;
|
||||||
|
-catch "remote_file host delete $file";
|
||||||
|
+#catch "remote_file host delete $file";
|
||||||
|
|
||||||
|
if {$result <0} then {
|
||||||
|
warning "Couldn't test self"
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/testsuite/gdb.gdb/selftest.exp
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/testsuite/gdb.gdb/selftest.exp 2009-02-26 22:09:59.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/testsuite/gdb.gdb/selftest.exp 2009-02-26 22:10:48.000000000 +0100
|
||||||
|
@@ -551,13 +551,13 @@ proc find_gdb { arg } {
|
||||||
|
set GDB_FULLPATH [find_gdb $GDB]
|
||||||
|
|
||||||
|
# Remove any old copy lying around.
|
||||||
|
-remote_file host delete x$tool
|
||||||
|
+#remote_file host delete x$tool
|
||||||
|
|
||||||
|
gdb_start
|
||||||
|
-set file [remote_download host $GDB_FULLPATH x$tool]
|
||||||
|
-set result [test_with_self $file];
|
||||||
|
+#set file [remote_download host $GDB_FULLPATH x$tool]
|
||||||
|
+set result [test_with_self $GDB_FULLPATH];
|
||||||
|
gdb_exit;
|
||||||
|
-catch "remote_file host delete $file";
|
||||||
|
+#catch "remote_file host delete $file";
|
||||||
|
|
||||||
|
if {$result <0} then {
|
||||||
|
warning "Couldn't test self"
|
||||||
|
Index: gdb-6.8.50.20090226/gdb/testsuite/gdb.gdb/xfullpath.exp
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/testsuite/gdb.gdb/xfullpath.exp 2009-01-03 06:58:04.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/testsuite/gdb.gdb/xfullpath.exp 2009-02-26 22:10:48.000000000 +0100
|
||||||
|
@@ -179,13 +179,13 @@ proc find_gdb { arg } {
|
||||||
|
set GDB_FULLPATH [find_gdb $GDB]
|
||||||
|
|
||||||
|
# Remove any old copy lying around.
|
||||||
|
-remote_file host delete x$tool
|
||||||
|
+#remote_file host delete x$tool
|
||||||
|
|
||||||
|
gdb_start
|
||||||
|
-set file [remote_download host $GDB_FULLPATH x$tool]
|
||||||
|
-set result [test_with_self $file];
|
||||||
|
+#set file [remote_download host $GDB_FULLPATH x$tool]
|
||||||
|
+set result [test_with_self $GDB_FULLPATH];
|
||||||
|
gdb_exit;
|
||||||
|
-catch "remote_file host delete $file";
|
||||||
|
+#catch "remote_file host delete $file";
|
||||||
|
|
||||||
|
if {$result <0} then {
|
||||||
|
warning "Couldn't test self"
|
55
gdb-6.3-test-sepcrc-20050402.patch
Normal file
55
gdb-6.3-test-sepcrc-20050402.patch
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
Index: gdb-6.8/gdb/testsuite/gdb.base/sepdebug.exp
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.orig/gdb/testsuite/gdb.base/sepdebug.exp 2008-02-26 09:14:11.000000000 +0100
|
||||||
|
+++ gdb-6.8/gdb/testsuite/gdb.base/sepdebug.exp 2008-07-14 10:26:19.000000000 +0200
|
||||||
|
@@ -981,3 +981,40 @@ if ![string compare $build_id_debug_file
|
||||||
|
# Spare debug files may confuse testsuite runs in the future.
|
||||||
|
remote_exec build "rm -f ${objdir}/${subdir}/${build_id_debug_filename}"
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+# Compile up a second, different, object file. Copy its debug info
|
||||||
|
+# over the top of the new debug info. Note that somewhere in the
|
||||||
|
+# above the "set debug-file-directory" variable is set to
|
||||||
|
+# ${objdir}/${subdir} so need to move things there.
|
||||||
|
+
|
||||||
|
+set existing_binfile $binfile
|
||||||
|
+set testfile "sepdebug2"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+set corrupt_debug_file [separate_debug_filename $binfile]
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug additional_flags=-w}] != "" } {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+if [gdb_gnu_strip_debug $binfile] {
|
||||||
|
+ # check that you have a recent version of strip and objcopy installed
|
||||||
|
+ unsupported "cannot produce separate debug info files"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+remote_exec build "cp $corrupt_debug_file ${existing_binfile}.debug"
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+set test "A corrupt debug file gets a warning"
|
||||||
|
+gdb_test_multiple "file $existing_binfile" "$test" {
|
||||||
|
+ -re "warning:.*mismatch.*" {
|
||||||
|
+ pass "$test"
|
||||||
|
+ }
|
||||||
|
+ -re ".y or n. " {
|
||||||
|
+ send_gdb "y\n"
|
||||||
|
+ exp_continue
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
Index: gdb-6.8/gdb/testsuite/gdb.base/sepdebug2.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8/gdb/testsuite/gdb.base/sepdebug2.c 2008-07-14 10:26:19.000000000 +0200
|
||||||
|
@@ -0,0 +1,5 @@
|
||||||
|
+int
|
||||||
|
+main (int argc, char *argv[], char *envp[])
|
||||||
|
+{
|
||||||
|
+ return 0;
|
||||||
|
+}
|
250
gdb-6.3-threaded-watchpoints2-20050225.patch
Normal file
250
gdb-6.3-threaded-watchpoints2-20050225.patch
Normal file
@ -0,0 +1,250 @@
|
|||||||
|
2005-02-28 Jeff Johnston <jjohnstn@redhat.com>
|
||||||
|
|
||||||
|
* config/i386/nm-linux.h: Change dr register routines to
|
||||||
|
accept a ptid_t first argument. Change all calling macros
|
||||||
|
to default the inferior_ptid for the first argument.
|
||||||
|
(i386_linux_insert_watchpoint): New prototype.
|
||||||
|
(i386_linux_remove_watchpoint, i386_linux_insert_hw_breakpoint): Ditto.
|
||||||
|
(i386_linux_remove_hw_breakpoint): Ditto.
|
||||||
|
(target_insert_watchpoint, target_remove_watchpoint): Undef and
|
||||||
|
override.
|
||||||
|
(target_insert_hw_breakpoint, target_remove_hw_breakpoint): Ditto.
|
||||||
|
* config/i386/nm-linux64.h: Ditto except add amd64 versions of
|
||||||
|
the watchpoint/hw-breakpoint insert/remove routines.
|
||||||
|
* i386-nat.c: Include "inferior.h" to define inferior_ptid.
|
||||||
|
* i386-linux-nat.c: Change all dr get/set routines to accept
|
||||||
|
ptid_t as first argument and to use this argument to determine
|
||||||
|
the tid for PTRACE.
|
||||||
|
(i386_linux_set_debug_regs_for_thread): New function.
|
||||||
|
(i386_linux_sync_debug_registers_callback): Ditto.
|
||||||
|
(i386_linux_sync_debug_registers_across_threads): Ditto.
|
||||||
|
(i386_linux_insert_watchpoint, i386_linux_remove_watchpoint): Ditto.
|
||||||
|
(i386_linux_hw_breakpoint, i386_linux_remove_hw_breakpoint): Ditto.
|
||||||
|
(i386_linux_new_thread): Ditto.
|
||||||
|
(_initialize_i386_linux_nat): Ditto.
|
||||||
|
* amd64-linux-nat.c: Change all dr get/set routines to accept
|
||||||
|
ptid_t as first argument and to use this argument to determine
|
||||||
|
the tid for PTRACE.
|
||||||
|
(amd64_linux_set_debug_regs_for_thread): New function.
|
||||||
|
(amd64_linux_sync_debug_registers_callback): Ditto.
|
||||||
|
(amd64_linux_sync_debug_registers_across_threads): Ditto.
|
||||||
|
(amd64_linux_insert_watchpoint, amd64_linux_remove_watchpoint): Ditto.
|
||||||
|
(amd64_linux_hw_breakpoint, amd64_linux_remove_hw_breakpoint): Ditto.
|
||||||
|
(amd64_linux_new_thread): Ditto.
|
||||||
|
(_initialize_amd64_linux_nat): Register linux new thread observer.
|
||||||
|
* testsuite/gdb.threads/watchthreads2.c: New test case.
|
||||||
|
* testsuite/gdb.threads/watchthreads2.exp: Ditto.
|
||||||
|
|
||||||
|
[ With recent upstream GDB (6.8) reduced only to the testcase. ]
|
||||||
|
|
||||||
|
FIXME: The testcase does not expects multiple watchpoints hits per one stop.
|
||||||
|
|
||||||
|
Index: gdb-6.5/gdb/testsuite/gdb.threads/watchthreads2.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.5/gdb/testsuite/gdb.threads/watchthreads2.c 2006-07-12 01:54:29.000000000 -0300
|
||||||
|
@@ -0,0 +1,66 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2002, 2003, 2004, 2005 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.
|
||||||
|
+
|
||||||
|
+ This file is copied from schedlock.c. */
|
||||||
|
+
|
||||||
|
+#include <stdio.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+#include <pthread.h>
|
||||||
|
+
|
||||||
|
+void *thread_function(void *arg); /* Pointer to function executed by each thread */
|
||||||
|
+
|
||||||
|
+#define NUM 5
|
||||||
|
+
|
||||||
|
+unsigned int args[NUM+1];
|
||||||
|
+
|
||||||
|
+int main() {
|
||||||
|
+ int res;
|
||||||
|
+ pthread_t threads[NUM];
|
||||||
|
+ void *thread_result;
|
||||||
|
+ long i;
|
||||||
|
+
|
||||||
|
+ for (i = 0; i < NUM; i++)
|
||||||
|
+ {
|
||||||
|
+ args[i] = 1; /* Init value. */
|
||||||
|
+ res = pthread_create(&threads[i],
|
||||||
|
+ NULL,
|
||||||
|
+ thread_function,
|
||||||
|
+ (void *) i);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ args[i] = 1;
|
||||||
|
+ thread_function ((void *) i);
|
||||||
|
+
|
||||||
|
+ exit(EXIT_SUCCESS);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+void *thread_function(void *arg) {
|
||||||
|
+ int my_number = (long) arg;
|
||||||
|
+ int *myp = (int *) &args[my_number];
|
||||||
|
+
|
||||||
|
+ /* Don't run forever. Run just short of it :) */
|
||||||
|
+ while (*myp > 0)
|
||||||
|
+ {
|
||||||
|
+ (*myp) ++; usleep (1); /* Loop increment. */
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ pthread_exit(NULL);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
Index: gdb-6.5/gdb/testsuite/gdb.threads/watchthreads2.exp
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.5/gdb/testsuite/gdb.threads/watchthreads2.exp 2006-07-12 01:54:29.000000000 -0300
|
||||||
|
@@ -0,0 +1,133 @@
|
||||||
|
+# This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+# Copyright 2005 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.
|
||||||
|
+
|
||||||
|
+# Check that GDB can support multiple watchpoints across threads.
|
||||||
|
+
|
||||||
|
+if $tracelevel {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+# This test verifies that a watchpoint is detected in the proper thread
|
||||||
|
+# so the test is only meaningful on a system with hardware watchpoints.
|
||||||
|
+if [target_info exists gdb,no_hardware_watchpoints] {
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "watchthreads2"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+if {[gdb_compile_pthreads "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable [list debug "incdir=${objdir}"]] != "" } {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+gdb_test "set can-use-hw-watchpoints 1" "" ""
|
||||||
|
+
|
||||||
|
+#
|
||||||
|
+# Run to `main' where we begin our tests.
|
||||||
|
+#
|
||||||
|
+
|
||||||
|
+if ![runto_main] then {
|
||||||
|
+ gdb_suppress_tests
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set args_2 0
|
||||||
|
+set args_3 0
|
||||||
|
+
|
||||||
|
+gdb_breakpoint "thread_function"
|
||||||
|
+gdb_continue_to_breakpoint "thread_function"
|
||||||
|
+gdb_test "disable 2" ""
|
||||||
|
+
|
||||||
|
+gdb_test_multiple "p args\[2\]" "get initial args2" {
|
||||||
|
+ -re "\\\$\[0-9\]* = (.*)$gdb_prompt $" {
|
||||||
|
+ set init_args_2 $expect_out(1,string)
|
||||||
|
+ pass "get initial args2"
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_test_multiple "p args\[3\]" "get initial args3" {
|
||||||
|
+ -re "\\\$\[0-9\]* = (.*)$gdb_prompt $" {
|
||||||
|
+ set init_args_3 $expect_out(1,string)
|
||||||
|
+ pass "get initial args3"
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set args_2 $init_args_2
|
||||||
|
+set args_3 $init_args_3
|
||||||
|
+
|
||||||
|
+# Watch values that will be modified by distinct threads.
|
||||||
|
+gdb_test "watch args\[2\]" "Hardware watchpoint 3: args\\\[2\\\]"
|
||||||
|
+gdb_test "watch args\[3\]" "Hardware watchpoint 4: args\\\[3\\\]"
|
||||||
|
+
|
||||||
|
+set init_line [expr [gdb_get_line_number "Init value"]+1]
|
||||||
|
+set inc_line [gdb_get_line_number "Loop increment"]
|
||||||
|
+
|
||||||
|
+# Loop and continue to allow both watchpoints to be triggered.
|
||||||
|
+for {set i 0} {$i < 30} {incr i} {
|
||||||
|
+ set test_flag 0
|
||||||
|
+ gdb_test_multiple "continue" "threaded watch loop" {
|
||||||
|
+ -re "Hardware watchpoint 3: args\\\[2\\\].*Old value = 0.*New value = 1.*main \\\(\\\) at .*watchthreads2.c:$init_line.*$gdb_prompt $"
|
||||||
|
+ { set args_2 1; set test_flag 1 }
|
||||||
|
+ -re "Hardware watchpoint 4: args\\\[3\\\].*Old value = 0.*New value = 1.*main \\\(\\\) at .*watchthreads2.c:$init_line.*$gdb_prompt $"
|
||||||
|
+ { set args_3 1; set test_flag 1 }
|
||||||
|
+ -re "Hardware watchpoint 3: args\\\[2\\\].*Old value = $args_2.*New value = [expr $args_2+1].*in thread_function \\\(arg=0x2\\\) at .*watchthreads2.c:$inc_line.*$gdb_prompt $"
|
||||||
|
+ { set args_2 [expr $args_2+1]; set test_flag 1 }
|
||||||
|
+ -re "Hardware watchpoint 4: args\\\[3\\\].*Old value = $args_3.*New value = [expr $args_3+1].*in thread_function \\\(arg=0x3\\\) at .*watchthreads2.c:$inc_line.*$gdb_prompt $"
|
||||||
|
+ { set args_3 [expr $args_3+1]; set test_flag 1 }
|
||||||
|
+ }
|
||||||
|
+ # If we fail above, don't bother continuing loop
|
||||||
|
+ if { $test_flag == 0 } {
|
||||||
|
+ set i 30;
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Print success message if loop succeeded.
|
||||||
|
+if { $test_flag == 1 } {
|
||||||
|
+ pass "threaded watch loop"
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Verify that we hit first watchpoint in child thread.
|
||||||
|
+set message "watchpoint on args\[2\] hit in thread"
|
||||||
|
+if { $args_2 > 1 } {
|
||||||
|
+ pass $message
|
||||||
|
+} else {
|
||||||
|
+ fail $message
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Verify that we hit second watchpoint in child thread.
|
||||||
|
+set message "watchpoint on args\[3\] hit in thread"
|
||||||
|
+if { $args_3 > 1 } {
|
||||||
|
+ pass $message
|
||||||
|
+} else {
|
||||||
|
+ fail $message
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Verify that all watchpoint hits are accounted for.
|
||||||
|
+set message "combination of threaded watchpoints = 30 + initial values"
|
||||||
|
+if { [expr $args_2+$args_3] == [expr [expr 30+$init_args_2]+$init_args_3] } {
|
||||||
|
+ pass $message
|
||||||
|
+} else {
|
||||||
|
+ fail $message
|
||||||
|
+}
|
128
gdb-6.3-watchpoint-cond-gone-test.patch
Normal file
128
gdb-6.3-watchpoint-cond-gone-test.patch
Normal file
@ -0,0 +1,128 @@
|
|||||||
|
--- /dev/null 2008-04-03 00:39:30.714021604 +0200
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.base/watchpoint-cond-gone-stripped.c 2008-04-05 20:26:29.000000000 +0200
|
||||||
|
@@ -0,0 +1,23 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2008 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. */
|
||||||
|
+
|
||||||
|
+void
|
||||||
|
+jumper (void (*jumpto) (void))
|
||||||
|
+{
|
||||||
|
+ (*jumpto) ();
|
||||||
|
+}
|
||||||
|
--- /dev/null 2008-04-03 00:39:30.714021604 +0200
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.base/watchpoint-cond-gone.c 2008-04-05 20:26:48.000000000 +0200
|
||||||
|
@@ -0,0 +1,37 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2008 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. */
|
||||||
|
+
|
||||||
|
+extern void jumper (void (*jumpto) (void));
|
||||||
|
+
|
||||||
|
+void
|
||||||
|
+func ()
|
||||||
|
+{
|
||||||
|
+ int a, b, c;
|
||||||
|
+
|
||||||
|
+ a = b = c = 5;
|
||||||
|
+ a = b = c = 10; /* watchpoint-here */
|
||||||
|
+ c = a + b;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int
|
||||||
|
+main ()
|
||||||
|
+{
|
||||||
|
+ jumper (func);
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
--- /dev/null 2008-04-03 00:39:30.714021604 +0200
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.base/watchpoint-cond-gone.exp 2008-04-05 20:33:19.000000000 +0200
|
||||||
|
@@ -0,0 +1,59 @@
|
||||||
|
+# Copyright 2008 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.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "watchpoint-cond-gone"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set srcfilestripped ${testfile}-stripped.c
|
||||||
|
+set objfilestripped ${objdir}/${subdir}/${testfile}-stripped.o
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+# We need to generate a function without DWARF to crash older GDB.
|
||||||
|
+# Stepping into a dynamic function trampoline or stepping out of MAIN may work
|
||||||
|
+# but it is not a reliable FAIL case.
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfilestripped}" "${objfilestripped}" object {}] != "" } {
|
||||||
|
+ gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile} ${objfilestripped}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
+ gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+# Problem does not occur otherwise.
|
||||||
|
+gdb_test "set can-use-hw-watchpoints 0"
|
||||||
|
+
|
||||||
|
+runto_main
|
||||||
|
+gdb_breakpoint [gdb_get_line_number "watchpoint-here"]
|
||||||
|
+gdb_continue_to_breakpoint "Place to set the watchpoint"
|
||||||
|
+
|
||||||
|
+# The condition `c == 30' is the tested culprit.
|
||||||
|
+gdb_test "watch c if c == 30" "" "Place the watchpoint"
|
||||||
|
+
|
||||||
|
+# No functionality, just to check the state.
|
||||||
|
+gdb_test "backtrace"
|
||||||
|
+
|
||||||
|
+gdb_test "finish" \
|
||||||
|
+ "Watchpoint .* deleted because the program has left the block in.*which its expression is valid..*in (jumper|func).*" \
|
||||||
|
+ "Catch the no longer valid watchpoint"
|
938
gdb-6.5-BEA-testsuite.patch
Normal file
938
gdb-6.5-BEA-testsuite.patch
Normal file
@ -0,0 +1,938 @@
|
|||||||
|
Index: ./gdb/testsuite/gdb.threads/threadcrash.c
|
||||||
|
===================================================================
|
||||||
|
RCS file: gdb/testsuite/gdb.threads/threadcrash.c
|
||||||
|
diff -N gdb/testsuite/gdb.threads/threadcrash.c
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.threads/threadcrash.c 31 Oct 2006 17:54:38 -0000
|
||||||
|
@@ -0,0 +1,301 @@
|
||||||
|
+/*
|
||||||
|
+ * The point of this program is to crash in a multi-threaded app.
|
||||||
|
+ * There are seven threads, doing the following things:
|
||||||
|
+ * * Spinning
|
||||||
|
+ * * Spinning inside a signal handler
|
||||||
|
+ * * Spinning inside a signal handler executing on the altstack
|
||||||
|
+ * * In a syscall
|
||||||
|
+ * * In a syscall inside a signal handler
|
||||||
|
+ * * In a syscall inside a signal handler executing on the altstack
|
||||||
|
+ * * Finally, the main thread crashes in main, with no frills.
|
||||||
|
+ *
|
||||||
|
+ * These are the things threads in JRockit tend to be doing. If gdb
|
||||||
|
+ * can handle those things, both in core files and during live
|
||||||
|
+ * debugging, that will help (at least) JRockit development.
|
||||||
|
+ *
|
||||||
|
+ * Let the program create a core file, then load the core file into
|
||||||
|
+ * gdb. Inside gdb, you should be able to do something like this:
|
||||||
|
+ *
|
||||||
|
+ * (gdb) t a a bt
|
||||||
|
+ *
|
||||||
|
+ * Thread 7 (process 4352):
|
||||||
|
+ * #0 0x001ba7dc in __nanosleep_nocancel () from /lib/tls/libc.so.6
|
||||||
|
+ * #1 0x001ba5ff in sleep () from /lib/tls/libc.so.6
|
||||||
|
+ * #2 0x080488a2 in makeSyscall (ignored=0x0) at threadcrash.c:118
|
||||||
|
+ * #3 0x006aadec in start_thread () from /lib/tls/libpthread.so.0
|
||||||
|
+ * #4 0x001ed19a in clone () from /lib/tls/libc.so.6
|
||||||
|
+ *
|
||||||
|
+ * Thread 6 (process 4353):
|
||||||
|
+ * #0 0x001ba7dc in __nanosleep_nocancel () from /lib/tls/libc.so.6
|
||||||
|
+ * #1 0x001ba5ff in sleep () from /lib/tls/libc.so.6
|
||||||
|
+ * #2 0x0804898f in syscallingSighandler (signo=10, info=0xb6be76f0, context=0xb6be7770)
|
||||||
|
+ * at threadcrash.c:168
|
||||||
|
+ * #3 <signal handler called>
|
||||||
|
+ * #4 0x006adf5e in pthread_kill () from /lib/tls/libpthread.so.0
|
||||||
|
+ * #5 0x08048a51 in makeSyscallFromSighandler (ignored=0x0) at threadcrash.c:204
|
||||||
|
+ * #6 0x006aadec in start_thread () from /lib/tls/libpthread.so.0
|
||||||
|
+ * #7 0x001ed19a in clone () from /lib/tls/libc.so.6
|
||||||
|
+ *
|
||||||
|
+ * Thread 5 (process 4354):
|
||||||
|
+ * #0 0x001ba7dc in __nanosleep_nocancel () from /lib/tls/libc.so.6
|
||||||
|
+ * #1 0x001ba5ff in sleep () from /lib/tls/libc.so.6
|
||||||
|
+ * #2 0x08048936 in syscallingAltSighandler (signo=3, info=0x959cd70, context=0x959cdf0)
|
||||||
|
+ * at threadcrash.c:144
|
||||||
|
+ * #3 <signal handler called>
|
||||||
|
+ * #4 0x006adf5e in pthread_kill () from /lib/tls/libpthread.so.0
|
||||||
|
+ * #5 0x080489e2 in makeSyscallFromAltSighandler (ignored=0x0) at threadcrash.c:190
|
||||||
|
+ * #6 0x006aadec in start_thread () from /lib/tls/libpthread.so.0
|
||||||
|
+ * #7 0x001ed19a in clone () from /lib/tls/libc.so.6
|
||||||
|
+ *
|
||||||
|
+ * Thread 4 (process 4355):
|
||||||
|
+ * #0 spin (ignored=0x0) at threadcrash.c:242
|
||||||
|
+ * #1 0x006aadec in start_thread () from /lib/tls/libpthread.so.0
|
||||||
|
+ * #2 0x001ed19a in clone () from /lib/tls/libc.so.6
|
||||||
|
+ *
|
||||||
|
+ * Thread 3 (process 4356):
|
||||||
|
+ * #0 spinningSighandler (signo=12, info=0xb4de46f0, context=0xb4de4770) at threadcrash.c:180
|
||||||
|
+ * #1 <signal handler called>
|
||||||
|
+ * #2 0x006adf5e in pthread_kill () from /lib/tls/libpthread.so.0
|
||||||
|
+ * #3 0x08048b2f in spinFromSighandler (ignored=0x0) at threadcrash.c:232
|
||||||
|
+ * #4 0x006aadec in start_thread () from /lib/tls/libpthread.so.0
|
||||||
|
+ * #5 0x001ed19a in clone () from /lib/tls/libc.so.6
|
||||||
|
+ *
|
||||||
|
+ * Thread 2 (process 4357):
|
||||||
|
+ * #0 spinningAltSighandler (signo=14, info=0x959ee50, context=0x959eed0) at threadcrash.c:156
|
||||||
|
+ * #1 <signal handler called>
|
||||||
|
+ * #2 0x006adf5e in pthread_kill () from /lib/tls/libpthread.so.0
|
||||||
|
+ * #3 0x08048ac0 in spinFromAltSighandler (ignored=0x0) at threadcrash.c:218
|
||||||
|
+ * #4 0x006aadec in start_thread () from /lib/tls/libpthread.so.0
|
||||||
|
+ * #5 0x001ed19a in clone () from /lib/tls/libc.so.6
|
||||||
|
+ *
|
||||||
|
+ * Thread 1 (process 4351):
|
||||||
|
+ * #0 0x08048cf3 in main (argc=1, argv=0xbfff9d74) at threadcrash.c:273
|
||||||
|
+ * (gdb)
|
||||||
|
+ */
|
||||||
|
+
|
||||||
|
+#include <pthread.h>
|
||||||
|
+#include <signal.h>
|
||||||
|
+#include <assert.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
+#include <stdio.h>
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+#include <string.h>
|
||||||
|
+
|
||||||
|
+#define SIGSYSCALL_ALT SIGQUIT
|
||||||
|
+#define SIGSYSCALL SIGUSR1
|
||||||
|
+#define SIGSPIN_ALT SIGALRM
|
||||||
|
+#define SIGSPIN SIGUSR2
|
||||||
|
+
|
||||||
|
+typedef void (*sigaction_t)(int, siginfo_t *, void *);
|
||||||
|
+
|
||||||
|
+static void installHandler(int signo, sigaction_t handler, int onAltstack) {
|
||||||
|
+ struct sigaction action;
|
||||||
|
+ sigset_t sigset;
|
||||||
|
+ int result;
|
||||||
|
+ stack_t altstack;
|
||||||
|
+ stack_t oldaltstack;
|
||||||
|
+
|
||||||
|
+ memset(&action, 0, sizeof(action));
|
||||||
|
+ memset(&altstack, 0, sizeof(altstack));
|
||||||
|
+ memset(&oldaltstack, 0, sizeof(oldaltstack));
|
||||||
|
+
|
||||||
|
+ if (onAltstack) {
|
||||||
|
+ altstack.ss_sp = malloc(SIGSTKSZ);
|
||||||
|
+ assert(altstack.ss_sp != NULL);
|
||||||
|
+ altstack.ss_size = SIGSTKSZ;
|
||||||
|
+ altstack.ss_flags = 0;
|
||||||
|
+ result = sigaltstack(&altstack, &oldaltstack);
|
||||||
|
+ assert(result == 0);
|
||||||
|
+ assert(oldaltstack.ss_flags == SS_DISABLE);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ sigemptyset(&sigset);
|
||||||
|
+
|
||||||
|
+ action.sa_handler = NULL;
|
||||||
|
+ action.sa_sigaction = handler;
|
||||||
|
+ action.sa_mask = sigset;
|
||||||
|
+ action.sa_flags = SA_SIGINFO;
|
||||||
|
+ if (onAltstack) {
|
||||||
|
+ action.sa_flags |= SA_ONSTACK;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ result = sigaction(signo, &action, NULL);
|
||||||
|
+ assert(result == 0);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void installNormalHandler(int signo, sigaction_t handler) {
|
||||||
|
+ installHandler(signo, handler, 0);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void installAlthandler(int signo, sigaction_t handler) {
|
||||||
|
+ installHandler(signo, handler, 1);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void *makeSyscall(void *ignored) {
|
||||||
|
+ (void)ignored;
|
||||||
|
+
|
||||||
|
+ sleep(42);
|
||||||
|
+
|
||||||
|
+ fprintf(stderr, "%s: returning\n", __FUNCTION__);
|
||||||
|
+ return NULL;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+/* Return true if we're currently executing on the altstack */
|
||||||
|
+static int onAltstack(void) {
|
||||||
|
+ stack_t stack;
|
||||||
|
+ int result;
|
||||||
|
+
|
||||||
|
+ result = sigaltstack(NULL, &stack);
|
||||||
|
+ assert(result == 0);
|
||||||
|
+
|
||||||
|
+ return stack.ss_flags & SS_ONSTACK;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void syscallingAltSighandler(int signo, siginfo_t *info, void *context) {
|
||||||
|
+ (void)signo;
|
||||||
|
+ (void)info;
|
||||||
|
+ (void)context;
|
||||||
|
+
|
||||||
|
+ if (!onAltstack()) {
|
||||||
|
+ printf("%s() not running on altstack!\n", __FUNCTION__);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ sleep(42);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void spinningAltSighandler(int signo, siginfo_t *info, void *context) {
|
||||||
|
+ (void)signo;
|
||||||
|
+ (void)info;
|
||||||
|
+ (void)context;
|
||||||
|
+
|
||||||
|
+ if (!onAltstack()) {
|
||||||
|
+ printf("%s() not running on altstack!\n", __FUNCTION__);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ while (1);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void syscallingSighandler(int signo, siginfo_t *info, void *context) {
|
||||||
|
+ (void)signo;
|
||||||
|
+ (void)info;
|
||||||
|
+ (void)context;
|
||||||
|
+
|
||||||
|
+ if (onAltstack()) {
|
||||||
|
+ printf("%s() running on altstack!\n", __FUNCTION__);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ sleep(42);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void spinningSighandler(int signo, siginfo_t *info, void *context) {
|
||||||
|
+ (void)signo;
|
||||||
|
+ (void)info;
|
||||||
|
+ (void)context;
|
||||||
|
+
|
||||||
|
+ if (onAltstack()) {
|
||||||
|
+ printf("%s() running on altstack!\n", __FUNCTION__);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ while (1);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void *makeSyscallFromAltSighandler(void *ignored) {
|
||||||
|
+ (void)ignored;
|
||||||
|
+
|
||||||
|
+ int result;
|
||||||
|
+
|
||||||
|
+ installAlthandler(SIGSYSCALL_ALT, syscallingAltSighandler);
|
||||||
|
+
|
||||||
|
+ result = pthread_kill(pthread_self(), SIGSYSCALL_ALT);
|
||||||
|
+ assert(result == 0);
|
||||||
|
+
|
||||||
|
+ fprintf(stderr, "%s: returning\n", __FUNCTION__);
|
||||||
|
+ return NULL;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void *makeSyscallFromSighandler(void *ignored) {
|
||||||
|
+ (void)ignored;
|
||||||
|
+
|
||||||
|
+ int result;
|
||||||
|
+
|
||||||
|
+ installNormalHandler(SIGSYSCALL, syscallingSighandler);
|
||||||
|
+
|
||||||
|
+ result = pthread_kill(pthread_self(), SIGSYSCALL);
|
||||||
|
+ assert(result == 0);
|
||||||
|
+
|
||||||
|
+ fprintf(stderr, "%s: returning\n", __FUNCTION__);
|
||||||
|
+ return NULL;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void *spinFromAltSighandler(void *ignored) {
|
||||||
|
+ (void)ignored;
|
||||||
|
+
|
||||||
|
+ int result;
|
||||||
|
+
|
||||||
|
+ installAlthandler(SIGSPIN_ALT, spinningAltSighandler);
|
||||||
|
+
|
||||||
|
+ result = pthread_kill(pthread_self(), SIGSPIN_ALT);
|
||||||
|
+ assert(result == 0);
|
||||||
|
+
|
||||||
|
+ fprintf(stderr, "%s: returning\n", __FUNCTION__);
|
||||||
|
+ return NULL;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void *spinFromSighandler(void *ignored) {
|
||||||
|
+ (void)ignored;
|
||||||
|
+
|
||||||
|
+ int result;
|
||||||
|
+
|
||||||
|
+ installNormalHandler(SIGSPIN, spinningSighandler);
|
||||||
|
+
|
||||||
|
+ result = pthread_kill(pthread_self(), SIGSPIN);
|
||||||
|
+ assert(result == 0);
|
||||||
|
+
|
||||||
|
+ fprintf(stderr, "%s: returning\n", __FUNCTION__);
|
||||||
|
+ return NULL;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void *spin(void *ignored) {
|
||||||
|
+ (void)ignored;
|
||||||
|
+
|
||||||
|
+ while (1);
|
||||||
|
+
|
||||||
|
+ fprintf(stderr, "%s: returning\n", __FUNCTION__);
|
||||||
|
+ return NULL;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int main(int argc, char *argv[]) {
|
||||||
|
+ int result;
|
||||||
|
+ pthread_t thread;
|
||||||
|
+ volatile int bad;
|
||||||
|
+
|
||||||
|
+ result = pthread_create(&thread, NULL, makeSyscall, NULL);
|
||||||
|
+ assert(result == 0);
|
||||||
|
+ result = pthread_create(&thread, NULL, makeSyscallFromSighandler, NULL);
|
||||||
|
+ assert(result == 0);
|
||||||
|
+ result = pthread_create(&thread, NULL, makeSyscallFromAltSighandler, NULL);
|
||||||
|
+ assert(result == 0);
|
||||||
|
+ result = pthread_create(&thread, NULL, spin, NULL);
|
||||||
|
+ assert(result == 0);
|
||||||
|
+ result = pthread_create(&thread, NULL, spinFromSighandler, NULL);
|
||||||
|
+ assert(result == 0);
|
||||||
|
+ result = pthread_create(&thread, NULL, spinFromAltSighandler, NULL);
|
||||||
|
+ assert(result == 0);
|
||||||
|
+
|
||||||
|
+ // Give threads some time to get going
|
||||||
|
+ sleep(3);
|
||||||
|
+
|
||||||
|
+ // Crash
|
||||||
|
+ bad = *(int*)7;
|
||||||
|
+
|
||||||
|
+ /* Workaround: http://gcc.gnu.org/bugzilla/show_bug.cgi?id=29628
|
||||||
|
+ Simulate use to ensure `DW_AT_location' for them:
|
||||||
|
+ readelf -a --debug threadcrash|grep -A5 -w argc
|
||||||
|
+ --> DW_AT_location : 2 byte block: 71 0 (DW_OP_breg1: 0)
|
||||||
|
+ This case verified on: gcc-4.1.1-30.i386
|
||||||
|
+ Keep it late to ensure persistency in the registers. */
|
||||||
|
+ bad = (int) argc;
|
||||||
|
+ bad = (unsigned long) argv;
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
Index: ./gdb/testsuite/gdb.threads/threadcrash.exp
|
||||||
|
===================================================================
|
||||||
|
RCS file: gdb/testsuite/gdb.threads/threadcrash.exp
|
||||||
|
diff -N gdb/testsuite/gdb.threads/threadcrash.exp
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.threads/threadcrash.exp 31 Oct 2006 17:54:38 -0000
|
||||||
|
@@ -0,0 +1,37 @@
|
||||||
|
+# threadcrash.exp - The point of this program is to crash in a multi-threaded app.
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+set testfile threadcrash
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set shellfile ${srcdir}/${subdir}/${testfile}.sh
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+set GDB_abs ${GDB}
|
||||||
|
+if [regexp "^\[^/\]" ${GDB_abs}] {
|
||||||
|
+ set GDB_abs $env(PWD)/${GDB_abs}
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if [istarget "*-*-linux"] then {
|
||||||
|
+ set target_cflags "-D_MIT_POSIX_THREADS"
|
||||||
|
+} else {
|
||||||
|
+ set target_cflags ""
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if {[gdb_compile_pthreads "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# ${shellfile} argument must not contain any directories.
|
||||||
|
+set fd [open "|bash ${shellfile} ${binfile} $GDB -nw $GDBFLAGS" r]
|
||||||
|
+while { [gets $fd line] >= 0 } {
|
||||||
|
+ if [regexp " PASS: (.*)$" $line trash message] {
|
||||||
|
+ pass $message
|
||||||
|
+ } elseif [regexp " FAIL: (.*)$" $line trash message] {
|
||||||
|
+ fail $message
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+catch {
|
||||||
|
+ close $fd
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+return 0
|
||||||
|
Index: ./gdb/testsuite/gdb.threads/threadcrash.sh
|
||||||
|
===================================================================
|
||||||
|
RCS file: gdb/testsuite/gdb.threads/threadcrash.sh
|
||||||
|
diff -N gdb/testsuite/gdb.threads/threadcrash.sh
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.threads/threadcrash.sh 31 Oct 2006 17:54:38 -0000
|
||||||
|
@@ -0,0 +1,324 @@
|
||||||
|
+#! /bin/bash
|
||||||
|
+
|
||||||
|
+# NOTE: threadcrash.c *must* be built with debugging symbols
|
||||||
|
+#
|
||||||
|
+# The point of this shell script is to crash treadcrash.c, load the
|
||||||
|
+# resulting core file into gdb and verify that gdb can extract enough
|
||||||
|
+# information from the core file.
|
||||||
|
+#
|
||||||
|
+# The return code from this script is the number of failed tests.
|
||||||
|
+
|
||||||
|
+LOG=gdbresult.log
|
||||||
|
+
|
||||||
|
+if [ $# = 0 ] ; then
|
||||||
|
+ echo >&2 Syntax: $0 \<name of threadcrash binary\> [\<gdb binary\> \<args...\>]
|
||||||
|
+ exit 1
|
||||||
|
+fi
|
||||||
|
+RUNME="$1"
|
||||||
|
+shift
|
||||||
|
+GDB="${*:-gdb}"
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+pf_prefix=""
|
||||||
|
+function pf_prefix() {
|
||||||
|
+ pf_prefix="$*"
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set_test=""
|
||||||
|
+function set_test() {
|
||||||
|
+ if [ -n "$set_test" ] ; then
|
||||||
|
+ echo >&2 "DEJAGNU-BASH ERROR: set_test already set"
|
||||||
|
+ exit 1
|
||||||
|
+ fi
|
||||||
|
+ set_test="$*"
|
||||||
|
+ if [ -n "$pf_prefix" ] ; then
|
||||||
|
+ set_test="$pf_prefix: $set_test"
|
||||||
|
+ fi
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# INTERNAL
|
||||||
|
+function record_test {
|
||||||
|
+ if [ -z "$set_test" ] ; then
|
||||||
|
+ echo >&2 "DEJAGNU-BASH ERROR: set_test not set"
|
||||||
|
+ exit 1
|
||||||
|
+ fi
|
||||||
|
+ # Provide the leading whitespace delimiter:
|
||||||
|
+ echo " $1: $set_test"
|
||||||
|
+ set_test=""
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+function pass() {
|
||||||
|
+ record_test PASS
|
||||||
|
+}
|
||||||
|
+function fail() {
|
||||||
|
+ record_test FAIL
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+# Verify that the gdb output doesn't contain $1.
|
||||||
|
+function mustNotHave() {
|
||||||
|
+ local BADWORD=$1
|
||||||
|
+ set_test gdb output contains "$BADWORD"
|
||||||
|
+ if grep -q "$BADWORD" $LOG ; then
|
||||||
|
+ fail
|
||||||
|
+ return 1
|
||||||
|
+ fi
|
||||||
|
+ pass
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Verify that the gdb output contains exactly $1 $2s.
|
||||||
|
+function mustHaveCorrectAmount() {
|
||||||
|
+ local WANTEDNUMBER=$1
|
||||||
|
+ local GOODWORD=$2
|
||||||
|
+ local ACTUALNUMBER=$(grep "$GOODWORD" $LOG | wc -l)
|
||||||
|
+ set_test gdb output contained $ACTUALNUMBER \""$GOODWORD"\", not $WANTEDNUMBER as expected
|
||||||
|
+ if [ $ACTUALNUMBER != $WANTEDNUMBER ] ; then
|
||||||
|
+ fail
|
||||||
|
+ return 1
|
||||||
|
+ fi
|
||||||
|
+ pass
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Verify that the gdb output contains seven threads
|
||||||
|
+function mustHaveSevenThreads() {
|
||||||
|
+ NTHREADS=$(egrep "^Thread [1-7] \(" $LOG | wc -l)
|
||||||
|
+ set_test gdb output contains $NTHREADS threads, not 7 as expected
|
||||||
|
+ if [ $NTHREADS != 7 ] ; then
|
||||||
|
+ fail
|
||||||
|
+ return 1
|
||||||
|
+ fi
|
||||||
|
+ pass
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Verify that the gdb output has all parameters on consecutive lines
|
||||||
|
+function mustHaveSequence() {
|
||||||
|
+ SEQUENCE="$*"
|
||||||
|
+ NPARTS=$#
|
||||||
|
+ grep "$1" -A$((NPARTS - 1)) $LOG > matches.log
|
||||||
|
+
|
||||||
|
+ while [ $# -gt 1 ] ; do
|
||||||
|
+ shift
|
||||||
|
+ ((NPARTS--))
|
||||||
|
+ grep "$1" -A$((NPARTS - 1)) matches.log > temp.log
|
||||||
|
+ mv temp.log matches.log
|
||||||
|
+ done
|
||||||
|
+ LASTPART=$1
|
||||||
|
+
|
||||||
|
+ set_test gdb output does not contain the sequence: $SEQUENCE
|
||||||
|
+ if ! grep -q "$LASTPART" matches.log ; then
|
||||||
|
+ fail
|
||||||
|
+ return 1
|
||||||
|
+ fi
|
||||||
|
+ pass
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Verify that $LOG contains all information we want
|
||||||
|
+function verifyLog() {
|
||||||
|
+ local FAILURES=0
|
||||||
|
+
|
||||||
|
+ mustNotHave '??' || ((FAILURES++))
|
||||||
|
+ mustHaveCorrectAmount 12 threadcrash.c: || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSevenThreads || ((FAILURES++))
|
||||||
|
+ mustHaveSequence sleep "makeSyscall (ignored=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSequence sleep "syscallingSighandler (signo=" "signal handler called" 0x || ((FAILURES++))
|
||||||
|
+ mustHaveSequence pthread_kill "makeSyscallFromSighandler (ignored=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSequence sleep "syscallingAltSighandler (signo=" "signal handler called" 0x || ((FAILURES++))
|
||||||
|
+ mustHaveSequence pthread_kill "makeSyscallFromAltSighandler (ignored=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSequence Thread "spin (ignored=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSequence "spinningSighandler (signo=" "signal handler called" 0x || ((FAILURES++))
|
||||||
|
+ mustHaveSequence pthread_kill "spinFromSighandler (ignored=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSequence "spinningAltSighandler (signo=" "signal handler called" 0x || ((FAILURES++))
|
||||||
|
+ mustHaveSequence pthread_kill "spinFromAltSighandler (ignored=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSequence Thread "main (argc=1, argv=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ return $FAILURES
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Put result of debugging a core file in $LOG
|
||||||
|
+function getLogFromCore() {
|
||||||
|
+ # Make sure we get a core file
|
||||||
|
+ set_test Make sure we get a core file
|
||||||
|
+ if ! ulimit -c unlimited ; then
|
||||||
|
+ fail
|
||||||
|
+ exit 1
|
||||||
|
+ fi
|
||||||
|
+ pass
|
||||||
|
+
|
||||||
|
+ # Run the crasher
|
||||||
|
+ ./$(basename "$RUNME")
|
||||||
|
+ EXITCODE=$?
|
||||||
|
+
|
||||||
|
+ # Verify that we actually crashed
|
||||||
|
+ set_test $RUNME should have been killed by a signal, got non-signal exit code $EXITCODE
|
||||||
|
+ if [ $EXITCODE -lt 128 ] ; then
|
||||||
|
+ fail
|
||||||
|
+ exit 1
|
||||||
|
+ fi
|
||||||
|
+ pass
|
||||||
|
+
|
||||||
|
+ # Verify that we got a core file
|
||||||
|
+ set_test $RUNME did not create a core file
|
||||||
|
+ if [ ! -r core* ] ; then
|
||||||
|
+ fail
|
||||||
|
+ exit 1
|
||||||
|
+ fi
|
||||||
|
+ pass
|
||||||
|
+
|
||||||
|
+ # Run gdb
|
||||||
|
+ cat > gdbscript.gdb <<EOF
|
||||||
|
+set width 0
|
||||||
|
+t a a bt 100
|
||||||
|
+quit
|
||||||
|
+EOF
|
||||||
|
+ cat gdbscript.gdb /dev/zero | $GDB -nx "./$(basename "$RUNME")" core* > $LOG
|
||||||
|
+ EXITCODE=$?
|
||||||
|
+
|
||||||
|
+ set_test gdb exited with error code
|
||||||
|
+ if [ $EXITCODE != 0 ] ; then
|
||||||
|
+ ((FAILURES++))
|
||||||
|
+ echo >&2 gdb exited with error code $EXITCODE
|
||||||
|
+ fail
|
||||||
|
+ fi
|
||||||
|
+ pass
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Put result of debugging a gcore file in $LOG
|
||||||
|
+function getLogFromGcore() {
|
||||||
|
+ # Create the core file
|
||||||
|
+ rm -f core*
|
||||||
|
+ cat > gdbscript.gdb <<EOF
|
||||||
|
+handle SIGQUIT pass noprint nostop
|
||||||
|
+handle SIGUSR1 pass noprint nostop
|
||||||
|
+handle SIGUSR2 pass noprint nostop
|
||||||
|
+handle SIGALRM pass noprint nostop
|
||||||
|
+run
|
||||||
|
+gcore
|
||||||
|
+quit
|
||||||
|
+EOF
|
||||||
|
+ cat gdbscript.gdb /dev/zero | $GDB -nx "./$(basename "$RUNME")" > /dev/null
|
||||||
|
+ EXITCODE=$?
|
||||||
|
+
|
||||||
|
+ set_test gdb exited with error code when creating gcore file
|
||||||
|
+ if [ $EXITCODE != 0 ] ; then
|
||||||
|
+ ((FAILURES++))
|
||||||
|
+ echo >&2 gdb exited with error code $EXITCODE when creating gcore file
|
||||||
|
+ fail
|
||||||
|
+ fi
|
||||||
|
+ pass
|
||||||
|
+
|
||||||
|
+ # Verify that we got a core file from gcore
|
||||||
|
+ set_test gdb gcore did not create a core file
|
||||||
|
+ if [ ! -r core* ] ; then
|
||||||
|
+ fail
|
||||||
|
+ exit 1
|
||||||
|
+ fi
|
||||||
|
+ pass
|
||||||
|
+
|
||||||
|
+ # Run gdb on the gcore file
|
||||||
|
+ cat > gdbscript.gdb <<EOF
|
||||||
|
+set width 0
|
||||||
|
+t a a bt 100
|
||||||
|
+quit
|
||||||
|
+EOF
|
||||||
|
+ cat gdbscript.gdb /dev/zero | $GDB -nx "./$(basename "$RUNME")" core* > $LOG
|
||||||
|
+ EXITCODE=$?
|
||||||
|
+
|
||||||
|
+ set_test gdb exited with error code when examining gcore file
|
||||||
|
+ if [ $EXITCODE != 0 ] ; then
|
||||||
|
+ ((FAILURES++))
|
||||||
|
+ echo >&2 gdb exited with error code $EXITCODE when examining gcore file
|
||||||
|
+ fail
|
||||||
|
+ fi
|
||||||
|
+ pass
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Put result of debugging a core file in $LOG
|
||||||
|
+function getLogFromLiveProcess() {
|
||||||
|
+ # Run gdb
|
||||||
|
+ cat > gdbscript.gdb <<EOF
|
||||||
|
+handle SIGQUIT pass noprint nostop
|
||||||
|
+handle SIGUSR1 pass noprint nostop
|
||||||
|
+handle SIGUSR2 pass noprint nostop
|
||||||
|
+handle SIGALRM pass noprint nostop
|
||||||
|
+set width 0
|
||||||
|
+run
|
||||||
|
+t a a bt 100
|
||||||
|
+quit
|
||||||
|
+EOF
|
||||||
|
+ cat gdbscript.gdb /dev/zero | $GDB -nx "./$(basename "$RUNME")" > $LOG
|
||||||
|
+ EXITCODE=$?
|
||||||
|
+
|
||||||
|
+ set_test gdb exited with error code
|
||||||
|
+ if [ $EXITCODE != 0 ] ; then
|
||||||
|
+ ((FAILURES++))
|
||||||
|
+ echo >&2 gdb exited with error code $EXITCODE
|
||||||
|
+ fail
|
||||||
|
+ fi
|
||||||
|
+ pass
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+####### Main program follows #####################
|
||||||
|
+
|
||||||
|
+# Make sure we don't clobber anybody else's (core) file(s)
|
||||||
|
+WORKDIR=/tmp/$PPID
|
||||||
|
+mkdir -p $WORKDIR
|
||||||
|
+cp "$RUNME" $WORKDIR
|
||||||
|
+cd $WORKDIR
|
||||||
|
+
|
||||||
|
+# Count problems
|
||||||
|
+FAILURES=0
|
||||||
|
+
|
||||||
|
+echo === Testing gdb vs core file...
|
||||||
|
+pf_prefix core file
|
||||||
|
+getLogFromCore
|
||||||
|
+verifyLog
|
||||||
|
+((FAILURES+=$?))
|
||||||
|
+pf_prefix
|
||||||
|
+echo === Core file tests done.
|
||||||
|
+
|
||||||
|
+echo
|
||||||
|
+
|
||||||
|
+echo === Testing gdb vs gcore file...
|
||||||
|
+pf_prefix gcore file
|
||||||
|
+getLogFromGcore
|
||||||
|
+verifyLog
|
||||||
|
+((FAILURES+=$?))
|
||||||
|
+pf_prefix
|
||||||
|
+echo === Gcore file tests done.
|
||||||
|
+
|
||||||
|
+echo
|
||||||
|
+
|
||||||
|
+echo === Testing gdb vs live process...
|
||||||
|
+pf_prefix live process
|
||||||
|
+getLogFromLiveProcess
|
||||||
|
+verifyLog
|
||||||
|
+((FAILURES+=$?))
|
||||||
|
+pf_prefix
|
||||||
|
+echo === Live process tests done.
|
||||||
|
+
|
||||||
|
+# Executive summary
|
||||||
|
+echo
|
||||||
|
+if [ $FAILURES == 0 ] ; then
|
||||||
|
+ echo All tests passed!
|
||||||
|
+else
|
||||||
|
+ echo $FAILURES tests failed!
|
||||||
|
+ echo
|
||||||
|
+ echo Make sure the threadcrash binary contains debugging information \(build with \"gcc -g\"\).
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+# Clean up
|
||||||
|
+cd /
|
||||||
|
+rm -rf $WORKDIR
|
||||||
|
+
|
||||||
|
+exit $FAILURES
|
||||||
|
Index: ./gdb/testsuite/gdb.threads/threadcrash.sh-orig
|
||||||
|
===================================================================
|
||||||
|
RCS file: gdb/testsuite/gdb.threads/threadcrash.sh-orig
|
||||||
|
diff -N gdb/testsuite/gdb.threads/threadcrash.sh-orig
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.threads/threadcrash.sh-orig 31 Oct 2006 17:54:38 -0000
|
||||||
|
@@ -0,0 +1,248 @@
|
||||||
|
+#! /bin/bash
|
||||||
|
+
|
||||||
|
+# NOTE: threadcrash.c *must* be built with debugging symbols
|
||||||
|
+#
|
||||||
|
+# The point of this shell script is to crash treadcrash.c, load the
|
||||||
|
+# resulting core file into gdb and verify that gdb can extract enough
|
||||||
|
+# information from the core file.
|
||||||
|
+#
|
||||||
|
+# The return code from this script is the number of failed tests.
|
||||||
|
+
|
||||||
|
+LOG=gdbresult.log
|
||||||
|
+
|
||||||
|
+if [ $# != 1 ] ; then
|
||||||
|
+ echo > /dev/stderr Syntax: $0 \<name of threadcrash binary\>
|
||||||
|
+ exit 1
|
||||||
|
+fi
|
||||||
|
+RUNME="$1"
|
||||||
|
+
|
||||||
|
+# Verify that the gdb output doesn't contain $1.
|
||||||
|
+function mustNotHave() {
|
||||||
|
+ local BADWORD=$1
|
||||||
|
+ if grep -q "$BADWORD" $LOG ; then
|
||||||
|
+ echo >> /dev/stderr WARNING: gdb output contains "$BADWORD"
|
||||||
|
+ return 1
|
||||||
|
+ fi
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Verify that the gdb output contains exactly $1 $2s.
|
||||||
|
+function mustHaveCorrectAmount() {
|
||||||
|
+ local WANTEDNUMBER=$1
|
||||||
|
+ local GOODWORD=$2
|
||||||
|
+ local ACTUALNUMBER=$(grep "$GOODWORD" $LOG | wc -l)
|
||||||
|
+ if [ $ACTUALNUMBER != $WANTEDNUMBER ] ; then
|
||||||
|
+ echo >> /dev/stderr WARNING: gdb output contained $ACTUALNUMBER \""$GOODWORD"\", not $WANTEDNUMBER as expected
|
||||||
|
+ return 1
|
||||||
|
+ fi
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Verify that the gdb output contains seven threads
|
||||||
|
+function mustHaveSevenThreads() {
|
||||||
|
+ NTHREADS=$(egrep "^Thread [1-7] \(" $LOG | wc -l)
|
||||||
|
+ if [ $NTHREADS != 7 ] ; then
|
||||||
|
+ echo >> /dev/stderr WARNING: gdb output contains $NTHREADS threads, not 7 as expected
|
||||||
|
+ return 1
|
||||||
|
+ fi
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Verify that the gdb output has all parameters on consecutive lines
|
||||||
|
+function mustHaveSequence() {
|
||||||
|
+ SEQUENCE="$*"
|
||||||
|
+ NPARTS=$#
|
||||||
|
+ grep "$1" -A$((NPARTS - 1)) $LOG > matches.log
|
||||||
|
+
|
||||||
|
+ while [ $# -gt 1 ] ; do
|
||||||
|
+ shift
|
||||||
|
+ ((NPARTS--))
|
||||||
|
+ grep "$1" -A$((NPARTS - 1)) matches.log > temp.log
|
||||||
|
+ mv temp.log matches.log
|
||||||
|
+ done
|
||||||
|
+ LASTPART=$1
|
||||||
|
+
|
||||||
|
+ if ! grep -q "$LASTPART" matches.log ; then
|
||||||
|
+ echo >> /dev/stderr WARNING: gdb output does not contain the sequence: $SEQUENCE
|
||||||
|
+ return 1
|
||||||
|
+ fi
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Verify that $LOG contains all information we want
|
||||||
|
+function verifyLog() {
|
||||||
|
+ local FAILURES=0
|
||||||
|
+
|
||||||
|
+ mustNotHave '??' || ((FAILURES++))
|
||||||
|
+ mustHaveCorrectAmount 12 threadcrash.c: || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSevenThreads || ((FAILURES++))
|
||||||
|
+ mustHaveSequence sleep "makeSyscall (ignored=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSequence sleep "syscallingSighandler (signo=" "signal handler called" 0x || ((FAILURES++))
|
||||||
|
+ mustHaveSequence pthread_kill "makeSyscallFromSighandler (ignored=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSequence sleep "syscallingAltSighandler (signo=" "signal handler called" 0x || ((FAILURES++))
|
||||||
|
+ mustHaveSequence pthread_kill "makeSyscallFromAltSighandler (ignored=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSequence Thread "spin (ignored=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSequence "spinningSighandler (signo=" "signal handler called" 0x || ((FAILURES++))
|
||||||
|
+ mustHaveSequence pthread_kill "spinFromSighandler (ignored=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSequence "spinningAltSighandler (signo=" "signal handler called" 0x || ((FAILURES++))
|
||||||
|
+ mustHaveSequence pthread_kill "spinFromAltSighandler (ignored=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ mustHaveSequence Thread "main (argc=1, argv=" || ((FAILURES++))
|
||||||
|
+
|
||||||
|
+ return $FAILURES
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Put result of debugging a core file in $LOG
|
||||||
|
+function getLogFromCore() {
|
||||||
|
+ # Make sure we get a core file
|
||||||
|
+ ulimit -c unlimited || exit 1
|
||||||
|
+
|
||||||
|
+ # Run the crasher
|
||||||
|
+ ./$(basename "$RUNME")
|
||||||
|
+ EXITCODE=$?
|
||||||
|
+
|
||||||
|
+ # Verify that we actually crashed
|
||||||
|
+ if [ $EXITCODE -lt 128 ] ; then
|
||||||
|
+ echo >> /dev/stderr ERROR: $RUNME should have been killed by a signal, got non-signal exit code $EXITCODE
|
||||||
|
+ exit 1
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ # Verify that we got a core file
|
||||||
|
+ if [ ! -r core* ] ; then
|
||||||
|
+ echo >> /dev/stderr ERROR: $RUNME did not create a core file
|
||||||
|
+ exit 1
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ # Run gdb
|
||||||
|
+ cat > gdbscript.gdb <<EOF
|
||||||
|
+set width 0
|
||||||
|
+t a a bt 100
|
||||||
|
+quit
|
||||||
|
+EOF
|
||||||
|
+ cat gdbscript.gdb /dev/zero | gdb -nx "./$(basename "$RUNME")" core* > $LOG
|
||||||
|
+ EXITCODE=$?
|
||||||
|
+
|
||||||
|
+ if [ $EXITCODE != 0 ] ; then
|
||||||
|
+ ((FAILURES++))
|
||||||
|
+ echo >> /dev/stderr WARNING: gdb exited with error code $EXITCODE
|
||||||
|
+ fi
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Put result of debugging a gcore file in $LOG
|
||||||
|
+function getLogFromGcore() {
|
||||||
|
+ # Create the core file
|
||||||
|
+ rm -f core*
|
||||||
|
+ cat > gdbscript.gdb <<EOF
|
||||||
|
+handle SIGQUIT pass noprint nostop
|
||||||
|
+handle SIGUSR1 pass noprint nostop
|
||||||
|
+handle SIGUSR2 pass noprint nostop
|
||||||
|
+handle SIGALRM pass noprint nostop
|
||||||
|
+run
|
||||||
|
+gcore
|
||||||
|
+quit
|
||||||
|
+EOF
|
||||||
|
+ cat gdbscript.gdb /dev/zero | gdb -nx "./$(basename "$RUNME")" > /dev/null
|
||||||
|
+ EXITCODE=$?
|
||||||
|
+
|
||||||
|
+ if [ $EXITCODE != 0 ] ; then
|
||||||
|
+ ((FAILURES++))
|
||||||
|
+ echo >> /dev/stderr WARNING: gdb exited with error code $EXITCODE when creating gcore file
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ # Verify that we got a core file from gcore
|
||||||
|
+ if [ ! -r core* ] ; then
|
||||||
|
+ echo >> /dev/stderr ERROR: gdb gcore did not create a core file
|
||||||
|
+ exit 1
|
||||||
|
+ fi
|
||||||
|
+
|
||||||
|
+ # Run gdb on the gcore file
|
||||||
|
+ cat > gdbscript.gdb <<EOF
|
||||||
|
+set width 0
|
||||||
|
+t a a bt 100
|
||||||
|
+quit
|
||||||
|
+EOF
|
||||||
|
+ cat gdbscript.gdb /dev/zero | gdb -nx "./$(basename "$RUNME")" core* > $LOG
|
||||||
|
+ EXITCODE=$?
|
||||||
|
+
|
||||||
|
+ if [ $EXITCODE != 0 ] ; then
|
||||||
|
+ ((FAILURES++))
|
||||||
|
+ echo >> /dev/stderr WARNING: gdb exited with error code $EXITCODE when examining gcore file
|
||||||
|
+ fi
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Put result of debugging a core file in $LOG
|
||||||
|
+function getLogFromLiveProcess() {
|
||||||
|
+ # Run gdb
|
||||||
|
+ cat > gdbscript.gdb <<EOF
|
||||||
|
+handle SIGQUIT pass noprint nostop
|
||||||
|
+handle SIGUSR1 pass noprint nostop
|
||||||
|
+handle SIGUSR2 pass noprint nostop
|
||||||
|
+handle SIGALRM pass noprint nostop
|
||||||
|
+set width 0
|
||||||
|
+run
|
||||||
|
+t a a bt 100
|
||||||
|
+quit
|
||||||
|
+EOF
|
||||||
|
+ cat gdbscript.gdb /dev/zero | gdb -nx "./$(basename "$RUNME")" > $LOG
|
||||||
|
+ EXITCODE=$?
|
||||||
|
+
|
||||||
|
+ if [ $EXITCODE != 0 ] ; then
|
||||||
|
+ ((FAILURES++))
|
||||||
|
+ echo >> /dev/stderr WARNING: gdb exited with error code $EXITCODE
|
||||||
|
+ fi
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+####### Main program follows #####################
|
||||||
|
+
|
||||||
|
+# Make sure we don't clobber anybody else's (core) file(s)
|
||||||
|
+WORKDIR=/tmp/$PPID
|
||||||
|
+mkdir -p $WORKDIR
|
||||||
|
+cp "$RUNME" $WORKDIR
|
||||||
|
+cd $WORKDIR
|
||||||
|
+
|
||||||
|
+# Count problems
|
||||||
|
+FAILURES=0
|
||||||
|
+
|
||||||
|
+echo === Testing gdb vs core file...
|
||||||
|
+getLogFromCore
|
||||||
|
+verifyLog
|
||||||
|
+((FAILURES+=$?))
|
||||||
|
+echo === Core file tests done.
|
||||||
|
+
|
||||||
|
+echo
|
||||||
|
+
|
||||||
|
+echo === Testing gdb vs gcore file...
|
||||||
|
+getLogFromGcore
|
||||||
|
+verifyLog
|
||||||
|
+((FAILURES+=$?))
|
||||||
|
+echo === Gcore file tests done.
|
||||||
|
+
|
||||||
|
+echo
|
||||||
|
+
|
||||||
|
+echo === Testing gdb vs live process...
|
||||||
|
+getLogFromLiveProcess
|
||||||
|
+verifyLog
|
||||||
|
+((FAILURES+=$?))
|
||||||
|
+echo === Live process tests done.
|
||||||
|
+
|
||||||
|
+# Executive summary
|
||||||
|
+echo
|
||||||
|
+if [ $FAILURES == 0 ] ; then
|
||||||
|
+ echo All tests passed!
|
||||||
|
+else
|
||||||
|
+ echo $FAILURES tests failed!
|
||||||
|
+ echo
|
||||||
|
+ echo Make sure the threadcrash binary contains debugging information \(build with \"gcc -g\"\).
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+# Clean up
|
||||||
|
+cd /
|
||||||
|
+rm -rf $WORKDIR
|
||||||
|
+
|
||||||
|
+exit $FAILURES
|
120
gdb-6.5-bz109921-DW_AT_decl_file-test.patch
Normal file
120
gdb-6.5-bz109921-DW_AT_decl_file-test.patch
Normal file
@ -0,0 +1,120 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=109921
|
||||||
|
|
||||||
|
It is duplicite to its upstream variant:
|
||||||
|
http://sourceware.org/ml/gdb-cvs/2007-01/msg00157.html
|
||||||
|
http://sourceware.org/ml/gdb-patches/2007-01/msg00434.html
|
||||||
|
2007-01-21 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
Daniel Jacobowitz <dan@codesourcery.com>
|
||||||
|
|
||||||
|
* gdb.base/included.c, gdb.base/included.exp,
|
||||||
|
gdb.base/included.h: New files.
|
||||||
|
|
||||||
|
------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
2007-01-09 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.dwarf2/dw2-included.exp, gdb.dwarf2/dw2-included.c,
|
||||||
|
gdb.dwarf2/dw2-included.h: New files.
|
||||||
|
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.dwarf2/dw2-included.c 2 Jan 2007 00:20:27 -0000
|
||||||
|
@@ -0,0 +1,26 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2006 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. */
|
||||||
|
+
|
||||||
|
+#include "dw2-included.h"
|
||||||
|
+
|
||||||
|
+int
|
||||||
|
+main()
|
||||||
|
+{
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.dwarf2/dw2-included.exp 2 Jan 2007 00:20:27 -0000
|
||||||
|
@@ -0,0 +1,47 @@
|
||||||
|
+# Copyright 2006 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.
|
||||||
|
+
|
||||||
|
+# Minimal DWARF-2 unit test
|
||||||
|
+
|
||||||
|
+# This test can only be run on targets which support DWARF-2.
|
||||||
|
+# For now pick a sampling of likely targets.
|
||||||
|
+if {![istarget *-*-linux*]
|
||||||
|
+ && ![istarget *-*-gnu*]
|
||||||
|
+ && ![istarget *-*-elf*]
|
||||||
|
+ && ![istarget *-*-openbsd*]
|
||||||
|
+ && ![istarget arm-*-eabi*]
|
||||||
|
+ && ![istarget powerpc-*-eabi*]} {
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "dw2-included"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+gdb_test "set listsize 1" ""
|
||||||
|
+gdb_test "list integer" "int integer;\r"
|
||||||
|
+gdb_test "ptype integer" "type = int\r"
|
||||||
|
+# Path varies depending on the build location.
|
||||||
|
+gdb_test "info variables integer" "\r\nFile \[^\r\n\]*/gdb.dwarf2/dw2-included.h:\r\nint integer;\r"
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.dwarf2/dw2-included.h 2 Jan 2007 00:20:27 -0000
|
||||||
|
@@ -0,0 +1,20 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2006 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. */
|
||||||
|
+
|
||||||
|
+int integer;
|
197
gdb-6.5-bz181390-memory-address-width.patch
Normal file
197
gdb-6.5-bz181390-memory-address-width.patch
Normal file
@ -0,0 +1,197 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=181390
|
||||||
|
|
||||||
|
2006-09-28 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb/utils.c (paddress): Disable cutting of the printed addresses
|
||||||
|
to the target's address bit size; user wants to see everything.
|
||||||
|
* gdb/value.c (value_as_address1): Original `value_as_address'.
|
||||||
|
(value_as_address): New `value_as_address' wrapper - cut memory address
|
||||||
|
to the target's address bit size, bugreport by John Reiser.
|
||||||
|
|
||||||
|
2008-03-02 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.8pre.
|
||||||
|
New testcase `gdb.arch/amd64-i386-address.exp'.
|
||||||
|
|
||||||
|
Index: gdb-6.7.50.20080227/gdb/utils.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.7.50.20080227.orig/gdb/utils.c 2008-03-02 14:28:44.000000000 +0100
|
||||||
|
+++ gdb-6.7.50.20080227/gdb/utils.c 2008-03-02 14:35:09.000000000 +0100
|
||||||
|
@@ -2540,6 +2540,14 @@ paddr_nz (CORE_ADDR addr)
|
||||||
|
const char *
|
||||||
|
paddress (CORE_ADDR addr)
|
||||||
|
{
|
||||||
|
+ /* Do not cut the address as the user should see all the information
|
||||||
|
+ available. Otherwise 64-bit gdb debugging 32-bit inferior would
|
||||||
|
+ report for `x/x 0xffffffffffffce70' error
|
||||||
|
+ `Cannot access memory at 0xffffce70' while the error occured just
|
||||||
|
+ because of the higher order bits 0xffffffff00000000 there.
|
||||||
|
+ This specific error no longer occurs as the address is now cut
|
||||||
|
+ during execution by `value_as_address'. */
|
||||||
|
+#if 0
|
||||||
|
/* Truncate address to the size of a target address, avoiding shifts
|
||||||
|
larger or equal than the width of a CORE_ADDR. The local
|
||||||
|
variable ADDR_BIT stops the compiler reporting a shift overflow
|
||||||
|
@@ -2553,6 +2561,8 @@ paddress (CORE_ADDR addr)
|
||||||
|
|
||||||
|
if (addr_bit < (sizeof (CORE_ADDR) * HOST_CHAR_BIT))
|
||||||
|
addr &= ((CORE_ADDR) 1 << addr_bit) - 1;
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
return hex_string (addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
Index: gdb-6.7.50.20080227/gdb/value.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.7.50.20080227.orig/gdb/value.c 2008-01-18 18:07:40.000000000 +0100
|
||||||
|
+++ gdb-6.7.50.20080227/gdb/value.c 2008-03-02 14:36:38.000000000 +0100
|
||||||
|
@@ -983,11 +983,9 @@ value_as_double (struct value *val)
|
||||||
|
return foo;
|
||||||
|
}
|
||||||
|
|
||||||
|
-/* Extract a value as a C pointer. Does not deallocate the value.
|
||||||
|
- Note that val's type may not actually be a pointer; value_as_long
|
||||||
|
- handles all the cases. */
|
||||||
|
-CORE_ADDR
|
||||||
|
-value_as_address (struct value *val)
|
||||||
|
+/* See `value_as_address' below - core of value to C pointer extraction. */
|
||||||
|
+static CORE_ADDR
|
||||||
|
+value_as_address1 (struct value *val)
|
||||||
|
{
|
||||||
|
/* Assume a CORE_ADDR can fit in a LONGEST (for now). Not sure
|
||||||
|
whether we want this to be true eventually. */
|
||||||
|
@@ -1087,6 +1085,34 @@ value_as_address (struct value *val)
|
||||||
|
return unpack_long (value_type (val), value_contents (val));
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+/* Extract a value as a C pointer. Does not deallocate the value.
|
||||||
|
+ Note that val's type may not actually be a pointer; value_as_long
|
||||||
|
+ handles all the cases. */
|
||||||
|
+CORE_ADDR
|
||||||
|
+value_as_address (struct value *val)
|
||||||
|
+{
|
||||||
|
+ CORE_ADDR addr;
|
||||||
|
+ int addr_bit;
|
||||||
|
+
|
||||||
|
+ addr = value_as_address1 (val);
|
||||||
|
+
|
||||||
|
+ /* Truncate address to the size of a target address, avoiding shifts
|
||||||
|
+ larger or equal than the width of a CORE_ADDR. The local
|
||||||
|
+ variable ADDR_BIT stops the compiler reporting a shift overflow
|
||||||
|
+ when it won't occur. */
|
||||||
|
+ /* NOTE: This assumes that the significant address information is
|
||||||
|
+ kept in the least significant bits of ADDR - the upper bits were
|
||||||
|
+ either zero or sign extended. Should ADDRESS_TO_POINTER() or
|
||||||
|
+ some ADDRESS_TO_PRINTABLE() be used to do the conversion? */
|
||||||
|
+
|
||||||
|
+ addr_bit = gdbarch_addr_bit (current_gdbarch);
|
||||||
|
+
|
||||||
|
+ if (addr_bit < (sizeof (CORE_ADDR) * HOST_CHAR_BIT))
|
||||||
|
+ addr &= ((CORE_ADDR) 1 << addr_bit) - 1;
|
||||||
|
+
|
||||||
|
+ return addr;
|
||||||
|
+}
|
||||||
|
|
||||||
|
/* Unpack raw data (copied from debugee, target byte order) at VALADDR
|
||||||
|
as a long, or as a double, assuming the raw data is described
|
||||||
|
--- /dev/null 2008-03-01 10:30:54.797374318 +0100
|
||||||
|
+++ gdb-6.7.50.20080227/gdb/testsuite/gdb.arch/amd64-i386-address.S 2008-03-02 12:47:06.000000000 +0100
|
||||||
|
@@ -0,0 +1,32 @@
|
||||||
|
+/* Copyright 2008 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/>.
|
||||||
|
+
|
||||||
|
+ Please email any bugs, comments, and/or additions to this file to:
|
||||||
|
+ bug-gdb@gnu.org
|
||||||
|
+
|
||||||
|
+ This file is part of the gdb testsuite.
|
||||||
|
+
|
||||||
|
+ Test UNsigned extension of the 32-bit inferior address on a 64-bit host.
|
||||||
|
+ This file is based on the work by John Reiser.
|
||||||
|
+ This file was created by Jan Kratochvil <jan.kratochvil@redhat.com>.
|
||||||
|
+ https://bugzilla.redhat.com/show_bug.cgi?id=181390 */
|
||||||
|
+
|
||||||
|
+_start: .globl _start
|
||||||
|
+ nop
|
||||||
|
+ int3
|
||||||
|
+ movl %esp,%ebx
|
||||||
|
+ int3 # examining memory from $ebx fails, from $esp succeeds
|
||||||
|
+ nop
|
||||||
|
+ nop
|
||||||
|
--- /dev/null 2008-03-01 10:30:54.797374318 +0100
|
||||||
|
+++ gdb-6.7.50.20080227/gdb/testsuite/gdb.arch/amd64-i386-address.exp 2008-03-02 12:57:11.000000000 +0100
|
||||||
|
@@ -0,0 +1,62 @@
|
||||||
|
+# Copyright 2008 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/>.
|
||||||
|
+
|
||||||
|
+# Please email any bugs, comments, and/or additions to this file to:
|
||||||
|
+# bug-gdb@gnu.org
|
||||||
|
+
|
||||||
|
+# This file is part of the gdb testsuite.
|
||||||
|
+
|
||||||
|
+# Test UNsigned extension of the 32-bit inferior address on a 64-bit host.
|
||||||
|
+# This file is based on the work by John Reiser.
|
||||||
|
+# This file was created by Jan Kratochvil <jan.kratochvil@redhat.com>.
|
||||||
|
+# https://bugzilla.redhat.com/show_bug.cgi?id=181390
|
||||||
|
+
|
||||||
|
+if {![istarget "x86_64-*-*"]} then {
|
||||||
|
+ verbose "Skipping amd64->i386 adress test."
|
||||||
|
+ return
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "amd64-i386-address"
|
||||||
|
+set srcfile ${testfile}.S
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable [list debug "additional_flags=-m32 -nostdlib"]] != "" } {
|
||||||
|
+ untested amd64-i386-address.exp
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Get things started.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+gdb_run_cmd
|
||||||
|
+
|
||||||
|
+set test "trap stop"
|
||||||
|
+gdb_test_multiple "" $test {
|
||||||
|
+ -re "Program received signal SIGTRAP,.*_start .*$gdb_prompt $" {
|
||||||
|
+ pass $test
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_test "stepi" ".*_start .*int3.*"
|
||||||
|
+
|
||||||
|
+gdb_test "x/x \$esp" "0x\[0-9a-f\]*:\t0x0*1"
|
||||||
|
+
|
||||||
|
+# Failure case would be:
|
||||||
|
+# 0xff8d7f00: Cannot access memory at address 0xff8d7f00
|
||||||
|
+gdb_test "x/x \$ebx" "0x\[0-9a-f\]*:\t0x0*1"
|
261
gdb-6.5-bz185337-resolve-tls-without-debuginfo-v2.patch
Normal file
261
gdb-6.5-bz185337-resolve-tls-without-debuginfo-v2.patch
Normal file
@ -0,0 +1,261 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=185337
|
||||||
|
|
||||||
|
2008-02-24 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.8pre.
|
||||||
|
|
||||||
|
currently for trivial nonthreaded helloworld with no debug info up to -ggdb2 you
|
||||||
|
will get:
|
||||||
|
(gdb) p errno
|
||||||
|
[some error]
|
||||||
|
|
||||||
|
* with -ggdb2 and less "errno" in fact does not exist anywhere as it was
|
||||||
|
compiled to "(*__errno_location ())" and the macro definition is not present.
|
||||||
|
Unfortunately gdb will find the TLS symbol and it will try to access it but
|
||||||
|
as the program has been compiled without -lpthread the TLS base register
|
||||||
|
(%gs on i386) is not setup and it will result in:
|
||||||
|
Cannot access memory at address 0x8
|
||||||
|
|
||||||
|
Attached suggestion patch how to deal with the most common "errno" symbol
|
||||||
|
for the most common under-ggdb3 compiled programs.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
2007-11-03 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* ./gdb/dwarf2read.c (read_partial_die, dwarf2_linkage_name): Prefer
|
||||||
|
DW_AT_MIPS_linkage_name over DW_AT_name now only for non-C.
|
||||||
|
|
||||||
|
glibc-debuginfo-2.7-2.x86_64: /usr/lib/debug/lib64/libc.so.6.debug:
|
||||||
|
<81a2> DW_AT_name : (indirect string, offset: 0x280e): __errno_location
|
||||||
|
<81a8> DW_AT_MIPS_linkage_name: (indirect string, offset: 0x2808): *__GI___errno_location
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20090228/gdb/gdbtypes.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090228.orig/gdb/gdbtypes.c 2009-03-02 01:01:15.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090228/gdb/gdbtypes.c 2009-03-02 01:01:53.000000000 +0100
|
||||||
|
@@ -3633,6 +3633,8 @@ gdbtypes_post_init (struct gdbarch *gdba
|
||||||
|
init_type (TYPE_CODE_INT,
|
||||||
|
gdbarch_int_bit (gdbarch) / TARGET_CHAR_BIT,
|
||||||
|
0, "int", OBJFILE_INTERNAL);
|
||||||
|
+ builtin_type->builtin_int_ptr =
|
||||||
|
+ make_pointer_type (builtin_type->builtin_int, NULL);
|
||||||
|
builtin_type->builtin_unsigned_int =
|
||||||
|
init_type (TYPE_CODE_INT,
|
||||||
|
gdbarch_int_bit (gdbarch) / TARGET_CHAR_BIT,
|
||||||
|
@@ -3742,6 +3744,12 @@ gdbtypes_post_init (struct gdbarch *gdba
|
||||||
|
"<text variable, no debug info>", OBJFILE_INTERNAL);
|
||||||
|
TYPE_TARGET_TYPE (builtin_type->nodebug_text_symbol) =
|
||||||
|
builtin_type->builtin_int;
|
||||||
|
+ builtin_type->nodebug_text_symbol_errno_location =
|
||||||
|
+ init_type (TYPE_CODE_FUNC, 1, 0,
|
||||||
|
+ "<text variable for __errno_location, no debug info>",
|
||||||
|
+ OBJFILE_INTERNAL);
|
||||||
|
+ TYPE_TARGET_TYPE (builtin_type->nodebug_text_symbol_errno_location) =
|
||||||
|
+ builtin_type->builtin_int_ptr;
|
||||||
|
builtin_type->nodebug_data_symbol =
|
||||||
|
init_type (TYPE_CODE_INT,
|
||||||
|
gdbarch_int_bit (gdbarch) / HOST_CHAR_BIT, 0,
|
||||||
|
Index: gdb-6.8.50.20090228/gdb/gdbtypes.h
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090228.orig/gdb/gdbtypes.h 2009-03-02 01:01:15.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090228/gdb/gdbtypes.h 2009-03-02 01:01:53.000000000 +0100
|
||||||
|
@@ -1053,6 +1053,7 @@ struct builtin_type
|
||||||
|
|
||||||
|
/* Types used for symbols with no debug information. */
|
||||||
|
struct type *nodebug_text_symbol;
|
||||||
|
+ struct type *nodebug_text_symbol_errno_location;
|
||||||
|
struct type *nodebug_data_symbol;
|
||||||
|
struct type *nodebug_unknown_symbol;
|
||||||
|
struct type *nodebug_tls_symbol;
|
||||||
|
@@ -1065,6 +1066,7 @@ struct builtin_type
|
||||||
|
struct type *builtin_char;
|
||||||
|
struct type *builtin_short;
|
||||||
|
struct type *builtin_int;
|
||||||
|
+ struct type *builtin_int_ptr;
|
||||||
|
struct type *builtin_long;
|
||||||
|
struct type *builtin_signed_char;
|
||||||
|
struct type *builtin_unsigned_char;
|
||||||
|
Index: gdb-6.8.50.20090228/gdb/parse.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090228.orig/gdb/parse.c 2009-03-02 01:01:15.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090228/gdb/parse.c 2009-03-02 01:01:53.000000000 +0100
|
||||||
|
@@ -508,7 +508,12 @@ write_exp_msymbol (struct minimal_symbol
|
||||||
|
case mst_text:
|
||||||
|
case mst_file_text:
|
||||||
|
case mst_solib_trampoline:
|
||||||
|
- write_exp_elt_type (builtin_type (gdbarch)->nodebug_text_symbol);
|
||||||
|
+ if (builtin_type (gdbarch)->nodebug_text_symbol_errno_location != NULL
|
||||||
|
+ && strcmp (SYMBOL_LINKAGE_NAME (msymbol), "__errno_location") == 0)
|
||||||
|
+ write_exp_elt_type (builtin_type (gdbarch)
|
||||||
|
+ ->nodebug_text_symbol_errno_location);
|
||||||
|
+ else
|
||||||
|
+ write_exp_elt_type (builtin_type (gdbarch)->nodebug_text_symbol);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case mst_data:
|
||||||
|
Index: gdb-6.8.50.20090228/gdb/target.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090228.orig/gdb/target.c 2009-03-02 01:01:44.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090228/gdb/target.c 2009-03-02 01:01:53.000000000 +0100
|
||||||
|
@@ -827,6 +827,25 @@ pop_all_targets (int quitting)
|
||||||
|
pop_all_targets_above (dummy_stratum, quitting);
|
||||||
|
}
|
||||||
|
|
||||||
|
+static int
|
||||||
|
+resolve_errno (void *arg)
|
||||||
|
+{
|
||||||
|
+ CORE_ADDR *arg_addr = arg;
|
||||||
|
+ struct expression *expr;
|
||||||
|
+ struct cleanup *old_chain = 0;
|
||||||
|
+ struct value *val;
|
||||||
|
+
|
||||||
|
+ expr = parse_expression ("__errno_location()");
|
||||||
|
+ old_chain = make_cleanup (free_current_contents, &expr);
|
||||||
|
+ val = evaluate_expression (expr);
|
||||||
|
+ *arg_addr = value_as_address (val);
|
||||||
|
+ release_value (val);
|
||||||
|
+ value_free (val);
|
||||||
|
+ do_cleanups (old_chain);
|
||||||
|
+
|
||||||
|
+ return 1;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
/* Using the objfile specified in OBJFILE, find the address for the
|
||||||
|
current thread's thread-local storage with offset OFFSET. */
|
||||||
|
CORE_ADDR
|
||||||
|
@@ -917,7 +936,28 @@ target_translate_tls_address (struct obj
|
||||||
|
/* It wouldn't be wrong here to try a gdbarch method, too; finding
|
||||||
|
TLS is an ABI-specific thing. But we don't do that yet. */
|
||||||
|
else
|
||||||
|
- error (_("Cannot find thread-local variables on this target"));
|
||||||
|
+ {
|
||||||
|
+ struct minimal_symbol *msymbol;
|
||||||
|
+
|
||||||
|
+ msymbol = lookup_minimal_symbol ("errno", NULL, NULL);
|
||||||
|
+ if (msymbol != NULL
|
||||||
|
+ && SYMBOL_VALUE_ADDRESS (msymbol) == offset
|
||||||
|
+ && (SYMBOL_OBJ_SECTION (msymbol)->objfile == objfile
|
||||||
|
+ || (objfile->separate_debug_objfile != NULL
|
||||||
|
+ && SYMBOL_OBJ_SECTION (msymbol)->objfile
|
||||||
|
+ == objfile->separate_debug_objfile)
|
||||||
|
+ || (objfile->separate_debug_objfile_backlink != NULL
|
||||||
|
+ && SYMBOL_OBJ_SECTION (msymbol)->objfile
|
||||||
|
+ == objfile->separate_debug_objfile_backlink)))
|
||||||
|
+ {
|
||||||
|
+ if (!catch_errors (resolve_errno, (void *) &addr, "",
|
||||||
|
+ RETURN_MASK_ALL))
|
||||||
|
+ error (_("TLS symbol `errno' not resolved for non-TLS program."
|
||||||
|
+ " You should compile the program with `gcc -pthread'."));
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ error (_("Cannot find thread-local variables on this target"));
|
||||||
|
+ }
|
||||||
|
|
||||||
|
return addr;
|
||||||
|
}
|
||||||
|
Index: gdb-6.8.50.20090228/gdb/testsuite/gdb.dwarf2/dw2-errno.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20090228/gdb/testsuite/gdb.dwarf2/dw2-errno.c 2009-03-02 01:01:53.000000000 +0100
|
||||||
|
@@ -0,0 +1,28 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2005, 2007 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/>.
|
||||||
|
+
|
||||||
|
+ Please email any bugs, comments, and/or additions to this file to:
|
||||||
|
+ bug-gdb@prep.ai.mit.edu */
|
||||||
|
+
|
||||||
|
+#include <errno.h>
|
||||||
|
+
|
||||||
|
+int main()
|
||||||
|
+{
|
||||||
|
+ errno = 42;
|
||||||
|
+
|
||||||
|
+ return 0; /* breakpoint */
|
||||||
|
+}
|
||||||
|
Index: gdb-6.8.50.20090228/gdb/testsuite/gdb.dwarf2/dw2-errno.exp
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20090228/gdb/testsuite/gdb.dwarf2/dw2-errno.exp 2009-03-02 01:01:53.000000000 +0100
|
||||||
|
@@ -0,0 +1,67 @@
|
||||||
|
+# Copyright 2007 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/>.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+set testfile dw2-errno
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+proc prep {} {
|
||||||
|
+ global srcdir subdir binfile
|
||||||
|
+ gdb_exit
|
||||||
|
+ gdb_start
|
||||||
|
+ gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+ gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+ runto_main
|
||||||
|
+
|
||||||
|
+ gdb_breakpoint [gdb_get_line_number "breakpoint"]
|
||||||
|
+ gdb_continue_to_breakpoint "breakpoint"
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable "additional_flags=-g2"] != "" } {
|
||||||
|
+ untested "Couldn't compile test program"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+prep
|
||||||
|
+gdb_test "print errno" ".* = 42" "errno with macros=N threads=N"
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable "additional_flags=-g3"] != "" } {
|
||||||
|
+ untested "Couldn't compile test program"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+prep
|
||||||
|
+gdb_test "print errno" ".* = 42" "errno with macros=Y threads=N"
|
||||||
|
+
|
||||||
|
+if {[gdb_compile_pthreads "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable "additional_flags=-g2"] != "" } {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+prep
|
||||||
|
+gdb_test "print errno" ".* = 42" "errno with macros=N threads=Y"
|
||||||
|
+
|
||||||
|
+if {[gdb_compile_pthreads "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable "additional_flags=-g3"] != "" } {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+prep
|
||||||
|
+gdb_test "print errno" ".* = 42" "errno with macros=Y threads=Y"
|
||||||
|
+
|
||||||
|
+# TODO: Test the error on resolving ERRNO with only libc loaded.
|
||||||
|
+# Just how to find the current libc filename?
|
29
gdb-6.5-bz190810-gdbserver-arch-advice.patch
Normal file
29
gdb-6.5-bz190810-gdbserver-arch-advice.patch
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=190810
|
||||||
|
|
||||||
|
|
||||||
|
2006-09-26 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* remote.c (remote_wait): Suggestion on crash due to nonmatching target.
|
||||||
|
(remote_async_wait): Likewise.
|
||||||
|
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/remote.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/remote.c 2008-12-09 16:59:51.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/remote.c 2008-12-09 17:00:04.000000000 +0100
|
||||||
|
@@ -4329,8 +4329,13 @@ Packet: '%s'\n"),
|
||||||
|
VEC_safe_push (cached_reg_t, event->regcache, &cached_reg);
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (*p != ';')
|
||||||
|
- error (_("Remote register badly formatted: %s\nhere: %s"),
|
||||||
|
+ /* It may also occur on amd64 which defaults to 32-bit i386
|
||||||
|
+ target. gdbserver(1) is not aware of the `set architecture'
|
||||||
|
+ name itself as it is not using libbfd. */
|
||||||
|
+ if (*p != ';')
|
||||||
|
+ error (_("Remote register badly formatted: %s\nhere: %s"
|
||||||
|
+ "\nTry to load the executable by `file' first,"
|
||||||
|
+ "\nyou may also check `set/show architecture'."),
|
||||||
|
buf, p);
|
||||||
|
++p;
|
||||||
|
}
|
17
gdb-6.5-bz203661-emit-relocs.patch
Normal file
17
gdb-6.5-bz203661-emit-relocs.patch
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
Index: gdb-6.5/gdb/symfile.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.5.orig/gdb/symfile.c 2006-08-24 02:56:02.000000000 -0300
|
||||||
|
+++ gdb-6.5/gdb/symfile.c 2006-08-24 02:56:36.000000000 -0300
|
||||||
|
@@ -3739,6 +3739,12 @@ symfile_dummy_outputs (bfd *abfd, asecti
|
||||||
|
bfd_byte *
|
||||||
|
symfile_relocate_debug_section (bfd *abfd, asection *sectp, bfd_byte *buf)
|
||||||
|
{
|
||||||
|
+ /* Executable files have all the relocations already resolved.
|
||||||
|
+ * Handle files linked with --emit-relocs.
|
||||||
|
+ * http://sources.redhat.com/ml/gdb/2006-08/msg00137.html */
|
||||||
|
+ if ((abfd->flags & EXEC_P) != 0)
|
||||||
|
+ return NULL;
|
||||||
|
+
|
||||||
|
/* We're only interested in debugging sections with relocation
|
||||||
|
information. */
|
||||||
|
if ((sectp->flags & SEC_RELOC) == 0)
|
278
gdb-6.5-bz216711-clone-is-outermost.patch
Normal file
278
gdb-6.5-bz216711-clone-is-outermost.patch
Normal file
@ -0,0 +1,278 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=216711
|
||||||
|
|
||||||
|
FIXME: This workaround should be dropped and
|
||||||
|
glibc/sysdeps/unix/sysv/linux/x86_64/clone.S should get CFI for the child
|
||||||
|
instead.
|
||||||
|
|
||||||
|
2006-12-17 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb/amd64-linux-tdep.c (linux_clone_code): New variable.
|
||||||
|
(LINUX_CLONE_LEN): New definition.
|
||||||
|
(amd64_linux_clone_running, amd64_linux_outermost_frame): New function.
|
||||||
|
(amd64_linux_init_abi): Initialize `outermost_frame_p'.
|
||||||
|
* gdb/i386-tdep.c (i386_gdbarch_init): Likewise.
|
||||||
|
* gdb/i386-tdep.h (gdbarch_tdep): Add `outermost_frame_p' member.
|
||||||
|
* gdb/amd64-tdep.c (amd64_frame_this_id): Call `outermost_frame_p'.
|
||||||
|
|
||||||
|
2006-12-17 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.threads/bt-clone-stop.exp, gdb.threads/bt-clone-stop.c:
|
||||||
|
New file.
|
||||||
|
|
||||||
|
2007-10-16 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/amd64-linux-tdep.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/amd64-linux-tdep.c 2008-12-08 10:56:17.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/amd64-linux-tdep.c 2008-12-08 21:11:08.000000000 +0100
|
||||||
|
@@ -234,6 +234,80 @@ amd64_linux_register_reggroup_p (struct
|
||||||
|
|
||||||
|
/* Set the program counter for process PTID to PC. */
|
||||||
|
|
||||||
|
+/* Detect the outermost frame; during unwind of
|
||||||
|
+ #5 0x000000305cec68c3 in clone () from /lib64/tls/libc.so.6
|
||||||
|
+ avoid the additional bogus frame
|
||||||
|
+ #6 0x0000000000000000 in ??
|
||||||
|
+ We compare if the `linux_clone_code' block is _before_ unwound PC. */
|
||||||
|
+
|
||||||
|
+static const unsigned char linux_clone_code[] =
|
||||||
|
+{
|
||||||
|
+/* libc/sysdeps/unix/sysv/linux/x86_64/clone.S */
|
||||||
|
+/* #ifdef RESET_PID */
|
||||||
|
+/* ... */
|
||||||
|
+/* mov $SYS_ify(getpid), %eax */
|
||||||
|
+/* 0xb8, 0x27, 0x00, 0x00, 0x00 */
|
||||||
|
+/* OR */
|
||||||
|
+/* mov $SYS_ify(getpid), %rax */
|
||||||
|
+/* 0x48, 0xc7, 0xc0, 0x27, 0x00, 0x00, 0x00 */
|
||||||
|
+/* so just: */
|
||||||
|
+ 0x27, 0x00, 0x00, 0x00,
|
||||||
|
+/* syscall */
|
||||||
|
+ 0x0f, 0x05,
|
||||||
|
+/* movl %eax, %fs:PID */
|
||||||
|
+ 0x64, 0x89, 0x04, 0x25, 0x94, 0x00, 0x00, 0x00,
|
||||||
|
+/* movl %eax, %fs:TID */
|
||||||
|
+ 0x64, 0x89, 0x04, 0x25, 0x90, 0x00, 0x00, 0x00,
|
||||||
|
+/* #endif */
|
||||||
|
+/* |* Set up arguments for the function call. *| */
|
||||||
|
+/* popq %rax |* Function to call. *| */
|
||||||
|
+ 0x58,
|
||||||
|
+/* popq %rdi |* Argument. *| */
|
||||||
|
+ 0x5f,
|
||||||
|
+/* call *%rax$ */
|
||||||
|
+ 0xff, 0xd0
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+#define LINUX_CLONE_LEN (sizeof linux_clone_code)
|
||||||
|
+
|
||||||
|
+static int
|
||||||
|
+amd64_linux_clone_running (struct frame_info *this_frame)
|
||||||
|
+{
|
||||||
|
+ CORE_ADDR pc = get_frame_pc (this_frame);
|
||||||
|
+ unsigned char buf[LINUX_CLONE_LEN];
|
||||||
|
+
|
||||||
|
+ if (!safe_frame_unwind_memory (this_frame, pc - LINUX_CLONE_LEN, buf,
|
||||||
|
+ LINUX_CLONE_LEN))
|
||||||
|
+ return 0;
|
||||||
|
+
|
||||||
|
+ if (memcmp (buf, linux_clone_code, LINUX_CLONE_LEN) != 0)
|
||||||
|
+ return 0;
|
||||||
|
+
|
||||||
|
+ return 1;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static int
|
||||||
|
+amd64_linux_outermost_frame (struct frame_info *this_frame)
|
||||||
|
+{
|
||||||
|
+ CORE_ADDR pc = get_frame_pc (this_frame);
|
||||||
|
+ char *name;
|
||||||
|
+
|
||||||
|
+ find_pc_partial_function (pc, &name, NULL, NULL);
|
||||||
|
+
|
||||||
|
+ /* If we have NAME, we can optimize the search.
|
||||||
|
+ `clone' NAME still needs to have the code checked as its name may be
|
||||||
|
+ present in the user code.
|
||||||
|
+ `__clone' NAME should not be present in the user code but in the initial
|
||||||
|
+ parts of the `__clone' implementation the unwind still makes sense.
|
||||||
|
+ More detailed unwinding decision would be too much sensitive to possible
|
||||||
|
+ subtle changes in specific glibc revisions. */
|
||||||
|
+ if (name == NULL || strcmp (name, "clone") == 0
|
||||||
|
+ || strcmp ("__clone", name) == 0)
|
||||||
|
+ return (amd64_linux_clone_running (this_frame) != 0);
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
static void
|
||||||
|
amd64_linux_write_pc (struct regcache *regcache, CORE_ADDR pc)
|
||||||
|
{
|
||||||
|
@@ -272,6 +346,8 @@ amd64_linux_init_abi (struct gdbarch_inf
|
||||||
|
tdep->sc_reg_offset = amd64_linux_sc_reg_offset;
|
||||||
|
tdep->sc_num_regs = ARRAY_SIZE (amd64_linux_sc_reg_offset);
|
||||||
|
|
||||||
|
+ tdep->outermost_frame_p = amd64_linux_outermost_frame;
|
||||||
|
+
|
||||||
|
/* GNU/Linux uses SVR4-style shared libraries. */
|
||||||
|
set_solib_svr4_fetch_link_map_offsets
|
||||||
|
(gdbarch, svr4_lp64_fetch_link_map_offsets);
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/amd64-tdep.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/amd64-tdep.c 2008-12-08 10:56:17.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/amd64-tdep.c 2008-12-08 21:05:12.000000000 +0100
|
||||||
|
@@ -1044,11 +1044,16 @@ amd64_frame_this_id (struct frame_info *
|
||||||
|
{
|
||||||
|
struct amd64_frame_cache *cache =
|
||||||
|
amd64_frame_cache (this_frame, this_cache);
|
||||||
|
+ struct gdbarch_tdep *tdep = gdbarch_tdep (get_frame_arch (this_frame));
|
||||||
|
|
||||||
|
/* This marks the outermost frame. */
|
||||||
|
if (cache->base == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
+ /* Detect OS dependent outermost frames; such as `clone'. */
|
||||||
|
+ if (tdep->outermost_frame_p && tdep->outermost_frame_p (this_frame))
|
||||||
|
+ return;
|
||||||
|
+
|
||||||
|
(*this_id) = frame_id_build (cache->base + 16, cache->pc);
|
||||||
|
}
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/i386-tdep.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/i386-tdep.c 2008-12-08 10:56:17.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/i386-tdep.c 2008-12-08 11:00:43.000000000 +0100
|
||||||
|
@@ -2698,6 +2698,9 @@ i386_gdbarch_init (struct gdbarch_info i
|
||||||
|
tdep->sc_pc_offset = -1;
|
||||||
|
tdep->sc_sp_offset = -1;
|
||||||
|
|
||||||
|
+ /* Unwinding stops on i386 automatically. */
|
||||||
|
+ tdep->outermost_frame_p = NULL;
|
||||||
|
+
|
||||||
|
/* The format used for `long double' on almost all i386 targets is
|
||||||
|
the i387 extended floating-point format. In fact, of all targets
|
||||||
|
in the GCC 2.95 tree, only OSF/1 does it different, and insists
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/i386-tdep.h
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/i386-tdep.h 2008-12-08 10:56:17.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/i386-tdep.h 2008-12-08 21:07:47.000000000 +0100
|
||||||
|
@@ -106,6 +106,9 @@ struct gdbarch_tdep
|
||||||
|
/* ISA-specific data types. */
|
||||||
|
struct type *i386_mmx_type;
|
||||||
|
struct type *i386_sse_type;
|
||||||
|
+
|
||||||
|
+ /* Detect OS dependent outermost frames; such as `clone'. */
|
||||||
|
+ int (*outermost_frame_p) (struct frame_info *this_frame);
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Floating-point registers. */
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.threads/bt-clone-stop.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.threads/bt-clone-stop.c 2008-12-08 11:00:43.000000000 +0100
|
||||||
|
@@ -0,0 +1,39 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2006 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., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
+ MA 02110-1301, USA. */
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+#include <pthread.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
+#include <assert.h>
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+void *threader (void *arg)
|
||||||
|
+{
|
||||||
|
+ assert (0);
|
||||||
|
+ return NULL;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int main (void)
|
||||||
|
+{
|
||||||
|
+ pthread_t t1;
|
||||||
|
+
|
||||||
|
+ pthread_create (&t1, NULL, threader, (void *) NULL);
|
||||||
|
+ for (;;)
|
||||||
|
+ pause();
|
||||||
|
+}
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.threads/bt-clone-stop.exp
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.threads/bt-clone-stop.exp 2008-12-08 11:00:43.000000000 +0100
|
||||||
|
@@ -0,0 +1,61 @@
|
||||||
|
+# Copyright 2006 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.
|
||||||
|
+
|
||||||
|
+# Backtraced `clone' must not have `PC == 0' as its previous frame.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile bt-clone-stop
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+if { [gdb_compile_pthreads "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
+ untested "Couldn't compile test program"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Get things started.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+# threader: threader.c:8: threader: Assertion `0' failed.
|
||||||
|
+# Program received signal SIGABRT, Aborted.
|
||||||
|
+
|
||||||
|
+gdb_test "run" \
|
||||||
|
+ "Program received signal SIGABRT.*" \
|
||||||
|
+ "run"
|
||||||
|
+
|
||||||
|
+# Former gdb unwind (the first function is `clone'):
|
||||||
|
+# #5 0x0000003421ecd62d in ?? () from /lib64/libc.so.6
|
||||||
|
+# #6 0x0000000000000000 in ?? ()
|
||||||
|
+# (gdb)
|
||||||
|
+# Tested `amd64_linux_outermost_frame' functionality should omit the line `#6'.
|
||||||
|
+#
|
||||||
|
+# Two `-re' cases below must be in this order (1st is a subset of the 2nd one).
|
||||||
|
+# Unhandled case below should not happen and it is fortunately handled by
|
||||||
|
+# `amd64_linux_outermost_frame' as FAIL (and result `0x0 entry output invalid').
|
||||||
|
+gdb_test_multiple "bt" "0x0 entry output invalid" {
|
||||||
|
+ -re "in threader \\(.*\n#\[0-9\]* *0x0* in .*$gdb_prompt $" {
|
||||||
|
+ fail "0x0 entry found"
|
||||||
|
+ }
|
||||||
|
+ -re "in threader \\(.*$gdb_prompt $" {
|
||||||
|
+ pass "0x0 entry not found"
|
||||||
|
+ }
|
||||||
|
+}
|
19
gdb-6.5-bz218379-ppc-solib-trampoline-fix.patch
Normal file
19
gdb-6.5-bz218379-ppc-solib-trampoline-fix.patch
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=218379
|
||||||
|
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/minsyms.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/minsyms.c 2008-10-01 18:56:52.000000000 +0200
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/minsyms.c 2008-12-02 23:24:27.000000000 +0100
|
||||||
|
@@ -544,6 +544,11 @@ lookup_minimal_symbol_by_pc_section_1 (C
|
||||||
|
don't fill the bfd_section member, so don't
|
||||||
|
throw away symbols on those platforms. */
|
||||||
|
&& SYMBOL_OBJ_SECTION (&msymbol[hi]) != NULL
|
||||||
|
+ /* Don't ignore symbols for solib trampolines.
|
||||||
|
+ Limit its sideeffects - only for non-0 sized trampolines.
|
||||||
|
+ Red Hat Bug 200533 with its regression Bug 218379. */
|
||||||
|
+ && (MSYMBOL_TYPE (&msymbol[hi]) != mst_solib_trampoline
|
||||||
|
+ || MSYMBOL_SIZE (&msymbol[hi]))
|
||||||
|
&& (!matching_obj_sections
|
||||||
|
(SYMBOL_OBJ_SECTION (&msymbol[hi]), section)))
|
||||||
|
{
|
91
gdb-6.5-bz218379-ppc-solib-trampoline-test.patch
Normal file
91
gdb-6.5-bz218379-ppc-solib-trampoline-test.patch
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=218379
|
||||||
|
|
||||||
|
|
||||||
|
--- /dev/null 2006-12-17 14:18:21.881669220 -0500
|
||||||
|
+++ gdb-6.5/gdb/testsuite/gdb.base/step-over-trampoline.exp 2006-12-17 16:52:51.000000000 -0500
|
||||||
|
@@ -0,0 +1,54 @@
|
||||||
|
+# Copyright 2006 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.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile step-over-trampoline
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
+ untested "Couldn't compile test program"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Get things started.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+# For C programs, "start" should stop in main().
|
||||||
|
+
|
||||||
|
+gdb_test "start" \
|
||||||
|
+ "main \\(\\) at .*$srcfile.*" \
|
||||||
|
+ "start"
|
||||||
|
+
|
||||||
|
+# main () at hello2.c:5
|
||||||
|
+# 5 puts("hello world\n");
|
||||||
|
+# (gdb) next
|
||||||
|
+# 0x100007e0 in call___do_global_ctors_aux ()
|
||||||
|
+
|
||||||
|
+gdb_test_multiple "next" "invalid `next' output" {
|
||||||
|
+ -re "\nhello world.*return 0;.*" {
|
||||||
|
+ pass "stepped over"
|
||||||
|
+ }
|
||||||
|
+ -re " in call___do_global_ctors_aux \\(\\).*" {
|
||||||
|
+ fail "stepped into trampoline"
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
--- /dev/null 2006-12-17 14:18:21.881669220 -0500
|
||||||
|
+++ gdb-6.5/gdb/testsuite/gdb.base/step-over-trampoline.c 2006-12-17 16:18:12.000000000 -0500
|
||||||
|
@@ -0,0 +1,28 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2006 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 */
|
||||||
|
+
|
||||||
|
+#include <stdio.h>
|
||||||
|
+
|
||||||
|
+int main (void)
|
||||||
|
+{
|
||||||
|
+ puts ("hello world");
|
||||||
|
+ return 0;
|
||||||
|
+}
|
21
gdb-6.5-bz218379-solib-trampoline-lookup-lock-fix.patch
Normal file
21
gdb-6.5-bz218379-solib-trampoline-lookup-lock-fix.patch
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=218379
|
||||||
|
|
||||||
|
|
||||||
|
Index: gdb-6.8/gdb/symtab.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.orig/gdb/symtab.c 2008-02-05 23:17:40.000000000 +0100
|
||||||
|
+++ gdb-6.8/gdb/symtab.c 2008-07-14 10:27:32.000000000 +0200
|
||||||
|
@@ -2132,6 +2132,13 @@ find_pc_sect_line (CORE_ADDR pc, struct
|
||||||
|
/* See above comment about why warning is commented out */
|
||||||
|
/* warning ("In stub for %s; unable to find real function/line info", SYMBOL_LINKAGE_NAME (msymbol)) */ ;
|
||||||
|
/* fall through */
|
||||||
|
+ /* `msymbol' trampoline may be located before its .text symbol
|
||||||
|
+ but this text symbol may be the address we were looking for.
|
||||||
|
+ Avoid `find_pc_sect_line'<->`find_pc_line' infinite loop.
|
||||||
|
+ Red Hat Bug 218379. */
|
||||||
|
+ else if (SYMBOL_VALUE (mfunsym) == pc)
|
||||||
|
+ warning ("In stub for %s (0x%s); interlocked, please submit the binary to http://bugzilla.redhat.com", SYMBOL_LINKAGE_NAME (msymbol), paddr (pc));
|
||||||
|
+ /* fall through */
|
||||||
|
else
|
||||||
|
return find_pc_line (SYMBOL_VALUE_ADDRESS (mfunsym), 0);
|
||||||
|
}
|
86
gdb-6.5-bz243845-stale-testing-zombie-test.patch
Normal file
86
gdb-6.5-bz243845-stale-testing-zombie-test.patch
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
diff -u -ruNp gdb-6.3-unpatched/gdb/testsuite/gdb.base/tracefork-zombie.exp gdb-6.3/gdb/testsuite/gdb.base/tracefork-zombie.exp
|
||||||
|
--- gdb-6.3-unpatched/gdb/testsuite/gdb.base/tracefork-zombie.exp 1969-12-31 19:00:00.000000000 -0500
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.base/tracefork-zombie.exp 2007-07-31 13:04:12.000000000 -0400
|
||||||
|
@@ -0,0 +1,82 @@
|
||||||
|
+# Copyright 2007 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. */
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+# are we on a target board
|
||||||
|
+if [is_remote target] then {
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Start the program running and then wait for a bit, to be sure
|
||||||
|
+# that it can be attached to.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_load sleep
|
||||||
|
+
|
||||||
|
+set gdb_pid [exp_pid -i [board_info host fileid]]
|
||||||
|
+set test "identified the child GDB"
|
||||||
|
+if {$gdb_pid != "" && $gdb_pid > 0} {
|
||||||
|
+ pass $test
|
||||||
|
+ verbose -log "Child GDB PID $gdb_pid"
|
||||||
|
+} else {
|
||||||
|
+ fail $test
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testpid [eval exec sleep 10 &]
|
||||||
|
+exec sleep 2
|
||||||
|
+
|
||||||
|
+set test "attach"
|
||||||
|
+gdb_test_multiple "attach $testpid" "$test" {
|
||||||
|
+ -re "Attaching to program.*`?.*'?, process $testpid..*$gdb_prompt $" {
|
||||||
|
+ pass "$test"
|
||||||
|
+ }
|
||||||
|
+ -re "Attaching to program.*`?.*\.exe'?, process $testpid.*\[Switching to thread $testpid\..*\].*$gdb_prompt $" {
|
||||||
|
+ # Response expected on Cygwin
|
||||||
|
+ pass "$test"
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Some time to let GDB spawn its testing child.
|
||||||
|
+exec sleep 2
|
||||||
|
+
|
||||||
|
+set found none
|
||||||
|
+foreach procpid [glob -directory /proc -type d {[0-9]*}] {
|
||||||
|
+ if {[catch {open $procpid/status} statusfi]} {
|
||||||
|
+ continue
|
||||||
|
+ }
|
||||||
|
+ set status [read $statusfi]
|
||||||
|
+ close $statusfi
|
||||||
|
+ if {1
|
||||||
|
+ && [regexp -line {^Name:\tgdb$} $status]
|
||||||
|
+ && [regexp -line {^PPid:\t1$} $status]
|
||||||
|
+ && [regexp -line "^TracerPid:\t$gdb_pid$" $status]} {
|
||||||
|
+ set found $procpid
|
||||||
|
+ verbose -log "Found linux_test_for_tracefork zombie PID $procpid"
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+set test "linux_test_for_tracefork leaves no zombie"
|
||||||
|
+if {$found eq {none}} {
|
||||||
|
+ pass $test
|
||||||
|
+} else {
|
||||||
|
+ fail $test
|
||||||
|
+}
|
52
gdb-6.5-dwarf-stack-overflow.patch
Normal file
52
gdb-6.5-dwarf-stack-overflow.patch
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
for gdb/ChangeLog:
|
||||||
|
2006-08-22 Will Drewry <wad@google.com>
|
||||||
|
Tavis Ormandy <taviso@google.com>
|
||||||
|
|
||||||
|
* dwarf2read.c (decode_locdesc): Enforce location description stack
|
||||||
|
boundaries.
|
||||||
|
* dwarfread.c (locval): Likewise.
|
||||||
|
|
||||||
|
2007-10-15 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7.
|
||||||
|
|
||||||
|
Index: gdb-6.7/gdb/dwarf2read.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.7.orig/gdb/dwarf2read.c 2007-10-15 00:08:30.000000000 +0200
|
||||||
|
+++ gdb-6.7/gdb/dwarf2read.c 2007-10-15 21:42:43.000000000 +0200
|
||||||
|
@@ -9070,8 +9070,7 @@ dwarf2_fundamental_type (struct objfile
|
||||||
|
callers will only want a very basic result and this can become a
|
||||||
|
complaint.
|
||||||
|
|
||||||
|
- Note that stack[0] is unused except as a default error return.
|
||||||
|
- Note that stack overflow is not yet handled. */
|
||||||
|
+ Note that stack[0] is unused except as a default error return. */
|
||||||
|
|
||||||
|
static CORE_ADDR
|
||||||
|
decode_locdesc (struct dwarf_block *blk, struct dwarf2_cu *cu)
|
||||||
|
@@ -9088,7 +9087,7 @@ decode_locdesc (struct dwarf_block *blk,
|
||||||
|
|
||||||
|
i = 0;
|
||||||
|
stacki = 0;
|
||||||
|
- stack[stacki] = 0;
|
||||||
|
+ stack[++stacki] = 0;
|
||||||
|
|
||||||
|
while (i < size)
|
||||||
|
{
|
||||||
|
@@ -9270,6 +9269,16 @@ decode_locdesc (struct dwarf_block *blk,
|
||||||
|
dwarf_stack_op_name (op));
|
||||||
|
return (stack[stacki]);
|
||||||
|
}
|
||||||
|
+ /* Enforce maximum stack depth of size-1 to avoid ++stacki writing
|
||||||
|
+ outside of the allocated space. Also enforce minimum > 0.
|
||||||
|
+ -- wad@google.com 14 Aug 2006 */
|
||||||
|
+ if (stacki >= sizeof (stack) / sizeof (*stack) - 1)
|
||||||
|
+ internal_error (__FILE__, __LINE__,
|
||||||
|
+ _("location description stack too deep: %d"),
|
||||||
|
+ stacki);
|
||||||
|
+ if (stacki <= 0)
|
||||||
|
+ internal_error (__FILE__, __LINE__,
|
||||||
|
+ _("location description stack too shallow"));
|
||||||
|
}
|
||||||
|
return (stack[stacki]);
|
||||||
|
}
|
146
gdb-6.5-gcore-buffer-limit-test.patch
Normal file
146
gdb-6.5-gcore-buffer-limit-test.patch
Normal file
@ -0,0 +1,146 @@
|
|||||||
|
diff -u -X /home/jkratoch/.diffi.list -ruNp gdb-6.5/gdb/testsuite/gdb.base/gcore-excessive-memory.c gdb-6.5-unknown/gdb/testsuite/gdb.base/gcore-excessive-memory.c
|
||||||
|
--- gdb-6.5/gdb/testsuite/gdb.base/gcore-excessive-memory.c 1970-01-01 01:00:00.000000000 +0100
|
||||||
|
+++ gdb-6.5-unknown/gdb/testsuite/gdb.base/gcore-excessive-memory.c 2008-01-08 11:25:45.000000000 +0100
|
||||||
|
@@ -0,0 +1,37 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2008 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 */
|
||||||
|
+
|
||||||
|
+#include <unistd.h>
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+
|
||||||
|
+#define MEGS 64
|
||||||
|
+
|
||||||
|
+int main()
|
||||||
|
+{
|
||||||
|
+ void *mem;
|
||||||
|
+
|
||||||
|
+ mem = malloc (MEGS * 1024ULL * 1024ULL);
|
||||||
|
+
|
||||||
|
+ for (;;)
|
||||||
|
+ sleep (1);
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
diff -u -X /home/jkratoch/.diffi.list -ruNp gdb-6.5/gdb/testsuite/gdb.base/gcore-excessive-memory.exp gdb-6.5-unknown/gdb/testsuite/gdb.base/gcore-excessive-memory.exp
|
||||||
|
--- gdb-6.5/gdb/testsuite/gdb.base/gcore-excessive-memory.exp 1970-01-01 01:00:00.000000000 +0100
|
||||||
|
+++ gdb-6.5-unknown/gdb/testsuite/gdb.base/gcore-excessive-memory.exp 2008-01-08 11:47:32.000000000 +0100
|
||||||
|
@@ -0,0 +1,101 @@
|
||||||
|
+# Copyright 2008 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.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+set testfile gcore-excessive-memory
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set shfile ${objdir}/${subdir}/${testfile}-gdb.sh
|
||||||
|
+set corefile ${objdir}/${subdir}/${testfile}.core
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
+ untested "Couldn't compile test program"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set f [open "|getconf PAGESIZE" "r"]
|
||||||
|
+gets $f pagesize
|
||||||
|
+close $f
|
||||||
|
+
|
||||||
|
+set pid_of_bin [eval exec $binfile &]
|
||||||
|
+sleep 2
|
||||||
|
+
|
||||||
|
+# Get things started.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+set pid_of_gdb [exp_pid -i [board_info host fileid]]
|
||||||
|
+
|
||||||
|
+gdb_test "attach $pid_of_bin" "Attaching to .*" "attach"
|
||||||
|
+gdb_test "up 99" "in main .*" "verify we can get to main"
|
||||||
|
+
|
||||||
|
+proc memory_v_pages_get {} {
|
||||||
|
+ global pid_of_gdb pagesize
|
||||||
|
+ set fd [open "/proc/$pid_of_gdb/statm"]
|
||||||
|
+ gets $fd line
|
||||||
|
+ close $fd
|
||||||
|
+ # number of pages of virtual memory
|
||||||
|
+ scan $line "%d" drs
|
||||||
|
+ return $drs
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set pages_found [memory_v_pages_get]
|
||||||
|
+
|
||||||
|
+# It must be definitely less than `MEGS' of `gcore-excessive-memory.c'.
|
||||||
|
+set mb_gcore_reserve 4
|
||||||
|
+verbose -log "pages_found = $pages_found, mb_gcore_reserve = $mb_gcore_reserve"
|
||||||
|
+set kb_found [expr $pages_found * $pagesize / 1024]
|
||||||
|
+set kb_permit [expr $kb_found + 1 * 1024 + $mb_gcore_reserve * 1024]
|
||||||
|
+verbose -log "kb_found = $kb_found, kb_permit = $kb_permit"
|
||||||
|
+
|
||||||
|
+# Create the ulimit wrapper.
|
||||||
|
+set f [open $shfile "w"]
|
||||||
|
+puts $f "#! /bin/sh"
|
||||||
|
+puts $f "ulimit -v $kb_permit"
|
||||||
|
+puts $f "exec $GDB \"\$@\""
|
||||||
|
+close $f
|
||||||
|
+remote_exec host "chmod +x $shfile"
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+set GDBold $GDB
|
||||||
|
+set GDB "$shfile"
|
||||||
|
+gdb_start
|
||||||
|
+set GDB $GDBold
|
||||||
|
+
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+set pid_of_gdb [exp_pid -i [board_info host fileid]]
|
||||||
|
+
|
||||||
|
+gdb_test "attach $pid_of_bin" "Attaching to .*" "attach"
|
||||||
|
+gdb_test "up 99" "in main .*" "verify we can get to main"
|
||||||
|
+
|
||||||
|
+verbose -log "kb_found before gcore = [expr [memory_v_pages_get] * $pagesize / 1024]"
|
||||||
|
+
|
||||||
|
+gdb_test "gcore $corefile" "Saved corefile \[^\n\r\]*" "Save the core file"
|
||||||
|
+
|
||||||
|
+verbose -log "kb_found after gcore = [expr [memory_v_pages_get] * $pagesize / 1024]"
|
||||||
|
+
|
||||||
|
+# Cleanup.
|
||||||
|
+exec kill -9 $pid_of_bin
|
847
gdb-6.5-gcore-i386-on-amd64.patch
Normal file
847
gdb-6.5-gcore-i386-on-amd64.patch
Normal file
@ -0,0 +1,847 @@
|
|||||||
|
2006-10-01 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
Fujitsu
|
||||||
|
|
||||||
|
* amd64-linux-nat.c: Support new linux_elfcore_write_prpsinfo,
|
||||||
|
linux_elfcore_write_prstatus, linux_elfcore_write_prfpreg.
|
||||||
|
(i386_linux_gregset32_reg_offset): New mapping for i386 on amd64.
|
||||||
|
* gcore.c (gcore_create_callback): Comment vdso Linux kernel bug.
|
||||||
|
* configure.ac: Check for <sys/user32.h>, <sys/procfs32.h>.
|
||||||
|
* configure, config.in: Regenerated.
|
||||||
|
* gdb_user32.h, gdb_procfs32.h: Define 32-bit core files even for
|
||||||
|
64-bit gdb, provide fallbacks for <sys/user32.h> and <sys/procfs32.h>.
|
||||||
|
* linux-nat.c: Virtualize `elfcore_*' by (*`linux_elfcore_*').
|
||||||
|
(linux_nat_do_thread_registers): Likewise.
|
||||||
|
(linux_nat_make_corefile_notes): Likewise.
|
||||||
|
* linux-nat.h: Likewise.
|
||||||
|
* Makefile.in: Dependencies updated.
|
||||||
|
|
||||||
|
2007-10-16 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7.
|
||||||
|
|
||||||
|
2008-02-24 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.8pre.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081214/gdb/amd64-linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081214.orig/gdb/amd64-linux-nat.c 2008-12-14 21:17:01.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081214/gdb/amd64-linux-nat.c 2008-12-14 21:24:19.000000000 +0100
|
||||||
|
@@ -50,6 +50,9 @@
|
||||||
|
#include "amd64-tdep.h"
|
||||||
|
#include "i386-linux-tdep.h"
|
||||||
|
#include "amd64-nat.h"
|
||||||
|
+#include "i387-tdep.h"
|
||||||
|
+#include "elf-bfd.h"
|
||||||
|
+#include "gdb_procfs32.h"
|
||||||
|
|
||||||
|
/* Mapping between the general-purpose registers in GNU/Linux x86-64
|
||||||
|
`struct user' format and GDB's register cache layout. */
|
||||||
|
@@ -84,6 +87,35 @@ static int amd64_linux_gregset64_reg_off
|
||||||
|
GNU/Linux i386 registers are all 32-bit, but since we're
|
||||||
|
little-endian we get away with that. */
|
||||||
|
|
||||||
|
+/* This info is not reusable from "i386-linux-nat.c" as gdb itself runs in
|
||||||
|
+ 64-bit mode and so ptrace(2) has 64-bit structure layout.
|
||||||
|
+ Just the corefile being generated has 32-bit layout so we need to do
|
||||||
|
+ a conversion specific to the i386-on-amd64 compatibility mode. */
|
||||||
|
+static int i386_linux_gregset32_reg_offset[] =
|
||||||
|
+{
|
||||||
|
+ 6 * 4, /* %eax */
|
||||||
|
+ 1 * 4, /* %ecx */
|
||||||
|
+ 2 * 4, /* %edx */
|
||||||
|
+ 0 * 4, /* %ebx */
|
||||||
|
+ 15 * 4, /* %esp */
|
||||||
|
+ 5 * 4, /* %ebp */
|
||||||
|
+ 3 * 4, /* %esi */
|
||||||
|
+ 4 * 4, /* %edi */
|
||||||
|
+ 12 * 4, /* %eip */
|
||||||
|
+ 14 * 4, /* %eflags */
|
||||||
|
+ 13 * 4, /* %cs */
|
||||||
|
+ 16 * 4, /* %ss */
|
||||||
|
+ 7 * 4, /* %ds */
|
||||||
|
+ 8 * 4, /* %es */
|
||||||
|
+ 9 * 4, /* %fs */
|
||||||
|
+ 10 * 4, /* %gs */
|
||||||
|
+ -1, -1, -1, -1, -1, -1, -1, -1,
|
||||||
|
+ -1, -1, -1, -1, -1, -1, -1, -1,
|
||||||
|
+ -1, -1, -1, -1, -1, -1, -1, -1,
|
||||||
|
+ -1,
|
||||||
|
+ 11 * 4 /* "orig_eax" */
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
/* From <sys/reg.h> on GNU/Linux i386. */
|
||||||
|
static int amd64_linux_gregset32_reg_offset[] =
|
||||||
|
{
|
||||||
|
@@ -102,6 +134,96 @@ static int amd64_linux_gregset32_reg_off
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
+/* This functions make ELF32 32-bit elfcore note sections
|
||||||
|
+ on amd64 environment. */
|
||||||
|
+
|
||||||
|
+static char *
|
||||||
|
+amd64_linux_elfcore_write_prpsinfo (bfd *abfd, char *buf, int *bufsiz,
|
||||||
|
+ const char *fname, const char *psargs)
|
||||||
|
+{
|
||||||
|
+ if (gdbarch_ptr_bit(current_gdbarch) == 32)
|
||||||
|
+ {
|
||||||
|
+ int note_type;
|
||||||
|
+ char *note_name = "CORE";
|
||||||
|
+ struct elf_prpsinfo32 data;
|
||||||
|
+ note_type = NT_PRPSINFO;
|
||||||
|
+
|
||||||
|
+ memset (&data, 0, sizeof (data));
|
||||||
|
+ strncpy (data.pr_fname, fname, sizeof (data.pr_fname));
|
||||||
|
+ strncpy (data.pr_psargs, psargs, sizeof (data.pr_psargs));
|
||||||
|
+ return elfcore_write_note (abfd, buf, bufsiz,
|
||||||
|
+ note_name, note_type, &data, sizeof (data));
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ return elfcore_write_prpsinfo (abfd, buf, bufsiz, fname, psargs);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void
|
||||||
|
+amd64_linux_set_registers (const gdb_byte *gregs, gdb_byte *buf)
|
||||||
|
+{
|
||||||
|
+ int i;
|
||||||
|
+ /* Copy the i386 registers in the amd64 layout into i386 layout. */
|
||||||
|
+ for (i = 0; i < I386_NUM_GREGS; i++)
|
||||||
|
+ memcpy(buf + i386_linux_gregset32_reg_offset[i],
|
||||||
|
+ gregs + amd64_linux_gregset32_reg_offset[i], 4);
|
||||||
|
+ for (i = I386_CS_REGNUM; i <= I386_GS_REGNUM; i++)
|
||||||
|
+ memcpy(buf + i386_linux_gregset32_reg_offset[i],
|
||||||
|
+ gregs + amd64_linux_gregset32_reg_offset[i], 4);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static char *
|
||||||
|
+amd64_linux_elfcore_write_prstatus (bfd *abfd, char *buf, int *bufsiz,
|
||||||
|
+ long pid, int cursig, const void *gregs)
|
||||||
|
+{
|
||||||
|
+ if (gdbarch_ptr_bit(current_gdbarch) == 32)
|
||||||
|
+ {
|
||||||
|
+ char *note_name = "CORE";
|
||||||
|
+ struct elf_prstatus32 prstat;
|
||||||
|
+ memset (&prstat, 0, sizeof (prstat));
|
||||||
|
+ prstat.pr_pid = pid;
|
||||||
|
+ prstat.pr_cursig = cursig;
|
||||||
|
+ amd64_linux_set_registers (gregs, (gdb_byte *) &prstat.pr_reg);
|
||||||
|
+ return elfcore_write_note (abfd, buf, bufsiz, note_name,
|
||||||
|
+ NT_PRSTATUS, &prstat, sizeof (prstat));
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ return elfcore_write_prstatus (abfd, buf, bufsiz, pid, cursig, gregs);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static char *
|
||||||
|
+amd64_elfcore_write_prxfpreg32 (bfd *abfd, char *buf, int *bufsiz,
|
||||||
|
+ struct regcache *regcache)
|
||||||
|
+{
|
||||||
|
+ char *note_name = "LINUX";
|
||||||
|
+ elf_fpxregset32_t fpxregs32;
|
||||||
|
+
|
||||||
|
+ i387_collect_fxsave (regcache, -1, &fpxregs32);
|
||||||
|
+ return elfcore_write_note(abfd, buf, bufsiz,
|
||||||
|
+ note_name, NT_PRXFPREG, &fpxregs32,
|
||||||
|
+ sizeof(fpxregs32));
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static char *
|
||||||
|
+amd64_linux_elfcore_write_prfpreg (bfd *abfd, char *buf,
|
||||||
|
+ int *bufsiz, const void *fpregs, int size,
|
||||||
|
+ struct regcache *regcache)
|
||||||
|
+{
|
||||||
|
+ if (gdbarch_ptr_bit(current_gdbarch) == 32)
|
||||||
|
+ {
|
||||||
|
+ char *note_name = "CORE";
|
||||||
|
+ elf_fpregset32_t fpregs32;
|
||||||
|
+
|
||||||
|
+ i387_collect_fsave (regcache, -1, &fpregs32);
|
||||||
|
+ buf = elfcore_write_note(abfd, buf, bufsiz, note_name,
|
||||||
|
+ NT_FPREGSET, &fpregs32, sizeof(fpregs32));
|
||||||
|
+
|
||||||
|
+ return amd64_elfcore_write_prxfpreg32 (abfd, buf, bufsiz, regcache);
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ return elfcore_write_prfpreg (abfd, buf, bufsiz, fpregs, size);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
/* Transfering the general-purpose registers between GDB, inferiors
|
||||||
|
and core files. */
|
||||||
|
|
||||||
|
@@ -431,6 +553,11 @@ _initialize_amd64_linux_nat (void)
|
||||||
|
t->to_fetch_registers = amd64_linux_fetch_inferior_registers;
|
||||||
|
t->to_store_registers = amd64_linux_store_inferior_registers;
|
||||||
|
|
||||||
|
+ /* This functions make elfcore note sections. */
|
||||||
|
+ linux_elfcore_write_prpsinfo = amd64_linux_elfcore_write_prpsinfo;
|
||||||
|
+ linux_elfcore_write_prstatus = amd64_linux_elfcore_write_prstatus;
|
||||||
|
+ linux_elfcore_write_prfpreg = amd64_linux_elfcore_write_prfpreg;
|
||||||
|
+
|
||||||
|
/* Register the target. */
|
||||||
|
linux_nat_add_target (t);
|
||||||
|
linux_nat_set_new_thread (t, amd64_linux_new_thread);
|
||||||
|
Index: gdb-6.8.50.20081214/gdb/config.in
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081214.orig/gdb/config.in 2008-12-14 21:17:01.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081214/gdb/config.in 2008-12-14 21:34:50.000000000 +0100
|
||||||
|
@@ -136,6 +136,9 @@
|
||||||
|
/* Define to 1 if you have the <elf_hp.h> header file. */
|
||||||
|
#undef HAVE_ELF_HP_H
|
||||||
|
|
||||||
|
+/* Define if struct elf_prstatus32 is available. */
|
||||||
|
+#undef HAVE_ELF_PRSTATUS32
|
||||||
|
+
|
||||||
|
/* Define to 1 if your system has the etext variable. */
|
||||||
|
#undef HAVE_ETEXT
|
||||||
|
|
||||||
|
@@ -465,6 +468,9 @@
|
||||||
|
/* Define to 1 if you have the <sys/poll.h> header file. */
|
||||||
|
#undef HAVE_SYS_POLL_H
|
||||||
|
|
||||||
|
+/* Define to 1 if you have the <sys/procfs32.h> header file. */
|
||||||
|
+#undef HAVE_SYS_PROCFS32_H
|
||||||
|
+
|
||||||
|
/* Define to 1 if you have the <sys/procfs.h> header file. */
|
||||||
|
#undef HAVE_SYS_PROCFS_H
|
||||||
|
|
||||||
|
@@ -492,6 +498,9 @@
|
||||||
|
/* Define to 1 if you have the <sys/types.h> header file. */
|
||||||
|
#undef HAVE_SYS_TYPES_H
|
||||||
|
|
||||||
|
+/* Define to 1 if you have the <sys/user32.h> header file. */
|
||||||
|
+#undef HAVE_SYS_USER32_H
|
||||||
|
+
|
||||||
|
/* Define to 1 if you have the <sys/user.h> header file. */
|
||||||
|
#undef HAVE_SYS_USER_H
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081214/gdb/configure
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081214.orig/gdb/configure 2008-12-14 21:17:01.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081214/gdb/configure 2008-12-14 21:33:30.000000000 +0100
|
||||||
|
@@ -12026,6 +12026,268 @@ _ACEOF
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+for ac_header in sys/user32.h sys/procfs32.h
|
||||||
|
+do
|
||||||
|
+as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh`
|
||||||
|
+if eval "test \"\${$as_ac_Header+set}\" = set"; then
|
||||||
|
+ echo "$as_me:$LINENO: checking for $ac_header" >&5
|
||||||
|
+echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6
|
||||||
|
+if eval "test \"\${$as_ac_Header+set}\" = set"; then
|
||||||
|
+ echo $ECHO_N "(cached) $ECHO_C" >&6
|
||||||
|
+fi
|
||||||
|
+echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5
|
||||||
|
+echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6
|
||||||
|
+else
|
||||||
|
+ # Is the header compilable?
|
||||||
|
+echo "$as_me:$LINENO: checking $ac_header usability" >&5
|
||||||
|
+echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6
|
||||||
|
+cat >conftest.$ac_ext <<_ACEOF
|
||||||
|
+/* confdefs.h. */
|
||||||
|
+_ACEOF
|
||||||
|
+cat confdefs.h >>conftest.$ac_ext
|
||||||
|
+cat >>conftest.$ac_ext <<_ACEOF
|
||||||
|
+/* end confdefs.h. */
|
||||||
|
+$ac_includes_default
|
||||||
|
+#include <$ac_header>
|
||||||
|
+_ACEOF
|
||||||
|
+rm -f conftest.$ac_objext
|
||||||
|
+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
|
||||||
|
+ (eval $ac_compile) 2>conftest.er1
|
||||||
|
+ ac_status=$?
|
||||||
|
+ grep -v '^ *+' conftest.er1 >conftest.err
|
||||||
|
+ rm -f conftest.er1
|
||||||
|
+ cat conftest.err >&5
|
||||||
|
+ echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||||
|
+ (exit $ac_status); } &&
|
||||||
|
+ { ac_try='test -z "$ac_c_werror_flag"
|
||||||
|
+ || test ! -s conftest.err'
|
||||||
|
+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
|
||||||
|
+ (eval $ac_try) 2>&5
|
||||||
|
+ ac_status=$?
|
||||||
|
+ echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||||
|
+ (exit $ac_status); }; } &&
|
||||||
|
+ { ac_try='test -s conftest.$ac_objext'
|
||||||
|
+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
|
||||||
|
+ (eval $ac_try) 2>&5
|
||||||
|
+ ac_status=$?
|
||||||
|
+ echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||||
|
+ (exit $ac_status); }; }; then
|
||||||
|
+ ac_header_compiler=yes
|
||||||
|
+else
|
||||||
|
+ echo "$as_me: failed program was:" >&5
|
||||||
|
+sed 's/^/| /' conftest.$ac_ext >&5
|
||||||
|
+
|
||||||
|
+ac_header_compiler=no
|
||||||
|
+fi
|
||||||
|
+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext
|
||||||
|
+echo "$as_me:$LINENO: result: $ac_header_compiler" >&5
|
||||||
|
+echo "${ECHO_T}$ac_header_compiler" >&6
|
||||||
|
+
|
||||||
|
+# Is the header present?
|
||||||
|
+echo "$as_me:$LINENO: checking $ac_header presence" >&5
|
||||||
|
+echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6
|
||||||
|
+cat >conftest.$ac_ext <<_ACEOF
|
||||||
|
+/* confdefs.h. */
|
||||||
|
+_ACEOF
|
||||||
|
+cat confdefs.h >>conftest.$ac_ext
|
||||||
|
+cat >>conftest.$ac_ext <<_ACEOF
|
||||||
|
+/* end confdefs.h. */
|
||||||
|
+#include <$ac_header>
|
||||||
|
+_ACEOF
|
||||||
|
+if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5
|
||||||
|
+ (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1
|
||||||
|
+ ac_status=$?
|
||||||
|
+ grep -v '^ *+' conftest.er1 >conftest.err
|
||||||
|
+ rm -f conftest.er1
|
||||||
|
+ cat conftest.err >&5
|
||||||
|
+ echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||||
|
+ (exit $ac_status); } >/dev/null; then
|
||||||
|
+ if test -s conftest.err; then
|
||||||
|
+ ac_cpp_err=$ac_c_preproc_warn_flag
|
||||||
|
+ ac_cpp_err=$ac_cpp_err$ac_c_werror_flag
|
||||||
|
+ else
|
||||||
|
+ ac_cpp_err=
|
||||||
|
+ fi
|
||||||
|
+else
|
||||||
|
+ ac_cpp_err=yes
|
||||||
|
+fi
|
||||||
|
+if test -z "$ac_cpp_err"; then
|
||||||
|
+ ac_header_preproc=yes
|
||||||
|
+else
|
||||||
|
+ echo "$as_me: failed program was:" >&5
|
||||||
|
+sed 's/^/| /' conftest.$ac_ext >&5
|
||||||
|
+
|
||||||
|
+ ac_header_preproc=no
|
||||||
|
+fi
|
||||||
|
+rm -f conftest.err conftest.$ac_ext
|
||||||
|
+echo "$as_me:$LINENO: result: $ac_header_preproc" >&5
|
||||||
|
+echo "${ECHO_T}$ac_header_preproc" >&6
|
||||||
|
+
|
||||||
|
+# So? What about this header?
|
||||||
|
+case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in
|
||||||
|
+ yes:no: )
|
||||||
|
+ { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5
|
||||||
|
+echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;}
|
||||||
|
+ { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5
|
||||||
|
+echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;}
|
||||||
|
+ ac_header_preproc=yes
|
||||||
|
+ ;;
|
||||||
|
+ no:yes:* )
|
||||||
|
+ { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5
|
||||||
|
+echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;}
|
||||||
|
+ { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5
|
||||||
|
+echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;}
|
||||||
|
+ { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5
|
||||||
|
+echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;}
|
||||||
|
+ { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5
|
||||||
|
+echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;}
|
||||||
|
+ { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5
|
||||||
|
+echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;}
|
||||||
|
+ { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5
|
||||||
|
+echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;}
|
||||||
|
+ (
|
||||||
|
+ cat <<\_ASBOX
|
||||||
|
+## ------------------------------------------ ##
|
||||||
|
+## Report this to the AC_PACKAGE_NAME lists. ##
|
||||||
|
+## ------------------------------------------ ##
|
||||||
|
+_ASBOX
|
||||||
|
+ ) |
|
||||||
|
+ sed "s/^/$as_me: WARNING: /" >&2
|
||||||
|
+ ;;
|
||||||
|
+esac
|
||||||
|
+echo "$as_me:$LINENO: checking for $ac_header" >&5
|
||||||
|
+echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6
|
||||||
|
+if eval "test \"\${$as_ac_Header+set}\" = set"; then
|
||||||
|
+ echo $ECHO_N "(cached) $ECHO_C" >&6
|
||||||
|
+else
|
||||||
|
+ eval "$as_ac_Header=\$ac_header_preproc"
|
||||||
|
+fi
|
||||||
|
+echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5
|
||||||
|
+echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6
|
||||||
|
+
|
||||||
|
+fi
|
||||||
|
+if test `eval echo '${'$as_ac_Header'}'` = yes; then
|
||||||
|
+ cat >>confdefs.h <<_ACEOF
|
||||||
|
+#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1
|
||||||
|
+_ACEOF
|
||||||
|
+
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+done
|
||||||
|
+
|
||||||
|
+echo "$as_me:$LINENO: checking for struct elf_prstatus32.pr_reg" >&5
|
||||||
|
+echo $ECHO_N "checking for struct elf_prstatus32.pr_reg... $ECHO_C" >&6
|
||||||
|
+if test "${ac_cv_member_struct_elf_prstatus32_pr_reg+set}" = set; then
|
||||||
|
+ echo $ECHO_N "(cached) $ECHO_C" >&6
|
||||||
|
+else
|
||||||
|
+ cat >conftest.$ac_ext <<_ACEOF
|
||||||
|
+/* confdefs.h. */
|
||||||
|
+_ACEOF
|
||||||
|
+cat confdefs.h >>conftest.$ac_ext
|
||||||
|
+cat >>conftest.$ac_ext <<_ACEOF
|
||||||
|
+/* end confdefs.h. */
|
||||||
|
+#include <sys/procfs.h>
|
||||||
|
+
|
||||||
|
+int
|
||||||
|
+main ()
|
||||||
|
+{
|
||||||
|
+static struct elf_prstatus32 ac_aggr;
|
||||||
|
+if (ac_aggr.pr_reg)
|
||||||
|
+return 0;
|
||||||
|
+ ;
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+_ACEOF
|
||||||
|
+rm -f conftest.$ac_objext
|
||||||
|
+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
|
||||||
|
+ (eval $ac_compile) 2>conftest.er1
|
||||||
|
+ ac_status=$?
|
||||||
|
+ grep -v '^ *+' conftest.er1 >conftest.err
|
||||||
|
+ rm -f conftest.er1
|
||||||
|
+ cat conftest.err >&5
|
||||||
|
+ echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||||
|
+ (exit $ac_status); } &&
|
||||||
|
+ { ac_try='test -z "$ac_c_werror_flag"
|
||||||
|
+ || test ! -s conftest.err'
|
||||||
|
+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
|
||||||
|
+ (eval $ac_try) 2>&5
|
||||||
|
+ ac_status=$?
|
||||||
|
+ echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||||
|
+ (exit $ac_status); }; } &&
|
||||||
|
+ { ac_try='test -s conftest.$ac_objext'
|
||||||
|
+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
|
||||||
|
+ (eval $ac_try) 2>&5
|
||||||
|
+ ac_status=$?
|
||||||
|
+ echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||||
|
+ (exit $ac_status); }; }; then
|
||||||
|
+ ac_cv_member_struct_elf_prstatus32_pr_reg=yes
|
||||||
|
+else
|
||||||
|
+ echo "$as_me: failed program was:" >&5
|
||||||
|
+sed 's/^/| /' conftest.$ac_ext >&5
|
||||||
|
+
|
||||||
|
+cat >conftest.$ac_ext <<_ACEOF
|
||||||
|
+/* confdefs.h. */
|
||||||
|
+_ACEOF
|
||||||
|
+cat confdefs.h >>conftest.$ac_ext
|
||||||
|
+cat >>conftest.$ac_ext <<_ACEOF
|
||||||
|
+/* end confdefs.h. */
|
||||||
|
+#include <sys/procfs.h>
|
||||||
|
+
|
||||||
|
+int
|
||||||
|
+main ()
|
||||||
|
+{
|
||||||
|
+static struct elf_prstatus32 ac_aggr;
|
||||||
|
+if (sizeof ac_aggr.pr_reg)
|
||||||
|
+return 0;
|
||||||
|
+ ;
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+_ACEOF
|
||||||
|
+rm -f conftest.$ac_objext
|
||||||
|
+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
|
||||||
|
+ (eval $ac_compile) 2>conftest.er1
|
||||||
|
+ ac_status=$?
|
||||||
|
+ grep -v '^ *+' conftest.er1 >conftest.err
|
||||||
|
+ rm -f conftest.er1
|
||||||
|
+ cat conftest.err >&5
|
||||||
|
+ echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||||
|
+ (exit $ac_status); } &&
|
||||||
|
+ { ac_try='test -z "$ac_c_werror_flag"
|
||||||
|
+ || test ! -s conftest.err'
|
||||||
|
+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
|
||||||
|
+ (eval $ac_try) 2>&5
|
||||||
|
+ ac_status=$?
|
||||||
|
+ echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||||
|
+ (exit $ac_status); }; } &&
|
||||||
|
+ { ac_try='test -s conftest.$ac_objext'
|
||||||
|
+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
|
||||||
|
+ (eval $ac_try) 2>&5
|
||||||
|
+ ac_status=$?
|
||||||
|
+ echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||||
|
+ (exit $ac_status); }; }; then
|
||||||
|
+ ac_cv_member_struct_elf_prstatus32_pr_reg=yes
|
||||||
|
+else
|
||||||
|
+ echo "$as_me: failed program was:" >&5
|
||||||
|
+sed 's/^/| /' conftest.$ac_ext >&5
|
||||||
|
+
|
||||||
|
+ac_cv_member_struct_elf_prstatus32_pr_reg=no
|
||||||
|
+fi
|
||||||
|
+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext
|
||||||
|
+fi
|
||||||
|
+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext
|
||||||
|
+fi
|
||||||
|
+echo "$as_me:$LINENO: result: $ac_cv_member_struct_elf_prstatus32_pr_reg" >&5
|
||||||
|
+echo "${ECHO_T}$ac_cv_member_struct_elf_prstatus32_pr_reg" >&6
|
||||||
|
+if test $ac_cv_member_struct_elf_prstatus32_pr_reg = yes; then
|
||||||
|
+
|
||||||
|
+cat >>confdefs.h <<\_ACEOF
|
||||||
|
+#define HAVE_ELF_PRSTATUS32 1
|
||||||
|
+_ACEOF
|
||||||
|
+
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
# elf_hp.h is for HP/UX 64-bit shared library support.
|
||||||
|
# FIXME: kettenis/20030102: In most cases we include these (ctype.h, time.h)
|
||||||
|
# unconditionally, so what's the point in checking these?
|
||||||
|
Index: gdb-6.8.50.20081214/gdb/configure.ac
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081214.orig/gdb/configure.ac 2008-12-14 21:17:01.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081214/gdb/configure.ac 2008-12-14 21:32:35.000000000 +0100
|
||||||
|
@@ -686,6 +686,11 @@ AC_SUBST(PYTHON_CFLAGS)
|
||||||
|
AC_HEADER_DIRENT
|
||||||
|
AC_HEADER_STAT
|
||||||
|
AC_HEADER_STDC
|
||||||
|
+AC_CHECK_HEADERS([sys/user32.h sys/procfs32.h])
|
||||||
|
+AC_CHECK_MEMBER([struct elf_prstatus32.pr_reg],
|
||||||
|
+ [AC_DEFINE(HAVE_ELF_PRSTATUS32, 1,
|
||||||
|
+ [Define if struct elf_prstatus32 is available. ])],
|
||||||
|
+ [], [#include <sys/procfs.h>])
|
||||||
|
# elf_hp.h is for HP/UX 64-bit shared library support.
|
||||||
|
# FIXME: kettenis/20030102: In most cases we include these (ctype.h, time.h)
|
||||||
|
# unconditionally, so what's the point in checking these?
|
||||||
|
Index: gdb-6.8.50.20081214/gdb/gcore.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081214.orig/gdb/gcore.c 2008-12-14 21:17:01.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081214/gdb/gcore.c 2008-12-14 21:17:10.000000000 +0100
|
||||||
|
@@ -320,6 +320,11 @@ gcore_create_callback (CORE_ADDR vaddr,
|
||||||
|
asection *osec;
|
||||||
|
flagword flags = SEC_ALLOC | SEC_HAS_CONTENTS | SEC_LOAD;
|
||||||
|
|
||||||
|
+ /* Some Linux kernel versions around 2.6.17 have for i386 inferiors running
|
||||||
|
+ in compatibility mode on amd64 kernel their VSYSCALL page (at 0xffffe000)
|
||||||
|
+ protected as RWX==000 by default and gdb fails to read the library header
|
||||||
|
+ upon loading the core. This is a Linux kernel bug being fixed. */
|
||||||
|
+
|
||||||
|
/* If the memory segment has no permissions set, ignore it, otherwise
|
||||||
|
when we later try to access it for read/write, we'll get an error
|
||||||
|
or jam the kernel. */
|
||||||
|
Index: gdb-6.8.50.20081214/gdb/gdb_procfs32.h
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081214/gdb/gdb_procfs32.h 2008-12-14 21:32:56.000000000 +0100
|
||||||
|
@@ -0,0 +1,128 @@
|
||||||
|
+#ifdef HAVE_SYS_PROCFS32_H
|
||||||
|
+#include <sys/procfs32.h>
|
||||||
|
+#elif !defined HAVE_ELF_PRSTATUS32
|
||||||
|
+
|
||||||
|
+/* Copyright (C) 2006 Free Software Foundation, Inc.
|
||||||
|
+ This file is part of the GNU C Library.
|
||||||
|
+
|
||||||
|
+ The GNU C Library is free software; you can redistribute it and/or
|
||||||
|
+ modify it under the terms of the GNU Lesser General Public
|
||||||
|
+ License as published by the Free Software Foundation; either
|
||||||
|
+ version 2.1 of the License, or (at your option) any later version.
|
||||||
|
+
|
||||||
|
+ The GNU C Library 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
|
||||||
|
+ Lesser General Public License for more details.
|
||||||
|
+
|
||||||
|
+ You should have received a copy of the GNU Lesser General Public
|
||||||
|
+ License along with the GNU C Library; if not, write to the Free
|
||||||
|
+ Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
+ 02111-1307 USA. */
|
||||||
|
+
|
||||||
|
+#ifndef _SYS_PROCFS32_H
|
||||||
|
+#define _SYS_PROCFS32_H 1
|
||||||
|
+
|
||||||
|
+/* This is somewhat modelled after the file of the same name on SVR4
|
||||||
|
+ systems. It provides a definition of the core file format for ELF
|
||||||
|
+ used on Linux. It doesn't have anything to do with the /proc file
|
||||||
|
+ system, even though Linux has one.
|
||||||
|
+
|
||||||
|
+ Anyway, the whole purpose of this file is for GDB and GDB only.
|
||||||
|
+ Don't read too much into it. Don't use it for anything other than
|
||||||
|
+ GDB unless you know what you are doing. */
|
||||||
|
+
|
||||||
|
+#include <features.h>
|
||||||
|
+#include <sys/time.h>
|
||||||
|
+#include <sys/types.h>
|
||||||
|
+#include "gdb_user32.h"
|
||||||
|
+
|
||||||
|
+/* We define here only the symbols differing from their 64-bit variant. */
|
||||||
|
+#include <sys/procfs.h>
|
||||||
|
+
|
||||||
|
+__BEGIN_DECLS
|
||||||
|
+
|
||||||
|
+/* Type for a general-purpose register. */
|
||||||
|
+typedef unsigned int elf_greg32_t;
|
||||||
|
+
|
||||||
|
+/* And the whole bunch of them. We could have used `struct
|
||||||
|
+ user_regs_struct' directly in the typedef, but tradition says that
|
||||||
|
+ the register set is an array, which does have some peculiar
|
||||||
|
+ semantics, so leave it that way. */
|
||||||
|
+#define ELF_NGREG32 (sizeof (struct user_regs32_struct) / sizeof(elf_greg32_t))
|
||||||
|
+typedef elf_greg32_t elf_gregset32_t[ELF_NGREG32];
|
||||||
|
+
|
||||||
|
+/* Register set for the floating-point registers. */
|
||||||
|
+typedef struct user_fpregs32_struct elf_fpregset32_t;
|
||||||
|
+
|
||||||
|
+/* Register set for the extended floating-point registers. Includes
|
||||||
|
+ the Pentium III SSE registers in addition to the classic
|
||||||
|
+ floating-point stuff. */
|
||||||
|
+typedef struct user_fpxregs32_struct elf_fpxregset32_t;
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+/* Definitions to generate Intel SVR4-like core files. These mostly
|
||||||
|
+ have the same names as the SVR4 types with "elf_" tacked on the
|
||||||
|
+ front to prevent clashes with Linux definitions, and the typedef
|
||||||
|
+ forms have been avoided. This is mostly like the SVR4 structure,
|
||||||
|
+ but more Linuxy, with things that Linux does not support and which
|
||||||
|
+ GDB doesn't really use excluded. */
|
||||||
|
+
|
||||||
|
+struct prstatus32_timeval
|
||||||
|
+ {
|
||||||
|
+ int tv_sec;
|
||||||
|
+ int tv_usec;
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+struct elf_prstatus32
|
||||||
|
+ {
|
||||||
|
+ struct elf_siginfo pr_info; /* Info associated with signal. */
|
||||||
|
+ short int pr_cursig; /* Current signal. */
|
||||||
|
+ unsigned int pr_sigpend; /* Set of pending signals. */
|
||||||
|
+ unsigned int pr_sighold; /* Set of held signals. */
|
||||||
|
+ __pid_t pr_pid;
|
||||||
|
+ __pid_t pr_ppid;
|
||||||
|
+ __pid_t pr_pgrp;
|
||||||
|
+ __pid_t pr_sid;
|
||||||
|
+ struct prstatus32_timeval pr_utime; /* User time. */
|
||||||
|
+ struct prstatus32_timeval pr_stime; /* System time. */
|
||||||
|
+ struct prstatus32_timeval pr_cutime; /* Cumulative user time. */
|
||||||
|
+ struct prstatus32_timeval pr_cstime; /* Cumulative system time. */
|
||||||
|
+ elf_gregset32_t pr_reg; /* GP registers. */
|
||||||
|
+ int pr_fpvalid; /* True if math copro being used. */
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+struct elf_prpsinfo32
|
||||||
|
+ {
|
||||||
|
+ char pr_state; /* Numeric process state. */
|
||||||
|
+ char pr_sname; /* Char for pr_state. */
|
||||||
|
+ char pr_zomb; /* Zombie. */
|
||||||
|
+ char pr_nice; /* Nice val. */
|
||||||
|
+ unsigned int pr_flag; /* Flags. */
|
||||||
|
+ unsigned short int pr_uid;
|
||||||
|
+ unsigned short int pr_gid;
|
||||||
|
+ int pr_pid, pr_ppid, pr_pgrp, pr_sid;
|
||||||
|
+ /* Lots missing */
|
||||||
|
+ char pr_fname[16]; /* Filename of executable. */
|
||||||
|
+ char pr_psargs[ELF_PRARGSZ]; /* Initial part of arg list. */
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+/* The rest of this file provides the types for emulation of the
|
||||||
|
+ Solaris <proc_service.h> interfaces that should be implemented by
|
||||||
|
+ users of libthread_db. */
|
||||||
|
+
|
||||||
|
+/* Register sets. Linux has different names. */
|
||||||
|
+typedef elf_gregset_t prgregset32_t;
|
||||||
|
+typedef elf_fpregset_t prfpregset32_t;
|
||||||
|
+
|
||||||
|
+/* Process status and info. In the end we do provide typedefs for them. */
|
||||||
|
+typedef struct elf_prstatus32 prstatus32_t;
|
||||||
|
+typedef struct elf_prpsinfo32 prpsinfo32_t;
|
||||||
|
+
|
||||||
|
+__END_DECLS
|
||||||
|
+
|
||||||
|
+#endif /* _SYS_PROCFS32_H */
|
||||||
|
+
|
||||||
|
+#endif /* HAVE_SYS_PROCFS32_H */
|
||||||
|
Index: gdb-6.8.50.20081214/gdb/gdb_user32.h
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081214/gdb/gdb_user32.h 2008-12-14 21:17:10.000000000 +0100
|
||||||
|
@@ -0,0 +1,108 @@
|
||||||
|
+#ifdef HAVE_SYS_USER32_H
|
||||||
|
+#include <sys/user32.h>
|
||||||
|
+#else
|
||||||
|
+
|
||||||
|
+#ifdef HAVE_STDINT_H
|
||||||
|
+#include <stdint.h>
|
||||||
|
+typedef int32_t gdb_int32_t;
|
||||||
|
+typedef uint32_t gdb_uint32_t;
|
||||||
|
+#else
|
||||||
|
+typedef signed int gdb_uint32_t;
|
||||||
|
+typedef unsigned int gdb_uint32_t;
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
+/* Copyright (C) 2006 Free Software Foundation, Inc.
|
||||||
|
+ This file is part of the GNU C Library.
|
||||||
|
+
|
||||||
|
+ The GNU C Library is free software; you can redistribute it and/or
|
||||||
|
+ modify it under the terms of the GNU Lesser General Public
|
||||||
|
+ License as published by the Free Software Foundation; either
|
||||||
|
+ version 2.1 of the License, or (at your option) any later version.
|
||||||
|
+
|
||||||
|
+ The GNU C Library 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
|
||||||
|
+ Lesser General Public License for more details.
|
||||||
|
+
|
||||||
|
+ You should have received a copy of the GNU Lesser General Public
|
||||||
|
+ License along with the GNU C Library; if not, write to the Free
|
||||||
|
+ Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
||||||
|
+ 02111-1307 USA. */
|
||||||
|
+
|
||||||
|
+#ifndef _SYS_USER32_H
|
||||||
|
+#define _SYS_USER32_H 1
|
||||||
|
+
|
||||||
|
+/* These are the 32-bit x86 structures. */
|
||||||
|
+
|
||||||
|
+struct user_fpregs32_struct
|
||||||
|
+{
|
||||||
|
+ int32_t cwd;
|
||||||
|
+ int32_t swd;
|
||||||
|
+ int32_t twd;
|
||||||
|
+ int32_t fip;
|
||||||
|
+ int32_t fcs;
|
||||||
|
+ int32_t foo;
|
||||||
|
+ int32_t fos;
|
||||||
|
+ int32_t st_space [20];
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+struct user_fpxregs32_struct
|
||||||
|
+{
|
||||||
|
+ unsigned short int cwd;
|
||||||
|
+ unsigned short int swd;
|
||||||
|
+ unsigned short int twd;
|
||||||
|
+ unsigned short int fop;
|
||||||
|
+ int32_t fip;
|
||||||
|
+ int32_t fcs;
|
||||||
|
+ int32_t foo;
|
||||||
|
+ int32_t fos;
|
||||||
|
+ int32_t mxcsr;
|
||||||
|
+ int32_t reserved;
|
||||||
|
+ int32_t st_space[32]; /* 8*16 bytes for each FP-reg = 128 bytes */
|
||||||
|
+ int32_t xmm_space[32]; /* 8*16 bytes for each XMM-reg = 128 bytes */
|
||||||
|
+ int32_t padding[56];
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+struct user_regs32_struct
|
||||||
|
+{
|
||||||
|
+ int32_t ebx;
|
||||||
|
+ int32_t ecx;
|
||||||
|
+ int32_t edx;
|
||||||
|
+ int32_t esi;
|
||||||
|
+ int32_t edi;
|
||||||
|
+ int32_t ebp;
|
||||||
|
+ int32_t eax;
|
||||||
|
+ int32_t xds;
|
||||||
|
+ int32_t xes;
|
||||||
|
+ int32_t xfs;
|
||||||
|
+ int32_t xgs;
|
||||||
|
+ int32_t orig_eax;
|
||||||
|
+ int32_t eip;
|
||||||
|
+ int32_t xcs;
|
||||||
|
+ int32_t eflags;
|
||||||
|
+ int32_t esp;
|
||||||
|
+ int32_t xss;
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+struct user32
|
||||||
|
+{
|
||||||
|
+ struct user_regs32_struct regs;
|
||||||
|
+ int u_fpvalid;
|
||||||
|
+ struct user_fpregs32_struct i387;
|
||||||
|
+ uint32_t u_tsize;
|
||||||
|
+ uint32_t u_dsize;
|
||||||
|
+ uint32_t u_ssize;
|
||||||
|
+ uint32_t start_code;
|
||||||
|
+ uint32_t start_stack;
|
||||||
|
+ int32_t signal;
|
||||||
|
+ int reserved;
|
||||||
|
+ struct user_regs32_struct* u_ar0;
|
||||||
|
+ struct user_fpregs32_struct* u_fpstate;
|
||||||
|
+ uint32_t magic;
|
||||||
|
+ char u_comm [32];
|
||||||
|
+ int u_debugreg [8];
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+#endif /* _SYS_USER32_H */
|
||||||
|
+
|
||||||
|
+#endif /* HAVE_SYS_USER32_H */
|
||||||
|
Index: gdb-6.8.50.20081214/gdb/linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081214.orig/gdb/linux-nat.c 2008-12-14 21:17:01.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081214/gdb/linux-nat.c 2008-12-14 21:24:20.000000000 +0100
|
||||||
|
@@ -213,6 +213,21 @@ static LONGEST (*super_xfer_partial) (st
|
||||||
|
const gdb_byte *,
|
||||||
|
ULONGEST, LONGEST);
|
||||||
|
|
||||||
|
+/* This functions make elfcore note sections.
|
||||||
|
+ They may get overriden by code adjusting data for multi-target builds. */
|
||||||
|
+char *(*linux_elfcore_write_prpsinfo)
|
||||||
|
+ (bfd *, char *, int *, const char *, const char *) = elfcore_write_prpsinfo;
|
||||||
|
+char *(*linux_elfcore_write_prstatus)
|
||||||
|
+ (bfd *, char *, int *, long, int, const void *) = elfcore_write_prstatus;
|
||||||
|
+static char *
|
||||||
|
+linux_elfcore_write_prfpreg_bfd (bfd *abfd, char *buf, int *bufsiz,
|
||||||
|
+ const void *fpregs, int size, struct regcache *regcache)
|
||||||
|
+{
|
||||||
|
+ return elfcore_write_prfpreg (abfd, buf, bufsiz, fpregs, size);
|
||||||
|
+}
|
||||||
|
+char *(*linux_elfcore_write_prfpreg) (bfd *, char *, int *, const void *, int,
|
||||||
|
+ struct regcache *) = linux_elfcore_write_prfpreg_bfd;
|
||||||
|
+
|
||||||
|
static int debug_linux_nat;
|
||||||
|
static void
|
||||||
|
show_debug_linux_nat (struct ui_file *file, int from_tty,
|
||||||
|
@@ -3473,7 +3488,7 @@ linux_nat_do_thread_registers (bfd *obfd
|
||||||
|
else
|
||||||
|
fill_gregset (regcache, &gregs, -1);
|
||||||
|
|
||||||
|
- note_data = (char *) elfcore_write_prstatus (obfd,
|
||||||
|
+ note_data = (char *) linux_elfcore_write_prstatus (obfd,
|
||||||
|
note_data,
|
||||||
|
note_size,
|
||||||
|
lwp,
|
||||||
|
@@ -3523,10 +3538,10 @@ linux_nat_do_thread_registers (bfd *obfd
|
||||||
|
else
|
||||||
|
fill_fpregset (regcache, &fpregs, -1);
|
||||||
|
|
||||||
|
- note_data = (char *) elfcore_write_prfpreg (obfd,
|
||||||
|
+ note_data = (char *) linux_elfcore_write_prfpreg (obfd,
|
||||||
|
note_data,
|
||||||
|
note_size,
|
||||||
|
- &fpregs, sizeof (fpregs));
|
||||||
|
+ &fpregs, sizeof (fpregs), regcache);
|
||||||
|
}
|
||||||
|
|
||||||
|
return note_data;
|
||||||
|
@@ -3595,9 +3610,9 @@ linux_nat_make_corefile_notes (bfd *obfd
|
||||||
|
psargs_end - string_end);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
- note_data = (char *) elfcore_write_prpsinfo (obfd,
|
||||||
|
- note_data,
|
||||||
|
- note_size, fname, psargs);
|
||||||
|
+ note_data = (char *) linux_elfcore_write_prpsinfo (obfd, note_data,
|
||||||
|
+ note_size, fname,
|
||||||
|
+ psargs);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Dump information for threads. */
|
||||||
|
Index: gdb-6.8.50.20081214/gdb/linux-nat.h
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081214.orig/gdb/linux-nat.h 2008-12-14 21:17:01.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081214/gdb/linux-nat.h 2008-12-14 21:24:11.000000000 +0100
|
||||||
|
@@ -134,3 +134,12 @@ void linux_nat_switch_fork (ptid_t new_p
|
||||||
|
|
||||||
|
/* Return the saved siginfo associated with PTID. */
|
||||||
|
struct siginfo *linux_nat_get_siginfo (ptid_t ptid);
|
||||||
|
+
|
||||||
|
+/* These functions make elfcore note sections.
|
||||||
|
+ They may get overriden by code adjusting data for multi-target builds. */
|
||||||
|
+extern char *(*linux_elfcore_write_prpsinfo)
|
||||||
|
+ (bfd *, char *, int *, const char *, const char *);
|
||||||
|
+extern char *(*linux_elfcore_write_prstatus)
|
||||||
|
+ (bfd *, char *, int *, long, int, const void *);
|
||||||
|
+extern char *(*linux_elfcore_write_prfpreg)
|
||||||
|
+ (bfd *, char *, int *, const void *, int, struct regcache *);
|
127
gdb-6.5-ia64-libunwind-leak-test.patch
Normal file
127
gdb-6.5-ia64-libunwind-leak-test.patch
Normal file
@ -0,0 +1,127 @@
|
|||||||
|
diff -u -rup gdb-6.3-orig/gdb/testsuite/gdb.base/unwind-leak.c gdb-6.3/gdb/testsuite/gdb.base/unwind-leak.c
|
||||||
|
--- gdb-6.3-orig/gdb/testsuite/gdb.base/unwind-leak.c 2007-12-19 15:12:55.000000000 -0500
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.base/unwind-leak.c 2007-12-19 13:55:22.000000000 -0500
|
||||||
|
@@ -0,0 +1,29 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2007 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 */
|
||||||
|
+
|
||||||
|
+#include <unistd.h>
|
||||||
|
+
|
||||||
|
+int main()
|
||||||
|
+{
|
||||||
|
+ for (;;)
|
||||||
|
+ alarm (0);
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
diff -u -rup gdb-6.3-orig/gdb/testsuite/gdb.base/unwind-leak.exp gdb-6.3/gdb/testsuite/gdb.base/unwind-leak.exp
|
||||||
|
--- gdb-6.3-orig/gdb/testsuite/gdb.base/unwind-leak.exp 2007-12-19 15:12:53.000000000 -0500
|
||||||
|
+++ gdb-6.3/gdb/testsuite/gdb.base/unwind-leak.exp 2007-12-19 15:11:35.000000000 -0500
|
||||||
|
@@ -0,0 +1,90 @@
|
||||||
|
+# Copyright 2007 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.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+set testfile unwind-leak
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set shfile ${objdir}/${subdir}/${testfile}-gdb.sh
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
+ untested "Couldn't compile test program"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Get things started.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+set pid [exp_pid -i [board_info host fileid]]
|
||||||
|
+
|
||||||
|
+# For C programs, "start" should stop in main().
|
||||||
|
+
|
||||||
|
+gdb_test "start" \
|
||||||
|
+ "main \\(\\) at .*$srcfile.*" \
|
||||||
|
+ "start"
|
||||||
|
+
|
||||||
|
+set loc [gdb_get_line_number "alarm"]
|
||||||
|
+gdb_breakpoint $loc
|
||||||
|
+
|
||||||
|
+proc memory_get {} {
|
||||||
|
+ global pid
|
||||||
|
+ set fd [open "/proc/$pid/statm"]
|
||||||
|
+ gets $fd line
|
||||||
|
+ close $fd
|
||||||
|
+ # number of pages of data/stack
|
||||||
|
+ scan $line "%*d%*d%*d%*d%*d%d" drs
|
||||||
|
+ return $drs
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set cycles 100
|
||||||
|
+# For 100 cycles it was 1308: from = 363 KB, to = 1671 KB
|
||||||
|
+set permit_kb 100
|
||||||
|
+verbose -log "cycles = $cycles, permit_kb = $permit_kb"
|
||||||
|
+
|
||||||
|
+set fail 0
|
||||||
|
+set test "breakpoint stop/continue cycles"
|
||||||
|
+for {set i $cycles} {$i > 0} {set i [expr {$i - 1}]} {
|
||||||
|
+ gdb_test_multiple "continue" $test {
|
||||||
|
+ -re "Breakpoint 2, main .*alarm .*.*${gdb_prompt} $" {
|
||||||
|
+ }
|
||||||
|
+ -re "Segmentation fault" {
|
||||||
|
+ fail $test
|
||||||
|
+ set i 0
|
||||||
|
+ set fail 1
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ if ![info exists from] {
|
||||||
|
+ set from [memory_get]
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+set to [memory_get]
|
||||||
|
+if {!$fail} {
|
||||||
|
+ verbose -log "from = $from KB, to = $to KB"
|
||||||
|
+ if {$from > 0 && $to > 10 && $to < $from + $permit_kb} {
|
||||||
|
+ pass $test
|
||||||
|
+ } else {
|
||||||
|
+ fail $test
|
||||||
|
+ }
|
||||||
|
+}
|
56
gdb-6.5-last-address-space-byte-test.patch
Normal file
56
gdb-6.5-last-address-space-byte-test.patch
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
Index: ./gdb/testsuite/gdb.base/largecore-last-address-lock.exp
|
||||||
|
===================================================================
|
||||||
|
RCS file: ./gdb/testsuite/gdb.base/largecore-last-address-lock.exp
|
||||||
|
diff -N ./gdb/testsuite/gdb.base/largecore-last-address-lock.exp
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.base/largecore-last-address-lock.exp 15 Nov 2006 21:43:24 -0000
|
||||||
|
@@ -0,0 +1,49 @@
|
||||||
|
+# Copyright 2006 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.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Get things started.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+
|
||||||
|
+# i386 (32-bit) only: gdb with Red Hat largecore patch did lock up:
|
||||||
|
+# https://enterprise.redhat.com/issue-tracker/?module=issues&action=view&tid=103263
|
||||||
|
+# https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=210614
|
||||||
|
+
|
||||||
|
+# i386: Bug exists when the `target_xfer_memory' condition
|
||||||
|
+# `(memaddr + len < region->hi)' operates on 64-bit operands on
|
||||||
|
+# largecore-patched with 32-bit addresses and so it can get `false' with
|
||||||
|
+# arbitrary `len'.
|
||||||
|
+
|
||||||
|
+# x86_64: The bug is not present as the operands and calculations have the same
|
||||||
|
+# bit size. Would would still need to pass there the highest address
|
||||||
|
+# (`memaddr == 0xffffffffffffffff') but we would need to pass `len == 0'
|
||||||
|
+# to make the condition `(memaddr + len < region->hi)' false.
|
||||||
|
+# `len == 0' would get caught eariler.
|
||||||
|
+
|
||||||
|
+# Error in the success case is immediate.
|
||||||
|
+set timeoutold ${timeout}
|
||||||
|
+set timeout 10
|
||||||
|
+
|
||||||
|
+gdb_test "x/xb 0xffffffff" \
|
||||||
|
+ "Cannot access memory at address 0xffffffff" \
|
||||||
|
+ "Read the last address space byte"
|
||||||
|
+
|
||||||
|
+set timeout ${timeoutold}
|
90
gdb-6.5-missed-trap-on-step-test.patch
Normal file
90
gdb-6.5-missed-trap-on-step-test.patch
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
Fix has been committed to:
|
||||||
|
gdb-6.6-scheduler_locking-step-sw-watchpoints2.patch
|
||||||
|
|
||||||
|
--- /dev/null 2007-12-14 20:45:09.113039517 +0100
|
||||||
|
+++ gdb-6.5/gdb/testsuite/gdb.base/watchpoint-during-step.exp 2007-12-24 19:42:00.000000000 +0100
|
||||||
|
@@ -0,0 +1,51 @@
|
||||||
|
+# Copyright 2007 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.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+set testfile watchpoint-during-step
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
+ untested "Couldn't compile test program"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Get things started.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+runto_main
|
||||||
|
+
|
||||||
|
+gdb_breakpoint [gdb_get_line_number "var = 2"]
|
||||||
|
+gdb_continue_to_breakpoint "Find the first var set"
|
||||||
|
+
|
||||||
|
+gdb_test "step" ".*var = 3;" "Step to the next var set"
|
||||||
|
+
|
||||||
|
+gdb_test "watch var" "atchpoint .*: var" "Set the watchpoint"
|
||||||
|
+
|
||||||
|
+# Here is the target point. Be careful to not have breakpoint set on the line
|
||||||
|
+# we step from as in this case it is a valid upstream KFAIL gdb/38
|
||||||
|
+
|
||||||
|
+gdb_test "step" ".*Old value = 2.*New value = 3.*" "Catch the watchpoint"
|
||||||
|
--- /dev/null 2007-12-14 20:45:09.113039517 +0100
|
||||||
|
+++ gdb-6.5/gdb/testsuite/gdb.base/watchpoint-during-step.c 2007-12-24 19:38:10.000000000 +0100
|
||||||
|
@@ -0,0 +1,30 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2007 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 */
|
||||||
|
+
|
||||||
|
+static int var;
|
||||||
|
+
|
||||||
|
+int main()
|
||||||
|
+{
|
||||||
|
+ var = 1;
|
||||||
|
+ var = 2;
|
||||||
|
+ var = 3;
|
||||||
|
+ return 0;
|
||||||
|
+}
|
136
gdb-6.5-readline-long-line-crash-test.patch
Normal file
136
gdb-6.5-readline-long-line-crash-test.patch
Normal file
@ -0,0 +1,136 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=214196
|
||||||
|
|
||||||
|
|
||||||
|
Index: ./gdb/testsuite/gdb.base/readline-overflow.exp
|
||||||
|
===================================================================
|
||||||
|
RCS file: ./gdb/testsuite/gdb.base/readline-overflow.exp
|
||||||
|
diff -N ./gdb/testsuite/gdb.base/readline-overflow.exp
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.base/readline-overflow.exp 13 Nov 2006 23:42:50 -0000
|
||||||
|
@@ -0,0 +1,125 @@
|
||||||
|
+# Copyright 2006 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
|
||||||
|
+
|
||||||
|
+# This file was written by Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
+
|
||||||
|
+# This file is part of the gdb testsuite.
|
||||||
|
+
|
||||||
|
+#
|
||||||
|
+# Tests for readline buffer overflow.
|
||||||
|
+#
|
||||||
|
+
|
||||||
|
+if $tracelevel {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Don't let a .inputrc file or an existing setting of INPUTRC mess up
|
||||||
|
+# the test results. Even if /dev/null doesn't exist on the particular
|
||||||
|
+# platform, the readline library will use the default setting just by
|
||||||
|
+# failing to open the file. OTOH, opening /dev/null successfully will
|
||||||
|
+# also result in the default settings being used since nothing will be
|
||||||
|
+# read from this file.
|
||||||
|
+global env
|
||||||
|
+if [info exists env(INPUTRC)] {
|
||||||
|
+ set old_inputrc $env(INPUTRC)
|
||||||
|
+}
|
||||||
|
+set env(INPUTRC) "/dev/null"
|
||||||
|
+
|
||||||
|
+set oldtimeout1 $timeout
|
||||||
|
+set timeout 600
|
||||||
|
+
|
||||||
|
+if [info exists env(GDBHISTFILE)] {
|
||||||
|
+ set old_gdbhistfile $env(GDBHISTFILE)
|
||||||
|
+}
|
||||||
|
+if [info exists env(HISTSIZE)] {
|
||||||
|
+ set old_histsize $env(HISTSIZE)
|
||||||
|
+}
|
||||||
|
+set env(GDBHISTFILE) "${srcdir}/${subdir}/gdb_history"
|
||||||
|
+set env(HISTSIZE) "10"
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+set width 11
|
||||||
|
+gdb_test "set width $width" \
|
||||||
|
+ "" \
|
||||||
|
+ "Setting width to $width."
|
||||||
|
+#gdb_test "set height 1" \
|
||||||
|
+# "" \
|
||||||
|
+# "Setting height to 1."
|
||||||
|
+send_gdb "run X"
|
||||||
|
+set i 0
|
||||||
|
+# It crashes using `set width 7' on `set total 3560'.
|
||||||
|
+# Sometimes it corrupts screen on `set width 7'.
|
||||||
|
+# Bugreport used `set total 130001':
|
||||||
|
+# https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=214196
|
||||||
|
+# Check also `timeout' above.
|
||||||
|
+set total 4200
|
||||||
|
+gdb_expect {
|
||||||
|
+ -re X {
|
||||||
|
+ incr i
|
||||||
|
+ if {$i <= $total} {
|
||||||
|
+ send_gdb "X"
|
||||||
|
+ exp_continue
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ -re "\[ \b\r\n\]" {
|
||||||
|
+ exp_continue
|
||||||
|
+ }
|
||||||
|
+ eof {
|
||||||
|
+ fail "gdb sending total $total characters"
|
||||||
|
+ note "Failed after sending $i characters, reason: EOF"
|
||||||
|
+ gdb_clear_suppressed
|
||||||
|
+ }
|
||||||
|
+ timeout {
|
||||||
|
+ fail "gdb sending total $total characters"
|
||||||
|
+ note "Failed after sending $i characters (timeout $timeout), reason: TIMEOUT"
|
||||||
|
+ gdb_clear_suppressed
|
||||||
|
+ }
|
||||||
|
+ default {
|
||||||
|
+ fail "gdb sending total $total characters"
|
||||||
|
+ note "Failed after sending $i characters, reason: 0=\[$expect_out(0,string)\] buffer=\[$expect_out(buffer)\]"
|
||||||
|
+ gdb_clear_suppressed
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+gdb_test "\r" \
|
||||||
|
+ "No executable file specified..*" \
|
||||||
|
+ "All the characters transferred"
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+# Restore globals modified in this test...
|
||||||
|
+if [info exists old_inputrc] {
|
||||||
|
+ set env(INPUTRC) $old_inputrc
|
||||||
|
+} else {
|
||||||
|
+ unset env(INPUTRC)
|
||||||
|
+}
|
||||||
|
+if [info exists old_gdbhistfile] {
|
||||||
|
+ set env(GDBHISTFILE) $old_gdbhistfile
|
||||||
|
+} else {
|
||||||
|
+ unset env(GDBHISTFILE)
|
||||||
|
+}
|
||||||
|
+if [info exists old_histsize] {
|
||||||
|
+ set env(HISTSIZE) $old_histsize
|
||||||
|
+} else {
|
||||||
|
+ unset env(HISTSIZE)
|
||||||
|
+}
|
||||||
|
+set timeout $oldtimeout1
|
||||||
|
+
|
||||||
|
+return 0
|
165
gdb-6.5-readline-long-line-crash.patch
Normal file
165
gdb-6.5-readline-long-line-crash.patch
Normal file
@ -0,0 +1,165 @@
|
|||||||
|
Fix Valgrind paste of >= 256 * (screen width) characters (as 130001).
|
||||||
|
|
||||||
|
Invalid write of size 4
|
||||||
|
at 0x8203BD9: rl_redisplay (display.c:812)
|
||||||
|
by 0x81F5130: _rl_internal_char_cleanup (readline.c:427)
|
||||||
|
by 0x81F52B3: readline_internal_char (readline.c:508)
|
||||||
|
by 0x8209817: rl_callback_read_char (callback.c:184)
|
||||||
|
by 0x8135312: rl_callback_read_char_wrapper (event-top.c:179)
|
||||||
|
by 0x8135B7B: stdin_event_handler (event-top.c:432)
|
||||||
|
by 0x81349F2: handle_file_event (event-loop.c:730)
|
||||||
|
by 0x81342AB: process_event (event-loop.c:343)
|
||||||
|
by 0x81342F4: gdb_do_one_event (event-loop.c:380)
|
||||||
|
by 0x81313AC: catch_errors (exceptions.c:515)
|
||||||
|
by 0x80CE8CA: tui_command_loop (tui-interp.c:151)
|
||||||
|
by 0x81318B9: current_interp_command_loop (interps.c:278)
|
||||||
|
Address 0x43DCEB8 is 0 bytes after a block of size 1,024 alloc'd
|
||||||
|
at 0x4005400: malloc (vg_replace_malloc.c:149)
|
||||||
|
by 0x8087084: xmalloc (utils.c:959)
|
||||||
|
by 0x8202CA7: init_line_structures (display.c:440)
|
||||||
|
by 0x8202D14: rl_redisplay (display.c:471)
|
||||||
|
by 0x81F4F53: readline_internal_setup (readline.c:363)
|
||||||
|
by 0x820958C: _rl_callback_newline (callback.c:89)
|
||||||
|
by 0x82095BB: rl_callback_handler_install (callback.c:101)
|
||||||
|
by 0x80CE896: tui_command_loop (tui-interp.c:138)
|
||||||
|
by 0x81318B9: current_interp_command_loop (interps.c:278)
|
||||||
|
by 0x807E69A: captured_command_loop (main.c:101)
|
||||||
|
by 0x81313AC: catch_errors (exceptions.c:515)
|
||||||
|
by 0x807F55A: captured_main (main.c:826)
|
||||||
|
|
||||||
|
|
||||||
|
2006-11-08 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* readline/display.c (line_state, line_state_array, line_state_visible,
|
||||||
|
line_state_invisible): Encapsulate _rl_wrapped_line, inv_lbreaks,
|
||||||
|
inv_lbsize, vis_lbreaks, vis_lbsize, visible_line, invisible_line.
|
||||||
|
(init_line_structures): Initialize both _rl_wrapped_line ones now.
|
||||||
|
(rl_redisplay): Fix _rl_wrapped_line handling by using its own size.
|
||||||
|
Swap whole `line_state_visible' / `line_state_invisible' structures.
|
||||||
|
(update_line): Update for new `_rl_wrapped_line'.
|
||||||
|
|
||||||
|
|
||||||
|
Index: ./readline/display.c
|
||||||
|
===================================================================
|
||||||
|
--- ./readline/display.c 5 May 2006 18:26:12 -0000 1.11
|
||||||
|
+++ ./readline/display.c 8 Nov 2006 18:23:33 -0000
|
||||||
|
@@ -73,15 +73,31 @@ static void delete_chars PARAMS((int));
|
||||||
|
static void insert_some_chars PARAMS((char *, int, int));
|
||||||
|
static void cr PARAMS((void));
|
||||||
|
|
||||||
|
+struct line_state
|
||||||
|
+ {
|
||||||
|
+ char *line;
|
||||||
|
+ int *lbreaks;
|
||||||
|
+ int lbreaks_size;
|
||||||
|
+#if defined (HANDLE_MULTIBYTE)
|
||||||
|
+ int *wrapped_line;
|
||||||
|
+ int wrapped_line_size;
|
||||||
|
+#endif
|
||||||
|
+ };
|
||||||
|
+static struct line_state line_state_array[2];
|
||||||
|
+static struct line_state *line_state_visible = &line_state_array[0];
|
||||||
|
+static struct line_state *line_state_invisible = &line_state_array[1];
|
||||||
|
+
|
||||||
|
#if defined (HANDLE_MULTIBYTE)
|
||||||
|
static int _rl_col_width PARAMS((const char *, int, int));
|
||||||
|
-static int *_rl_wrapped_line;
|
||||||
|
#else
|
||||||
|
# define _rl_col_width(l, s, e) (((e) <= (s)) ? 0 : (e) - (s))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
-static int *inv_lbreaks, *vis_lbreaks;
|
||||||
|
-static int inv_lbsize, vis_lbsize;
|
||||||
|
+/* FIXME: Backward compatible naming. */
|
||||||
|
+#define inv_lbreaks (line_state_invisible->lbreaks)
|
||||||
|
+#define inv_lbsize (line_state_invisible->lbreaks_size)
|
||||||
|
+#define vis_lbreaks (line_state_visible->lbreaks)
|
||||||
|
+#define vis_lbsize (line_state_visible->lbreaks_size)
|
||||||
|
|
||||||
|
/* Heuristic used to decide whether it is faster to move from CUR to NEW
|
||||||
|
by backing up or outputting a carriage return and moving forward. */
|
||||||
|
@@ -150,8 +166,9 @@ static int last_lmargin;
|
||||||
|
|
||||||
|
/* The line display buffers. One is the line currently displayed on
|
||||||
|
the screen. The other is the line about to be displayed. */
|
||||||
|
-static char *visible_line = (char *)NULL;
|
||||||
|
-static char *invisible_line = (char *)NULL;
|
||||||
|
+/* FIXME: Backward compatible naming. */
|
||||||
|
+#define visible_line (line_state_visible->line)
|
||||||
|
+#define invisible_line (line_state_invisible->line)
|
||||||
|
|
||||||
|
/* A buffer for `modeline' messages. */
|
||||||
|
static char msg_buf[128];
|
||||||
|
@@ -437,7 +454,10 @@ init_line_structures (minsize)
|
||||||
|
inv_lbreaks = (int *)xmalloc (inv_lbsize * sizeof (int));
|
||||||
|
vis_lbreaks = (int *)xmalloc (vis_lbsize * sizeof (int));
|
||||||
|
#if defined (HANDLE_MULTIBYTE)
|
||||||
|
- _rl_wrapped_line = (int *)xmalloc (vis_lbsize * sizeof (int));
|
||||||
|
+ line_state_visible->wrapped_line_size = vis_lbsize;
|
||||||
|
+ line_state_visible->wrapped_line = (int *)xmalloc (line_state_visible->wrapped_line_size * sizeof (int));
|
||||||
|
+ line_state_invisible->wrapped_line_size = inv_lbsize;
|
||||||
|
+ line_state_invisible->wrapped_line = (int *)xmalloc (line_state_invisible->wrapped_line_size * sizeof (int));
|
||||||
|
#endif
|
||||||
|
inv_lbreaks[0] = vis_lbreaks[0] = 0;
|
||||||
|
}
|
||||||
|
@@ -572,10 +592,15 @@ rl_redisplay ()
|
||||||
|
{ \
|
||||||
|
inv_lbsize *= 2; \
|
||||||
|
inv_lbreaks = (int *)xrealloc (inv_lbreaks, inv_lbsize * sizeof (int)); \
|
||||||
|
- _rl_wrapped_line = (int *)xrealloc (_rl_wrapped_line, inv_lbsize * sizeof (int)); \
|
||||||
|
} \
|
||||||
|
inv_lbreaks[++newlines] = out; \
|
||||||
|
- _rl_wrapped_line[newlines] = _rl_wrapped_multicolumn; \
|
||||||
|
+ if (newlines >= (line_state_invisible->wrapped_line_size - 1)) \
|
||||||
|
+ { \
|
||||||
|
+ line_state_invisible->wrapped_line_size *= 2; \
|
||||||
|
+ line_state_invisible->wrapped_line = (int *)xrealloc (line_state_invisible->wrapped_line, \
|
||||||
|
+ line_state_invisible->wrapped_line_size * sizeof (int)); \
|
||||||
|
+ } \
|
||||||
|
+ line_state_invisible->wrapped_line[newlines] = _rl_wrapped_multicolumn; \
|
||||||
|
lpos = 0; \
|
||||||
|
} \
|
||||||
|
} while (0)
|
||||||
|
@@ -605,7 +630,7 @@ rl_redisplay ()
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (HANDLE_MULTIBYTE)
|
||||||
|
- memset (_rl_wrapped_line, 0, vis_lbsize);
|
||||||
|
+ memset (line_state_invisible->wrapped_line, 0, line_state_invisible->wrapped_line_size * sizeof (int));
|
||||||
|
num = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@@ -1118,17 +1143,10 @@ rl_redisplay ()
|
||||||
|
|
||||||
|
/* Swap visible and non-visible lines. */
|
||||||
|
{
|
||||||
|
- char *vtemp = visible_line;
|
||||||
|
- int *itemp = vis_lbreaks, ntemp = vis_lbsize;
|
||||||
|
-
|
||||||
|
- visible_line = invisible_line;
|
||||||
|
- invisible_line = vtemp;
|
||||||
|
-
|
||||||
|
- vis_lbreaks = inv_lbreaks;
|
||||||
|
- inv_lbreaks = itemp;
|
||||||
|
-
|
||||||
|
- vis_lbsize = inv_lbsize;
|
||||||
|
- inv_lbsize = ntemp;
|
||||||
|
+ struct line_state *line_state_temp = line_state_visible;
|
||||||
|
+
|
||||||
|
+ line_state_visible = line_state_invisible;
|
||||||
|
+ line_state_invisible = line_state_temp;
|
||||||
|
|
||||||
|
rl_display_fixed = 0;
|
||||||
|
/* If we are displaying on a single line, and last_lmargin is > 0, we
|
||||||
|
@@ -1194,8 +1212,9 @@ update_line (old, new, current_line, oma
|
||||||
|
/* This fixes only double-column characters, but if the wrapped
|
||||||
|
character comsumes more than three columns, spaces will be
|
||||||
|
inserted in the string buffer. */
|
||||||
|
- if (_rl_wrapped_line[current_line] > 0)
|
||||||
|
- _rl_clear_to_eol (_rl_wrapped_line[current_line]);
|
||||||
|
+ if (current_line < line_state_visible->wrapped_line_size
|
||||||
|
+ && line_state_visible->wrapped_line[current_line] > 0)
|
||||||
|
+ _rl_clear_to_eol (line_state_visible->wrapped_line[current_line]);
|
||||||
|
|
||||||
|
memset (&ps, 0, sizeof (mbstate_t));
|
||||||
|
ret = mbrtowc (&wc, new, MB_CUR_MAX, &ps);
|
111
gdb-6.5-section-num-fixup-test.patch
Normal file
111
gdb-6.5-section-num-fixup-test.patch
Normal file
@ -0,0 +1,111 @@
|
|||||||
|
diff -up -ruNp gdb-6.5-orig/gdb/testsuite/gdb.base/datalib-lib.c gdb-6.5/gdb/testsuite/gdb.base/datalib-lib.c
|
||||||
|
--- gdb-6.5-orig/gdb/testsuite/gdb.base/datalib-lib.c 1969-12-31 19:00:00.000000000 -0500
|
||||||
|
+++ gdb-6.5/gdb/testsuite/gdb.base/datalib-lib.c 2008-05-29 13:51:50.000000000 -0400
|
||||||
|
@@ -0,0 +1,22 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2008 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 */
|
||||||
|
+
|
||||||
|
+int var;
|
||||||
|
diff -up -ruNp gdb-6.5-orig/gdb/testsuite/gdb.base/datalib-main.c gdb-6.5/gdb/testsuite/gdb.base/datalib-main.c
|
||||||
|
--- gdb-6.5-orig/gdb/testsuite/gdb.base/datalib-main.c 1969-12-31 19:00:00.000000000 -0500
|
||||||
|
+++ gdb-6.5/gdb/testsuite/gdb.base/datalib-main.c 2008-05-29 13:51:39.000000000 -0400
|
||||||
|
@@ -0,0 +1,26 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2008 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 */
|
||||||
|
+
|
||||||
|
+int
|
||||||
|
+main (void)
|
||||||
|
+{
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
diff -up -ruNp gdb-6.5-orig/gdb/testsuite/gdb.base/datalib.exp gdb-6.5/gdb/testsuite/gdb.base/datalib.exp
|
||||||
|
--- gdb-6.5-orig/gdb/testsuite/gdb.base/datalib.exp 1969-12-31 19:00:00.000000000 -0500
|
||||||
|
+++ gdb-6.5/gdb/testsuite/gdb.base/datalib.exp 2008-05-29 14:58:33.000000000 -0400
|
||||||
|
@@ -0,0 +1,51 @@
|
||||||
|
+# Copyright 2008 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.
|
||||||
|
+
|
||||||
|
+set testfile datalib
|
||||||
|
+set srcfilemain ${testfile}-main.c
|
||||||
|
+set srcfilelib ${testfile}-lib.c
|
||||||
|
+set libfile ${objdir}/${subdir}/${testfile}-lib.so
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}-main
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfilelib}" "${libfile}" executable [list debug {additional_flags=-shared -nostdlib}]] != "" } {
|
||||||
|
+ untested "Couldn't compile test program"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfilemain}" "${binfile} ${libfile}" executable {debug}] != "" } {
|
||||||
|
+ untested "Couldn't compile test program"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Get things started.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+# We must use a separate library as the main executable is compiled to the
|
||||||
|
+# address 0 by default and it would get fixed up already at the end of
|
||||||
|
+# INIT_OBJFILE_SECT_INDICES. We also cannot PRELINK it as PRELINK is missing
|
||||||
|
+# on ia64. The library must be NOSTDLIB as otherwise some stub code would
|
||||||
|
+# create the `.text' section there. Also DEBUG option is useful as some of
|
||||||
|
+# the crashes occur in dwarf2read.c.
|
||||||
|
+
|
||||||
|
+# FAIL case:
|
||||||
|
+# ../../gdb/ia64-tdep.c:2838: internal-error: sect_index_text not initialized
|
||||||
|
+# A problem internal to GDB has been detected,
|
||||||
|
+
|
||||||
|
+gdb_test "start" \
|
||||||
|
+ "main \\(\\) at .*${srcfilemain}.*" \
|
||||||
|
+ "start"
|
171
gdb-6.5-sharedlibrary-path.patch
Normal file
171
gdb-6.5-sharedlibrary-path.patch
Normal file
@ -0,0 +1,171 @@
|
|||||||
|
If you provided some relative path to the shared library, such as with
|
||||||
|
export LD_LIBRARY_PATH=.
|
||||||
|
then gdb would fail to match the shared library name during the TLS lookup.
|
||||||
|
|
||||||
|
|
||||||
|
Dropped the workaround/fix for gdb-6.8.50.20081128 - is it still needed?
|
||||||
|
|
||||||
|
|
||||||
|
The testsuite needs `gdb-6.3-bz146810-solib_absolute_prefix_is_empty.patch'.
|
||||||
|
The testsuite needs `gdb-6.5-tls-of-separate-debuginfo.patch'.
|
||||||
|
|
||||||
|
|
||||||
|
2006-09-01 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* solib-svr4.c (svr4_fetch_objfile_link_map): Match even absolute
|
||||||
|
requested pathnames to the internal loaded relative pathnames.
|
||||||
|
|
||||||
|
2007-10-16 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7.
|
||||||
|
|
||||||
|
2008-02-27 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to gdb-6.7.50.20080227.
|
||||||
|
|
||||||
|
Index: gdb-6.7.50.20080227/gdb/testsuite/gdb.threads/tls-sepdebug-main.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.7.50.20080227/gdb/testsuite/gdb.threads/tls-sepdebug-main.c 2008-02-27 09:00:15.000000000 +0100
|
||||||
|
@@ -0,0 +1,25 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2006 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 */
|
||||||
|
+
|
||||||
|
+int main()
|
||||||
|
+{
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
Index: gdb-6.7.50.20080227/gdb/testsuite/gdb.threads/tls-sepdebug-shared.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.7.50.20080227/gdb/testsuite/gdb.threads/tls-sepdebug-shared.c 2008-02-27 09:00:15.000000000 +0100
|
||||||
|
@@ -0,0 +1,22 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2006 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 */
|
||||||
|
+
|
||||||
|
+__thread int var = 42;
|
||||||
|
--- /dev/null 2009-02-10 00:19:00.494289687 +0100
|
||||||
|
+++ gdb-6.8.50.20090209-x/gdb/testsuite/gdb.threads/tls-sepdebug.exp 2009-02-10 00:49:38.000000000 +0100
|
||||||
|
@@ -0,0 +1,86 @@
|
||||||
|
+# Copyright 2006 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.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile tls-sepdebug
|
||||||
|
+set srcmainfile ${testfile}-main.c
|
||||||
|
+set srcsharedfile ${testfile}-shared.c
|
||||||
|
+
|
||||||
|
+set binmainfile ${objdir}/${subdir}/${testfile}-main
|
||||||
|
+set binsharedbase ${testfile}-shared.so
|
||||||
|
+set binsharedfile ${objdir}/${subdir}/${binsharedbase}
|
||||||
|
+set binshareddebugfile ${objdir}/${subdir}/${binsharedbase}.debug
|
||||||
|
+
|
||||||
|
+# Use explicit -soname as otherwise the full path to the library would get
|
||||||
|
+# encoded into ${binmainfile} making LD_LIBRARY_PATH tests useless.
|
||||||
|
+
|
||||||
|
+# FIXME: gcc dependency (-Wl,-soname).
|
||||||
|
+
|
||||||
|
+if { [gdb_compile_shlib "${srcdir}/${subdir}/${srcsharedfile}" "${binsharedfile}" [list debug additional_flags=-Wl,-soname=${binsharedbase}]] != "" } {
|
||||||
|
+ untested "Couldn't compile test library"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# eu-strip(1) works fine but it is a part of `elfutils', not `binutils'.
|
||||||
|
+if 0 then {
|
||||||
|
+ remote_exec build "eu-strip -f ${binshareddebugfile} ${binsharedfile}"
|
||||||
|
+} else {
|
||||||
|
+ remote_exec build "objcopy --only-keep-debug ${binsharedfile} ${binshareddebugfile}"
|
||||||
|
+ remote_exec build "objcopy --strip-debug ${binsharedfile}"
|
||||||
|
+ remote_exec build "objcopy --add-gnu-debuglink=${binshareddebugfile} ${binsharedfile}"
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Do not use `shlib=' as it will automatically add also -rpath for gcc.
|
||||||
|
+
|
||||||
|
+if { [gdb_compile_pthreads "${srcdir}/${subdir}/${srcmainfile} ${binsharedfile}" "${binmainfile}" executable {debug}] != "" } {
|
||||||
|
+ untested "Couldn't compile test program"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Get things started.
|
||||||
|
+
|
||||||
|
+# Test also the proper resolving of relative library names to absolute ones.
|
||||||
|
+# \$PWD is easy - it is the absolute way
|
||||||
|
+# ${subdir} would fail on "print var"
|
||||||
|
+
|
||||||
|
+foreach ld_library_path [list [pwd]/${subdir} ./${subdir}] name { absolute relative } {
|
||||||
|
+
|
||||||
|
+ gdb_exit
|
||||||
|
+ gdb_start
|
||||||
|
+ ###gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+
|
||||||
|
+ gdb_test "set env LD_LIBRARY_PATH=$ld_library_path" \
|
||||||
|
+ "" \
|
||||||
|
+ "set env LD_LIBRARY_PATH is $name"
|
||||||
|
+
|
||||||
|
+ gdb_load ${binmainfile}
|
||||||
|
+
|
||||||
|
+ # For C programs, "start" should stop in main().
|
||||||
|
+
|
||||||
|
+ gdb_test "start" \
|
||||||
|
+ "main \\(\\) at .*${srcmainfile}.*" \
|
||||||
|
+ "start"
|
||||||
|
+
|
||||||
|
+ # Check for: Cannot find shared library `/usr/lib/debug/lib/libc-2.4.90.so.debug' in dynamic linker's load module list
|
||||||
|
+ # as happens with TLS variables and `separate_debug_objfile_backlink'.
|
||||||
|
+
|
||||||
|
+ gdb_test "print var" \
|
||||||
|
+ "\\\$1 = \[0-9\].*" \
|
||||||
|
+ "print TLS variable from a shared library with $name-directory separate debug info file"
|
||||||
|
+}
|
24
gdb-6.5-tls-of-separate-debuginfo.patch
Normal file
24
gdb-6.5-tls-of-separate-debuginfo.patch
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
Dependency on: gdb-6.5-bz185337-resolve-tls-without-debuginfo-v2.patch
|
||||||
|
|
||||||
|
|
||||||
|
2006-09-01 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* target.c (target_translate_tls_address): Fix for separate debuginfo.
|
||||||
|
|
||||||
|
|
||||||
|
diff -rup gdb-6.5.orig/gdb/target.c gdb-6.5/gdb/target.c
|
||||||
|
--- gdb-6.5.orig/gdb/target.c 2006-09-20 17:13:35.000000000 -0400
|
||||||
|
+++ gdb-6.5/gdb/target.c 2006-09-20 17:15:53.000000000 -0400
|
||||||
|
@@ -769,6 +769,12 @@ target_translate_tls_address (struct obj
|
||||||
|
ptid_t ptid = inferior_ptid;
|
||||||
|
volatile struct gdb_exception ex;
|
||||||
|
|
||||||
|
+ /* Resolve: Cannot find shared library
|
||||||
|
+ `/usr/lib/debug/lib/lib....so.debug' in dynamic linker's load
|
||||||
|
+ module list */
|
||||||
|
+ if (objfile->separate_debug_objfile_backlink != NULL)
|
||||||
|
+ objfile = objfile->separate_debug_objfile_backlink;
|
||||||
|
+
|
||||||
|
TRY_CATCH (ex, RETURN_MASK_ALL)
|
||||||
|
{
|
||||||
|
CORE_ADDR lm_addr;
|
1671
gdb-6.6-buildid-locate-rpm.patch
Normal file
1671
gdb-6.6-buildid-locate-rpm.patch
Normal file
File diff suppressed because it is too large
Load Diff
1006
gdb-6.6-buildid-locate.patch
Normal file
1006
gdb-6.6-buildid-locate.patch
Normal file
File diff suppressed because it is too large
Load Diff
33
gdb-6.6-bz225783-gdb-debuginfo-paths.patch
Normal file
33
gdb-6.6-bz225783-gdb-debuginfo-paths.patch
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=225783
|
||||||
|
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/Makefile.in
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/Makefile.in 2008-12-02 23:06:16.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/Makefile.in 2008-12-02 23:28:02.000000000 +0100
|
||||||
|
@@ -1490,8 +1490,10 @@ po/$(PACKAGE).pot: force
|
||||||
|
|
||||||
|
.SUFFIXES: .y .l
|
||||||
|
.y.c:
|
||||||
|
- $(SHELL) $(YLWRAP) $< y.tab.c $@.tmp -- $(YACC) $(YFLAGS)
|
||||||
|
- -sed -e '/extern.*malloc/d' \
|
||||||
|
+ rm -f $@ $@.tmp
|
||||||
|
+ $(SHELL) $(YLWRAP) $< y.tab.c $@ -- $(YACC) $(YFLAGS) && mv $@ $@.tmp \
|
||||||
|
+ || (rm -f $@; false)
|
||||||
|
+ sed -e '/extern.*malloc/d' \
|
||||||
|
-e '/extern.*realloc/d' \
|
||||||
|
-e '/extern.*free/d' \
|
||||||
|
-e '/include.*malloc.h/d' \
|
||||||
|
@@ -1500,9 +1502,9 @@ po/$(PACKAGE).pot: force
|
||||||
|
-e 's/\([ \t;,(]\)free\([ \t]*[&(),]\)/\1xfree\2/g' \
|
||||||
|
-e 's/\([ \t;,(]\)free$$/\1xfree/g' \
|
||||||
|
-e '/^#line.*y.tab.c/d' \
|
||||||
|
- < $@.tmp > $@.new
|
||||||
|
- -rm $@.tmp
|
||||||
|
- mv $@.new ./$*.c
|
||||||
|
+ -e "s/^\(#line.*\)`basename $<`/\1`echo $<|sed 's/\//\\\\\//g'`/" \
|
||||||
|
+ < $@.tmp > $@
|
||||||
|
+ rm -f $@.tmp
|
||||||
|
.l.c:
|
||||||
|
if [ "$(FLEX)" ] && $(FLEX) --version >/dev/null 2>&1; then \
|
||||||
|
$(FLEX) -o$@ $< && \
|
27
gdb-6.6-bz225783-prelink-path.patch
Normal file
27
gdb-6.6-bz225783-prelink-path.patch
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=225783
|
||||||
|
|
||||||
|
--- gdb-6.8/gdb/testsuite/gdb.base/prelink.exp.orig 2008-07-12 08:56:43.000000000 +0200
|
||||||
|
+++ gdb-6.8/gdb/testsuite/gdb.base/prelink.exp 2008-07-12 08:59:59.000000000 +0200
|
||||||
|
@@ -55,7 +55,7 @@ if { [gdb_compile "${srcdir}/${subdir}/$
|
||||||
|
# single new unprelinked library address without wasting the first one/two
|
||||||
|
# memory areas. We do not care of the efficiency of loading such resulting
|
||||||
|
# exec-shield unfriendly prelinked library.
|
||||||
|
-if {[catch "system \"prelink -qNR --no-exec-shield ${libfile}\""] != 0} {
|
||||||
|
+if {[catch "system \"/usr/sbin/prelink -qNR --no-exec-shield ${libfile}\""] != 0} {
|
||||||
|
# Maybe we don't have prelink.
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
@@ -96,11 +96,11 @@ if { $found == 0 } {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
-if {[catch "system \"prelink -uN ${libfile}\""] != 0} {
|
||||||
|
+if {[catch "system \"/usr/sbin/prelink -uN ${libfile}\""] != 0} {
|
||||||
|
untested "${testfile}.so was not prelinked, maybe system libraries are not prelinked?"
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
-catch "system \"prelink -qNR --no-exec-shield ${libfile}\""
|
||||||
|
+catch "system \"/usr/sbin/prelink -qNR --no-exec-shield ${libfile}\""
|
||||||
|
|
||||||
|
# Start with a fresh gdb
|
||||||
|
|
191
gdb-6.6-bz229517-gcore-without-terminal.patch
Normal file
191
gdb-6.6-bz229517-gcore-without-terminal.patch
Normal file
@ -0,0 +1,191 @@
|
|||||||
|
2007-04-22 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb_gcore.sh: Redirect GDB from `</dev/null'.
|
||||||
|
|
||||||
|
2007-04-22 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.base/gcorebg.exp, gdb.base/gcorebg.c: New files.
|
||||||
|
|
||||||
|
|
||||||
|
--- gdb-6.6-orig/gdb/gdb_gcore.sh 2005-12-17 17:33:59.000000000 -0500
|
||||||
|
+++ gdb-6.6/gdb/gdb_gcore.sh 2007-04-22 05:42:50.000000000 -0400
|
||||||
|
@@ -71,7 +71,9 @@
|
||||||
|
quit
|
||||||
|
EOF
|
||||||
|
|
||||||
|
- gdb -x $tmpfile -batch
|
||||||
|
+ # `</dev/null' to avoid touching interactive terminal if it is
|
||||||
|
+ # available but not accessible (SIGTTIN risk)
|
||||||
|
+ gdb -x $tmpfile -batch </dev/null
|
||||||
|
|
||||||
|
if [ -r $name.$pid ] ; then
|
||||||
|
rc=0
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.base/gcorebg.c 25 Feb 2007 12:21:20 -0000
|
||||||
|
@@ -0,0 +1,43 @@
|
||||||
|
+#include <stdio.h>
|
||||||
|
+#include <sys/types.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+#include <signal.h>
|
||||||
|
+
|
||||||
|
+int main (int argc, char **argv)
|
||||||
|
+{
|
||||||
|
+ pid_t pid = 0;
|
||||||
|
+ pid_t ppid;
|
||||||
|
+ char buf[256];
|
||||||
|
+
|
||||||
|
+ if (argc != 4)
|
||||||
|
+ {
|
||||||
|
+ fprintf (stderr, "Syntax: %s {standard|detached} <gcore command> <core output file>\n",
|
||||||
|
+ argv[0]);
|
||||||
|
+ exit (1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ pid = fork ();
|
||||||
|
+
|
||||||
|
+ switch (pid)
|
||||||
|
+ {
|
||||||
|
+ case 0:
|
||||||
|
+ if (strcmp (argv[1], "detached") == 0)
|
||||||
|
+ setpgrp ();
|
||||||
|
+ ppid = getppid ();
|
||||||
|
+ sprintf (buf, "sh %s -o %s %d", argv[2], argv[3], (int) ppid);
|
||||||
|
+ system (buf);
|
||||||
|
+ kill (ppid, SIGTERM);
|
||||||
|
+ break;
|
||||||
|
+
|
||||||
|
+ case -1:
|
||||||
|
+ perror ("fork err\n");
|
||||||
|
+ exit (1);
|
||||||
|
+ break;
|
||||||
|
+
|
||||||
|
+ default:
|
||||||
|
+ sleep (60);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.base/gcorebg.exp 25 Feb 2007 12:21:20 -0000
|
||||||
|
@@ -0,0 +1,120 @@
|
||||||
|
+# Copyright 2007 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
|
||||||
|
+
|
||||||
|
+# This file was written by Jan Kratochvil <jan.kratochvil@redhat.com>.
|
||||||
|
+# This is a test for `gdb_gcore.sh' functionality.
|
||||||
|
+# It also tests a regression with `gdb_gcore.sh' being run without its
|
||||||
|
+# accessible terminal.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+if ![info exists GCORE] {
|
||||||
|
+ set GCORE "${srcdir}/../gdb_gcore.sh"
|
||||||
|
+}
|
||||||
|
+verbose "using GCORE = $GCORE" 2
|
||||||
|
+
|
||||||
|
+set testfile "gcorebg"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+set corefile ${objdir}/${subdir}/${testfile}.test
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
+ untested gcorebg.exp
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Cleanup.
|
||||||
|
+
|
||||||
|
+proc core_clean {} {
|
||||||
|
+ global corefile
|
||||||
|
+
|
||||||
|
+ foreach file [glob -nocomplain [join [list $corefile *] ""]] {
|
||||||
|
+ verbose "Delete file $file" 1
|
||||||
|
+ remote_file target delete $file
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+core_clean
|
||||||
|
+remote_file target delete "./gdb"
|
||||||
|
+
|
||||||
|
+# Generate the core file.
|
||||||
|
+
|
||||||
|
+# Provide `./gdb' for `gdb_gcore.sh' running it as a bare `gdb' command.
|
||||||
|
+# Setup also `$PATH' appropriately.
|
||||||
|
+# If GDB was not found let `gdb_gcore.sh' to find the system GDB by `$PATH'.
|
||||||
|
+if {$GDB != "gdb"} {
|
||||||
|
+ file link ./gdb $GDB
|
||||||
|
+}
|
||||||
|
+global env
|
||||||
|
+set oldpath $env(PATH)
|
||||||
|
+set env(PATH) [join [list . $env(PATH)] ":"]
|
||||||
|
+verbose "PATH = $env(PATH)" 2
|
||||||
|
+
|
||||||
|
+# Test file body.
|
||||||
|
+# $detached == "standard" || $detached == "detached"
|
||||||
|
+
|
||||||
|
+proc test_body { detached } {
|
||||||
|
+ global binfile
|
||||||
|
+ global GCORE
|
||||||
|
+ global corefile
|
||||||
|
+
|
||||||
|
+ set res [remote_spawn target "$binfile $detached $GCORE $corefile"]
|
||||||
|
+ if { $res < 0 || $res == "" } {
|
||||||
|
+ fail "Spawning $detached gcore"
|
||||||
|
+ return 1
|
||||||
|
+ }
|
||||||
|
+ pass "Spawning $detached gcore"
|
||||||
|
+ remote_expect target 20 {
|
||||||
|
+ timeout {
|
||||||
|
+ fail "Spawned $detached gcore finished"
|
||||||
|
+ remote_exec target "kill -9 -[exp_pid -i $res]"
|
||||||
|
+ return 1
|
||||||
|
+ }
|
||||||
|
+ eof {
|
||||||
|
+ pass "Spawned $detached gcore finished"
|
||||||
|
+ remote_wait target 20
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if {1 == [llength [glob -nocomplain [join [list $corefile *] ""]]]} {
|
||||||
|
+ pass "Core file generated by $detached gcore"
|
||||||
|
+ } else {
|
||||||
|
+ fail "Core file generated by $detached gcore"
|
||||||
|
+ }
|
||||||
|
+ core_clean
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# First a general `gdb_gcore.sh' spawn with its controlling terminal available.
|
||||||
|
+
|
||||||
|
+test_body standard
|
||||||
|
+
|
||||||
|
+# And now `gdb_gcore.sh' spawn without its controlling terminal available.
|
||||||
|
+# It is spawned through `gcorebg.c' using setpgrp ().
|
||||||
|
+
|
||||||
|
+test_body detached
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+# Cleanup.
|
||||||
|
+
|
||||||
|
+set env(PATH) $oldpath
|
||||||
|
+remote_file target delete "./gdb"
|
83
gdb-6.6-bz230000-power6-disassembly-test.patch
Normal file
83
gdb-6.6-bz230000-power6-disassembly-test.patch
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=230000
|
||||||
|
|
||||||
|
The original testcase
|
||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=230000#c1
|
||||||
|
requires too recent GCC.
|
||||||
|
|
||||||
|
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.arch/powerpc-power6.exp 25 Feb 2007 18:27:39 -0000
|
||||||
|
@@ -0,0 +1,54 @@
|
||||||
|
+# Copyright 2007 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.
|
||||||
|
+
|
||||||
|
+# Test PowerPC Power6 instructions disassembly.
|
||||||
|
+
|
||||||
|
+if {![istarget "powerpc*-*-*"]} then {
|
||||||
|
+ verbose "Skipping PowerPC Power6 instructions disassembly."
|
||||||
|
+ return
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "powerpc-power6"
|
||||||
|
+set srcfile ${testfile}.s
|
||||||
|
+set objfile ${objdir}/${subdir}/${testfile}.o
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${objfile}" object {debug}] != "" } {
|
||||||
|
+ untested "PowerPC prologue tests"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${objfile}
|
||||||
|
+
|
||||||
|
+# Disassemble the function.
|
||||||
|
+
|
||||||
|
+gdb_test "disass func" ":\tblr\r\n.*" "Basic disassembly"
|
||||||
|
+
|
||||||
|
+gdb_test "disass func" ":\tdcbzl *r8,r9\r\n.*" "Power5 disassembly dcbzl"
|
||||||
|
+gdb_test "disass func" ":\tfrsqrtes *f10,f11\r\n.*" "Power5 disassembly frsqrtes"
|
||||||
|
+gdb_test "disass func" ":\tdadd *f1,f2,f1\r\n.*" "Power6 disassembly dadd"
|
||||||
|
+gdb_test "disass func" ":\tdaddq *f1,f2,f1\r\n.*" "Power6 disassembly daddq"
|
||||||
|
+gdb_test "disass func" ":\tdsub *f1,f2,f1\r\n.*" "Power6 disassembly dsub"
|
||||||
|
+gdb_test "disass func" ":\tdsubq *f1,f2,f1\r\n.*" "Power6 disassembly dsubq"
|
||||||
|
+gdb_test "disass func" ":\tdmul *f1,f2,f1\r\n.*" "Power6 disassembly dmul"
|
||||||
|
+gdb_test "disass func" ":\tdmulq *f1,f2,f1\r\n.*" "Power6 disassembly dmulq"
|
||||||
|
+gdb_test "disass func" ":\tddiv *f1,f2,f1\r\n.*" "Power6 disassembly ddiv"
|
||||||
|
+gdb_test "disass func" ":\tddivq *f1,f2,f1\r\n.*" "Power6 disassembly ddivq"
|
||||||
|
+gdb_test "disass func" ":\tdcmpu *cr1,f2,f1\r\n.*" "Power6 disassembly dcmpu"
|
||||||
|
+gdb_test "disass func" ":\tdcmpuq *cr1,f2,f1\r\n.*" "Power6 disassembly dcmpuq"
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.arch/powerpc-power6.s 25 Feb 2007 18:27:39 -0000
|
||||||
|
@@ -0,0 +1,16 @@
|
||||||
|
+ .text
|
||||||
|
+ .globl func
|
||||||
|
+func:
|
||||||
|
+ blr
|
||||||
|
+ .long 0x7c284fec /* dcbzl r8,r9 */
|
||||||
|
+ .long 0xed405834 /* frsqrtes f10,f11 */
|
||||||
|
+ .long 0xec220804 /* dadd f1,f2,f1 */
|
||||||
|
+ .long 0xfc220804 /* daddq f1,f2,f1 */
|
||||||
|
+ .long 0xec220c04 /* dsub f1,f2,f1 */
|
||||||
|
+ .long 0xfc220c04 /* dsubq f1,f2,f1 */
|
||||||
|
+ .long 0xec220844 /* dmul f1,f2,f1 */
|
||||||
|
+ .long 0xfc220844 /* dmulq f1,f2,f1 */
|
||||||
|
+ .long 0xec220c44 /* ddiv f1,f2,f1 */
|
||||||
|
+ .long 0xfc220c44 /* ddivq f1,f2,f1 */
|
||||||
|
+ .long 0xec820d04 /* dcmpu cr1,f2,f1 */
|
||||||
|
+ .long 0xfc820d04 /* dcmpuq cr1,f2,f1 */
|
128
gdb-6.6-bz235197-fork-detach-info.patch
Normal file
128
gdb-6.6-bz235197-fork-detach-info.patch
Normal file
@ -0,0 +1,128 @@
|
|||||||
|
2008-03-01 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.8pre.
|
||||||
|
Remove the `[' character from the GDB-6.8 default message.
|
||||||
|
|
||||||
|
Index: gdb-6.7.50.20080227/gdb/linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.7.50.20080227.orig/gdb/linux-nat.c 2008-03-01 10:30:48.000000000 +0100
|
||||||
|
+++ gdb-6.7.50.20080227/gdb/linux-nat.c 2008-03-01 10:48:25.000000000 +0100
|
||||||
|
@@ -415,7 +415,7 @@ linux_child_follow_fork (struct target_o
|
||||||
|
/* Detach new forked process? */
|
||||||
|
if (detach_fork)
|
||||||
|
{
|
||||||
|
- if (info_verbose || debug_linux_nat)
|
||||||
|
+ if (1 /* Fedora Bug 235197 */ || info_verbose || debug_linux_nat)
|
||||||
|
{
|
||||||
|
target_terminal_ours ();
|
||||||
|
fprintf_filtered (gdb_stdlog,
|
||||||
|
Index: gdb-6.7.50.20080227/gdb/testsuite/gdb.base/fork-detach.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.7.50.20080227/gdb/testsuite/gdb.base/fork-detach.c 2008-03-01 10:30:49.000000000 +0100
|
||||||
|
@@ -0,0 +1,57 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2007 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 */
|
||||||
|
+
|
||||||
|
+#include <sys/types.h>
|
||||||
|
+#include <sys/wait.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
+#include <assert.h>
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+
|
||||||
|
+static void func (void)
|
||||||
|
+{
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int main (void)
|
||||||
|
+{
|
||||||
|
+ pid_t child;
|
||||||
|
+
|
||||||
|
+ child = fork ();
|
||||||
|
+ switch (child)
|
||||||
|
+ {
|
||||||
|
+ case -1:
|
||||||
|
+ abort ();
|
||||||
|
+ case 0:
|
||||||
|
+ func ();
|
||||||
|
+ break;
|
||||||
|
+ default:
|
||||||
|
+ {
|
||||||
|
+/* We do not test the switching to the other fork by GDB `fork 1'. */
|
||||||
|
+#if 0
|
||||||
|
+ pid_t got;
|
||||||
|
+
|
||||||
|
+ got = waitpid (child, NULL, 0);
|
||||||
|
+ assert (got == child);
|
||||||
|
+#endif
|
||||||
|
+ break;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
Index: gdb-6.7.50.20080227/gdb/testsuite/gdb.base/fork-detach.exp
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.7.50.20080227/gdb/testsuite/gdb.base/fork-detach.exp 2008-03-01 10:49:36.000000000 +0100
|
||||||
|
@@ -0,0 +1,43 @@
|
||||||
|
+# Copyright 2007 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.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+set testfile fork-detach
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
+ untested "Couldn't compile test program"
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Get things started.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+gdb_run_cmd
|
||||||
|
+# `Starting program: .*' prefix is available since gdb-6.7.
|
||||||
|
+gdb_test "" \
|
||||||
|
+ "Detaching after fork from child process.*Program exited normally\\..*" \
|
||||||
|
+ "Info message caught"
|
270
gdb-6.6-bz237572-ppc-atomic-sequence-test.patch
Normal file
270
gdb-6.6-bz237572-ppc-atomic-sequence-test.patch
Normal file
@ -0,0 +1,270 @@
|
|||||||
|
2007-06-25 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.threads/atomic-seq-threaded.c,
|
||||||
|
gdb.threads/atomic-seq-threaded.exp: New files.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.threads/atomic-seq-threaded.c
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.threads/atomic-seq-threaded.c 2008-12-08 22:27:01.000000000 +0100
|
||||||
|
@@ -0,0 +1,171 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2007 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., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
+ MA 02110-1301, USA. */
|
||||||
|
+
|
||||||
|
+/* Test stepping over RISC atomic sequences.
|
||||||
|
+ This variant testcases the code for stepping another thread while skipping
|
||||||
|
+ over the atomic sequence in the former thread
|
||||||
|
+ (STEPPING_PAST_SINGLESTEP_BREAKPOINT).
|
||||||
|
+ Code comes from gcc/testsuite/gcc.dg/sync-2.c */
|
||||||
|
+
|
||||||
|
+/* { dg-options "-march=i486" { target { { i?86-*-* x86_64-*-* } && ilp32 } } } */
|
||||||
|
+/* { dg-options "-mcpu=v9" { target sparc*-*-* } } */
|
||||||
|
+
|
||||||
|
+/* Test functionality of the intrinsics for 'short' and 'char'. */
|
||||||
|
+
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+#include <string.h>
|
||||||
|
+#include <pthread.h>
|
||||||
|
+#include <assert.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
+
|
||||||
|
+#define LOOPS 2
|
||||||
|
+
|
||||||
|
+static int unused;
|
||||||
|
+
|
||||||
|
+static char AI[18];
|
||||||
|
+static char init_qi[18] = { 3,5,7,9,0,0,0,0,-1,0,0,0,0,0,-1,0,0,0 };
|
||||||
|
+static char test_qi[18] = { 3,5,7,9,1,4,22,-12,7,8,9,7,1,-12,7,8,9,7 };
|
||||||
|
+
|
||||||
|
+static void
|
||||||
|
+do_qi (void)
|
||||||
|
+{
|
||||||
|
+ if (__sync_fetch_and_add(AI+4, 1) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_add(AI+5, 4) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_add(AI+6, 22) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_sub(AI+7, 12) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_and(AI+8, 7) != (char)-1)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_or(AI+9, 8) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_xor(AI+10, 9) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_nand(AI+11, 7) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+
|
||||||
|
+ if (__sync_add_and_fetch(AI+12, 1) != 1)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_sub_and_fetch(AI+13, 12) != (char)-12)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_and_and_fetch(AI+14, 7) != 7)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_or_and_fetch(AI+15, 8) != 8)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_xor_and_fetch(AI+16, 9) != 9)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_nand_and_fetch(AI+17, 7) != 7)
|
||||||
|
+ abort ();
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static short AL[18];
|
||||||
|
+static short init_hi[18] = { 3,5,7,9,0,0,0,0,-1,0,0,0,0,0,-1,0,0,0 };
|
||||||
|
+static short test_hi[18] = { 3,5,7,9,1,4,22,-12,7,8,9,7,1,-12,7,8,9,7 };
|
||||||
|
+
|
||||||
|
+static void
|
||||||
|
+do_hi (void)
|
||||||
|
+{
|
||||||
|
+ if (__sync_fetch_and_add(AL+4, 1) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_add(AL+5, 4) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_add(AL+6, 22) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_sub(AL+7, 12) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_and(AL+8, 7) != -1)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_or(AL+9, 8) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_xor(AL+10, 9) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_fetch_and_nand(AL+11, 7) != 0)
|
||||||
|
+ abort ();
|
||||||
|
+
|
||||||
|
+ if (__sync_add_and_fetch(AL+12, 1) != 1)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_sub_and_fetch(AL+13, 12) != -12)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_and_and_fetch(AL+14, 7) != 7)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_or_and_fetch(AL+15, 8) != 8)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_xor_and_fetch(AL+16, 9) != 9)
|
||||||
|
+ abort ();
|
||||||
|
+ if (__sync_nand_and_fetch(AL+17, 7) != 7)
|
||||||
|
+ abort ();
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void *
|
||||||
|
+start1 (void *arg)
|
||||||
|
+{
|
||||||
|
+ unsigned loop;
|
||||||
|
+ sleep(1);
|
||||||
|
+
|
||||||
|
+ for (loop = 0; loop < LOOPS; loop++)
|
||||||
|
+ {
|
||||||
|
+ memcpy(AI, init_qi, sizeof(init_qi));
|
||||||
|
+
|
||||||
|
+ do_qi ();
|
||||||
|
+
|
||||||
|
+ if (memcmp (AI, test_qi, sizeof(test_qi)))
|
||||||
|
+ abort ();
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return arg; /* _delete1_ */
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void *
|
||||||
|
+start2 (void *arg)
|
||||||
|
+{
|
||||||
|
+ unsigned loop;
|
||||||
|
+
|
||||||
|
+ for (loop = 0; loop < LOOPS; loop++)
|
||||||
|
+ {
|
||||||
|
+ memcpy(AL, init_hi, sizeof(init_hi));
|
||||||
|
+
|
||||||
|
+ do_hi ();
|
||||||
|
+
|
||||||
|
+ if (memcmp (AL, test_hi, sizeof(test_hi)))
|
||||||
|
+ abort ();
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return arg; /* _delete2_ */
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int
|
||||||
|
+main (int argc, char **argv)
|
||||||
|
+{
|
||||||
|
+ pthread_t thread;
|
||||||
|
+ int i;
|
||||||
|
+
|
||||||
|
+ i = pthread_create (&thread, NULL, start1, NULL); /* _create_ */
|
||||||
|
+ assert (i == 0); /* _create_after_ */
|
||||||
|
+
|
||||||
|
+ sleep (1);
|
||||||
|
+
|
||||||
|
+ start2 (NULL);
|
||||||
|
+
|
||||||
|
+ i = pthread_join (thread, NULL); /* _delete_ */
|
||||||
|
+ assert (i == 0);
|
||||||
|
+
|
||||||
|
+ return 0; /* _exit_ */
|
||||||
|
+}
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.threads/atomic-seq-threaded.exp
|
||||||
|
===================================================================
|
||||||
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.threads/atomic-seq-threaded.exp 2008-12-08 22:31:01.000000000 +0100
|
||||||
|
@@ -0,0 +1,84 @@
|
||||||
|
+# atomic-seq-threaded.exp -- Test case for stepping over RISC atomic code seqs.
|
||||||
|
+# This variant testcases the code for stepping another thread while skipping
|
||||||
|
+# over the atomic sequence in the former thread
|
||||||
|
+# (STEPPING_PAST_SINGLESTEP_BREAKPOINT).
|
||||||
|
+# Copyright (C) 2007 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
|
||||||
|
+
|
||||||
|
+set testfile atomic-seq-threaded
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+foreach opts {{} {compiler=gcc4} {FAIL}} {
|
||||||
|
+ if {$opts eq "FAIL"} {
|
||||||
|
+ return -1
|
||||||
|
+ }
|
||||||
|
+ if {[gdb_compile_pthreads "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable [list debug $opts]] eq "" } {
|
||||||
|
+ break
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+if ![runto_main] then {
|
||||||
|
+ fail "Can't run to main"
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# pthread_create () will not pass even on x86_64 with software watchpoint.
|
||||||
|
+# Pass after pthread_create () without any watchpoint active.
|
||||||
|
+set line [gdb_get_line_number "_create_after_"]
|
||||||
|
+gdb_test "tbreak $line" \
|
||||||
|
+ "reakpoint (\[0-9\]+) at .*$srcfile, line $line\..*" \
|
||||||
|
+ "set breakpoint after pthread_create ()"
|
||||||
|
+gdb_test "c" \
|
||||||
|
+ ".*/\\* _create_after_ \\*/.*" \
|
||||||
|
+ "run till after pthread_create ()"
|
||||||
|
+
|
||||||
|
+# Without a watchpoint being software no single-stepping would be used.
|
||||||
|
+set test "Start (software) watchpoint"
|
||||||
|
+gdb_test_multiple "watch unused" $test {
|
||||||
|
+ -re "Watchpoint \[0-9\]+: unused.*$gdb_prompt $" {
|
||||||
|
+ pass $test
|
||||||
|
+ }
|
||||||
|
+ -re "Hardware watchpoint \[0-9\]+: unused.*$gdb_prompt $" {
|
||||||
|
+ # We do not test the goal but still the whole testcase should pass.
|
||||||
|
+ unsupported $test
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# More thorough testing of the scheduling logic.
|
||||||
|
+gdb_test "set scheduler-locking step" ""
|
||||||
|
+
|
||||||
|
+# Critical code path is stepped through at this point.
|
||||||
|
+set line [gdb_get_line_number "_exit_"]
|
||||||
|
+gdb_test "tbreak $line" \
|
||||||
|
+ "reakpoint \[0-9\]+ at .*$srcfile, line $line\..*" \
|
||||||
|
+ "set breakpoint at _exit_"
|
||||||
|
+gdb_test "c" \
|
||||||
|
+ ".*/\\* _exit_ \\*/.*" \
|
||||||
|
+ "run till _exit_"
|
||||||
|
+
|
||||||
|
+# Just a nonproblematic program exit.
|
||||||
|
+gdb_test "c" \
|
||||||
|
+ ".*Program exited normally\\..*" \
|
||||||
|
+ "run till program exit"
|
142
gdb-6.6-bz247354-leader-exit-fix.patch
Normal file
142
gdb-6.6-bz247354-leader-exit-fix.patch
Normal file
@ -0,0 +1,142 @@
|
|||||||
|
2007-07-08 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* linux-nat.c (linux_lwp_is_zombie): New function.
|
||||||
|
(wait_lwp): Fix lockup on exit of the thread group leader.
|
||||||
|
(linux_xfer_partial): Renamed to ...
|
||||||
|
(linux_xfer_partial_lwp): ... here.
|
||||||
|
(linux_xfer_partial): New function wrapping LINUX_XFER_PARTIAL_LWP.
|
||||||
|
|
||||||
|
2008-02-24 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.8pre.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081209/gdb/linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081209.orig/gdb/linux-nat.c 2008-12-10 01:27:34.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081209/gdb/linux-nat.c 2008-12-10 01:28:14.000000000 +0100
|
||||||
|
@@ -1981,6 +1981,31 @@ linux_handle_extended_wait (struct lwp_i
|
||||||
|
_("unknown ptrace event %d"), event);
|
||||||
|
}
|
||||||
|
|
||||||
|
+static int
|
||||||
|
+linux_lwp_is_zombie (long lwp)
|
||||||
|
+{
|
||||||
|
+ char buffer[MAXPATHLEN];
|
||||||
|
+ FILE *procfile;
|
||||||
|
+ int retval = 0;
|
||||||
|
+
|
||||||
|
+ sprintf (buffer, "/proc/%ld/status", lwp);
|
||||||
|
+ procfile = fopen (buffer, "r");
|
||||||
|
+ if (procfile == NULL)
|
||||||
|
+ {
|
||||||
|
+ warning (_("unable to open /proc file '%s'"), buffer);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+ while (fgets (buffer, sizeof (buffer), procfile) != NULL)
|
||||||
|
+ if (strcmp (buffer, "State:\tZ (zombie)\n") == 0)
|
||||||
|
+ {
|
||||||
|
+ retval = 1;
|
||||||
|
+ break;
|
||||||
|
+ }
|
||||||
|
+ fclose (procfile);
|
||||||
|
+
|
||||||
|
+ return retval;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
/* Wait for LP to stop. Returns the wait status, or 0 if the LWP has
|
||||||
|
exited. */
|
||||||
|
|
||||||
|
@@ -1988,16 +2013,31 @@ static int
|
||||||
|
wait_lwp (struct lwp_info *lp)
|
||||||
|
{
|
||||||
|
pid_t pid;
|
||||||
|
- int status;
|
||||||
|
+ int status = 0;
|
||||||
|
int thread_dead = 0;
|
||||||
|
|
||||||
|
gdb_assert (!lp->stopped);
|
||||||
|
gdb_assert (lp->status == 0);
|
||||||
|
|
||||||
|
- pid = my_waitpid (GET_LWP (lp->ptid), &status, 0);
|
||||||
|
- if (pid == -1 && errno == ECHILD)
|
||||||
|
+ /* Thread group leader may have exited but we would lock up by WAITPID as it
|
||||||
|
+ waits on all its threads; __WCLONE is not applicable for the leader.
|
||||||
|
+ The thread leader restrictions is only a performance optimization here.
|
||||||
|
+ LINUX_NAT_THREAD_ALIVE cannot be used here as it requires a STOPPED
|
||||||
|
+ process; it gets ESRCH both for the zombie and for running processes. */
|
||||||
|
+ if (is_lwp (lp->ptid) && GET_PID (lp->ptid) == GET_LWP (lp->ptid)
|
||||||
|
+ && linux_lwp_is_zombie (GET_LWP (lp->ptid)))
|
||||||
|
+ {
|
||||||
|
+ thread_dead = 1;
|
||||||
|
+ if (debug_linux_nat)
|
||||||
|
+ fprintf_unfiltered (gdb_stdlog, "WL: Threads leader %s vanished.\n",
|
||||||
|
+ target_pid_to_str (lp->ptid));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (!thread_dead)
|
||||||
|
{
|
||||||
|
- pid = my_waitpid (GET_LWP (lp->ptid), &status, __WCLONE);
|
||||||
|
+ pid = my_waitpid (GET_LWP (lp->ptid), &status, 0);
|
||||||
|
+ if (pid == -1 && errno == ECHILD)
|
||||||
|
+ pid = my_waitpid (GET_LWP (lp->ptid), &status, __WCLONE);
|
||||||
|
if (pid == -1 && errno == ECHILD)
|
||||||
|
{
|
||||||
|
/* The thread has previously exited. We need to delete it
|
||||||
|
@@ -4153,8 +4193,10 @@ linux_nat_xfer_osdata (struct target_ops
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
|
||||||
|
+/* Transfer from the specific LWP currently set by PID of INFERIOR_PTID. */
|
||||||
|
+
|
||||||
|
static LONGEST
|
||||||
|
-linux_xfer_partial (struct target_ops *ops, enum target_object object,
|
||||||
|
+linux_xfer_partial_lwp (struct target_ops *ops, enum target_object object,
|
||||||
|
const char *annex, gdb_byte *readbuf,
|
||||||
|
const gdb_byte *writebuf, ULONGEST offset, LONGEST len)
|
||||||
|
{
|
||||||
|
@@ -4201,6 +4243,45 @@ linux_xfer_partial (struct target_ops *o
|
||||||
|
offset, len);
|
||||||
|
}
|
||||||
|
|
||||||
|
+/* nptl_db expects being able to transfer memory just by specifying PID.
|
||||||
|
+ After the thread group leader exists the Linux kernel turns the task
|
||||||
|
+ into zombie no longer permitting accesses to its memory.
|
||||||
|
+ Transfer the memory from an arbitrary LWP_LIST entry in such case. */
|
||||||
|
+
|
||||||
|
+static LONGEST
|
||||||
|
+linux_xfer_partial (struct target_ops *ops, enum target_object object,
|
||||||
|
+ const char *annex, gdb_byte *readbuf,
|
||||||
|
+ const gdb_byte *writebuf, ULONGEST offset, LONGEST len)
|
||||||
|
+{
|
||||||
|
+ LONGEST xfer;
|
||||||
|
+ struct lwp_info *lp;
|
||||||
|
+ /* Not using SAVE_INFERIOR_PTID already here for better performance. */
|
||||||
|
+ struct cleanup *old_chain = NULL;
|
||||||
|
+ ptid_t inferior_ptid_orig = inferior_ptid;
|
||||||
|
+
|
||||||
|
+ errno = 0;
|
||||||
|
+ xfer = linux_xfer_partial_lwp (ops, object, annex, readbuf, writebuf,
|
||||||
|
+ offset, len);
|
||||||
|
+
|
||||||
|
+ for (lp = lwp_list; xfer == 0 && (errno == EACCES || errno == ESRCH)
|
||||||
|
+ && lp != NULL; lp = lp->next)
|
||||||
|
+ {
|
||||||
|
+ if (!is_lwp (lp->ptid) || ptid_equal (lp->ptid, inferior_ptid_orig))
|
||||||
|
+ continue;
|
||||||
|
+
|
||||||
|
+ if (old_chain == NULL)
|
||||||
|
+ old_chain = save_inferior_ptid ();
|
||||||
|
+ inferior_ptid = BUILD_LWP (GET_LWP (lp->ptid), GET_LWP (lp->ptid));
|
||||||
|
+ errno = 0;
|
||||||
|
+ xfer = linux_xfer_partial_lwp (ops, object, annex, readbuf, writebuf,
|
||||||
|
+ offset, len);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (old_chain != NULL)
|
||||||
|
+ do_cleanups (old_chain);
|
||||||
|
+ return xfer;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
/* Create a prototype generic GNU/Linux target. The client can override
|
||||||
|
it with local methods. */
|
||||||
|
|
121
gdb-6.6-bz247354-leader-exit-test.patch
Normal file
121
gdb-6.6-bz247354-leader-exit-test.patch
Normal file
@ -0,0 +1,121 @@
|
|||||||
|
2007-07-07 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.threads/leader-exit.c, gdb.threads/leader-exit.exp: New files.
|
||||||
|
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.threads/leader-exit.c 7 Jul 2007 15:21:57 -0000
|
||||||
|
@@ -0,0 +1,47 @@
|
||||||
|
+/* Clean exit of the thread group leader should not break GDB.
|
||||||
|
+
|
||||||
|
+ Copyright 2007 Free Software Foundation, Inc.
|
||||||
|
+
|
||||||
|
+ This file is part of GDB.
|
||||||
|
+
|
||||||
|
+ 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. */
|
||||||
|
+
|
||||||
|
+#include <pthread.h>
|
||||||
|
+#include <assert.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
+
|
||||||
|
+static void *start (void *arg)
|
||||||
|
+{
|
||||||
|
+ for (;;)
|
||||||
|
+ pause ();
|
||||||
|
+ /* NOTREACHED */
|
||||||
|
+ assert (0);
|
||||||
|
+ return arg;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int main (void)
|
||||||
|
+{
|
||||||
|
+ pthread_t thread;
|
||||||
|
+ int i;
|
||||||
|
+
|
||||||
|
+ i = pthread_create (&thread, NULL, start, NULL); /* create1 */
|
||||||
|
+ assert (i == 0);
|
||||||
|
+
|
||||||
|
+ pthread_exit (NULL);
|
||||||
|
+ /* NOTREACHED */
|
||||||
|
+ assert (0);
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.threads/leader-exit.exp 7 Jul 2007 15:21:57 -0000
|
||||||
|
@@ -0,0 +1,64 @@
|
||||||
|
+# Copyright (C) 2007 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.
|
||||||
|
+
|
||||||
|
+# Exit of the thread group leader should not break GDB.
|
||||||
|
+
|
||||||
|
+# This file was written by Jan Kratochvil <jan.kratochvil@redhat.com>.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "leader-exit"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+if {[gdb_compile_pthreads "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+gdb_run_cmd
|
||||||
|
+
|
||||||
|
+proc stop_process { description } {
|
||||||
|
+ global gdb_prompt
|
||||||
|
+
|
||||||
|
+ # For this to work we must be sure to consume the "Continuing."
|
||||||
|
+ # message first, or GDB's signal handler may not be in place.
|
||||||
|
+ after 1000 {send_gdb "\003"}
|
||||||
|
+ gdb_expect {
|
||||||
|
+ -re "Program received signal SIGINT.*$gdb_prompt $"
|
||||||
|
+ {
|
||||||
|
+ pass $description
|
||||||
|
+ }
|
||||||
|
+ timeout
|
||||||
|
+ {
|
||||||
|
+ fail "$description (timeout)"
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Prevent races.
|
||||||
|
+sleep 8
|
||||||
|
+
|
||||||
|
+stop_process "Threads could be stopped"
|
||||||
|
+
|
||||||
|
+gdb_test "info threads" \
|
||||||
|
+ "\\* 2 Thread \[^\r\n\]* in \[^\r\n\]*" \
|
||||||
|
+ "Single thread has been left"
|
216
gdb-6.6-gcore32-test.patch
Normal file
216
gdb-6.6-gcore32-test.patch
Normal file
@ -0,0 +1,216 @@
|
|||||||
|
Test GCORE on 32bit inferiors on 64bit platforms.
|
||||||
|
|
||||||
|
UNSUPPORTED results are valid for `-m64' on 32bit targets.
|
||||||
|
|
||||||
|
|
||||||
|
Index: gdb-6.8/gdb/testsuite/gdb.base/gcore.exp
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.orig/gdb/testsuite/gdb.base/gcore.exp 2008-01-01 23:53:19.000000000 +0100
|
||||||
|
+++ gdb-6.8/gdb/testsuite/gdb.base/gcore.exp 2008-07-14 10:28:05.000000000 +0200
|
||||||
|
@@ -30,9 +30,14 @@ set testfile "gcore"
|
||||||
|
set srcfile ${testfile}.c
|
||||||
|
set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
|
||||||
|
-if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
||||||
|
- untested gcore.exp
|
||||||
|
- return -1
|
||||||
|
+# `-static-libgcc' to avoid dependency on `libgcc.{i386,ppc}'.
|
||||||
|
+foreach additional_flags {{} {-m32 -static-libgcc} {-m64 -static-libgcc}} {
|
||||||
|
+
|
||||||
|
+set prefix "arch{$additional_flags}:"
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable [list debug additional_flags=$additional_flags]] != "" } {
|
||||||
|
+ unsupported "${prefix} gcore.exp"
|
||||||
|
+ continue
|
||||||
|
}
|
||||||
|
|
||||||
|
# Start with a fresh gdb.
|
||||||
|
@@ -47,23 +52,23 @@ send_gdb "help gcore\n"
|
||||||
|
gdb_expect {
|
||||||
|
-re "Undefined command: .gcore.*$gdb_prompt $" {
|
||||||
|
# gcore command not supported -- nothing to test here.
|
||||||
|
- unsupported "gdb does not support gcore on this target"
|
||||||
|
- return -1;
|
||||||
|
+ unsupported "${prefix} gdb does not support gcore on this target"
|
||||||
|
+ continue
|
||||||
|
}
|
||||||
|
-re "Save a core file .*$gdb_prompt $" {
|
||||||
|
- pass "help gcore"
|
||||||
|
+ pass "${prefix} help gcore"
|
||||||
|
}
|
||||||
|
-re ".*$gdb_prompt $" {
|
||||||
|
- fail "help gcore"
|
||||||
|
+ fail "${prefix} help gcore"
|
||||||
|
}
|
||||||
|
timeout {
|
||||||
|
- fail "help gcore (timeout)"
|
||||||
|
+ fail "${prefix} help gcore (timeout)"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if { ! [ runto_main ] } then {
|
||||||
|
- untested gcore.exp
|
||||||
|
- return -1
|
||||||
|
+ untested "${prefix} gcore.exp"
|
||||||
|
+ continue
|
||||||
|
}
|
||||||
|
|
||||||
|
proc capture_command_output { command prefix } {
|
||||||
|
@@ -77,7 +82,7 @@ proc capture_command_output { command pr
|
||||||
|
set output_string $expect_out(1,string)
|
||||||
|
}
|
||||||
|
default {
|
||||||
|
- fail "capture_command_output failed on $command."
|
||||||
|
+ fail "${prefix} capture_command_output failed on $command."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $output_string
|
||||||
|
@@ -109,22 +114,22 @@ set escapedfilename [string_to_regexp ${
|
||||||
|
|
||||||
|
set core_supported 0
|
||||||
|
gdb_test_multiple "gcore ${objdir}/${subdir}/gcore.test" \
|
||||||
|
- "save a corefile" \
|
||||||
|
+ "${prefix} save a corefile" \
|
||||||
|
{
|
||||||
|
-re "Saved corefile ${escapedfilename}\[\r\n\]+$gdb_prompt $" {
|
||||||
|
- pass "save a corefile"
|
||||||
|
+ pass "${prefix} save a corefile"
|
||||||
|
global core_supported
|
||||||
|
set core_supported 1
|
||||||
|
}
|
||||||
|
-re "Can't create a corefile\[\r\n\]+$gdb_prompt $" {
|
||||||
|
- unsupported "save a corefile"
|
||||||
|
+ unsupported "${prefix} save a corefile"
|
||||||
|
global core_supported
|
||||||
|
set core_supported 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if {!$core_supported} {
|
||||||
|
- return -1
|
||||||
|
+ continue
|
||||||
|
}
|
||||||
|
|
||||||
|
# Now restart gdb and load the corefile.
|
||||||
|
@@ -136,31 +141,31 @@ gdb_load ${binfile}
|
||||||
|
send_gdb "core ${objdir}/${subdir}/gcore.test\n"
|
||||||
|
gdb_expect {
|
||||||
|
-re ".* is not a core dump:.*$gdb_prompt $" {
|
||||||
|
- fail "re-load generated corefile (bad file format)"
|
||||||
|
+ fail "${prefix} re-load generated corefile (bad file format)"
|
||||||
|
# No use proceeding from here.
|
||||||
|
- return;
|
||||||
|
+ continue
|
||||||
|
}
|
||||||
|
-re ".*: No such file or directory.*$gdb_prompt $" {
|
||||||
|
- fail "re-load generated corefile (file not found)"
|
||||||
|
+ fail "${prefix} re-load generated corefile (file not found)"
|
||||||
|
# No use proceeding from here.
|
||||||
|
- return;
|
||||||
|
+ continue
|
||||||
|
}
|
||||||
|
-re ".*Couldn't find .* registers in core file.*$gdb_prompt $" {
|
||||||
|
- fail "re-load generated corefile (incomplete note section)"
|
||||||
|
+ fail "${prefix} re-load generated corefile (incomplete note section)"
|
||||||
|
}
|
||||||
|
-re "Core was generated by .*$gdb_prompt $" {
|
||||||
|
- pass "re-load generated corefile"
|
||||||
|
+ pass "${prefix} re-load generated corefile"
|
||||||
|
}
|
||||||
|
-re ".*$gdb_prompt $" {
|
||||||
|
- fail "re-load generated corefile"
|
||||||
|
+ fail "${prefix} re-load generated corefile"
|
||||||
|
}
|
||||||
|
timeout {
|
||||||
|
- fail "re-load generated corefile (timeout)"
|
||||||
|
+ fail "${prefix} re-load generated corefile (timeout)"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
send_gdb "where\n"
|
||||||
|
-gdb_expect_list "where in corefile" ".*$gdb_prompt $" {
|
||||||
|
+gdb_expect_list "${prefix} where in corefile" ".*$gdb_prompt $" {
|
||||||
|
".*\[\r\n\]+#0 .* terminal_func \\(\\) at "
|
||||||
|
".*\[\r\n\]+#1 .* array_func \\(\\) at "
|
||||||
|
".*\[\r\n\]+#2 .* factorial_func \\(value=1\\) at "
|
||||||
|
@@ -174,61 +179,64 @@ gdb_expect_list "where in corefile" ".*$
|
||||||
|
|
||||||
|
set post_corefile_regs [capture_command_output "info registers" ""]
|
||||||
|
if ![string compare $pre_corefile_regs $post_corefile_regs] then {
|
||||||
|
- pass "corefile restored general registers"
|
||||||
|
+ pass "${prefix} corefile restored general registers"
|
||||||
|
} else {
|
||||||
|
- fail "corefile restored general registers"
|
||||||
|
+ fail "${prefix} corefile restored general registers"
|
||||||
|
}
|
||||||
|
|
||||||
|
set post_corefile_allregs [capture_command_output "info all-reg" ""]
|
||||||
|
if ![string compare $pre_corefile_allregs $post_corefile_allregs] then {
|
||||||
|
- pass "corefile restored all registers"
|
||||||
|
+ pass "${prefix} corefile restored all registers"
|
||||||
|
} else {
|
||||||
|
- fail "corefile restored all registers"
|
||||||
|
+ fail "${prefix} corefile restored all registers"
|
||||||
|
}
|
||||||
|
|
||||||
|
set post_corefile_extern_array \
|
||||||
|
[capture_command_output "print extern_array" "$print_prefix"]
|
||||||
|
if ![string compare $pre_corefile_extern_array $post_corefile_extern_array] {
|
||||||
|
- pass "corefile restored extern array"
|
||||||
|
+ pass "${prefix} corefile restored extern array"
|
||||||
|
} else {
|
||||||
|
- fail "corefile restored extern array"
|
||||||
|
+ fail "${prefix} corefile restored extern array"
|
||||||
|
}
|
||||||
|
|
||||||
|
set post_corefile_static_array \
|
||||||
|
[capture_command_output "print static_array" "$print_prefix"]
|
||||||
|
if ![string compare $pre_corefile_static_array $post_corefile_static_array] {
|
||||||
|
- pass "corefile restored static array"
|
||||||
|
+ pass "${prefix} corefile restored static array"
|
||||||
|
} else {
|
||||||
|
- fail "corefile restored static array"
|
||||||
|
+ fail "${prefix} corefile restored static array"
|
||||||
|
}
|
||||||
|
|
||||||
|
set post_corefile_uninit_array \
|
||||||
|
[capture_command_output "print un_initialized_array" "$print_prefix"]
|
||||||
|
if ![string compare $pre_corefile_uninit_array $post_corefile_uninit_array] {
|
||||||
|
- pass "corefile restored un-initialized array"
|
||||||
|
+ pass "${prefix} corefile restored un-initialized array"
|
||||||
|
} else {
|
||||||
|
- fail "corefile restored un-initialized array"
|
||||||
|
+ fail "${prefix} corefile restored un-initialized array"
|
||||||
|
}
|
||||||
|
|
||||||
|
set post_corefile_heap_string \
|
||||||
|
[capture_command_output "print heap_string" "$print_prefix"]
|
||||||
|
if ![string compare $pre_corefile_heap_string $post_corefile_heap_string] {
|
||||||
|
- pass "corefile restored heap array"
|
||||||
|
+ pass "${prefix} corefile restored heap array"
|
||||||
|
} else {
|
||||||
|
- fail "corefile restored heap array"
|
||||||
|
+ fail "${prefix} corefile restored heap array"
|
||||||
|
}
|
||||||
|
|
||||||
|
set post_corefile_local_array \
|
||||||
|
[capture_command_output "print array_func::local_array" "$print_prefix"]
|
||||||
|
if ![string compare $pre_corefile_local_array $post_corefile_local_array] {
|
||||||
|
- pass "corefile restored stack array"
|
||||||
|
+ pass "${prefix} corefile restored stack array"
|
||||||
|
} else {
|
||||||
|
- fail "corefile restored stack array"
|
||||||
|
+ fail "${prefix} corefile restored stack array"
|
||||||
|
}
|
||||||
|
|
||||||
|
set post_corefile_backtrace [capture_command_output "backtrace" ""]
|
||||||
|
if ![string compare $pre_corefile_backtrace $post_corefile_backtrace] {
|
||||||
|
- pass "corefile restored backtrace"
|
||||||
|
+ pass "${prefix} corefile restored backtrace"
|
||||||
|
} else {
|
||||||
|
- fail "corefile restored backtrace"
|
||||||
|
+ fail "${prefix} corefile restored backtrace"
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# $additional_flags:
|
||||||
|
}
|
1337
gdb-6.6-multifork-debugreg.patch
Normal file
1337
gdb-6.6-multifork-debugreg.patch
Normal file
File diff suppressed because it is too large
Load Diff
116
gdb-6.6-readline-system.patch
Normal file
116
gdb-6.6-readline-system.patch
Normal file
@ -0,0 +1,116 @@
|
|||||||
|
2007-10-16 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7.
|
||||||
|
|
||||||
|
Index: gdb-6.7/gdb/doc/Makefile.in
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.7.orig/gdb/doc/Makefile.in 2007-07-26 12:34:00.000000000 +0200
|
||||||
|
+++ gdb-6.7/gdb/doc/Makefile.in 2007-10-16 16:31:08.000000000 +0200
|
||||||
|
@@ -109,9 +109,7 @@ DVIPS = dvips
|
||||||
|
GDB_DOC_SOURCE_INCLUDES = \
|
||||||
|
$(srcdir)/fdl.texi \
|
||||||
|
$(srcdir)/gpl.texi \
|
||||||
|
- $(srcdir)/agentexpr.texi \
|
||||||
|
- $(READLINE_DIR)/rluser.texi \
|
||||||
|
- $(READLINE_DIR)/inc-hist.texinfo
|
||||||
|
+ $(srcdir)/agentexpr.texi
|
||||||
|
GDB_DOC_BUILD_INCLUDES = \
|
||||||
|
gdb-cfg.texi \
|
||||||
|
GDBvn.texi
|
||||||
|
Index: gdb-6.7/gdb/doc/gdb.texinfo
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.7.orig/gdb/doc/gdb.texinfo 2007-10-16 16:19:19.000000000 +0200
|
||||||
|
+++ gdb-6.7/gdb/doc/gdb.texinfo 2007-10-16 16:32:10.000000000 +0200
|
||||||
|
@@ -158,8 +158,8 @@ software in general. We will miss him.
|
||||||
|
|
||||||
|
* GDB Bugs:: Reporting bugs in @value{GDBN}
|
||||||
|
|
||||||
|
-* Command Line Editing:: Command Line Editing
|
||||||
|
-* Using History Interactively:: Using History Interactively
|
||||||
|
+* Command Line Editing: (rluserman). Command Line Editing
|
||||||
|
+* Using History Interactively: (history). Using History Interactively
|
||||||
|
* Formatting Documentation:: How to format and print @value{GDBN} documentation
|
||||||
|
* Installing GDB:: Installing GDB
|
||||||
|
* Maintenance Commands:: Maintenance Commands
|
||||||
|
@@ -15533,7 +15533,7 @@ Disable command line editing.
|
||||||
|
Show whether command line editing is enabled.
|
||||||
|
@end table
|
||||||
|
|
||||||
|
-@xref{Command Line Editing}, for more details about the Readline
|
||||||
|
+@xref{Command Line Editing, , , rluserman, GNU Readline Library}, for more details about the Readline
|
||||||
|
interface. Users unfamiliar with @sc{gnu} Emacs or @code{vi} are
|
||||||
|
encouraged to read that chapter.
|
||||||
|
|
||||||
|
@@ -15548,7 +15548,8 @@ history facility.
|
||||||
|
|
||||||
|
@value{GDBN} uses the @sc{gnu} History library, a part of the Readline
|
||||||
|
package, to provide the history facility. @xref{Using History
|
||||||
|
-Interactively}, for the detailed description of the History library.
|
||||||
|
+Interactively, , , history, GNU History Library}, for the detailed description
|
||||||
|
+of the History library.
|
||||||
|
|
||||||
|
To issue a command to @value{GDBN} without affecting certain aspects of
|
||||||
|
the state which is seen by users, prefix it with @samp{server }
|
||||||
|
@@ -15600,7 +15601,7 @@ This defaults to the value of the enviro
|
||||||
|
@end table
|
||||||
|
|
||||||
|
History expansion assigns special meaning to the character @kbd{!}.
|
||||||
|
-@xref{Event Designators}, for more details.
|
||||||
|
+@xref{Event Designators, , , history, GNU History Library}, for more details.
|
||||||
|
|
||||||
|
@cindex history expansion, turn on/off
|
||||||
|
Since @kbd{!} is also the logical not operator in C, history expansion
|
||||||
|
@@ -16660,7 +16661,8 @@ Indicates the current program counter ad
|
||||||
|
@cindex TUI key bindings
|
||||||
|
|
||||||
|
The TUI installs several key bindings in the readline keymaps
|
||||||
|
-(@pxref{Command Line Editing}). The following key bindings
|
||||||
|
+(@pxref{Command Line Editing, , , rluserman, GNU Readline Library}).
|
||||||
|
+The following key bindings
|
||||||
|
are installed for both TUI mode and the @value{GDBN} standard mode.
|
||||||
|
|
||||||
|
@table @kbd
|
||||||
|
@@ -21937,15 +21939,6 @@ Such guesses are usually wrong. Even we
|
||||||
|
things without first using the debugger to find the facts.
|
||||||
|
@end itemize
|
||||||
|
|
||||||
|
-@c The readline documentation is distributed with the readline code
|
||||||
|
-@c and consists of the two following files:
|
||||||
|
-@c rluser.texinfo
|
||||||
|
-@c inc-hist.texinfo
|
||||||
|
-@c Use -I with makeinfo to point to the appropriate directory,
|
||||||
|
-@c environment var TEXINPUTS with TeX.
|
||||||
|
-@include rluser.texi
|
||||||
|
-@include inc-hist.texinfo
|
||||||
|
-
|
||||||
|
|
||||||
|
@node Formatting Documentation
|
||||||
|
@appendix Formatting Documentation
|
||||||
|
@@ -22115,9 +22108,6 @@ source for the @samp{-liberty} free soft
|
||||||
|
@item gdb-@value{GDBVN}/opcodes
|
||||||
|
source for the library of opcode tables and disassemblers
|
||||||
|
|
||||||
|
-@item gdb-@value{GDBVN}/readline
|
||||||
|
-source for the @sc{gnu} command-line interface
|
||||||
|
-
|
||||||
|
@item gdb-@value{GDBVN}/glob
|
||||||
|
source for the @sc{gnu} filename pattern-matching subroutine
|
||||||
|
|
||||||
|
@@ -22149,7 +22139,7 @@ where @var{host} is an identifier such a
|
||||||
|
correct value by examining your system.)
|
||||||
|
|
||||||
|
Running @samp{configure @var{host}} and then running @code{make} builds the
|
||||||
|
-@file{bfd}, @file{readline}, @file{mmalloc}, and @file{libiberty}
|
||||||
|
+@file{bfd}, @file{mmalloc}, and @file{libiberty}
|
||||||
|
libraries, then @code{gdb} itself. The configured source files, and the
|
||||||
|
binaries, are left in the corresponding source directories.
|
||||||
|
|
||||||
|
@@ -22175,7 +22165,7 @@ source tree, the @file{gdb-@var{version-
|
||||||
|
that subdirectory. That is usually not what you want. In particular,
|
||||||
|
if you run the first @file{configure} from the @file{gdb} subdirectory
|
||||||
|
of the @file{gdb-@var{version-number}} directory, you will omit the
|
||||||
|
-configuration of @file{bfd}, @file{readline}, and other sibling
|
||||||
|
+configuration of @file{bfd}, and other sibling
|
||||||
|
directories of the @file{gdb} subdirectory. This leads to build errors
|
||||||
|
about missing include files such as @file{bfd/bfd.h}.
|
||||||
|
|
41
gdb-6.6-scheduler_locking-step-is-default.patch
Normal file
41
gdb-6.6-scheduler_locking-step-is-default.patch
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
Index: gdb-6.8.50.20081128/gdb/infrun.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/infrun.c 2008-12-09 15:56:16.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/infrun.c 2008-12-09 15:56:59.000000000 +0100
|
||||||
|
@@ -931,7 +931,7 @@ static const char *scheduler_enums[] = {
|
||||||
|
schedlock_step,
|
||||||
|
NULL
|
||||||
|
};
|
||||||
|
-static const char *scheduler_mode = schedlock_off;
|
||||||
|
+static const char *scheduler_mode = schedlock_step;
|
||||||
|
static void
|
||||||
|
show_scheduler_mode (struct ui_file *file, int from_tty,
|
||||||
|
struct cmd_list_element *c, const char *value)
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.mi/mi-console.exp
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/testsuite/gdb.mi/mi-console.exp 2008-08-06 14:52:08.000000000 +0200
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.mi/mi-console.exp 2008-12-09 15:59:34.000000000 +0100
|
||||||
|
@@ -47,6 +47,9 @@ if { [gdb_compile "${srcdir}/${subdir}/
|
||||||
|
|
||||||
|
mi_run_to_main
|
||||||
|
|
||||||
|
+# thread-id=\"all\" vs. thread-id=\"1\" below:
|
||||||
|
+mi_gdb_test "210-gdb-set scheduler-locking off" "210\\^done" "set scheduler-locking off"
|
||||||
|
+
|
||||||
|
# Next over the hello() call which will produce lots of output
|
||||||
|
mi_gdb_test "220-exec-next" \
|
||||||
|
"220\\^running(\r\n\\*running,thread-id=\"all\")?" \
|
||||||
|
Index: gdb-6.8.50.20081128/gdb/testsuite/gdb.mi/mi2-console.exp
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081128.orig/gdb/testsuite/gdb.mi/mi2-console.exp 2008-08-06 14:52:08.000000000 +0200
|
||||||
|
+++ gdb-6.8.50.20081128/gdb/testsuite/gdb.mi/mi2-console.exp 2008-12-09 16:00:33.000000000 +0100
|
||||||
|
@@ -47,6 +47,9 @@ if { [gdb_compile "${srcdir}/${subdir}/
|
||||||
|
|
||||||
|
mi_run_to_main
|
||||||
|
|
||||||
|
+# thread-id=\"all\" vs. thread-id=\"1\" below:
|
||||||
|
+mi_gdb_test "210-gdb-set scheduler-locking off" "210\\^done" "set scheduler-locking off"
|
||||||
|
+
|
||||||
|
# Next over the hello() call which will produce lots of output
|
||||||
|
send_gdb "220-exec-next\n"
|
||||||
|
gdb_expect {
|
202
gdb-6.6-scheduler_locking-step-sw-watchpoints2.patch
Normal file
202
gdb-6.6-scheduler_locking-step-sw-watchpoints2.patch
Normal file
@ -0,0 +1,202 @@
|
|||||||
|
2007-06-25 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* inferior.h (enum resume_step): New definition.
|
||||||
|
(resume): Change STEP parameter type to ENUM RESUME_STEP.
|
||||||
|
* infrun.c (resume): Likewise. Extend debug printing of the STEP
|
||||||
|
parameter. Lock the scheduler only for intentional stepping.
|
||||||
|
(proceed): Replace the variable ONESTEP with tristate RESUME_STEP.
|
||||||
|
Set the third RESUME_STEP state according to BPSTAT_SHOULD_STEP.
|
||||||
|
(currently_stepping): Change the return type to ENUM RESUME_STEP.
|
||||||
|
Return RESUME_STEP_NEEDED if it is just due to BPSTAT_SHOULD_STEP.
|
||||||
|
* linux-nat.c (select_singlestep_lwp_callback): Do not focus on
|
||||||
|
the software watchpoint events.
|
||||||
|
* linux-nat.h (struct lwp_info): Redeclare STEP as ENUM RESUME_STEP.
|
||||||
|
|
||||||
|
2007-10-19 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* infrun.c (proceed): RESUME_STEP initialized for non-stepping.
|
||||||
|
RESUME_STEP set according to STEP only at the end of the function.
|
||||||
|
|
||||||
|
2008-02-24 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.8pre.
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081209/gdb/inferior.h
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081209.orig/gdb/inferior.h 2008-11-20 01:35:23.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081209/gdb/inferior.h 2008-12-10 01:22:23.000000000 +0100
|
||||||
|
@@ -168,7 +168,15 @@ extern void reopen_exec_file (void);
|
||||||
|
/* The `resume' routine should only be called in special circumstances.
|
||||||
|
Normally, use `proceed', which handles a lot of bookkeeping. */
|
||||||
|
|
||||||
|
-extern void resume (int, enum target_signal);
|
||||||
|
+enum resume_step
|
||||||
|
+ {
|
||||||
|
+ /* currently_stepping () should return non-zero for non-continue. */
|
||||||
|
+ RESUME_STEP_CONTINUE = 0,
|
||||||
|
+ RESUME_STEP_USER, /* Stepping is intentional by the user. */
|
||||||
|
+ RESUME_STEP_NEEDED /* Stepping only for software watchpoints. */
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
+extern void resume (enum resume_step, enum target_signal);
|
||||||
|
|
||||||
|
/* From misc files */
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081209/gdb/infrun.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081209.orig/gdb/infrun.c 2008-12-02 20:20:23.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081209/gdb/infrun.c 2008-12-10 01:23:46.000000000 +0100
|
||||||
|
@@ -73,7 +73,7 @@ static int follow_fork (void);
|
||||||
|
static void set_schedlock_func (char *args, int from_tty,
|
||||||
|
struct cmd_list_element *c);
|
||||||
|
|
||||||
|
-static int currently_stepping (struct thread_info *tp);
|
||||||
|
+static enum resume_step currently_stepping (struct thread_info *tp);
|
||||||
|
|
||||||
|
static int currently_stepping_callback (struct thread_info *tp, void *data);
|
||||||
|
|
||||||
|
@@ -961,7 +961,7 @@ set_schedlock_func (char *args, int from
|
||||||
|
STEP nonzero if we should step (zero to continue instead).
|
||||||
|
SIG is the signal to give the inferior (zero for none). */
|
||||||
|
void
|
||||||
|
-resume (int step, enum target_signal sig)
|
||||||
|
+resume (enum resume_step step, enum target_signal sig)
|
||||||
|
{
|
||||||
|
int should_resume = 1;
|
||||||
|
struct cleanup *old_cleanups = make_cleanup (resume_cleanups, 0);
|
||||||
|
@@ -975,10 +975,12 @@ resume (int step, enum target_signal sig
|
||||||
|
QUIT;
|
||||||
|
|
||||||
|
if (debug_infrun)
|
||||||
|
- fprintf_unfiltered (gdb_stdlog,
|
||||||
|
- "infrun: resume (step=%d, signal=%d), "
|
||||||
|
- "trap_expected=%d\n",
|
||||||
|
- step, sig, tp->trap_expected);
|
||||||
|
+ fprintf_unfiltered (gdb_stdlog, "infrun: resume (step=%s, signal=%d), "
|
||||||
|
+ "trap_expected=%d\n",
|
||||||
|
+ (step == RESUME_STEP_CONTINUE ? "RESUME_STEP_CONTINUE"
|
||||||
|
+ : (step == RESUME_STEP_USER ? "RESUME_STEP_USER"
|
||||||
|
+ : "RESUME_STEP_NEEDED")),
|
||||||
|
+ sig, tp->trap_expected);
|
||||||
|
|
||||||
|
/* Some targets (e.g. Solaris x86) have a kernel bug when stepping
|
||||||
|
over an instruction that causes a page fault without triggering
|
||||||
|
@@ -1127,9 +1129,10 @@ a command like `return' or `jump' to con
|
||||||
|
individually. */
|
||||||
|
resume_ptid = inferior_ptid;
|
||||||
|
}
|
||||||
|
- else if ((scheduler_mode == schedlock_on)
|
||||||
|
+ else if (scheduler_mode == schedlock_on
|
||||||
|
|| (scheduler_mode == schedlock_step
|
||||||
|
- && (step || singlestep_breakpoints_inserted_p)))
|
||||||
|
+ && (step == RESUME_STEP_USER
|
||||||
|
+ || singlestep_breakpoints_inserted_p)))
|
||||||
|
{
|
||||||
|
/* User-settable 'scheduler' mode requires solo thread resume. */
|
||||||
|
resume_ptid = inferior_ptid;
|
||||||
|
@@ -1302,7 +1305,7 @@ proceed (CORE_ADDR addr, enum target_sig
|
||||||
|
struct gdbarch *gdbarch = get_regcache_arch (regcache);
|
||||||
|
struct thread_info *tp;
|
||||||
|
CORE_ADDR pc = regcache_read_pc (regcache);
|
||||||
|
- int oneproc = 0;
|
||||||
|
+ enum resume_step resume_step = RESUME_STEP_CONTINUE;
|
||||||
|
|
||||||
|
if (step > 0)
|
||||||
|
step_start_function = find_pc_function (pc);
|
||||||
|
@@ -1322,13 +1325,13 @@ proceed (CORE_ADDR addr, enum target_sig
|
||||||
|
actually be executing the breakpoint insn anyway.
|
||||||
|
We'll be (un-)executing the previous instruction. */
|
||||||
|
|
||||||
|
- oneproc = 1;
|
||||||
|
+ resume_step = RESUME_STEP_USER;
|
||||||
|
else if (gdbarch_single_step_through_delay_p (gdbarch)
|
||||||
|
&& gdbarch_single_step_through_delay (gdbarch,
|
||||||
|
get_current_frame ()))
|
||||||
|
/* We stepped onto an instruction that needs to be stepped
|
||||||
|
again before re-inserting the breakpoint, do so. */
|
||||||
|
- oneproc = 1;
|
||||||
|
+ resume_step = RESUME_STEP_USER;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
@@ -1359,13 +1362,13 @@ proceed (CORE_ADDR addr, enum target_sig
|
||||||
|
is required it returns TRUE and sets the current thread to
|
||||||
|
the old thread. */
|
||||||
|
if (prepare_to_proceed (step))
|
||||||
|
- oneproc = 1;
|
||||||
|
+ resume_step = RESUME_STEP_USER;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* prepare_to_proceed may change the current thread. */
|
||||||
|
tp = inferior_thread ();
|
||||||
|
|
||||||
|
- if (oneproc)
|
||||||
|
+ if (resume_step == RESUME_STEP_USER)
|
||||||
|
{
|
||||||
|
tp->trap_expected = 1;
|
||||||
|
/* If displaced stepping is enabled, we can step over the
|
||||||
|
@@ -1451,8 +1454,13 @@ proceed (CORE_ADDR addr, enum target_sig
|
||||||
|
/* Reset to normal state. */
|
||||||
|
init_infwait_state ();
|
||||||
|
|
||||||
|
+ if (step)
|
||||||
|
+ resume_step = RESUME_STEP_USER;
|
||||||
|
+ if (resume_step == RESUME_STEP_CONTINUE && bpstat_should_step ())
|
||||||
|
+ resume_step = RESUME_STEP_NEEDED;
|
||||||
|
+
|
||||||
|
/* Resume inferior. */
|
||||||
|
- resume (oneproc || step || bpstat_should_step (), tp->stop_signal);
|
||||||
|
+ resume (resume_step, tp->stop_signal);
|
||||||
|
|
||||||
|
/* Wait for it to stop (if not standalone)
|
||||||
|
and in any case decode why it stopped, and act accordingly. */
|
||||||
|
@@ -3690,10 +3698,16 @@ currently_stepping_callback (struct thre
|
||||||
|
return tp != data && currently_stepping_thread (tp);
|
||||||
|
}
|
||||||
|
|
||||||
|
-static int
|
||||||
|
+static enum resume_step
|
||||||
|
currently_stepping (struct thread_info *tp)
|
||||||
|
{
|
||||||
|
- return currently_stepping_thread (tp) || bpstat_should_step ();
|
||||||
|
+ if (currently_stepping_thread (tp))
|
||||||
|
+ return RESUME_STEP_USER;
|
||||||
|
+
|
||||||
|
+ if (bpstat_should_step ())
|
||||||
|
+ return RESUME_STEP_NEEDED;
|
||||||
|
+
|
||||||
|
+ return RESUME_STEP_CONTINUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Inferior has stepped into a subroutine call with source code that
|
||||||
|
Index: gdb-6.8.50.20081209/gdb/linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081209.orig/gdb/linux-nat.c 2008-12-02 08:57:36.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081209/gdb/linux-nat.c 2008-12-10 01:22:23.000000000 +0100
|
||||||
|
@@ -2343,7 +2343,10 @@ count_events_callback (struct lwp_info *
|
||||||
|
static int
|
||||||
|
select_singlestep_lwp_callback (struct lwp_info *lp, void *data)
|
||||||
|
{
|
||||||
|
- if (lp->step && lp->status != 0)
|
||||||
|
+ /* We do not focus on software watchpoints as we would not catch
|
||||||
|
+ STEPPING_PAST_SINGLESTEP_BREAKPOINT breakpoints in some other thread
|
||||||
|
+ as they would remain pending due to `Push back breakpoint for %s'. */
|
||||||
|
+ if (lp->step == RESUME_STEP_USER && lp->status != 0)
|
||||||
|
return 1;
|
||||||
|
else
|
||||||
|
return 0;
|
||||||
|
Index: gdb-6.8.50.20081209/gdb/linux-nat.h
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081209.orig/gdb/linux-nat.h 2008-07-27 23:12:40.000000000 +0200
|
||||||
|
+++ gdb-6.8.50.20081209/gdb/linux-nat.h 2008-12-10 01:22:23.000000000 +0100
|
||||||
|
@@ -55,8 +55,8 @@ struct lwp_info
|
||||||
|
/* If non-zero, a pending wait status. */
|
||||||
|
int status;
|
||||||
|
|
||||||
|
- /* Non-zero if we were stepping this LWP. */
|
||||||
|
- int step;
|
||||||
|
+ /* The kind of stepping of this LWP. */
|
||||||
|
+ enum resume_step step;
|
||||||
|
|
||||||
|
/* Non-zero si_signo if this LWP stopped with a trap. si_addr may
|
||||||
|
be the address of a hardware watchpoint. */
|
61
gdb-6.6-step-thread-exit.patch
Normal file
61
gdb-6.6-step-thread-exit.patch
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
Index: gdb-6.8.50.20090226/gdb/linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090226.orig/gdb/linux-nat.c 2009-02-27 00:04:35.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090226/gdb/linux-nat.c 2009-02-27 07:51:44.000000000 +0100
|
||||||
|
@@ -1790,15 +1790,17 @@ resume_set_callback (struct lwp_info *lp
|
||||||
|
|
||||||
|
static void
|
||||||
|
linux_nat_resume (struct target_ops *ops,
|
||||||
|
- ptid_t ptid, int step, enum target_signal signo)
|
||||||
|
+ ptid_t ptid, int step_int, enum target_signal signo)
|
||||||
|
{
|
||||||
|
struct lwp_info *lp;
|
||||||
|
int resume_all;
|
||||||
|
+ enum resume_step step = step_int;
|
||||||
|
|
||||||
|
if (debug_linux_nat)
|
||||||
|
fprintf_unfiltered (gdb_stdlog,
|
||||||
|
"LLR: Preparing to %s %s, %s, inferior_ptid %s\n",
|
||||||
|
- step ? "step" : "resume",
|
||||||
|
+ (step == RESUME_STEP_NEEDED
|
||||||
|
+ ? "needed" : (step ? "step" : "resume")),
|
||||||
|
target_pid_to_str (ptid),
|
||||||
|
signo ? strsignal (signo) : "0",
|
||||||
|
target_pid_to_str (inferior_ptid));
|
||||||
|
@@ -2740,6 +2742,9 @@ linux_nat_filter_event (int lwpid, int s
|
||||||
|
/* Check if the thread has exited. */
|
||||||
|
if ((WIFEXITED (status) || WIFSIGNALED (status)) && num_lwps > 1)
|
||||||
|
{
|
||||||
|
+ enum resume_step step = lp->step;
|
||||||
|
+ pid_t pid = GET_PID (lp->ptid);
|
||||||
|
+
|
||||||
|
/* If this is the main thread, we must stop all threads and
|
||||||
|
verify if they are still alive. This is because in the nptl
|
||||||
|
thread model, there is no signal issued for exiting LWPs
|
||||||
|
@@ -2763,6 +2768,26 @@ linux_nat_filter_event (int lwpid, int s
|
||||||
|
|
||||||
|
exit_lwp (lp);
|
||||||
|
|
||||||
|
+ if (step == RESUME_STEP_USER)
|
||||||
|
+ {
|
||||||
|
+ /* Now stop the closest LWP's ... */
|
||||||
|
+ lp = find_lwp_pid (pid_to_ptid (pid));
|
||||||
|
+ if (!lp)
|
||||||
|
+ lp = lwp_list;
|
||||||
|
+ gdb_assert (lp != NULL);
|
||||||
|
+ errno = 0;
|
||||||
|
+ ptrace (PTRACE_CONT, GET_LWP (lp->ptid), 0,
|
||||||
|
+ (void *) (unsigned long) SIGSTOP);
|
||||||
|
+ if (debug_linux_nat)
|
||||||
|
+ fprintf_unfiltered (gdb_stdlog,
|
||||||
|
+ "PTRACE_CONT %s, 0, 0 (%s)\n",
|
||||||
|
+ target_pid_to_str (lp->ptid),
|
||||||
|
+ errno ? safe_strerror (errno)
|
||||||
|
+ : "OK");
|
||||||
|
+ /* Avoid the silent `delayed SIGSTOP' handling. */
|
||||||
|
+ lp->signalled = 0;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
/* If there is at least one more LWP, then the exit signal was
|
||||||
|
not the end of the debugged application and should be
|
||||||
|
ignored. */
|
42
gdb-6.6-testsuite-timeouts.patch
Normal file
42
gdb-6.6-testsuite-timeouts.patch
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
--- ./gdb/testsuite/gdb.base/annota1.exp 10 Jan 2007 03:23:04 -0000 1.23
|
||||||
|
+++ ./gdb/testsuite/gdb.base/annota1.exp 10 May 2007 12:54:11 -0000
|
||||||
|
@@ -57,6 +57,8 @@ if [target_info exists gdb_stub] {
|
||||||
|
gdb_step_for_stub;
|
||||||
|
}
|
||||||
|
|
||||||
|
+gdb_test "set breakpoint pending off" "" "Avoid lockup on nonexisting functions"
|
||||||
|
+
|
||||||
|
#
|
||||||
|
# the line at which break main will put the breakpoint
|
||||||
|
#
|
||||||
|
--- ./gdb/testsuite/gdb.base/annota3.exp 9 Jan 2007 17:59:09 -0000 1.12
|
||||||
|
+++ ./gdb/testsuite/gdb.base/annota3.exp 10 May 2007 12:54:11 -0000
|
||||||
|
@@ -56,6 +56,8 @@ if [target_info exists gdb_stub] {
|
||||||
|
gdb_step_for_stub;
|
||||||
|
}
|
||||||
|
|
||||||
|
+gdb_test "set breakpoint pending off" "" "Avoid lockup on nonexisting functions"
|
||||||
|
+
|
||||||
|
#
|
||||||
|
# the line at which break main will put the breakpoint
|
||||||
|
#
|
||||||
|
--- gdb-6.6/gdb/testsuite/gdb.threads/step-thread-exit.exp-orig 2007-05-10 15:03:15.000000000 +0200
|
||||||
|
+++ gdb-6.6/gdb/testsuite/gdb.threads/step-thread-exit.exp 2007-05-10 15:04:24.000000000 +0200
|
||||||
|
@@ -58,6 +58,9 @@ gdb_test "continue" "Break.*thread_funct
|
||||||
|
# thread to be stopped and a message printed to tell us we have stepped
|
||||||
|
# over the thread exit.
|
||||||
|
set test "step over thread exit 1"
|
||||||
|
+# ppc64 is currently failing:
|
||||||
|
+set timeout_old $timeout
|
||||||
|
+set timeout 60
|
||||||
|
gdb_test_multiple "next" "$test" {
|
||||||
|
-re "\}.*$gdb_prompt $" {
|
||||||
|
send_gdb "next\n"
|
||||||
|
@@ -71,6 +74,7 @@ gdb_test_multiple "next" "$test" {
|
||||||
|
exp_continue
|
||||||
|
}
|
||||||
|
}
|
||||||
|
+set timeout $timeout_old
|
||||||
|
|
||||||
|
# Without this fixup we could end up in:
|
||||||
|
# #0 0x00110416 in __kernel_vsyscall ()
|
25
gdb-6.6-threads-static-test.patch
Normal file
25
gdb-6.6-threads-static-test.patch
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
--- gdb-6.6/gdb/testsuite/gdb.threads/staticthreads.exp-orig 2005-04-30 21:56:47.000000000 +0200
|
||||||
|
+++ gdb-6.6/gdb/testsuite/gdb.threads/staticthreads.exp 2008-01-11 14:30:15.000000000 +0100
|
||||||
|
@@ -44,9 +44,21 @@ gdb_load ${binfile}
|
||||||
|
gdb_test "set print sevenbit-strings" ""
|
||||||
|
|
||||||
|
|
||||||
|
+runto_main
|
||||||
|
+
|
||||||
|
+# See if we get excessive LWP there (patched glibc with unpatched GDB):
|
||||||
|
+# * 2 Thread 135661664 (LWP 3856) main () at threadloop.c:41
|
||||||
|
+# 1 process 3856 main () at threadloop.c:41
|
||||||
|
+
|
||||||
|
+set test "info threads on start"
|
||||||
|
+gdb_test_multiple "info threads" "$test" {
|
||||||
|
+ -re "^info threads\r?\n\[^\r\n\]* Thread \[^\r\n\]*\r?\n$gdb_prompt" {
|
||||||
|
+ pass "$test"
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
# See if the static multi-threaded program runs.
|
||||||
|
|
||||||
|
-runto_main
|
||||||
|
gdb_test "break sem_post"
|
||||||
|
set test "Continue to main's call of sem_post"
|
||||||
|
gdb_test_multiple "continue" "$test" {
|
41
gdb-6.7-bz426600-DW_TAG_interface_type-fix.patch
Normal file
41
gdb-6.7-bz426600-DW_TAG_interface_type-fix.patch
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
Original patch was:
|
||||||
|
http://sourceware.org/ml/gdb-patches/2007-12/msg00397.html
|
||||||
|
http://sourceware.org/ml/gdb-cvs/2007-12/msg00123.html
|
||||||
|
|
||||||
|
extended for the RHEL safety:
|
||||||
|
|
||||||
|
2007-12-28 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* dwarf2read.c (fixup_partial_die): Provide full
|
||||||
|
`DW_TAG_class_type'-type backing for `DW_TAG_interface_type', even for
|
||||||
|
namespaces which should not apply for Java `DW_TAG_interface_type'.
|
||||||
|
|
||||||
|
2008-02-24 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.8pre.
|
||||||
|
|
||||||
|
Index: ./gdb/dwarf2read.c
|
||||||
|
===================================================================
|
||||||
|
RCS file: /cvs/src/src/gdb/dwarf2read.c,v
|
||||||
|
retrieving revision 1.245
|
||||||
|
diff -u -p -r1.245 dwarf2read.c
|
||||||
|
--- ./gdb/dwarf2read.c 26 Dec 2007 12:36:18 -0000 1.245
|
||||||
|
+++ ./gdb/dwarf2read.c 27 Dec 2007 23:25:49 -0000
|
||||||
|
@@ -5887,7 +5887,8 @@ fixup_partial_die (struct partial_die_in
|
||||||
|
|
||||||
|
/* Set default names for some unnamed DIEs. */
|
||||||
|
if (part_die->name == NULL && (part_die->tag == DW_TAG_structure_type
|
||||||
|
- || part_die->tag == DW_TAG_class_type))
|
||||||
|
+ || part_die->tag == DW_TAG_class_type
|
||||||
|
+ || part_die->tag == DW_TAG_interface_type))
|
||||||
|
part_die->name = "(anonymous class)";
|
||||||
|
|
||||||
|
if (part_die->name == NULL && part_die->tag == DW_TAG_namespace)
|
||||||
|
@@ -5895,6 +5896,7 @@ fixup_partial_die (struct partial_die_in
|
||||||
|
|
||||||
|
if (part_die->tag == DW_TAG_structure_type
|
||||||
|
|| part_die->tag == DW_TAG_class_type
|
||||||
|
+ || part_die->tag == DW_TAG_interface_type
|
||||||
|
|| part_die->tag == DW_TAG_union_type)
|
||||||
|
guess_structure_name (part_die, cu);
|
||||||
|
}
|
710
gdb-6.7-bz426600-DW_TAG_interface_type-test.patch
Normal file
710
gdb-6.7-bz426600-DW_TAG_interface_type-test.patch
Normal file
@ -0,0 +1,710 @@
|
|||||||
|
http://sourceware.org/ml/gdb-patches/2007-12/msg00397.html
|
||||||
|
|
||||||
|
2007-12-22 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.arch/i386-interface.S, gdb.arch/i386-interface.exp: New files.
|
||||||
|
|
||||||
|
2008-03-02 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.arch/i386-interface.exp: Fix a testcase race.
|
||||||
|
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.arch/i386-interface.S 22 Dec 2007 19:07:28 -0000
|
||||||
|
@@ -0,0 +1,628 @@
|
||||||
|
+/* Copyright 2007 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/>.
|
||||||
|
+
|
||||||
|
+ Please email any bugs, comments, and/or additions to this file to:
|
||||||
|
+ bug-gdb@gnu.org
|
||||||
|
+
|
||||||
|
+ This file is part of the gdb testsuite.
|
||||||
|
+
|
||||||
|
+ This file was produced by:
|
||||||
|
+ $ gcj -S interface.java -ggdb2 -Wall -m32
|
||||||
|
+ from the .java file:
|
||||||
|
+ interface Interface
|
||||||
|
+ {
|
||||||
|
+ }
|
||||||
|
+ class Class implements Interface
|
||||||
|
+ {
|
||||||
|
+ }
|
||||||
|
+*/
|
||||||
|
+
|
||||||
|
+ .file "cc28Pp2B.jar"
|
||||||
|
+ .section .debug_abbrev,"",@progbits
|
||||||
|
+.Ldebug_abbrev0:
|
||||||
|
+ .section .debug_info,"",@progbits
|
||||||
|
+.Ldebug_info0:
|
||||||
|
+ .section .debug_line,"",@progbits
|
||||||
|
+.Ldebug_line0:
|
||||||
|
+ .text
|
||||||
|
+.Ltext0:
|
||||||
|
+ .local _MT_Interface
|
||||||
|
+ .comm _MT_Interface,0,4
|
||||||
|
+ .data
|
||||||
|
+ .align 4
|
||||||
|
+ .type _catch_classes_Interface, @object
|
||||||
|
+ .size _catch_classes_Interface, 24
|
||||||
|
+_catch_classes_Interface:
|
||||||
|
+ .zero 24
|
||||||
|
+ .section .rodata
|
||||||
|
+ .align 2
|
||||||
|
+ .type _Utf1, @object
|
||||||
|
+ .size _Utf1, 4
|
||||||
|
+_Utf1:
|
||||||
|
+ .value 36121
|
||||||
|
+ .value 9
|
||||||
|
+ .ascii "Interface"
|
||||||
|
+ .zero 1
|
||||||
|
+.globl _ZN9Interface6class$E
|
||||||
|
+ .data
|
||||||
|
+ .align 32
|
||||||
|
+ .type _ZN9Interface6class$E, @object
|
||||||
|
+ .size _ZN9Interface6class$E, 144
|
||||||
|
+_ZN9Interface6class$E:
|
||||||
|
+ .long _ZTVN4java4lang5ClassE+8
|
||||||
|
+ .long 403000
|
||||||
|
+ .long _Utf1
|
||||||
|
+ .value 1536
|
||||||
|
+ .zero 2
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long _MT_Interface
|
||||||
|
+ .value 0
|
||||||
|
+ .value 6
|
||||||
|
+ .long 0
|
||||||
|
+ .long 4
|
||||||
|
+ .value 0
|
||||||
|
+ .value 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long _catch_classes_Interface
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .value 0
|
||||||
|
+ .byte 1
|
||||||
|
+ .zero 1
|
||||||
|
+ .long 0
|
||||||
|
+ .value 0
|
||||||
|
+ .zero 2
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .hidden _ZN9Interface7class$$E
|
||||||
|
+.globl _ZN9Interface7class$$E
|
||||||
|
+ .section .rodata
|
||||||
|
+ .align 4
|
||||||
|
+ .type _ZN9Interface7class$$E, @object
|
||||||
|
+ .size _ZN9Interface7class$$E, 4
|
||||||
|
+_ZN9Interface7class$$E:
|
||||||
|
+ .long _ZN9Interface6class$E
|
||||||
|
+ .text
|
||||||
|
+ .align 2
|
||||||
|
+.globl _ZN5ClassC1Ev
|
||||||
|
+ .type _ZN5ClassC1Ev, @function
|
||||||
|
+_ZN5ClassC1Ev:
|
||||||
|
+.LFB2:
|
||||||
|
+ pushl %ebp
|
||||||
|
+.LCFI0:
|
||||||
|
+ movl %esp, %ebp
|
||||||
|
+.LCFI1:
|
||||||
|
+ subl $24, %esp
|
||||||
|
+.LCFI2:
|
||||||
|
+.LBB2:
|
||||||
|
+#if 0
|
||||||
|
+ .file 1 "interface.java"
|
||||||
|
+#else
|
||||||
|
+ .file "interface.java"
|
||||||
|
+#endif
|
||||||
|
+ .loc 1 4 0
|
||||||
|
+ movl 8(%ebp), %eax
|
||||||
|
+ movl %eax, -4(%ebp)
|
||||||
|
+ movl -4(%ebp), %eax
|
||||||
|
+ movl %eax, (%esp)
|
||||||
|
+ call _ZN4java4lang6ObjectC1Ev
|
||||||
|
+.LBE2:
|
||||||
|
+ leave
|
||||||
|
+ ret
|
||||||
|
+.LFE2:
|
||||||
|
+ .size _ZN5ClassC1Ev, .-_ZN5ClassC1Ev
|
||||||
|
+ .hidden _ZTVN5ClassE
|
||||||
|
+.globl _ZTVN5ClassE
|
||||||
|
+ .data
|
||||||
|
+ .align 32
|
||||||
|
+ .type _ZTVN5ClassE, @object
|
||||||
|
+ .size _ZTVN5ClassE, 40
|
||||||
|
+_ZTVN5ClassE:
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long _ZN5Class6class$E
|
||||||
|
+ .long 4
|
||||||
|
+ .long _ZN4java4lang6Object8finalizeEJvv
|
||||||
|
+ .long _ZN4java4lang6Object8hashCodeEJiv
|
||||||
|
+ .long _ZN4java4lang6Object6equalsEJbPS1_
|
||||||
|
+ .long _ZN4java4lang6Object8toStringEJPNS0_6StringEv
|
||||||
|
+ .long _ZN4java4lang6Object5cloneEJPS1_v
|
||||||
|
+ .long _ZN4java4lang6Object22throwNoSuchMethodErrorEJvv
|
||||||
|
+ .set .L_ZN5ClassC1Ev0,_ZN5ClassC1Ev
|
||||||
|
+ .section .rodata
|
||||||
|
+ .align 2
|
||||||
|
+ .type _Utf2, @object
|
||||||
|
+ .size _Utf2, 4
|
||||||
|
+_Utf2:
|
||||||
|
+ .value 626
|
||||||
|
+ .value 6
|
||||||
|
+ .ascii "<init>"
|
||||||
|
+ .zero 1
|
||||||
|
+ .align 2
|
||||||
|
+ .type _Utf3, @object
|
||||||
|
+ .size _Utf3, 4
|
||||||
|
+_Utf3:
|
||||||
|
+ .value 39797
|
||||||
|
+ .value 3
|
||||||
|
+ .ascii "()V"
|
||||||
|
+ .zero 1
|
||||||
|
+ .data
|
||||||
|
+ .align 4
|
||||||
|
+ .type _MT_Class, @object
|
||||||
|
+ .size _MT_Class, 20
|
||||||
|
+_MT_Class:
|
||||||
|
+ .long _Utf2
|
||||||
|
+ .long _Utf3
|
||||||
|
+ .value 16384
|
||||||
|
+ .value -1
|
||||||
|
+ .long .L_ZN5ClassC1Ev0
|
||||||
|
+ .long 0
|
||||||
|
+ .align 4
|
||||||
|
+ .type _IF_Class, @object
|
||||||
|
+ .size _IF_Class, 4
|
||||||
|
+_IF_Class:
|
||||||
|
+ .long _ZN9Interface6class$E
|
||||||
|
+ .align 4
|
||||||
|
+ .type _catch_classes_Class, @object
|
||||||
|
+ .size _catch_classes_Class, 24
|
||||||
|
+_catch_classes_Class:
|
||||||
|
+ .zero 24
|
||||||
|
+ .section .rodata
|
||||||
|
+ .align 2
|
||||||
|
+ .type _Utf4, @object
|
||||||
|
+ .size _Utf4, 4
|
||||||
|
+_Utf4:
|
||||||
|
+ .value 47448
|
||||||
|
+ .value 5
|
||||||
|
+ .ascii "Class"
|
||||||
|
+ .zero 1
|
||||||
|
+.globl _ZN5Class6class$E
|
||||||
|
+ .data
|
||||||
|
+ .align 32
|
||||||
|
+ .type _ZN5Class6class$E, @object
|
||||||
|
+ .size _ZN5Class6class$E, 144
|
||||||
|
+_ZN5Class6class$E:
|
||||||
|
+ .long _ZTVN4java4lang5ClassE+8
|
||||||
|
+ .long 403000
|
||||||
|
+ .long _Utf4
|
||||||
|
+ .value 32
|
||||||
|
+ .zero 2
|
||||||
|
+ .long _ZN4java4lang6Object6class$E
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long _MT_Class
|
||||||
|
+ .value 1
|
||||||
|
+ .value 6
|
||||||
|
+ .long 0
|
||||||
|
+ .long 4
|
||||||
|
+ .value 0
|
||||||
|
+ .value 0
|
||||||
|
+ .long _ZTVN5ClassE+8
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long _catch_classes_Class
|
||||||
|
+ .long _IF_Class
|
||||||
|
+ .long 0
|
||||||
|
+ .value 1
|
||||||
|
+ .byte 1
|
||||||
|
+ .zero 1
|
||||||
|
+ .long 0
|
||||||
|
+ .value 0
|
||||||
|
+ .zero 2
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .long 0
|
||||||
|
+ .hidden _ZN5Class7class$$E
|
||||||
|
+.globl _ZN5Class7class$$E
|
||||||
|
+ .section .rodata
|
||||||
|
+ .align 4
|
||||||
|
+ .type _ZN5Class7class$$E, @object
|
||||||
|
+ .size _ZN5Class7class$$E, 4
|
||||||
|
+_ZN5Class7class$$E:
|
||||||
|
+ .long _ZN5Class6class$E
|
||||||
|
+ .section .jcr,"aw",@progbits
|
||||||
|
+ .align 4
|
||||||
|
+ .long _ZN9Interface6class$E
|
||||||
|
+ .long _ZN5Class6class$E
|
||||||
|
+ .section .debug_frame,"",@progbits
|
||||||
|
+.Lframe0:
|
||||||
|
+ .long .LECIE0-.LSCIE0
|
||||||
|
+.LSCIE0:
|
||||||
|
+ .long 0xffffffff
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .string ""
|
||||||
|
+ .uleb128 0x1
|
||||||
|
+ .sleb128 -4
|
||||||
|
+ .byte 0x8
|
||||||
|
+ .byte 0xc
|
||||||
|
+ .uleb128 0x4
|
||||||
|
+ .uleb128 0x4
|
||||||
|
+ .byte 0x88
|
||||||
|
+ .uleb128 0x1
|
||||||
|
+ .align 4
|
||||||
|
+.LECIE0:
|
||||||
|
+.LSFDE0:
|
||||||
|
+ .long .LEFDE0-.LASFDE0
|
||||||
|
+.LASFDE0:
|
||||||
|
+ .long .Lframe0
|
||||||
|
+ .long .LFB2
|
||||||
|
+ .long .LFE2-.LFB2
|
||||||
|
+ .byte 0x4
|
||||||
|
+ .long .LCFI0-.LFB2
|
||||||
|
+ .byte 0xe
|
||||||
|
+ .uleb128 0x8
|
||||||
|
+ .byte 0x85
|
||||||
|
+ .uleb128 0x2
|
||||||
|
+ .byte 0x4
|
||||||
|
+ .long .LCFI1-.LCFI0
|
||||||
|
+ .byte 0xd
|
||||||
|
+ .uleb128 0x5
|
||||||
|
+ .align 4
|
||||||
|
+.LEFDE0:
|
||||||
|
+ .section .eh_frame,"a",@progbits
|
||||||
|
+.Lframe1:
|
||||||
|
+ .long .LECIE1-.LSCIE1
|
||||||
|
+.LSCIE1:
|
||||||
|
+ .long 0x0
|
||||||
|
+ .byte 0x1
|
||||||
|
+.globl __gcj_personality_v0
|
||||||
|
+ .string "zP"
|
||||||
|
+ .uleb128 0x1
|
||||||
|
+ .sleb128 -4
|
||||||
|
+ .byte 0x8
|
||||||
|
+ .uleb128 0x5
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .long __gcj_personality_v0
|
||||||
|
+ .byte 0xc
|
||||||
|
+ .uleb128 0x4
|
||||||
|
+ .uleb128 0x4
|
||||||
|
+ .byte 0x88
|
||||||
|
+ .uleb128 0x1
|
||||||
|
+ .align 4
|
||||||
|
+.LECIE1:
|
||||||
|
+.LSFDE1:
|
||||||
|
+ .long .LEFDE1-.LASFDE1
|
||||||
|
+.LASFDE1:
|
||||||
|
+ .long .LASFDE1-.Lframe1
|
||||||
|
+ .long .LFB2
|
||||||
|
+ .long .LFE2-.LFB2
|
||||||
|
+ .uleb128 0x0
|
||||||
|
+ .byte 0x4
|
||||||
|
+ .long .LCFI0-.LFB2
|
||||||
|
+ .byte 0xe
|
||||||
|
+ .uleb128 0x8
|
||||||
|
+ .byte 0x85
|
||||||
|
+ .uleb128 0x2
|
||||||
|
+ .byte 0x4
|
||||||
|
+ .long .LCFI1-.LCFI0
|
||||||
|
+ .byte 0xd
|
||||||
|
+ .uleb128 0x5
|
||||||
|
+ .align 4
|
||||||
|
+.LEFDE1:
|
||||||
|
+ .text
|
||||||
|
+.Letext0:
|
||||||
|
+ .section .debug_loc,"",@progbits
|
||||||
|
+.Ldebug_loc0:
|
||||||
|
+.LLST0:
|
||||||
|
+ .long .LFB2-.Ltext0
|
||||||
|
+ .long .LCFI0-.Ltext0
|
||||||
|
+ .value 0x2
|
||||||
|
+ .byte 0x74
|
||||||
|
+ .sleb128 4
|
||||||
|
+ .long .LCFI0-.Ltext0
|
||||||
|
+ .long .LCFI1-.Ltext0
|
||||||
|
+ .value 0x2
|
||||||
|
+ .byte 0x74
|
||||||
|
+ .sleb128 8
|
||||||
|
+ .long .LCFI1-.Ltext0
|
||||||
|
+ .long .LFE2-.Ltext0
|
||||||
|
+ .value 0x2
|
||||||
|
+ .byte 0x75
|
||||||
|
+ .sleb128 8
|
||||||
|
+ .long 0x0
|
||||||
|
+ .long 0x0
|
||||||
|
+ .section .debug_info
|
||||||
|
+ .long 0x117
|
||||||
|
+ .value 0x2
|
||||||
|
+ .long .Ldebug_abbrev0
|
||||||
|
+ .byte 0x4
|
||||||
|
+ .uleb128 0x1
|
||||||
|
+ .string "GNU Java 4.3.0 20071221 (experimental)"
|
||||||
|
+ .byte 0xb
|
||||||
|
+ .string "interface.java"
|
||||||
|
+ .string "/home/jkratoch/redhat/bz371831"
|
||||||
|
+ .long .Ltext0
|
||||||
|
+ .long .Letext0
|
||||||
|
+ .long .Ldebug_line0
|
||||||
|
+ .uleb128 0x2
|
||||||
|
+ .string "Interface"
|
||||||
|
+ .byte 0x4
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .long 0x8e
|
||||||
|
+ .long 0x8e
|
||||||
|
+ .uleb128 0x3
|
||||||
|
+ .long 0x8e
|
||||||
|
+ .byte 0x2
|
||||||
|
+ .byte 0x23
|
||||||
|
+ .uleb128 0x0
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x4
|
||||||
|
+ .string "java.lang.Object"
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .uleb128 0x5
|
||||||
|
+ .string "Class"
|
||||||
|
+ .byte 0x4
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .long 0x8e
|
||||||
|
+ .long 0xe8
|
||||||
|
+ .uleb128 0x3
|
||||||
|
+ .long 0x8e
|
||||||
|
+ .byte 0x2
|
||||||
|
+ .byte 0x23
|
||||||
|
+ .uleb128 0x0
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .uleb128 0x6
|
||||||
|
+ .long 0x6e
|
||||||
|
+ .byte 0x2
|
||||||
|
+ .byte 0x23
|
||||||
|
+ .uleb128 0x0
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .uleb128 0x7
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .string "<init>"
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .string "_ZN5ClassC1Ev"
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .uleb128 0x8
|
||||||
|
+ .long 0xe8
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x9
|
||||||
|
+ .byte 0x4
|
||||||
|
+ .long 0xa1
|
||||||
|
+ .uleb128 0xa
|
||||||
|
+ .long 0xc6
|
||||||
|
+ .long .LFB2
|
||||||
|
+ .long .LFE2
|
||||||
|
+ .long .LLST0
|
||||||
|
+ .long 0x114
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .long 0xe8
|
||||||
|
+ .byte 0x2
|
||||||
|
+ .byte 0x91
|
||||||
|
+ .sleb128 0
|
||||||
|
+ .uleb128 0xc
|
||||||
|
+ .long 0x114
|
||||||
|
+ .byte 0x2
|
||||||
|
+ .byte 0x91
|
||||||
|
+ .sleb128 -12
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x9
|
||||||
|
+ .byte 0x4
|
||||||
|
+ .long 0x8e
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .section .debug_abbrev
|
||||||
|
+ .uleb128 0x1
|
||||||
|
+ .uleb128 0x11
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .uleb128 0x25
|
||||||
|
+ .uleb128 0x8
|
||||||
|
+ .uleb128 0x13
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0x3
|
||||||
|
+ .uleb128 0x8
|
||||||
|
+ .uleb128 0x1b
|
||||||
|
+ .uleb128 0x8
|
||||||
|
+ .uleb128 0x11
|
||||||
|
+ .uleb128 0x1
|
||||||
|
+ .uleb128 0x12
|
||||||
|
+ .uleb128 0x1
|
||||||
|
+ .uleb128 0x10
|
||||||
|
+ .uleb128 0x6
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x2
|
||||||
|
+ .uleb128 0x38
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .uleb128 0x3
|
||||||
|
+ .uleb128 0x8
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0x3a
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0x3b
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0x1d
|
||||||
|
+ .uleb128 0x13
|
||||||
|
+ .uleb128 0x1
|
||||||
|
+ .uleb128 0x13
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x3
|
||||||
|
+ .uleb128 0x1c
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x49
|
||||||
|
+ .uleb128 0x13
|
||||||
|
+ .uleb128 0x38
|
||||||
|
+ .uleb128 0xa
|
||||||
|
+ .uleb128 0x32
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x4
|
||||||
|
+ .uleb128 0x2
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x3
|
||||||
|
+ .uleb128 0x8
|
||||||
|
+ .uleb128 0x3c
|
||||||
|
+ .uleb128 0xc
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x5
|
||||||
|
+ .uleb128 0x2
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .uleb128 0x3
|
||||||
|
+ .uleb128 0x8
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0x3a
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0x3b
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0x1d
|
||||||
|
+ .uleb128 0x13
|
||||||
|
+ .uleb128 0x1
|
||||||
|
+ .uleb128 0x13
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x6
|
||||||
|
+ .uleb128 0x1c
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x49
|
||||||
|
+ .uleb128 0x13
|
||||||
|
+ .uleb128 0x38
|
||||||
|
+ .uleb128 0xa
|
||||||
|
+ .uleb128 0x4c
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0x32
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x7
|
||||||
|
+ .uleb128 0x2e
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .uleb128 0x3f
|
||||||
|
+ .uleb128 0xc
|
||||||
|
+ .uleb128 0x3
|
||||||
|
+ .uleb128 0x8
|
||||||
|
+ .uleb128 0x3a
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0x3b
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0x2007
|
||||||
|
+ .uleb128 0x8
|
||||||
|
+ .uleb128 0x3c
|
||||||
|
+ .uleb128 0xc
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x8
|
||||||
|
+ .uleb128 0x5
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x49
|
||||||
|
+ .uleb128 0x13
|
||||||
|
+ .uleb128 0x34
|
||||||
|
+ .uleb128 0xc
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x9
|
||||||
|
+ .uleb128 0xf
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0x49
|
||||||
|
+ .uleb128 0x13
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0xa
|
||||||
|
+ .uleb128 0x2e
|
||||||
|
+ .byte 0x1
|
||||||
|
+ .uleb128 0x47
|
||||||
|
+ .uleb128 0x13
|
||||||
|
+ .uleb128 0x11
|
||||||
|
+ .uleb128 0x1
|
||||||
|
+ .uleb128 0x12
|
||||||
|
+ .uleb128 0x1
|
||||||
|
+ .uleb128 0x40
|
||||||
|
+ .uleb128 0x6
|
||||||
|
+ .uleb128 0x1
|
||||||
|
+ .uleb128 0x13
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0xb
|
||||||
|
+ .uleb128 0x5
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x49
|
||||||
|
+ .uleb128 0x13
|
||||||
|
+ .uleb128 0x2
|
||||||
|
+ .uleb128 0xa
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0xc
|
||||||
|
+ .uleb128 0x34
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .uleb128 0x49
|
||||||
|
+ .uleb128 0x13
|
||||||
|
+ .uleb128 0x2
|
||||||
|
+ .uleb128 0xa
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .section .debug_pubnames,"",@progbits
|
||||||
|
+ .long 0x15
|
||||||
|
+ .value 0x2
|
||||||
|
+ .long .Ldebug_info0
|
||||||
|
+ .long 0x11b
|
||||||
|
+ .long 0xee
|
||||||
|
+ .string "()"
|
||||||
|
+ .long 0x0
|
||||||
|
+ .section .debug_aranges,"",@progbits
|
||||||
|
+ .long 0x1c
|
||||||
|
+ .value 0x2
|
||||||
|
+ .long .Ldebug_info0
|
||||||
|
+ .byte 0x4
|
||||||
|
+ .byte 0x0
|
||||||
|
+ .value 0x0
|
||||||
|
+ .value 0x0
|
||||||
|
+ .long .Ltext0
|
||||||
|
+ .long .Letext0-.Ltext0
|
||||||
|
+ .long 0x0
|
||||||
|
+ .long 0x0
|
||||||
|
+ .ident "GCC: (GNU) 4.3.0 20071221 (experimental)"
|
||||||
|
+ .section .note.GNU-stack,"",@progbits
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.arch/i386-interface.exp 22 Dec 2007 19:07:28 -0000
|
||||||
|
@@ -0,0 +1,66 @@
|
||||||
|
+# Copyright 2007 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/>.
|
||||||
|
+
|
||||||
|
+# Please email any bugs, comments, and/or additions to this file to:
|
||||||
|
+# bug-gdb@gnu.org
|
||||||
|
+
|
||||||
|
+# This file is part of the gdb testsuite.
|
||||||
|
+
|
||||||
|
+# Test basis recognization of DW_TAG_interface_type.
|
||||||
|
+# GCC java_classify_record() produces it if returns RECORD_IS_INTERFACE.
|
||||||
|
+
|
||||||
|
+if $tracelevel {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+if {![istarget "i?86-*-*"] && ![istarget "x86_64-*-*"]} then {
|
||||||
|
+ verbose "Skipping i386 Java DW_TAG_interface_type test."
|
||||||
|
+ return
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "i386-interface"
|
||||||
|
+set srcfile ${testfile}.S
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}.o
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" object {debug additional_flags=-m32}] != "" } {
|
||||||
|
+ untested i386-gnu-cfi.exp
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Get things started.
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+gdb_test "set language java"
|
||||||
|
+
|
||||||
|
+set test "ptype Interface"
|
||||||
|
+gdb_test_multiple $test $test {
|
||||||
|
+ -re "type = class Interface *extends java.lang.Object \{.*$gdb_prompt $" {
|
||||||
|
+ pass $test
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set test "ptype Class"
|
||||||
|
+gdb_test_multiple $test $test {
|
||||||
|
+ -re "type = class Class *extends java.lang.Object implements Interface \{.*$gdb_prompt $" {
|
||||||
|
+ pass $test
|
||||||
|
+ }
|
||||||
|
+}
|
125
gdb-6.7-charsign-test.patch
Normal file
125
gdb-6.7-charsign-test.patch
Normal file
@ -0,0 +1,125 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=224128
|
||||||
|
|
||||||
|
2007-01-25 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.base/charsign.exp, gdb.base/charsign.c: New files.
|
||||||
|
[ stripped ]
|
||||||
|
|
||||||
|
2007-10-19 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
Port to GDB-6.7 - only the testcase left, patch has been reverted,
|
||||||
|
char-vectors restricted.
|
||||||
|
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.base/charsign.c 26 Jan 2007 10:32:00 -0000
|
||||||
|
@@ -0,0 +1,37 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2007 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 */
|
||||||
|
+
|
||||||
|
+int main()
|
||||||
|
+{
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+char n[]="A";
|
||||||
|
+signed char s[]="A";
|
||||||
|
+unsigned char u[]="A";
|
||||||
|
+
|
||||||
|
+typedef char char_n;
|
||||||
|
+typedef signed char char_s;
|
||||||
|
+typedef unsigned char char_u;
|
||||||
|
+
|
||||||
|
+char_n n_typed[]="A";
|
||||||
|
+char_s s_typed[]="A";
|
||||||
|
+char_u u_typed[]="A";
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.base/charsign.exp 26 Jan 2007 10:32:00 -0000
|
||||||
|
@@ -0,0 +1,70 @@
|
||||||
|
+# Copyright 2007 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.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+set testfile charsign
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+proc do_test { cflags } {
|
||||||
|
+ global srcdir
|
||||||
|
+ global binfile
|
||||||
|
+ global subdir
|
||||||
|
+ global srcfile
|
||||||
|
+ global gdb_prompt
|
||||||
|
+
|
||||||
|
+ if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable [list debug additional_flags=$cflags]] != "" } {
|
||||||
|
+ untested "Couldn't compile test program"
|
||||||
|
+ return -1
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ # Get things started.
|
||||||
|
+
|
||||||
|
+ gdb_exit
|
||||||
|
+ gdb_start
|
||||||
|
+ gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+ gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+ # For C programs, "start" should stop in main().
|
||||||
|
+
|
||||||
|
+ gdb_test "p n" \
|
||||||
|
+ "= \"A\""
|
||||||
|
+ gdb_test "p s" \
|
||||||
|
+ "= \\{65 'A', 0 '\\\\0'\\}"
|
||||||
|
+ gdb_test "p u" \
|
||||||
|
+ "= \\{65 'A', 0 '\\\\0'\\}"
|
||||||
|
+ gdb_test "p n_typed" \
|
||||||
|
+ "= \"A\""
|
||||||
|
+ gdb_test "p s_typed" \
|
||||||
|
+ "= \\{65 'A', 0 '\\\\0'\\}"
|
||||||
|
+ gdb_test "p u_typed" \
|
||||||
|
+ "= \\{65 'A', 0 '\\\\0'\\}"
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# The string identification works despite the compiler flags below due to
|
||||||
|
+# gdbtypes.c:
|
||||||
|
+# if (name && strcmp (name, "char") == 0)
|
||||||
|
+# TYPE_FLAGS (type) |= TYPE_FLAG_NOSIGN;
|
||||||
|
+
|
||||||
|
+do_test {}
|
||||||
|
+do_test {-fsigned-char}
|
||||||
|
+do_test {-funsigned-char}
|
24
gdb-6.7-kernel-headers-compat.patch
Normal file
24
gdb-6.7-kernel-headers-compat.patch
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
kernel-headers-2.6.25-0.40.rc1.git2.fc9.x86_64
|
||||||
|
|
||||||
|
In file included from /usr/include/asm/ptrace.h:4,
|
||||||
|
from ../../gdb/amd64-linux-nat.c:44:
|
||||||
|
/usr/include/asm/ptrace-abi.h:92: error: expected specifier-qualifier-list before ‘u32’
|
||||||
|
|
||||||
|
--- gdb-6.7.1-13.fc9.x86_64/gdb/amd64-linux-nat.c-orig 2008-02-15 15:37:28.000000000 -0500
|
||||||
|
+++ gdb-6.7.1-13.fc9.x86_64/gdb/amd64-linux-nat.c 2008-02-15 15:40:13.000000000 -0500
|
||||||
|
@@ -35,13 +35,13 @@
|
||||||
|
#include <sys/procfs.h>
|
||||||
|
#include <asm/prctl.h>
|
||||||
|
/* FIXME ezannoni-2003-07-09: we need <sys/reg.h> to be included after
|
||||||
|
- <asm/ptrace.h> because the latter redefines FS and GS for no apparent
|
||||||
|
+ <sys/ptrace.h> because the latter redefines FS and GS for no apparent
|
||||||
|
reason, and those definitions don't match the ones that libpthread_db
|
||||||
|
uses, which come from <sys/reg.h>. */
|
||||||
|
/* ezannoni-2003-07-09: I think this is fixed. The extraneous defs have
|
||||||
|
been removed from ptrace.h in the kernel. However, better safe than
|
||||||
|
sorry. */
|
||||||
|
-#include <asm/ptrace.h>
|
||||||
|
+#include <sys/ptrace.h>
|
||||||
|
#include <sys/reg.h>
|
||||||
|
#include "gdb_proc_service.h"
|
||||||
|
|
103
gdb-6.7-ppc-clobbered-registers-O2-test.patch
Normal file
103
gdb-6.7-ppc-clobbered-registers-O2-test.patch
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
2007-11-04 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.arch/ppc-clobbered-registers-O2.exp: `powerpc64' changed to
|
||||||
|
`powerpc*'.
|
||||||
|
|
||||||
|
Testcase for:
|
||||||
|
|
||||||
|
http://sourceware.org/ml/gdb-patches/2007-09/msg00228.html
|
||||||
|
|
||||||
|
2007-10-21 Luis Machado <luisgpm@br.ibm.com>
|
||||||
|
|
||||||
|
* rs6000-tdep.c (ppc_dwarf2_frame_init_reg): New function.
|
||||||
|
* (rs6000_gdbarch_init): Install ppc_dwarf2_frame_init_reg as
|
||||||
|
default dwarf2_frame_set_init_reg function.
|
||||||
|
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.arch/ppc-clobbered-registers-O2.c 3 Nov 2007 22:22:28 -0000
|
||||||
|
@@ -0,0 +1,21 @@
|
||||||
|
+
|
||||||
|
+unsigned * __attribute__((noinline))
|
||||||
|
+start_sequence (unsigned * x, unsigned * y)
|
||||||
|
+{
|
||||||
|
+ return (unsigned *)0xdeadbeef;
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+unsigned __attribute__((noinline))
|
||||||
|
+gen_movsd (unsigned * operand0, unsigned * operand1)
|
||||||
|
+{
|
||||||
|
+ return *start_sequence(operand0, operand1);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int main(void)
|
||||||
|
+{
|
||||||
|
+ unsigned x, y;
|
||||||
|
+
|
||||||
|
+ x = 13;
|
||||||
|
+ y = 14;
|
||||||
|
+ return (int)gen_movsd (&x, &y);
|
||||||
|
+}
|
||||||
|
--- /dev/null 1 Jan 1970 00:00:00 -0000
|
||||||
|
+++ ./gdb/testsuite/gdb.arch/ppc-clobbered-registers-O2.exp 3 Nov 2007 22:22:28 -0000
|
||||||
|
@@ -0,0 +1,61 @@
|
||||||
|
+# Copyright 2006 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.
|
||||||
|
+#
|
||||||
|
+# This file is part of the gdb testsuite.
|
||||||
|
+
|
||||||
|
+if $tracelevel {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# Test displaying call clobbered registers in optimized binaries for ppc.
|
||||||
|
+# GDB should not show incorrect values.
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+if ![istarget "powerpc*-*"] then {
|
||||||
|
+ verbose "Skipping powerpc* call clobbered registers testing."
|
||||||
|
+ return
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set testfile "ppc-clobbered-registers-O2"
|
||||||
|
+set srcfile ${testfile}.c
|
||||||
|
+set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+set compile_flags "debug additional_flags=-O2"
|
||||||
|
+
|
||||||
|
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable ${compile_flags}] != "" } {
|
||||||
|
+ unsupported "Testcase compile failed."
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_exit
|
||||||
|
+gdb_start
|
||||||
|
+gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+if ![runto_main] then {
|
||||||
|
+ perror "Couldn't run to breakpoint"
|
||||||
|
+ continue
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+gdb_test "b start_sequence" ".*Breakpoint 2 at.*line 6.*" \
|
||||||
|
+ "Insert breakpoint at problematic function"
|
||||||
|
+
|
||||||
|
+gdb_test continue ".*Breakpoint 2.*in start_sequence.*" \
|
||||||
|
+ "Run until problematic function"
|
||||||
|
+
|
||||||
|
+gdb_test backtrace ".*operand0=<value optimized out>.*operand1=<value optimized out>.*" \
|
||||||
|
+ "Check value of call clobbered registers"
|
208
gdb-6.7-testsuite-stable-results.patch
Normal file
208
gdb-6.7-testsuite-stable-results.patch
Normal file
@ -0,0 +1,208 @@
|
|||||||
|
gdb/testsuite/gdb.base/fileio.c:
|
||||||
|
gdb/testsuite/gdb.base/fileio.exp:
|
||||||
|
2007-12-08 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.base/fileio.c (ROOTSUBDIR): New macro.
|
||||||
|
(main): CHDIR into ROOTSUBDIR. CHOWN ROOTSUBDIR and CHDIR into
|
||||||
|
ROOTSUBDIR if we are being run as root.
|
||||||
|
* gdb.base/fileio.exp: Change the startup and finish cleanup.
|
||||||
|
Change the test file reference to be into the `fileio.dir' directory.
|
||||||
|
|
||||||
|
|
||||||
|
sources/gdb/testsuite/gdb.base/dump.exp:
|
||||||
|
Found on RHEL-5.s390x.
|
||||||
|
|
||||||
|
|
||||||
|
gdb-6.8.50.20090209/gdb/testsuite/gdb.base/auxv.exp:
|
||||||
|
random FAIL: gdb.base/auxv.exp: matching auxv data from live and gcore
|
||||||
|
|
||||||
|
|
||||||
|
gdb-6.8.50.20090209/gdb/testsuite/gdb.base/annota1.exp:
|
||||||
|
frames-invalid can happen asynchronously.
|
||||||
|
|
||||||
|
--- ./gdb/testsuite/gdb.base/fileio.c 13 Jun 2006 08:55:22 -0000 1.10
|
||||||
|
+++ ./gdb/testsuite/gdb.base/fileio.c 8 Dec 2007 16:04:10 -0000
|
||||||
|
@@ -58,6 +58,8 @@ system (const char * string);
|
||||||
|
1) Invalid string/command. - returns 127. */
|
||||||
|
static const char *strerrno (int err);
|
||||||
|
|
||||||
|
+#define ROOTSUBDIR "fileio.dir"
|
||||||
|
+
|
||||||
|
#define FILENAME "foo.fileio.test"
|
||||||
|
#define RENAMED "bar.fileio.test"
|
||||||
|
#define NONEXISTANT "nofoo.fileio.test"
|
||||||
|
@@ -542,6 +544,37 @@ strerrno (int err)
|
||||||
|
int
|
||||||
|
main ()
|
||||||
|
{
|
||||||
|
+ /* ROOTSUBDIR is already prepared by fileio.exp. We use it for easy cleanup
|
||||||
|
+ (by fileio.exp) if we are run by multiple users in the same directory. */
|
||||||
|
+
|
||||||
|
+ if (chdir (ROOTSUBDIR) != 0)
|
||||||
|
+ {
|
||||||
|
+ printf ("chdir " ROOTSUBDIR ": %s\n", strerror (errno));
|
||||||
|
+ exit (1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /* These tests
|
||||||
|
+ Open for write but no write permission returns EACCES
|
||||||
|
+ Unlinking a file in a directory w/o write access returns EACCES
|
||||||
|
+ fail if we are being run as root - drop the privileges here. */
|
||||||
|
+
|
||||||
|
+ if (geteuid () == 0)
|
||||||
|
+ {
|
||||||
|
+ uid_t uid = 99;
|
||||||
|
+
|
||||||
|
+ if (chown (".", uid, uid) != 0)
|
||||||
|
+ {
|
||||||
|
+ printf ("chown %d.%d " ROOTSUBDIR ": %s\n", (int) uid, (int) uid,
|
||||||
|
+ strerror (errno));
|
||||||
|
+ exit (1);
|
||||||
|
+ }
|
||||||
|
+ if (setuid (uid) || geteuid () == 0)
|
||||||
|
+ {
|
||||||
|
+ printf ("setuid %d: %s\n", (int) uid, strerror (errno));
|
||||||
|
+ exit (1);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
/* Don't change the order of the calls. They partly depend on each other */
|
||||||
|
test_open ();
|
||||||
|
test_write ();
|
||||||
|
--- ./gdb/testsuite/gdb.base/fileio.exp 23 Aug 2007 18:14:16 -0000 1.12
|
||||||
|
+++ ./gdb/testsuite/gdb.base/fileio.exp 8 Dec 2007 16:04:10 -0000
|
||||||
|
@@ -46,8 +46,8 @@ if [get_compiler_info ${binfile}] {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
-remote_exec build {sh -xc test\ -r\ dir2.fileio.test\ &&\ chmod\ -f\ +w\ dir2.fileio.test}
|
||||||
|
-remote_exec build {sh -xc rm\ -rf\ *.fileio.test}
|
||||||
|
+remote_exec build {sh -xc rm\ -rf\ fileio.dir}
|
||||||
|
+remote_exec build {sh -xc mkdir\ -m777\ fileio.dir}
|
||||||
|
|
||||||
|
set oldtimeout $timeout
|
||||||
|
set timeout [expr "$timeout + 60"]
|
||||||
|
@@ -88,7 +88,7 @@ gdb_test continue \
|
||||||
|
"Opening nonexistant file returns ENOENT"
|
||||||
|
|
||||||
|
send_gdb "continue\n" ; gdb_expect -re "$gdb_prompt $"
|
||||||
|
-catch "system \"chmod -f -w nowrt.fileio.test\""
|
||||||
|
+catch "system \"chmod -f -w fileio.dir/nowrt.fileio.test\""
|
||||||
|
|
||||||
|
gdb_test continue \
|
||||||
|
"Continuing\\..*open 5:.*EACCES$stop_msg" \
|
||||||
|
@@ -252,8 +252,8 @@ gdb_test continue \
|
||||||
|
send_gdb "quit\n"
|
||||||
|
send_gdb "y\n"
|
||||||
|
|
||||||
|
-remote_exec build {sh -xc test\ -r\ dir2.fileio.test\ &&\ chmod\ -f\ +w\ dir2.fileio.test}
|
||||||
|
-remote_exec build {sh -xc rm\ -rf\ *.fileio.test}
|
||||||
|
+remote_exec build {sh -xc test\ -r\ fileio.dir/dir2.fileio.test\ &&\ chmod\ -f\ +w\ fileio.dir/dir2.fileio.test}
|
||||||
|
+remote_exec build {sh -xc rm\ -rf\ fileio.dir}
|
||||||
|
|
||||||
|
set timeout $oldtimeout
|
||||||
|
return 0
|
||||||
|
--- sources/gdb/testsuite/gdb.base/dump.exp-orig 2008-08-28 11:44:40.000000000 +0200
|
||||||
|
+++ sources/gdb/testsuite/gdb.base/dump.exp 2008-08-28 11:44:49.000000000 +0200
|
||||||
|
@@ -493,8 +493,10 @@ if ![string compare $is64bitonly "no"] t
|
||||||
|
gdb_test "print zero_all ()" "" ""
|
||||||
|
|
||||||
|
# restore with expressions
|
||||||
|
+ # Address may fit in int32 but its negative result would be 0xffffxxxx for
|
||||||
|
+ # 64-bit LONGEST addresses.
|
||||||
|
test_restore_saved_value \
|
||||||
|
- "intarr3.srec ${array2_start}-${array_start} &intarray\[3\] &intarray\[4\]" \
|
||||||
|
+ "intarr3.srec (long)${array2_start}-${array_start} &intarray\[3\] &intarray\[4\]" \
|
||||||
|
"array partial with expressions" 4 "intarray2\[3\]"
|
||||||
|
|
||||||
|
gdb_test "print intarray2\[2\] == 0" " = 1" "element 2 not changed, == 4"
|
||||||
|
--- gdb-6.8.50.20090209/gdb/testsuite/gdb.base/annota1.exp-orig 2009-02-09 16:31:11.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090209/gdb/testsuite/gdb.base/annota1.exp 2009-02-09 21:27:38.000000000 +0100
|
||||||
|
@@ -286,7 +286,7 @@ if [target_info exists gdb,nosignals] {
|
||||||
|
} else {
|
||||||
|
send_gdb "signal SIGUSR1\n"
|
||||||
|
gdb_expect {
|
||||||
|
- -re "\r\n\032\032post-prompt\r\nContinuing with signal SIGUSR1.\r\n\r\n\032\032starting\r\n\r\n\032\032frames-invalid\r\n\r\n\032\032breakpoint 2\r\n\r\nBreakpoint 2, \r\n\032\032frame-begin 0 $hex\r\n\r\n\032\032frame-function-name\r\nhandle_USR1\r\n\032\032frame-args\r\n \\(\r\n\032\032arg-begin\r\nsig\r\n\032\032arg-name-end\r\n=\r\n\032\032arg-value -\r\n$decimal\r\n\032\032arg-end\r\n\\)\r\n\032\032frame-source-begin\r\n at \r\n\032\032frame-source-file\r\n${escapedsrcfile}\r\n\032\032frame-source-file-end\r\n:\r\n\032\032frame-source-line\r\n.*\r\n\032\032frame-source-end\r\n\r\n\r\n\032\032source.*annota1.c:.*:.*:beg:$hex\r\n\r\n\032\032frame-end\r\n\r\n\032\032stopped\r\n$gdb_prompt$" \
|
||||||
|
+ -re "\r\n\032\032post-prompt\r\nContinuing with signal SIGUSR1.\r\n\r\n\032\032starting\r\n(\r\n\032\032frames-invalid\r\n)*\r\n\032\032breakpoint 2\r\n\r\nBreakpoint 2, \r\n\032\032frame-begin 0 $hex\r\n\r\n\032\032frame-function-name\r\nhandle_USR1\r\n\032\032frame-args\r\n \\(\r\n\032\032arg-begin\r\nsig\r\n\032\032arg-name-end\r\n=\r\n\032\032arg-value -\r\n$decimal\r\n\032\032arg-end\r\n\\)\r\n\032\032frame-source-begin\r\n at \r\n\032\032frame-source-file\r\n${escapedsrcfile}\r\n\032\032frame-source-file-end\r\n:\r\n\032\032frame-source-line\r\n.*\r\n\032\032frame-source-end\r\n\r\n\r\n\032\032source.*annota1.c:.*:.*:beg:$hex\r\n\r\n\032\032frame-end\r\n\r\n\032\032stopped\r\n$gdb_prompt$" \
|
||||||
|
{ pass "send SIGUSR1" }
|
||||||
|
-re "\r\n\032\032post-prompt\r\nContinuing with signal SIGUSR1.\r\n\r\n\032\032starting\r\n\r\n\032\032frames-invalid\r\n\r\n\032\032breakpoint 2\r\n\r\nBreakpoint 2, \r\n\032\032frame-begin 0 $hex\r\n\r\n\032\032frame-function-name\r\nhandle_USR1\r\n\032\032frame-args\r\n \\(\r\n\032\032arg-begin\r\nsig\r\n\032\032arg-name-end\r\n=\r\n\032\032arg-value -\r\n$decimal\r\n\032\032arg-end\r\n\\)\r\n\032\032frame-source-begin\r\n at \r\n\032\032frame-source-file\r\n.*${srcfile}\r\n\032\032frame-source-file-end\r\n:\r\n\032\032frame-source-line\r\n.*\r\n\032\032frame-source-end\r\n\r\n\r\n\032\032source.*annota1.c:.*:.*:beg:$hex\r\n\r\n\032\032frame-end\r\n\r\n\032\032stopped\r\n$gdb_prompt$" \
|
||||||
|
{ setup_xfail "*-*-*" 1270
|
||||||
|
--- ./gdb/testsuite/gdb.base/auxv.exp 2009-02-11 00:54:54.000000000 +0100
|
||||||
|
+++ ./gdb/testsuite/gdb.base/auxv.exp 2009-02-11 00:51:30.000000000 +0100
|
||||||
|
@@ -78,8 +78,10 @@ proc fetch_auxv {test} {
|
||||||
|
|
||||||
|
set auxv_lines {}
|
||||||
|
set bad -1
|
||||||
|
+ # Former trailing `\[\r\n\]+' may eat just \r leaving \n in the buffer
|
||||||
|
+ # corrupting the next matches.
|
||||||
|
if {[gdb_test_multiple "info auxv" $test {
|
||||||
|
- -re "info auxv\[\r\n\]+" {
|
||||||
|
+ -re "info auxv\r\n" {
|
||||||
|
exp_continue
|
||||||
|
}
|
||||||
|
-ex "The program has no auxiliary information now" {
|
||||||
|
@@ -94,20 +96,20 @@ proc fetch_auxv {test} {
|
||||||
|
set bad 1
|
||||||
|
exp_continue
|
||||||
|
}
|
||||||
|
- -re "^\[0-9\]+\[ \t\]+(AT_\[^ \t\]+)\[^\r\n\]+\[\r\n\]+" {
|
||||||
|
+ -re "^\[0-9\]+\[ \t\]+(AT_\[^ \t\]+)\[^\r\n\]+\r\n" {
|
||||||
|
lappend auxv_lines $expect_out(0,string)
|
||||||
|
exp_continue
|
||||||
|
}
|
||||||
|
- -re "^\[0-9\]+\[ \t\]+\\?\\?\\?\[^\r\n\]+\[\r\n\]+" {
|
||||||
|
+ -re "^\[0-9\]+\[ \t\]+\\?\\?\\?\[^\r\n\]+\r\n" {
|
||||||
|
warning "Unrecognized tag value: $expect_out(0,string)"
|
||||||
|
set bad 1
|
||||||
|
lappend auxv_lines $expect_out(0,string)
|
||||||
|
exp_continue
|
||||||
|
}
|
||||||
|
- -re ".*$gdb_prompt $" {
|
||||||
|
+ -re "$gdb_prompt $" {
|
||||||
|
incr bad
|
||||||
|
}
|
||||||
|
- -re "^\[^\r\n\]+\[\r\n\]+" {
|
||||||
|
+ -re "^\[^\r\n\]+\r\n" {
|
||||||
|
if {!$bad} {
|
||||||
|
warning "Unrecognized output: $expect_out(0,string)"
|
||||||
|
set bad 1
|
||||||
|
--- ./gdb/testsuite/gdb.base/callfuncs.exp 2009-01-03 06:58:03.000000000 +0100
|
||||||
|
+++ ./gdb/testsuite/gdb.base/callfuncs.exp 2009-02-11 00:51:42.000000000 +0100
|
||||||
|
@@ -249,15 +249,17 @@ proc fetch_all_registers {test} {
|
||||||
|
|
||||||
|
set all_registers_lines {}
|
||||||
|
set bad -1
|
||||||
|
+ # Former trailing `\[\r\n\]+' may eat just \r leaving \n in the buffer
|
||||||
|
+ # corrupting the next matches.
|
||||||
|
if {[gdb_test_multiple "info all-registers" $test {
|
||||||
|
- -re "info all-registers\[\r\n\]+" {
|
||||||
|
+ -re "info all-registers\r\n" {
|
||||||
|
exp_continue
|
||||||
|
}
|
||||||
|
-ex "The program has no registers now" {
|
||||||
|
set bad 1
|
||||||
|
exp_continue
|
||||||
|
}
|
||||||
|
- -re "^bspstore\[ \t\]+\[^\r\n\]+\[\r\n\]+" {
|
||||||
|
+ -re "^bspstore\[ \t\]+\[^\r\n\]+\r\n" {
|
||||||
|
if [istarget "ia64-*-*"] {
|
||||||
|
# Filter out bspstore which is specially tied to bsp,
|
||||||
|
# giving spurious differences.
|
||||||
|
@@ -266,14 +268,14 @@ proc fetch_all_registers {test} {
|
||||||
|
}
|
||||||
|
exp_continue
|
||||||
|
}
|
||||||
|
- -re "^\[^ \t\]+\[ \t\]+\[^\r\n\]+\[\r\n\]+" {
|
||||||
|
+ -re "^\[^ \t\]+\[ \t\]+\[^\r\n\]+\r\n" {
|
||||||
|
lappend all_registers_lines $expect_out(0,string)
|
||||||
|
exp_continue
|
||||||
|
}
|
||||||
|
- -re ".*$gdb_prompt $" {
|
||||||
|
+ -re "$gdb_prompt $" {
|
||||||
|
incr bad
|
||||||
|
}
|
||||||
|
- -re "^\[^\r\n\]+\[\r\n\]+" {
|
||||||
|
+ -re "^\[^\r\n\]+\r\n" {
|
||||||
|
if {!$bad} {
|
||||||
|
warning "Unrecognized output: $expect_out(0,string)"
|
||||||
|
set bad 1
|
183
gdb-6.8-attach-signalled-detach-stopped.patch
Normal file
183
gdb-6.8-attach-signalled-detach-stopped.patch
Normal file
@ -0,0 +1,183 @@
|
|||||||
|
Index: gdb-6.8.50.20090209/gdb/linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090209.orig/gdb/linux-nat.c 2009-02-09 16:12:23.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090209/gdb/linux-nat.c 2009-02-09 16:15:30.000000000 +0100
|
||||||
|
@@ -204,6 +204,9 @@ blocked. */
|
||||||
|
static struct target_ops *linux_ops;
|
||||||
|
static struct target_ops linux_ops_saved;
|
||||||
|
|
||||||
|
+/* PID of the inferior stopped by SIGSTOP before attaching (or zero). */
|
||||||
|
+static pid_t pid_was_stopped;
|
||||||
|
+
|
||||||
|
/* The method to call, if any, when a new thread is attached. */
|
||||||
|
static void (*linux_nat_new_thread) (ptid_t);
|
||||||
|
|
||||||
|
@@ -902,7 +905,14 @@ linux_child_follow_fork (struct target_o
|
||||||
|
fork_save_infrun_state (fp, 0);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
- target_detach (NULL, 0);
|
||||||
|
+ {
|
||||||
|
+ /* We should check PID_WAS_STOPPED and detach it stopped accordingly.
|
||||||
|
+ In this point of code it cannot be 1 as we would not get FORK
|
||||||
|
+ executed without CONTINUE first which resets PID_WAS_STOPPED.
|
||||||
|
+ We would have to first TARGET_STOP and WAITPID it as with running
|
||||||
|
+ inferior PTRACE_DETACH, SIGSTOP will ignore the signal. */
|
||||||
|
+ target_detach (NULL, 0);
|
||||||
|
+ }
|
||||||
|
|
||||||
|
inferior_ptid = ptid_build (child_pid, child_pid, 0);
|
||||||
|
|
||||||
|
@@ -1229,6 +1239,7 @@ linux_nat_post_attach_wait (ptid_t ptid,
|
||||||
|
if (debug_linux_nat)
|
||||||
|
fprintf_unfiltered (gdb_stdlog,
|
||||||
|
"LNPAW: Attaching to a stopped process\n");
|
||||||
|
+ pid_was_stopped = GET_PID (ptid);
|
||||||
|
|
||||||
|
/* The process is definitely stopped. It is in a job control
|
||||||
|
stop, unless the kernel predates the TASK_STOPPED /
|
||||||
|
@@ -1561,6 +1572,9 @@ GPT: lwp %s had signal %s, but it is in
|
||||||
|
*status = lp->status;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ if (*status == 0 && GET_PID (lp->ptid) == pid_was_stopped)
|
||||||
|
+ *status = W_STOPCODE (SIGSTOP);
|
||||||
|
+
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -1671,6 +1685,8 @@ linux_nat_detach (struct target_ops *ops
|
||||||
|
}
|
||||||
|
else
|
||||||
|
linux_ops->to_detach (ops, args, from_tty);
|
||||||
|
+
|
||||||
|
+ pid_was_stopped = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Resume LP. */
|
||||||
|
@@ -1825,6 +1841,14 @@ linux_nat_resume (ptid_t ptid, int step_
|
||||||
|
resume_callback. */
|
||||||
|
lp->stopped = 0;
|
||||||
|
|
||||||
|
+ /* At this point, we are going to resume the inferior and if we
|
||||||
|
+ have attached to a stopped process, we no longer should leave
|
||||||
|
+ it as stopped if the user detaches. PTID variable has PID set to LWP
|
||||||
|
+ while we need to check the real PID here. */
|
||||||
|
+
|
||||||
|
+ if (!step && lp && pid_was_stopped == GET_PID (lp->ptid))
|
||||||
|
+ pid_was_stopped = 0;
|
||||||
|
+
|
||||||
|
if (resume_all)
|
||||||
|
iterate_over_lwps (resume_callback, NULL);
|
||||||
|
|
||||||
|
@@ -3316,6 +3340,8 @@ linux_nat_mourn_inferior (struct target_
|
||||||
|
there are other viable forks to debug. Delete the exiting
|
||||||
|
one and context-switch to the first available. */
|
||||||
|
linux_fork_mourn_inferior ();
|
||||||
|
+
|
||||||
|
+ pid_was_stopped = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Convert a native/host siginfo object, into/from the siginfo in the
|
||||||
|
Index: gdb-6.8.50.20090209/gdb/testsuite/gdb.threads/attach-stopped.exp
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090209.orig/gdb/testsuite/gdb.threads/attach-stopped.exp 2009-01-03 06:58:07.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090209/gdb/testsuite/gdb.threads/attach-stopped.exp 2009-02-09 16:12:41.000000000 +0100
|
||||||
|
@@ -62,7 +62,65 @@ proc corefunc { threadtype } {
|
||||||
|
gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
gdb_load ${binfile}
|
||||||
|
|
||||||
|
- # Verify that we can attach to the stopped process.
|
||||||
|
+ # Verify that we can attach to the process by first giving its
|
||||||
|
+ # executable name via the file command, and using attach with the
|
||||||
|
+ # process ID.
|
||||||
|
+
|
||||||
|
+ set test "$threadtype: set file, before attach1 to stopped process"
|
||||||
|
+ gdb_test_multiple "file $binfile" "$test" {
|
||||||
|
+ -re "Load new symbol table from.*y or n. $" {
|
||||||
|
+ gdb_test "y" "Reading symbols from $escapedbinfile\.\.\.*done." \
|
||||||
|
+ "$test (re-read)"
|
||||||
|
+ }
|
||||||
|
+ -re "Reading symbols from $escapedbinfile\.\.\.*done.*$gdb_prompt $" {
|
||||||
|
+ pass "$test"
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ set test "$threadtype: attach1 to stopped, after setting file"
|
||||||
|
+ gdb_test_multiple "attach $testpid" "$test" {
|
||||||
|
+ -re "Attaching to program.*`?$escapedbinfile'?, process $testpid.*$gdb_prompt $" {
|
||||||
|
+ pass "$test"
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ # ".*sleep.*clone.*" would fail on s390x as bt stops at START_THREAD there.
|
||||||
|
+ if {[string equal $threadtype threaded]} {
|
||||||
|
+ gdb_test "thread apply all bt" ".*sleep.*start_thread.*" "$threadtype: attach1 to stopped bt"
|
||||||
|
+ } else {
|
||||||
|
+ gdb_test "bt" ".*sleep.*main.*" "$threadtype: attach1 to stopped bt"
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ # Exit and detach the process.
|
||||||
|
+
|
||||||
|
+ gdb_exit
|
||||||
|
+
|
||||||
|
+ # Avoid some race:
|
||||||
|
+ sleep 2
|
||||||
|
+
|
||||||
|
+ if [catch {open /proc/${testpid}/status r} fileid] {
|
||||||
|
+ set line2 "NOTFOUND"
|
||||||
|
+ } else {
|
||||||
|
+ gets $fileid line1;
|
||||||
|
+ gets $fileid line2;
|
||||||
|
+ close $fileid;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ set test "$threadtype: attach1, exit leaves process stopped"
|
||||||
|
+ if {[string match "*(stopped)*" $line2]} {
|
||||||
|
+ pass $test
|
||||||
|
+ } else {
|
||||||
|
+ fail $test
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ # At this point, the process should still be stopped
|
||||||
|
+
|
||||||
|
+ gdb_start
|
||||||
|
+ gdb_reinitialize_dir $srcdir/$subdir
|
||||||
|
+ gdb_load ${binfile}
|
||||||
|
+
|
||||||
|
+ # Verify that we can attach to the process just by giving the
|
||||||
|
+ # process ID.
|
||||||
|
|
||||||
|
set test "$threadtype: attach2 to stopped, after setting file"
|
||||||
|
gdb_test_multiple "attach $testpid" "$test" {
|
||||||
|
Index: gdb-6.8.50.20090209/gdb/testsuite/gdb.threads/attachstop-mt.exp
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20090209.orig/gdb/testsuite/gdb.threads/attachstop-mt.exp 2009-01-03 06:58:07.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20090209/gdb/testsuite/gdb.threads/attachstop-mt.exp 2009-02-09 16:12:41.000000000 +0100
|
||||||
|
@@ -176,12 +176,23 @@ gdb_test "bt" ".*sleep.*(func|main).*" "
|
||||||
|
# Exit and detach the process.
|
||||||
|
gdb_exit
|
||||||
|
|
||||||
|
-# Stop the program
|
||||||
|
-remote_exec build "kill -s STOP ${testpid}"
|
||||||
|
-
|
||||||
|
# No race
|
||||||
|
sleep 2
|
||||||
|
|
||||||
|
+set fileid3 [open $status2 r];
|
||||||
|
+gets $fileid3 line1;
|
||||||
|
+gets $fileid3 line2;
|
||||||
|
+close $fileid3;
|
||||||
|
+
|
||||||
|
+set test "attach3, exit leaves process stopped"
|
||||||
|
+if {[string match "*(stopped)*" $line2]} {
|
||||||
|
+ pass $test
|
||||||
|
+} else {
|
||||||
|
+ fail $test
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+# At this point, the process should still be stopped
|
||||||
|
+
|
||||||
|
# Continue the test as we would hit another expected bug regarding
|
||||||
|
# Program received signal SIGSTOP, Stopped (signal).
|
||||||
|
# across NPTL threads.
|
351
gdb-6.8-bz254229-gcore-prpsinfo.patch
Normal file
351
gdb-6.8-bz254229-gcore-prpsinfo.patch
Normal file
@ -0,0 +1,351 @@
|
|||||||
|
Index: gdb-6.8.50.20081209/bfd/elf-bfd.h
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081209.orig/bfd/elf-bfd.h 2008-12-03 15:50:57.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081209/bfd/elf-bfd.h 2008-12-10 01:35:08.000000000 +0100
|
||||||
|
@@ -2154,7 +2154,7 @@ extern Elf_Internal_Phdr * _bfd_elf_find
|
||||||
|
extern char *elfcore_write_note
|
||||||
|
(bfd *, char *, int *, const char *, int, const void *, int);
|
||||||
|
extern char *elfcore_write_prpsinfo
|
||||||
|
- (bfd *, char *, int *, const char *, const char *);
|
||||||
|
+ (bfd *, char *, int *, void *, const char *, const char *);
|
||||||
|
extern char *elfcore_write_prstatus
|
||||||
|
(bfd *, char *, int *, long, int, const void *);
|
||||||
|
extern char * elfcore_write_pstatus
|
||||||
|
Index: gdb-6.8.50.20081209/bfd/elf.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081209.orig/bfd/elf.c 2008-12-03 15:50:57.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081209/bfd/elf.c 2008-12-10 01:35:08.000000000 +0100
|
||||||
|
@@ -8345,6 +8345,7 @@ char *
|
||||||
|
elfcore_write_prpsinfo (bfd *abfd,
|
||||||
|
char *buf,
|
||||||
|
int *bufsiz,
|
||||||
|
+ void *info,
|
||||||
|
const char *fname,
|
||||||
|
const char *psargs)
|
||||||
|
{
|
||||||
|
@@ -8371,9 +8372,15 @@ elfcore_write_prpsinfo (bfd *abfd,
|
||||||
|
int note_type = NT_PRPSINFO;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
- memset (&data, 0, sizeof (data));
|
||||||
|
- strncpy (data.pr_fname, fname, sizeof (data.pr_fname));
|
||||||
|
- strncpy (data.pr_psargs, psargs, sizeof (data.pr_psargs));
|
||||||
|
+ if (info)
|
||||||
|
+ memcpy (&data, info, sizeof (data));
|
||||||
|
+ else
|
||||||
|
+ {
|
||||||
|
+ memset (&data, 0, sizeof (data));
|
||||||
|
+ strncpy (data.pr_fname, fname, sizeof (data.pr_fname));
|
||||||
|
+ strncpy (data.pr_psargs, psargs, sizeof (data.pr_psargs));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
return elfcore_write_note (abfd, buf, bufsiz,
|
||||||
|
note_name, note_type, &data, sizeof (data));
|
||||||
|
}
|
||||||
|
@@ -8388,9 +8395,15 @@ elfcore_write_prpsinfo (bfd *abfd,
|
||||||
|
int note_type = NT_PRPSINFO;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
- memset (&data, 0, sizeof (data));
|
||||||
|
- strncpy (data.pr_fname, fname, sizeof (data.pr_fname));
|
||||||
|
- strncpy (data.pr_psargs, psargs, sizeof (data.pr_psargs));
|
||||||
|
+ if (info)
|
||||||
|
+ memcpy (&data, info, sizeof (data));
|
||||||
|
+ else
|
||||||
|
+ {
|
||||||
|
+ memset (&data, 0, sizeof (data));
|
||||||
|
+ strncpy (data.pr_fname, fname, sizeof (data.pr_fname));
|
||||||
|
+ strncpy (data.pr_psargs, psargs, sizeof (data.pr_psargs));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
return elfcore_write_note (abfd, buf, bufsiz,
|
||||||
|
note_name, note_type, &data, sizeof (data));
|
||||||
|
}
|
||||||
|
Index: gdb-6.8.50.20081209/gdb/amd64-linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081209.orig/gdb/amd64-linux-nat.c 2008-12-10 01:28:28.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081209/gdb/amd64-linux-nat.c 2008-12-10 01:35:08.000000000 +0100
|
||||||
|
@@ -139,6 +139,7 @@ static int amd64_linux_gregset32_reg_off
|
||||||
|
|
||||||
|
static char *
|
||||||
|
amd64_linux_elfcore_write_prpsinfo (bfd *abfd, char *buf, int *bufsiz,
|
||||||
|
+ void *info,
|
||||||
|
const char *fname, const char *psargs)
|
||||||
|
{
|
||||||
|
if (gdbarch_ptr_bit(current_gdbarch) == 32)
|
||||||
|
@@ -148,14 +149,20 @@ amd64_linux_elfcore_write_prpsinfo (bfd
|
||||||
|
struct elf_prpsinfo32 data;
|
||||||
|
note_type = NT_PRPSINFO;
|
||||||
|
|
||||||
|
- memset (&data, 0, sizeof (data));
|
||||||
|
- strncpy (data.pr_fname, fname, sizeof (data.pr_fname));
|
||||||
|
- strncpy (data.pr_psargs, psargs, sizeof (data.pr_psargs));
|
||||||
|
+ if (info)
|
||||||
|
+ memcpy (&data, info, sizeof (data));
|
||||||
|
+ else
|
||||||
|
+ {
|
||||||
|
+ memset (&data, 0, sizeof (data));
|
||||||
|
+ strncpy (data.pr_fname, fname, sizeof (data.pr_fname));
|
||||||
|
+ strncpy (data.pr_psargs, psargs, sizeof (data.pr_psargs));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
return elfcore_write_note (abfd, buf, bufsiz,
|
||||||
|
note_name, note_type, &data, sizeof (data));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
- return elfcore_write_prpsinfo (abfd, buf, bufsiz, fname, psargs);
|
||||||
|
+ return elfcore_write_prpsinfo (abfd, buf, bufsiz, info, fname, psargs);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
Index: gdb-6.8.50.20081209/gdb/fbsd-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081209.orig/gdb/fbsd-nat.c 2008-10-28 16:22:12.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081209/gdb/fbsd-nat.c 2008-12-10 01:35:08.000000000 +0100
|
||||||
|
@@ -210,6 +210,7 @@ fbsd_make_corefile_notes (bfd *obfd, int
|
||||||
|
psargs = reconcat (psargs, psargs, " ", get_inferior_args (), NULL);
|
||||||
|
|
||||||
|
note_data = elfcore_write_prpsinfo (obfd, note_data, note_size,
|
||||||
|
+ NULL,
|
||||||
|
fname, psargs);
|
||||||
|
}
|
||||||
|
|
||||||
|
Index: gdb-6.8.50.20081209/gdb/linux-nat.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081209.orig/gdb/linux-nat.c 2008-12-10 01:28:14.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081209/gdb/linux-nat.c 2008-12-10 01:35:25.000000000 +0100
|
||||||
|
@@ -53,6 +53,7 @@
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include "gdb_dirent.h"
|
||||||
|
#include "xml-support.h"
|
||||||
|
+#include "gdb_procfs32.h" /* for struct elf_prpsinfo32 */
|
||||||
|
|
||||||
|
#ifdef HAVE_PERSONALITY
|
||||||
|
# include <sys/personality.h>
|
||||||
|
@@ -216,7 +217,7 @@ static LONGEST (*super_xfer_partial) (st
|
||||||
|
/* This functions make elfcore note sections.
|
||||||
|
They may get overriden by code adjusting data for multi-target builds. */
|
||||||
|
char *(*linux_elfcore_write_prpsinfo)
|
||||||
|
- (bfd *, char *, int *, const char *, const char *) = elfcore_write_prpsinfo;
|
||||||
|
+ (bfd *, char *, int *, void *, const char *, const char *) = elfcore_write_prpsinfo;
|
||||||
|
char *(*linux_elfcore_write_prstatus)
|
||||||
|
(bfd *, char *, int *, long, int, const void *) = elfcore_write_prstatus;
|
||||||
|
static char *
|
||||||
|
@@ -3614,6 +3615,159 @@ linux_nat_corefile_thread_callback (stru
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
+/* Should be always true for Linux */
|
||||||
|
+#define HAVE_PRPSINFO_T 1
|
||||||
|
+
|
||||||
|
+#if defined (HAVE_PRPSINFO_T)
|
||||||
|
+
|
||||||
|
+/* Fills struct elf_prpsinfo{32,64} as much as possible, imitate Linux kernel
|
||||||
|
+ binfmt_elf.c. Unknown values are filled with zeroes. The structure is
|
||||||
|
+ malloced. */
|
||||||
|
+
|
||||||
|
+static void*
|
||||||
|
+fill_prpsinfo (void)
|
||||||
|
+{
|
||||||
|
+ struct stat sb;
|
||||||
|
+ char filename[sizeof ("/proc//cmdline") + sizeof (int) * 3 + 2];
|
||||||
|
+ char buf[1024];
|
||||||
|
+ char proc_state[5];
|
||||||
|
+ char proc_cmdline[sizeof (((struct elf_prpsinfo*)0)->pr_psargs) + 1];
|
||||||
|
+ unsigned flags;
|
||||||
|
+ long proc_nice;
|
||||||
|
+ unsigned proc_ppid;
|
||||||
|
+ unsigned proc_pgid;
|
||||||
|
+ unsigned proc_sid;
|
||||||
|
+ pid_t pid;
|
||||||
|
+ int fd, n;
|
||||||
|
+ char *cp, *proc_comm, *state_s;
|
||||||
|
+ /* String comes from Linux kernel binfmt_elf.c FILL_PSINFO but it is already
|
||||||
|
+ obsolete there to <linux/sched.h> TASK_* constants. */
|
||||||
|
+ const char state_string[] = "RSDTZW";
|
||||||
|
+ int state_num;
|
||||||
|
+
|
||||||
|
+ /* Get /proc/$PID/stat. */
|
||||||
|
+ pid = ptid_get_pid (inferior_ptid);
|
||||||
|
+ sprintf (filename, "/proc/%u/stat", (unsigned)pid);
|
||||||
|
+ fd = open (filename, O_RDONLY);
|
||||||
|
+ if (fd < 0)
|
||||||
|
+ return NULL;
|
||||||
|
+ fstat (fd, &sb); /* No error checking (can it ever happen?). */
|
||||||
|
+ n = read (fd, buf, sizeof (buf) - 1);
|
||||||
|
+ close (fd);
|
||||||
|
+ if (n < 0)
|
||||||
|
+ return NULL;
|
||||||
|
+ buf[n] = 0;
|
||||||
|
+
|
||||||
|
+ cp = strrchr (buf, ')'); /* Split into "PID (COMM" and "<rest>". */
|
||||||
|
+ if (!cp)
|
||||||
|
+ return NULL;
|
||||||
|
+ *cp = 0;
|
||||||
|
+
|
||||||
|
+ /* Grab COMM. */
|
||||||
|
+ proc_comm = strchr (buf, '(');
|
||||||
|
+ if (!proc_comm)
|
||||||
|
+ return NULL;
|
||||||
|
+ proc_comm++;
|
||||||
|
+
|
||||||
|
+ /* Read /proc/$PID/cmdline. */
|
||||||
|
+ proc_cmdline[0] = 0;
|
||||||
|
+ strcpy (strrchr (filename, '/'), "/cmdline");
|
||||||
|
+ fd = open (filename, O_RDONLY);
|
||||||
|
+ if (fd >= 0)
|
||||||
|
+ {
|
||||||
|
+ int n;
|
||||||
|
+
|
||||||
|
+ n = read (fd, proc_cmdline, sizeof (proc_cmdline) - 1);
|
||||||
|
+ if (n < 0)
|
||||||
|
+ n = 0;
|
||||||
|
+ proc_cmdline[n] = 0;
|
||||||
|
+ while (n--) /* Replace NULs with spaces. */
|
||||||
|
+ if (proc_cmdline[n] == 0)
|
||||||
|
+ proc_cmdline[n] = ' ';
|
||||||
|
+ close (fd);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /* Parse /proc/$PID/stat. */
|
||||||
|
+ n = sscanf (cp + 2, /* skip ") " */
|
||||||
|
+ "%4s %u " /* state, ppid */
|
||||||
|
+ "%u %u %*s %*s " /* pgid, sid, tty, tpgid */
|
||||||
|
+ "%u %*s %*s %*s " /* flags, min_flt, cmin_flt, maj_flt */
|
||||||
|
+ "%*s " /* cmaj_flt */
|
||||||
|
+ "%*s %*s " /* utime, stime */
|
||||||
|
+ "%*s %*s %*s " /* cutime, cstime, priority */
|
||||||
|
+ "%ld " /* nice */
|
||||||
|
+ /*"%*s %*s " timeout, it_real_value */
|
||||||
|
+ /*"%lu " start_time */
|
||||||
|
+ /*"%lu " vsize */
|
||||||
|
+ /*"%lu " rss */
|
||||||
|
+ /*"%lu %lu %lu " rss_rlim, start_code, end_code */
|
||||||
|
+ /*"%lu %lu %lu " start_stack, kstk_esp, kstk_eip */
|
||||||
|
+ /*"%u %u %u %u " signal, blocked, sigignore, sigcatch */
|
||||||
|
+ /*"%lu %lu %lu" wchan, nswap, cnswap */
|
||||||
|
+ , proc_state, &proc_ppid,
|
||||||
|
+ &proc_pgid, &proc_sid,
|
||||||
|
+ &flags,
|
||||||
|
+ &proc_nice);
|
||||||
|
+ if (n != 6)
|
||||||
|
+ return NULL;
|
||||||
|
+
|
||||||
|
+ state_s = strchr (state_string, proc_state[0]);
|
||||||
|
+ if (state_s != NULL)
|
||||||
|
+ state_num = state_s - state_string;
|
||||||
|
+ else
|
||||||
|
+ {
|
||||||
|
+ /* 0 means Running, some more unusal state would be better. */
|
||||||
|
+ state_num = 0;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+#if ULONG_MAX > 0xffffffffU
|
||||||
|
+ /* We skip this code on 32-bit gdb. */
|
||||||
|
+ if (gdbarch_ptr_bit (current_gdbarch) == 64)
|
||||||
|
+ {
|
||||||
|
+ struct elf_prpsinfo *info = xzalloc (sizeof (*info));
|
||||||
|
+
|
||||||
|
+ info->pr_state = state_num;
|
||||||
|
+ info->pr_sname = proc_state[0];
|
||||||
|
+ info->pr_zomb = (proc_state[0] == 'Z');
|
||||||
|
+ info->pr_nice = proc_nice;
|
||||||
|
+ info->pr_flag = flags;
|
||||||
|
+ info->pr_uid = sb.st_uid;
|
||||||
|
+ info->pr_gid = sb.st_gid;
|
||||||
|
+ info->pr_pid = pid;
|
||||||
|
+ info->pr_ppid = proc_ppid;
|
||||||
|
+ info->pr_pgrp = proc_pgid;
|
||||||
|
+ info->pr_sid = proc_sid;
|
||||||
|
+ strncpy (info->pr_fname, proc_comm, sizeof (info->pr_fname));
|
||||||
|
+ strncpy (info->pr_psargs, proc_cmdline, sizeof (info->pr_psargs));
|
||||||
|
+
|
||||||
|
+ return info;
|
||||||
|
+ }
|
||||||
|
+#endif
|
||||||
|
+ if (gdbarch_ptr_bit (current_gdbarch) == 32)
|
||||||
|
+ {
|
||||||
|
+ struct elf_prpsinfo32 *info = xzalloc (sizeof (*info));
|
||||||
|
+
|
||||||
|
+ info->pr_state = state_num;
|
||||||
|
+ info->pr_sname = proc_state[0];
|
||||||
|
+ info->pr_zomb = (proc_state[0] == 'Z');
|
||||||
|
+ info->pr_nice = proc_nice;
|
||||||
|
+ info->pr_flag = flags;
|
||||||
|
+ info->pr_uid = sb.st_uid;
|
||||||
|
+ info->pr_gid = sb.st_gid;
|
||||||
|
+ info->pr_pid = pid;
|
||||||
|
+ info->pr_ppid = proc_ppid;
|
||||||
|
+ info->pr_pgrp = proc_pgid;
|
||||||
|
+ info->pr_sid = proc_sid;
|
||||||
|
+ strncpy (info->pr_fname, proc_comm, sizeof (info->pr_fname));
|
||||||
|
+ strncpy (info->pr_psargs, proc_cmdline, sizeof (info->pr_psargs));
|
||||||
|
+
|
||||||
|
+ return info;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return NULL;
|
||||||
|
+}
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
/* Fills the "to_make_corefile_note" target vector. Builds the note
|
||||||
|
section for a corefile, and returns it in a malloc buffer. */
|
||||||
|
|
||||||
|
@@ -3633,8 +3787,14 @@ linux_nat_make_corefile_notes (bfd *obfd
|
||||||
|
|
||||||
|
if (get_exec_file (0))
|
||||||
|
{
|
||||||
|
+#if defined (HAVE_PRPSINFO_T)
|
||||||
|
+ void *data = fill_prpsinfo ();
|
||||||
|
+#define DATAPTR data
|
||||||
|
+#else
|
||||||
|
+#define DATAPTR NULL
|
||||||
|
strncpy (fname, strrchr (get_exec_file (0), '/') + 1, sizeof (fname));
|
||||||
|
strncpy (psargs, get_exec_file (0), sizeof (psargs));
|
||||||
|
+#endif
|
||||||
|
if (get_inferior_args ())
|
||||||
|
{
|
||||||
|
char *string_end;
|
||||||
|
@@ -3650,9 +3810,15 @@ linux_nat_make_corefile_notes (bfd *obfd
|
||||||
|
psargs_end - string_end);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
- note_data = (char *) linux_elfcore_write_prpsinfo (obfd, note_data,
|
||||||
|
- note_size, fname,
|
||||||
|
+ note_data = (char *) linux_elfcore_write_prpsinfo (obfd,
|
||||||
|
+ note_data, note_size,
|
||||||
|
+ DATAPTR,
|
||||||
|
+ fname,
|
||||||
|
psargs);
|
||||||
|
+#if defined (HAVE_PRPSINFO_T)
|
||||||
|
+ xfree (DATAPTR);
|
||||||
|
+#endif
|
||||||
|
+#undef DATAPTR
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Dump information for threads. */
|
||||||
|
Index: gdb-6.8.50.20081209/gdb/linux-nat.h
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081209.orig/gdb/linux-nat.h 2008-12-10 01:27:33.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081209/gdb/linux-nat.h 2008-12-10 01:35:08.000000000 +0100
|
||||||
|
@@ -138,7 +138,7 @@ struct siginfo *linux_nat_get_siginfo (p
|
||||||
|
/* These functions make elfcore note sections.
|
||||||
|
They may get overriden by code adjusting data for multi-target builds. */
|
||||||
|
extern char *(*linux_elfcore_write_prpsinfo)
|
||||||
|
- (bfd *, char *, int *, const char *, const char *);
|
||||||
|
+ (bfd *, char *, int *, void *, const char *, const char *);
|
||||||
|
extern char *(*linux_elfcore_write_prstatus)
|
||||||
|
(bfd *, char *, int *, long, int, const void *);
|
||||||
|
extern char *(*linux_elfcore_write_prfpreg)
|
||||||
|
Index: gdb-6.8.50.20081209/gdb/procfs.c
|
||||||
|
===================================================================
|
||||||
|
--- gdb-6.8.50.20081209.orig/gdb/procfs.c 2008-11-09 12:27:17.000000000 +0100
|
||||||
|
+++ gdb-6.8.50.20081209/gdb/procfs.c 2008-12-10 01:35:08.000000000 +0100
|
||||||
|
@@ -6181,6 +6181,7 @@ procfs_make_note_section (bfd *obfd, int
|
||||||
|
note_data = (char *) elfcore_write_prpsinfo (obfd,
|
||||||
|
note_data,
|
||||||
|
note_size,
|
||||||
|
+ NULL,
|
||||||
|
fname,
|
||||||
|
psargs);
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user