- Fix unwinding of non-debug (.eh_frame) PPC code, Andreas Schwab (BZ
140532). - Fix unwinding of debug (.debug_frame) PPC code, workaround GCC (BZ 140532). - Fix missing testsuite .log output of testcases using get_compiler_info(). - Resolves: rhbz#140532
This commit is contained in:
parent
48f079c103
commit
4dddad4251
141
gdb-6.5-bz140532-ppc-debug_frame-return_address-test.patch
Normal file
141
gdb-6.5-bz140532-ppc-debug_frame-return_address-test.patch
Normal file
@ -0,0 +1,141 @@
|
|||||||
|
2007-01-13 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* gdb.base/bt-ppc.c, gdb.base/bt-ppc.exp: New files.
|
||||||
|
|
||||||
|
|
||||||
|
diff -u -rupN gdb-6.5-ppc/gdb/testsuite/gdb.base/bt-ppc.c gdb-6.5/gdb/testsuite/gdb.base/bt-ppc.c
|
||||||
|
--- gdb-6.5-ppc/gdb/testsuite/gdb.base/bt-ppc.c 1969-12-31 19:00:00.000000000 -0500
|
||||||
|
+++ gdb-6.5/gdb/testsuite/gdb.base/bt-ppc.c 2007-01-12 21:34:55.000000000 -0500
|
||||||
|
@@ -0,0 +1,41 @@
|
||||||
|
+/* 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 <stdlib.h>
|
||||||
|
+
|
||||||
|
+/* Force `-fpie' double jump bl->blrl. */
|
||||||
|
+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;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int main (void)
|
||||||
|
+{
|
||||||
|
+ func1 ();
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
diff -u -rupN gdb-6.5-ppc/gdb/testsuite/gdb.base/bt-ppc.exp gdb-6.5/gdb/testsuite/gdb.base/bt-ppc.exp
|
||||||
|
--- gdb-6.5-ppc/gdb/testsuite/gdb.base/bt-ppc.exp 1969-12-31 19:00:00.000000000 -0500
|
||||||
|
+++ gdb-6.5/gdb/testsuite/gdb.base/bt-ppc.exp 2007-01-12 21:27:25.000000000 -0500
|
||||||
|
@@ -0,0 +1,86 @@
|
||||||
|
+# 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 multiple unwinding fixes of PPC platform.
|
||||||
|
+# As the tests are platform independent we can run it everywhere.
|
||||||
|
+
|
||||||
|
+if $tracelevel then {
|
||||||
|
+ strace $tracelevel
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+set prms_id 0
|
||||||
|
+set bug_id 0
|
||||||
|
+
|
||||||
|
+# This test uses GCC-specific syntax.
|
||||||
|
+if [get_compiler_info not-used] {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if {![test_compiler_info "gcc-*"]} {
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+proc do_test { opts addons } {
|
||||||
|
+ global objdir srcdir subdir gdb_prompt
|
||||||
|
+
|
||||||
|
+ set testfile "bt-ppc"
|
||||||
|
+ set srcfile ${testfile}.c
|
||||||
|
+ set binfile ${objdir}/${subdir}/${testfile}
|
||||||
|
+
|
||||||
|
+ # `additional_flags' should be last as it eats arguments till eol.
|
||||||
|
+ if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" ${binfile} executable [list $opts additional_flags=$addons]] != ""} {
|
||||||
|
+ 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 show [concat $opts $addons]
|
||||||
|
+ gdb_test_multiple "bt" "Correct unwind for: $show" {
|
||||||
|
+ -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 "Correct unwind for: $show"
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+foreach eh_frame {{-fno-asynchronous-unwind-tables}
|
||||||
|
+ {-fasynchronous-unwind-tables}} {
|
||||||
|
+ foreach pie {{} {-fpie -pie}} {
|
||||||
|
+ foreach optim {{} {-O2}} {
|
||||||
|
+ foreach is_debug {{} {debug}} {
|
||||||
|
+ do_test $is_debug [concat $eh_frame $pie $optim]
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+}
|
145
gdb-6.5-bz140532-ppc-debug_frame-return_address.patch
Normal file
145
gdb-6.5-bz140532-ppc-debug_frame-return_address.patch
Normal file
@ -0,0 +1,145 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=140532
|
||||||
|
|
||||||
|
|
||||||
|
2007-01-13 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* dwarf2-frame.c (decode_frame_entry_1): Call
|
||||||
|
dwarf2_frame_return_address_regnum when processing CIE return address.
|
||||||
|
(struct dwarf2_frame_ops): Add return_address_regnum.
|
||||||
|
(dwarf2_frame_set_return_address_regnum): Define.
|
||||||
|
(dwarf2_frame_return_address_regnum): Define.
|
||||||
|
* dwarf2-frame.h (dwarf2_frame_set_return_address_regnum): Declare.
|
||||||
|
(dwarf2_frame_return_address_regnum): Declare.
|
||||||
|
* rs6000-tdep.c (rs6000_dwarf2_reg_to_regnum): Map also 64(CR) and
|
||||||
|
65(FPSCR) DWARF2 registers.
|
||||||
|
(rs6000_return_address_regnum): Define.
|
||||||
|
(rs6000_gdbarch_init): Register rs6000_return_address_regnum.
|
||||||
|
|
||||||
|
|
||||||
|
--- gdb-6.5-ppc/gdb/dwarf2-frame.c 2007-01-12 14:40:32.000000000 -0500
|
||||||
|
+++ gdb-6.5/gdb/dwarf2-frame.c 2007-01-12 18:46:32.000000000 -0500
|
||||||
|
@@ -586,6 +586,10 @@ struct dwarf2_frame_ops
|
||||||
|
|
||||||
|
/* Convert .eh_frame register number to DWARF register number. */
|
||||||
|
int (*eh_frame_regnum) (struct gdbarch *, int);
|
||||||
|
+
|
||||||
|
+ /* Convert .eh_frame/.debug_frame CIE return address register number to DWARF
|
||||||
|
+ register number. */
|
||||||
|
+ int (*return_address_regnum) (struct gdbarch *, int, int);
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Default architecture-specific register state initialization
|
||||||
|
@@ -693,6 +697,32 @@ dwarf2_frame_signal_frame_p (struct gdba
|
||||||
|
return ops->signal_frame_p (gdbarch, next_frame);
|
||||||
|
}
|
||||||
|
|
||||||
|
+/* Set the architecture-specific mapping of .eh_frame/.debug_frame CIE return
|
||||||
|
+ address register number to DWARF register number. */
|
||||||
|
+
|
||||||
|
+void
|
||||||
|
+dwarf2_frame_set_return_address_regnum (struct gdbarch *gdbarch,
|
||||||
|
+ int (*return_address_regnum)
|
||||||
|
+ (struct gdbarch *, int, int))
|
||||||
|
+{
|
||||||
|
+ struct dwarf2_frame_ops *ops = gdbarch_data (gdbarch, dwarf2_frame_data);
|
||||||
|
+
|
||||||
|
+ ops->return_address_regnum = return_address_regnum;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+/* Translate a .eh_frame/.debug_frame CIE register to DWARF register. */
|
||||||
|
+
|
||||||
|
+int
|
||||||
|
+dwarf2_frame_return_address_regnum (struct gdbarch *gdbarch, int regnum,
|
||||||
|
+ int eh_frame_p)
|
||||||
|
+{
|
||||||
|
+ struct dwarf2_frame_ops *ops = gdbarch_data (gdbarch, dwarf2_frame_data);
|
||||||
|
+
|
||||||
|
+ if (ops->return_address_regnum == NULL)
|
||||||
|
+ return regnum;
|
||||||
|
+ return ops->return_address_regnum (gdbarch, regnum, eh_frame_p);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
/* Set the architecture-specific mapping of .eh_frame register numbers to
|
||||||
|
DWARF register numbers. */
|
||||||
|
|
||||||
|
@@ -1618,6 +1648,11 @@ decode_frame_entry_1 (struct comp_unit *
|
||||||
|
else
|
||||||
|
cie->return_address_register = read_unsigned_leb128 (unit->abfd, buf,
|
||||||
|
&bytes_read);
|
||||||
|
+
|
||||||
|
+ cie->return_address_register
|
||||||
|
+ = dwarf2_frame_return_address_regnum (current_gdbarch,
|
||||||
|
+ cie->return_address_register,
|
||||||
|
+ eh_frame_p);
|
||||||
|
if (eh_frame_p)
|
||||||
|
cie->return_address_register
|
||||||
|
= dwarf2_frame_eh_frame_regnum (current_gdbarch,
|
||||||
|
--- gdb-6.5-ppc/gdb/dwarf2-frame.h 2007-01-12 14:40:32.000000000 -0500
|
||||||
|
+++ gdb-6.5/gdb/dwarf2-frame.h 2007-01-12 18:36:47.000000000 -0500
|
||||||
|
@@ -107,6 +107,20 @@ extern void
|
||||||
|
extern int
|
||||||
|
dwarf2_frame_eh_frame_regnum (struct gdbarch *gdbarch, int regnum);
|
||||||
|
|
||||||
|
+/* Set the architecture-specific mapping of .eh_frame/.debug_frame CIE return
|
||||||
|
+ address register number to DWARF register number. */
|
||||||
|
+
|
||||||
|
+extern void
|
||||||
|
+ dwarf2_frame_set_return_address_regnum (struct gdbarch *gdbarch,
|
||||||
|
+ int (*return_address_regnum)
|
||||||
|
+ (struct gdbarch *, int, int));
|
||||||
|
+
|
||||||
|
+/* Translate a .eh_frame/.debug_frame CIE register to DWARF register. */
|
||||||
|
+
|
||||||
|
+extern int
|
||||||
|
+ dwarf2_frame_return_address_regnum (struct gdbarch *gdbarch, int regnum,
|
||||||
|
+ int eh_frame_p);
|
||||||
|
+
|
||||||
|
/* Return the frame unwind methods for the function that contains PC,
|
||||||
|
or NULL if it can't be handled by DWARF CFI frame unwinder. */
|
||||||
|
|
||||||
|
--- gdb-6.5-ppc/gdb/rs6000-tdep.c 2007-01-12 14:40:32.000000000 -0500
|
||||||
|
+++ gdb-6.5/gdb/rs6000-tdep.c 2007-01-12 18:44:21.000000000 -0500
|
||||||
|
@@ -2307,6 +2307,11 @@ rs6000_dwarf2_reg_to_regnum (int num)
|
||||||
|
else
|
||||||
|
switch (num)
|
||||||
|
{
|
||||||
|
+ case 64:
|
||||||
|
+ return tdep->ppc_cr_regnum;
|
||||||
|
+ /* Broken GCC uses it for CIE `Return address column' as LR. */
|
||||||
|
+ case 65:
|
||||||
|
+ return tdep->ppc_fpscr_regnum;
|
||||||
|
case 67:
|
||||||
|
return tdep->ppc_vrsave_regnum - 1; /* vscr */
|
||||||
|
case 99:
|
||||||
|
@@ -2363,6 +2368,22 @@ rs6000_eh_frame_regnum (struct gdbarch *
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
+/* Convert a .eh_frame/.debug_frame CIE return address register number to DWARF
|
||||||
|
+ register number. */
|
||||||
|
+static int
|
||||||
|
+rs6000_return_address_regnum (struct gdbarch *gdbarch, int regnum,
|
||||||
|
+ int eh_frame_p)
|
||||||
|
+{
|
||||||
|
+ if (eh_frame_p != 0)
|
||||||
|
+ return regnum;
|
||||||
|
+
|
||||||
|
+ /* Broken GCC uses it for CIE `Return address column' as LR. */
|
||||||
|
+ if (regnum == 65)
|
||||||
|
+ return 108;
|
||||||
|
+
|
||||||
|
+ return regnum;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
static void
|
||||||
|
rs6000_store_return_value (struct type *type,
|
||||||
|
struct regcache *regcache,
|
||||||
|
@@ -3584,6 +3605,8 @@ rs6000_gdbarch_init (struct gdbarch_info
|
||||||
|
/* Hook in the DWARF CFI frame unwinder. */
|
||||||
|
frame_unwind_append_sniffer (gdbarch, dwarf2_frame_sniffer);
|
||||||
|
dwarf2_frame_set_eh_frame_regnum (gdbarch, rs6000_eh_frame_regnum);
|
||||||
|
+ dwarf2_frame_set_return_address_regnum (gdbarch,
|
||||||
|
+ rs6000_return_address_regnum);
|
||||||
|
|
||||||
|
/* Hook in ABI-specific overrides, if they have been registered. */
|
||||||
|
gdbarch_init_osabi (info, gdbarch);
|
91
gdb-6.5-bz140532-ppc-eh_frame-regnum.patch
Normal file
91
gdb-6.5-bz140532-ppc-eh_frame-regnum.patch
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=140532
|
||||||
|
|
||||||
|
|
||||||
|
2006-05-09 Andreas Schwab <schwab@suse.de>
|
||||||
|
|
||||||
|
* rs6000-tdep.c: Include "dwarf2-frame.h".
|
||||||
|
(rs6000_eh_frame_regnum): Define.
|
||||||
|
(rs6000_gdbarch_init): Enable use of DWARF CFI frame unwinder.
|
||||||
|
Register rs6000_eh_frame_regnum.
|
||||||
|
|
||||||
|
* Makefile.in (rs6000-tdep.o): Update dependencies.
|
||||||
|
|
||||||
|
|
||||||
|
http://sourceware.org/ml/gdb-patches/2006-05/msg00341.html
|
||||||
|
Selectively enabling them on platforms that are unlikely to have ever
|
||||||
|
used GCC versions before 3.4 should be fine.
|
||||||
|
|
||||||
|
|
||||||
|
--- ./gdb/Makefile.in 5 May 2006 22:39:12 -0000 1.812
|
||||||
|
+++ ./gdb/Makefile.in 9 May 2006 14:10:40 -0000
|
||||||
|
@@ -2515,7 +2515,7 @@ rs6000-tdep.o: rs6000-tdep.c $(defs_h) $
|
||||||
|
$(reggroups_h) $(libbfd_h) $(coff_internal_h) $(libcoff_h) \
|
||||||
|
$(coff_xcoff_h) $(libxcoff_h) $(elf_bfd_h) $(solib_svr4_h) \
|
||||||
|
$(ppc_tdep_h) $(gdb_assert_h) $(dis_asm_h) $(trad_frame_h) \
|
||||||
|
- $(frame_unwind_h) $(frame_base_h) $(rs6000_tdep_h)
|
||||||
|
+ $(frame_unwind_h) $(frame_base_h) $(rs6000_tdep_h) $(dwarf2_frame_h)
|
||||||
|
rs6000-aix-tdep.o: rs6000-aix-tdep.c $(defs_h) $(osabi_h) $(rs6000_tdep_h)
|
||||||
|
s390-nat.o: s390-nat.c $(defs_h) $(tm_h) $(regcache_h) $(inferior_h) \
|
||||||
|
$(s390_tdep_h) $(target_h) $(linux_nat_h)
|
||||||
|
--- ./gdb/rs6000-tdep.c 23 Apr 2006 14:15:01 -0000 1.258
|
||||||
|
+++ ./gdb/rs6000-tdep.c 9 May 2006 14:10:15 -0000
|
||||||
|
@@ -40,6 +40,7 @@
|
||||||
|
#include "sim-regno.h"
|
||||||
|
#include "gdb/sim-ppc.h"
|
||||||
|
#include "reggroups.h"
|
||||||
|
+#include "dwarf2-frame.h"
|
||||||
|
|
||||||
|
#include "libbfd.h" /* for bfd_default_set_arch_mach */
|
||||||
|
#include "coff/internal.h" /* for libcoff.h */
|
||||||
|
@@ -2243,6 +2244,40 @@ rs6000_dwarf2_reg_to_regnum (int num)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
+/* Convert a .eh_frame register number to a Dwarf 2 register number. */
|
||||||
|
+static int
|
||||||
|
+rs6000_eh_frame_regnum (struct gdbarch *gdbarch, int num)
|
||||||
|
+{
|
||||||
|
+ if (0 <= num && num <= 63) /* r0-r31,fp0-fp31 */
|
||||||
|
+ return num;
|
||||||
|
+ else if (68 <= num && num <= 75) /* cr0-cr8 */
|
||||||
|
+ return num - 68 + 86;
|
||||||
|
+ else if (77 <= num && num <= 108) /* vr0-vr31 */
|
||||||
|
+ return num - 77 + 1124;
|
||||||
|
+ else
|
||||||
|
+ switch (num)
|
||||||
|
+ {
|
||||||
|
+ case 64: /* mq */
|
||||||
|
+ return 100;
|
||||||
|
+ case 65: /* lr */
|
||||||
|
+ return 108;
|
||||||
|
+ case 66: /* ctr */
|
||||||
|
+ return 109;
|
||||||
|
+ case 76: /* xer */
|
||||||
|
+ return 101;
|
||||||
|
+ case 109: /* vrsave */
|
||||||
|
+ return 356;
|
||||||
|
+ case 110: /* vscr */
|
||||||
|
+ return 67;
|
||||||
|
+ case 111: /* spe_acc */
|
||||||
|
+ return 99;
|
||||||
|
+ case 112: /* spefscr */
|
||||||
|
+ return 612;
|
||||||
|
+ default:
|
||||||
|
+ return num;
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
static void
|
||||||
|
rs6000_store_return_value (struct type *type,
|
||||||
|
struct regcache *regcache,
|
||||||
|
@@ -3461,6 +3496,10 @@ rs6000_gdbarch_init (struct gdbarch_info
|
||||||
|
/* Helpers for function argument information. */
|
||||||
|
set_gdbarch_fetch_pointer_argument (gdbarch, rs6000_fetch_pointer_argument);
|
||||||
|
|
||||||
|
+ /* Hook in the DWARF CFI frame unwinder. */
|
||||||
|
+ frame_unwind_append_sniffer (gdbarch, dwarf2_frame_sniffer);
|
||||||
|
+ dwarf2_frame_set_eh_frame_regnum (gdbarch, rs6000_eh_frame_regnum);
|
||||||
|
+
|
||||||
|
/* Hook in ABI-specific overrides, if they have been registered. */
|
||||||
|
gdbarch_init_osabi (info, gdbarch);
|
||||||
|
|
20
gdb-6.5-testsuite-log.patch
Normal file
20
gdb-6.5-testsuite-log.patch
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
2007-01-13 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||||
|
|
||||||
|
* lib/gdb.exp (get_compiler_info): Cope with nondefault output logs.
|
||||||
|
|
||||||
|
|
||||||
|
diff -u -rupN gdb-6.5-ppc/gdb/testsuite/lib/gdb.exp gdb-6.5/gdb/testsuite/lib/gdb.exp
|
||||||
|
--- gdb-6.5-ppc/gdb/testsuite/lib/gdb.exp 2007-01-12 14:33:26.000000000 -0500
|
||||||
|
+++ gdb-6.5/gdb/testsuite/lib/gdb.exp 2007-01-12 21:15:02.000000000 -0500
|
||||||
|
@@ -1351,9 +1351,10 @@ proc get_compiler_info {binfile args} {
|
||||||
|
|
||||||
|
# Run $ifile through the right preprocessor.
|
||||||
|
# Toggle gdb.log to keep the compiler output out of the log.
|
||||||
|
+ set log_old [log_file -info]
|
||||||
|
log_file
|
||||||
|
set cppout [ gdb_compile "${ifile}" "" preprocess [list "$args" quiet] ]
|
||||||
|
- log_file -a "$outdir/$tool.log"
|
||||||
|
+ eval "log_file $log_old"
|
||||||
|
|
||||||
|
# Eval the output.
|
||||||
|
set unknown 0
|
23
gdb.spec
23
gdb.spec
@ -11,7 +11,7 @@ Name: gdb
|
|||||||
Version: 6.5
|
Version: 6.5
|
||||||
|
|
||||||
# The release always contains a leading reserved number, start it at 0.
|
# The release always contains a leading reserved number, start it at 0.
|
||||||
Release: 25%{?dist}
|
Release: 26%{?dist}
|
||||||
|
|
||||||
License: GPL
|
License: GPL
|
||||||
Group: Development/Debuggers
|
Group: Development/Debuggers
|
||||||
@ -106,9 +106,6 @@ Patch124: gdb-6.3-pie-20050110.patch
|
|||||||
# Get selftest working with sep-debug-info
|
# Get selftest working with sep-debug-info
|
||||||
Patch125: gdb-6.3-test-self-20050110.patch
|
Patch125: gdb-6.3-test-self-20050110.patch
|
||||||
|
|
||||||
# Enable PPC CFI support.
|
|
||||||
Patch127: gdb-6.3-ppccfi-20041104.patch
|
|
||||||
|
|
||||||
# Fix for non-threaded watchpoints.
|
# Fix for non-threaded watchpoints.
|
||||||
Patch128: gdb-6.3-nonthreaded-wp-20050117.patch
|
Patch128: gdb-6.3-nonthreaded-wp-20050117.patch
|
||||||
|
|
||||||
@ -324,6 +321,14 @@ Patch225: gdb-6.5-bz109921-DW_AT_decl_file-test.patch
|
|||||||
|
|
||||||
# Fix unwinding of non-CFI (w/o debuginfo) PPC code by recent GCC (BZ 140532).
|
# Fix unwinding of non-CFI (w/o debuginfo) PPC code by recent GCC (BZ 140532).
|
||||||
Patch226: gdb-6.3-bz140532-ppcnoncfi-skip_prologue-PIC.patch
|
Patch226: gdb-6.3-bz140532-ppcnoncfi-skip_prologue-PIC.patch
|
||||||
|
# Fix unwinding of non-debug (.eh_frame) PPC code, Andreas Schwab (BZ 140532).
|
||||||
|
Patch227: gdb-6.5-bz140532-ppc-eh_frame-regnum.patch
|
||||||
|
# Fix unwinding of debug (.debug_frame) PPC code, workaround GCC (BZ 140532).
|
||||||
|
Patch228: gdb-6.5-bz140532-ppc-debug_frame-return_address.patch
|
||||||
|
Patch229: gdb-6.5-bz140532-ppc-debug_frame-return_address-test.patch
|
||||||
|
|
||||||
|
# Fix missing testsuite .log output of testcases using get_compiler_info().
|
||||||
|
Patch230: gdb-6.5-testsuite-log.patch
|
||||||
|
|
||||||
BuildRequires: ncurses-devel glibc-devel gcc make gzip texinfo dejagnu gettext
|
BuildRequires: ncurses-devel glibc-devel gcc make gzip texinfo dejagnu gettext
|
||||||
BuildRequires: flex bison sharutils
|
BuildRequires: flex bison sharutils
|
||||||
@ -380,7 +385,6 @@ and printing their data.
|
|||||||
%patch122 -p1
|
%patch122 -p1
|
||||||
%patch124 -p1
|
%patch124 -p1
|
||||||
%patch125 -p1
|
%patch125 -p1
|
||||||
%patch127 -p1
|
|
||||||
%patch128 -p1
|
%patch128 -p1
|
||||||
%patch130 -p1
|
%patch130 -p1
|
||||||
%patch133 -p1
|
%patch133 -p1
|
||||||
@ -455,6 +459,10 @@ and printing their data.
|
|||||||
%patch224 -p1
|
%patch224 -p1
|
||||||
%patch225 -p1
|
%patch225 -p1
|
||||||
%patch226 -p1
|
%patch226 -p1
|
||||||
|
%patch227 -p1
|
||||||
|
%patch228 -p1
|
||||||
|
%patch229 -p1
|
||||||
|
%patch230 -p1
|
||||||
|
|
||||||
# Change the version that gets printed at GDB startup, so it is RedHat
|
# Change the version that gets printed at GDB startup, so it is RedHat
|
||||||
# specific.
|
# specific.
|
||||||
@ -617,6 +625,11 @@ fi
|
|||||||
# don't include the files in include, they are part of binutils
|
# don't include the files in include, they are part of binutils
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Fri Jan 13 2007 Jan Kratochvil <jan.kratochvil@redhat.com> - 6.5-26
|
||||||
|
- Fix unwinding of non-debug (.eh_frame) PPC code, Andreas Schwab (BZ 140532).
|
||||||
|
- Fix unwinding of debug (.debug_frame) PPC code, workaround GCC (BZ 140532).
|
||||||
|
- Fix missing testsuite .log output of testcases using get_compiler_info().
|
||||||
|
|
||||||
* Fri Jan 12 2007 Jan Kratochvil <jan.kratochvil@redhat.com> - 6.5-25
|
* Fri Jan 12 2007 Jan Kratochvil <jan.kratochvil@redhat.com> - 6.5-25
|
||||||
- Fix unwinding of non-CFI (w/o debuginfo) PPC code by recent GCC (BZ 140532).
|
- Fix unwinding of non-CFI (w/o debuginfo) PPC code by recent GCC (BZ 140532).
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user