- Rebase to FSF GDB 7.2.50.20110125 (which is a 7.3 pre-release).

- Fix discontiguous address ranges in .gdb_index - v3->v4 (BZ 672281).
- Fix DWARF-3+ DW_AT_accessibility default assumption for F15 gcc-4.6.
This commit is contained in:
Jan Kratochvil 2011-01-25 22:51:27 +01:00
parent f4677c421e
commit 8973456f5a
5 changed files with 152 additions and 125 deletions

2
.gitignore vendored
View File

@ -1,2 +1,2 @@
/libstdc++-v3-python-r155978.tar.bz2 /libstdc++-v3-python-r155978.tar.bz2
/gdb-7.2.50.20110117.tar.bz2 /gdb-7.2.50.20110125.tar.bz2

View File

@ -2,7 +2,7 @@ http://sourceware.org/gdb/wiki/ProjectArcher
http://sourceware.org/gdb/wiki/ArcherBranchManagement http://sourceware.org/gdb/wiki/ArcherBranchManagement
GIT snapshot: GIT snapshot:
commit ce88fe365322b0f7479c43eede6d3a0d337eb786 commit b3fa51e30637989ca4a8ee4763ba921322a1bd0d
branch `archer' - the merge of branches: branch `archer' - the merge of branches:
archer-jankratochvil-vla archer-jankratochvil-vla
@ -14,7 +14,7 @@ archer-tromey-python
diff --git a/gdb/Makefile.in b/gdb/Makefile.in diff --git a/gdb/Makefile.in b/gdb/Makefile.in
index 226faf6..03aaa2c 100644 index 36cc734..977fe0c 100644
--- a/gdb/Makefile.in --- a/gdb/Makefile.in
+++ b/gdb/Makefile.in +++ b/gdb/Makefile.in
@@ -783,7 +783,8 @@ annotate.h sim-regno.h dictionary.h dfp.h main.h frame-unwind.h \ @@ -783,7 +783,8 @@ annotate.h sim-regno.h dictionary.h dfp.h main.h frame-unwind.h \
@ -1123,7 +1123,7 @@ index 9409dde..f0fa4c7 100644
extern char *xfullpath (const char *); extern char *xfullpath (const char *);
diff --git a/gdb/doc/gdb.texinfo b/gdb/doc/gdb.texinfo diff --git a/gdb/doc/gdb.texinfo b/gdb/doc/gdb.texinfo
index d48d95c..4cac1ba 100644 index cc2391b..161ac1f 100644
--- a/gdb/doc/gdb.texinfo --- a/gdb/doc/gdb.texinfo
+++ b/gdb/doc/gdb.texinfo +++ b/gdb/doc/gdb.texinfo
@@ -1177,6 +1177,16 @@ for remote debugging. @@ -1177,6 +1177,16 @@ for remote debugging.
@ -1143,7 +1143,7 @@ index d48d95c..4cac1ba 100644
@c resolve the situation of these eventually @c resolve the situation of these eventually
@item -tui @item -tui
@cindex @code{--tui} @cindex @code{--tui}
@@ -20630,8 +20640,6 @@ containing @code{end}. For example: @@ -20652,8 +20662,6 @@ containing @code{end}. For example:
@smallexample @smallexample
(@value{GDBP}) python (@value{GDBP}) python
@ -1152,7 +1152,7 @@ index d48d95c..4cac1ba 100644
>print 23 >print 23
>end >end
23 23
@@ -20644,6 +20652,14 @@ in a Python script. This can be controlled using @code{maint set @@ -20666,6 +20674,14 @@ in a Python script. This can be controlled using @code{maint set
python print-stack}: if @code{on}, the default, then Python stack python print-stack}: if @code{on}, the default, then Python stack
printing is enabled; if @code{off}, then Python stack printing is printing is enabled; if @code{off}, then Python stack printing is
disabled. disabled.
@ -1167,7 +1167,7 @@ index d48d95c..4cac1ba 100644
@end table @end table
It is also possible to execute a Python script from the @value{GDBN} It is also possible to execute a Python script from the @value{GDBN}
@@ -20665,6 +20681,14 @@ and thus is always available. @@ -20687,6 +20703,14 @@ and thus is always available.
@cindex python api @cindex python api
@cindex programming in python @cindex programming in python
@ -3254,7 +3254,7 @@ index ad988d2..985fef6 100644
{ {
case TYPE_CODE_ARRAY: case TYPE_CODE_ARRAY:
diff --git a/gdb/f-valprint.c b/gdb/f-valprint.c diff --git a/gdb/f-valprint.c b/gdb/f-valprint.c
index 4d26ade..206a62b 100644 index 94a70a1..7bb04e7 100644
--- a/gdb/f-valprint.c --- a/gdb/f-valprint.c
+++ b/gdb/f-valprint.c +++ b/gdb/f-valprint.c
@@ -54,15 +54,17 @@ int f77_array_offset_tbl[MAX_FORTRAN_DIMS + 1][2]; @@ -54,15 +54,17 @@ int f77_array_offset_tbl[MAX_FORTRAN_DIMS + 1][2];
@ -3337,7 +3337,7 @@ index 4d26ade..206a62b 100644
} }
} }
@@ -173,36 +183,34 @@ f77_print_array_1 (int nss, int ndimensions, struct type *type, @@ -174,37 +184,35 @@ f77_print_array_1 (int nss, int ndimensions, struct type *type,
if (nss != ndimensions) if (nss != ndimensions)
{ {
@ -3348,10 +3348,10 @@ index 4d26ade..206a62b 100644
{ {
fprintf_filtered (stream, "( "); fprintf_filtered (stream, "( ");
f77_print_array_1 (nss + 1, ndimensions, TYPE_TARGET_TYPE (type), f77_print_array_1 (nss + 1, ndimensions, TYPE_TARGET_TYPE (type),
- valaddr + i * F77_DIM_OFFSET (nss), valaddr,
- address + i * F77_DIM_OFFSET (nss), - embedded_offset + i * F77_DIM_OFFSET (nss),
+ valaddr + i * F77_DIM_BYTE_STRIDE (nss), + embedded_offset + i * F77_DIM_BYTE_STRIDE (nss),
+ address + i * F77_DIM_BYTE_STRIDE (nss), address,
stream, recurse, val, options, elts); stream, recurse, val, options, elts);
fprintf_filtered (stream, ") "); fprintf_filtered (stream, ") ");
} }
@ -3366,12 +3366,11 @@ index 4d26ade..206a62b 100644
i++, (*elts)++) i++, (*elts)++)
{ {
val_print (TYPE_TARGET_TYPE (type), val_print (TYPE_TARGET_TYPE (type),
- valaddr + i * F77_DIM_OFFSET (ndimensions), valaddr,
+ valaddr + i * F77_DIM_BYTE_STRIDE (ndimensions), - embedded_offset + i * F77_DIM_OFFSET (ndimensions),
0, + embedded_offset + i * F77_DIM_BYTE_STRIDE (ndimensions),
- address + i * F77_DIM_OFFSET (ndimensions), address, stream, recurse,
+ address + i * F77_DIM_BYTE_STRIDE (ndimensions), val, options, current_language);
stream, recurse, val, options, current_language);
- if (i != (F77_DIM_SIZE (nss) - 1)) - if (i != (F77_DIM_SIZE (nss) - 1))
+ if (i != (F77_DIM_COUNT (nss) - 1)) + if (i != (F77_DIM_COUNT (nss) - 1))
@ -3383,7 +3382,7 @@ index 4d26ade..206a62b 100644
fprintf_filtered (stream, "..."); fprintf_filtered (stream, "...");
} }
} }
@@ -260,6 +268,9 @@ f_val_print (struct type *type, const gdb_byte *valaddr, int embedded_offset, @@ -263,6 +271,9 @@ f_val_print (struct type *type, const gdb_byte *valaddr, int embedded_offset,
CORE_ADDR addr; CORE_ADDR addr;
int index; int index;
@ -5486,7 +5485,7 @@ index 75de56c..2a64a0e 100644
/* Handle the case of functions lacking debugging info. /* Handle the case of functions lacking debugging info.
Their values are characters since their addresses are char. */ Their values are characters since their addresses are char. */
diff --git a/gdb/linux-nat.c b/gdb/linux-nat.c diff --git a/gdb/linux-nat.c b/gdb/linux-nat.c
index 62a4538..8d14fcd 100644 index a855219..1668f95 100644
--- a/gdb/linux-nat.c --- a/gdb/linux-nat.c
+++ b/gdb/linux-nat.c +++ b/gdb/linux-nat.c
@@ -1254,6 +1254,64 @@ iterate_over_lwps (ptid_t filter, @@ -1254,6 +1254,64 @@ iterate_over_lwps (ptid_t filter,
@ -5785,7 +5784,7 @@ index 8497991..4635853 100644
SYMBOL_LINKAGE_NAME (tsymbol)) == 0) SYMBOL_LINKAGE_NAME (tsymbol)) == 0)
return SYMBOL_VALUE_ADDRESS (msymbol); return SYMBOL_VALUE_ADDRESS (msymbol);
diff --git a/gdb/p-valprint.c b/gdb/p-valprint.c diff --git a/gdb/p-valprint.c b/gdb/p-valprint.c
index e993c05..affbe45 100644 index 34decb9..0399e0a 100644
--- a/gdb/p-valprint.c --- a/gdb/p-valprint.c
+++ b/gdb/p-valprint.c +++ b/gdb/p-valprint.c
@@ -38,6 +38,7 @@ @@ -38,6 +38,7 @@
@ -5796,7 +5795,7 @@ index e993c05..affbe45 100644
@@ -68,8 +69,27 @@ pascal_val_print (struct type *type, const gdb_byte *valaddr, @@ -68,8 +69,31 @@ pascal_val_print (struct type *type, const gdb_byte *valaddr,
struct type *char_type; struct type *char_type;
LONGEST val; LONGEST val;
CORE_ADDR addr; CORE_ADDR addr;
@ -5805,6 +5804,7 @@ index e993c05..affbe45 100644
+ CORE_ADDR saved_address = address; + CORE_ADDR saved_address = address;
+ +
+ back_to = make_cleanup (null_cleanup, 0); + back_to = make_cleanup (null_cleanup, 0);
+ address += embedded_offset;
+ type = object_address_get_data (type, &address); + type = object_address_get_data (type, &address);
+ if (type == NULL) + if (type == NULL)
+ { + {
@ -5813,7 +5813,7 @@ index e993c05..affbe45 100644
+ do_cleanups (back_to); + do_cleanups (back_to);
+ return 0; + return 0;
+ } + }
+ if (address != saved_address) + if (address != saved_address + embedded_offset)
+ { + {
+ size_t length = TYPE_LENGTH (type); + size_t length = TYPE_LENGTH (type);
@ -5821,22 +5821,25 @@ index e993c05..affbe45 100644
+ valaddr = xmalloc (length); + valaddr = xmalloc (length);
+ make_cleanup (xfree, (gdb_byte *) valaddr); + make_cleanup (xfree, (gdb_byte *) valaddr);
+ read_memory (address, (gdb_byte *) valaddr, length); + read_memory (address, (gdb_byte *) valaddr, length);
+ embedded_offset = 0;
+ } + }
+ else
+ address -= embedded_offset;
switch (TYPE_CODE (type)) switch (TYPE_CODE (type))
{ {
case TYPE_CODE_ARRAY: case TYPE_CODE_ARRAY:
@@ -125,8 +145,8 @@ pascal_val_print (struct type *type, const gdb_byte *valaddr, @@ -125,8 +149,8 @@ pascal_val_print (struct type *type, const gdb_byte *valaddr,
{ {
i = 0; i = 0;
} }
- val_print_array_elements (type, valaddr + embedded_offset, - val_print_array_elements (type, valaddr, embedded_offset,
- address, stream, recurse, - address, stream, recurse,
+ val_print_array_elements (saved_type, valaddr + embedded_offset, + val_print_array_elements (saved_type, valaddr, embedded_offset,
+ saved_address, stream, recurse, + saved_address, stream, recurse,
original_value, options, i); original_value, options, i);
fprintf_filtered (stream, "}"); fprintf_filtered (stream, "}");
} }
@@ -165,6 +185,7 @@ pascal_val_print (struct type *type, const gdb_byte *valaddr, @@ -165,6 +189,7 @@ pascal_val_print (struct type *type, const gdb_byte *valaddr,
/* Try to print what function it points to. */ /* Try to print what function it points to. */
print_address_demangle (gdbarch, addr, stream, demangle); print_address_demangle (gdbarch, addr, stream, demangle);
/* Return value is irrelevant except for string pointers. */ /* Return value is irrelevant except for string pointers. */
@ -5844,7 +5847,7 @@ index e993c05..affbe45 100644
return (0); return (0);
} }
@@ -256,6 +277,7 @@ pascal_val_print (struct type *type, const gdb_byte *valaddr, @@ -256,6 +281,7 @@ pascal_val_print (struct type *type, const gdb_byte *valaddr,
/* Return number of characters printed, including the terminating /* Return number of characters printed, including the terminating
'\0' if we reached the end. val_print_string takes care including '\0' if we reached the end. val_print_string takes care including
the terminating '\0' if necessary. */ the terminating '\0' if necessary. */
@ -5852,7 +5855,7 @@ index e993c05..affbe45 100644
return i; return i;
break; break;
@@ -572,6 +594,7 @@ pascal_val_print (struct type *type, const gdb_byte *valaddr, @@ -572,6 +598,7 @@ pascal_val_print (struct type *type, const gdb_byte *valaddr,
TYPE_CODE (type)); TYPE_CODE (type));
} }
gdb_flush (stream); gdb_flush (stream);
@ -6504,7 +6507,7 @@ index 0000000..96b6618
+AliasCommand() +AliasCommand()
diff --git a/gdb/python/lib/gdb/command/backtrace.py b/gdb/python/lib/gdb/command/backtrace.py diff --git a/gdb/python/lib/gdb/command/backtrace.py b/gdb/python/lib/gdb/command/backtrace.py
new file mode 100644 new file mode 100644
index 0000000..2aa5b90 index 0000000..eeea909
--- /dev/null --- /dev/null
+++ b/gdb/python/lib/gdb/command/backtrace.py +++ b/gdb/python/lib/gdb/command/backtrace.py
@@ -0,0 +1,106 @@ @@ -0,0 +1,106 @@
@ -6590,7 +6593,7 @@ index 0000000..2aa5b90
+ +
+ # FIXME: provide option to start at selected frame + # FIXME: provide option to start at selected frame
+ # However, should still number as if starting from newest + # However, should still number as if starting from newest
+ newest_frame = gdb.selected_thread ().newest_frame () + newest_frame = gdb.newest_frame()
+ iter = itertools.imap (FrameWrapper, + iter = itertools.imap (FrameWrapper,
+ FrameIterator (newest_frame)) + FrameIterator (newest_frame))
+ if filter: + if filter:
@ -9360,10 +9363,10 @@ index 0000000..45bc650
+gdb_test_no_output {delete $bpnum} +gdb_test_no_output {delete $bpnum}
diff --git a/gdb/testsuite/gdb.dwarf2/dw2-bound-loclist.S b/gdb/testsuite/gdb.dwarf2/dw2-bound-loclist.S diff --git a/gdb/testsuite/gdb.dwarf2/dw2-bound-loclist.S b/gdb/testsuite/gdb.dwarf2/dw2-bound-loclist.S
new file mode 100644 new file mode 100644
index 0000000..7fb00ea index 0000000..aac3baa
--- /dev/null --- /dev/null
+++ b/gdb/testsuite/gdb.dwarf2/dw2-bound-loclist.S +++ b/gdb/testsuite/gdb.dwarf2/dw2-bound-loclist.S
@@ -0,0 +1,212 @@ @@ -0,0 +1,246 @@
+/* This testcase is part of GDB, the GNU debugger. +/* This testcase is part of GDB, the GNU debugger.
+ +
+ Copyright 2010 Free Software Foundation, Inc. + Copyright 2010 Free Software Foundation, Inc.
@ -9428,6 +9431,19 @@ index 0000000..7fb00ea
+ .4byte .Llenb_var-.Lcu1_begin /* DW_AT_upper_bound */ + .4byte .Llenb_var-.Lcu1_begin /* DW_AT_upper_bound */
+ .byte 0 /* End of children of die */ + .byte 0 /* End of children of die */
+ +
+ /* DW_AT_upper_bound is referencing register. */
+.Larrayreg_type:
+ .uleb128 2 /* Abbrev: DW_TAG_array_type */
+ .4byte .Lchar_type-.Lcu1_begin /* DW_AT_type */
+
+ .uleb128 8 /* Abbrev: DW_TAG_subrange_type with block */
+ .4byte .Luint_type-.Lcu1_begin /* DW_AT_type */
+ .byte 0 /* DW_AT_lower_bound */
+ .byte 2f - 1f /* DW_AT_upper_bound */
+1: .byte 0x50 /* DW_OP_reg0 */
+2:
+ .byte 0 /* End of children of die */
+
+.Luint_type: +.Luint_type:
+ .uleb128 4 /* Abbrev: DW_TAG_base_type */ + .uleb128 4 /* Abbrev: DW_TAG_base_type */
+ .4byte .Luint_str /* DW_AT_name */ + .4byte .Luint_str /* DW_AT_name */
@ -9469,6 +9485,15 @@ index 0000000..7fb00ea
+ .4byte vardata /* <addr> */ + .4byte vardata /* <addr> */
+2: +2:
+ +
+ /* DW_AT_upper_bound is referencing register. */
+ .uleb128 6 /* Abbrev: DW_TAG_variable DW_FORM_string */
+ .string "reg_string" /* DW_AT_name */
+ .4byte .Larrayreg_type-.Lcu1_begin /* DW_AT_type */
+ .byte 2f - 1f /* DW_AT_location */
+1: .byte 3 /* DW_OP_addr */
+ .4byte vardata /* <addr> */
+2:
+
+ .byte 0 /* End of children of CU */ + .byte 0 /* End of children of CU */
+.Lcu1_end: +.Lcu1_end:
+ +
@ -9566,6 +9591,18 @@ index 0000000..7fb00ea
+ .byte 0x0 /* Terminator */ + .byte 0x0 /* Terminator */
+ .byte 0x0 /* Terminator */ + .byte 0x0 /* Terminator */
+ +
+ .uleb128 8 /* Abbrev code */
+ .uleb128 0x21 /* DW_TAG_subrange_type with block */
+ .byte 0x0 /* no children */
+ .uleb128 0x49 /* DW_AT_type */
+ .uleb128 0x13 /* DW_FORM_ref4 */
+ .uleb128 0x22 /* DW_AT_lower_bound */
+ .uleb128 0xb /* DW_FORM_data1 */
+ .uleb128 0x2f /* DW_AT_upper_bound */
+ .uleb128 0xa /* DW_FORM_block1 */
+ .byte 0x0 /* Terminator */
+ .byte 0x0 /* Terminator */
+
+ .byte 0x0 /* Terminator */ + .byte 0x0 /* Terminator */
+ +
+/* String table */ +/* String table */
@ -9578,10 +9615,10 @@ index 0000000..7fb00ea
+ .string "unsigned int" + .string "unsigned int"
diff --git a/gdb/testsuite/gdb.dwarf2/dw2-bound-loclist.exp b/gdb/testsuite/gdb.dwarf2/dw2-bound-loclist.exp diff --git a/gdb/testsuite/gdb.dwarf2/dw2-bound-loclist.exp b/gdb/testsuite/gdb.dwarf2/dw2-bound-loclist.exp
new file mode 100644 new file mode 100644
index 0000000..5dbed3f index 0000000..815ed93
--- /dev/null --- /dev/null
+++ b/gdb/testsuite/gdb.dwarf2/dw2-bound-loclist.exp +++ b/gdb/testsuite/gdb.dwarf2/dw2-bound-loclist.exp
@@ -0,0 +1,51 @@ @@ -0,0 +1,54 @@
+# Copyright 2010 Free Software Foundation, Inc. +# Copyright 2010 Free Software Foundation, Inc.
+ +
+# This program is free software; you can redistribute it and/or modify +# This program is free software; you can redistribute it and/or modify
@ -9633,6 +9670,9 @@ index 0000000..5dbed3f
+ +
+gdb_test "p b_string" { = (0x[0-9a-f]+ )?"seennotseen"} +gdb_test "p b_string" { = (0x[0-9a-f]+ )?"seennotseen"}
+gdb_test "ptype b_string" {type = char \[\]} +gdb_test "ptype b_string" {type = char \[\]}
+
+# The register contains unpredictable value - the array size.
+gdb_test "ptype reg_string" {type = char \[-?[0-9]+\]}
diff --git a/gdb/testsuite/gdb.dwarf2/dw2-stripped.c b/gdb/testsuite/gdb.dwarf2/dw2-stripped.c diff --git a/gdb/testsuite/gdb.dwarf2/dw2-stripped.c b/gdb/testsuite/gdb.dwarf2/dw2-stripped.c
new file mode 100644 new file mode 100644
index 0000000..1f02d90 index 0000000..1f02d90
@ -10856,85 +10896,6 @@ index 0000000..f2de718
+# Seen regression: +# Seen regression:
+# Address requested for identifier "arr" which is in register $rdi +# Address requested for identifier "arr" which is in register $rdi
+gdb_test "p arr\[0\]" "\\$\[0-9\]+ = 42" +gdb_test "p arr\[0\]" "\\$\[0-9\]+ = 42"
diff --git a/gdb/testsuite/gdb.opt/fortran-string.exp b/gdb/testsuite/gdb.opt/fortran-string.exp
new file mode 100644
index 0000000..c108ea5
--- /dev/null
+++ b/gdb/testsuite/gdb.opt/fortran-string.exp
@@ -0,0 +1,39 @@
+# Copyright 2009 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 was written by Jan Kratochvil <jan.kratochvil@redhat.com>.
+
+# Test GDB can cope with Fortran strings having their length present in a CPU
+# register. With -O0 the string length is passed on the stack. To make this
+# test meaningful the follow assertion should pass. It is not being checked
+# here as the "_s" symbol is compiler dependent:
+# (gdb) info address _s
+# Symbol "_s" is a variable in register XX.
+
+set test fortran-string
+set srcfile ${test}.f90
+if { [prepare_for_testing ${test}.exp ${test} ${srcfile} {debug f77 additional_flags=-O2}] } {
+ return -1
+}
+
+if ![runto $srcfile:[gdb_get_line_number "s = s"]] then {
+ perror "couldn't run to breakpoint MAIN__"
+ continue
+}
+
+gdb_test "frame" ".*s='foo'.*"
+gdb_test "ptype s" "type = character\\*3"
+gdb_test "p s" "\\$\[0-9\]* = 'foo'"
diff --git a/gdb/testsuite/gdb.opt/fortran-string.f90 b/gdb/testsuite/gdb.opt/fortran-string.f90
new file mode 100644
index 0000000..e48d520
--- /dev/null
+++ b/gdb/testsuite/gdb.opt/fortran-string.f90
@@ -0,0 +1,28 @@
+! Copyright 2009 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.
+!
+! Ihis file is the Fortran source file for dynamic.exp.
+! Original file written by Jakub Jelinek <jakub@redhat.com>.
+! Modified for the GDB testcase by Jan Kratochvil <jan.kratochvil@redhat.com>.
+
+ subroutine f(s)
+ character*(*) s
+ s = s
+ end
+
+ program main
+ call f ('foo')
+ end
diff --git a/gdb/testsuite/gdb.pascal/arrays.exp b/gdb/testsuite/gdb.pascal/arrays.exp diff --git a/gdb/testsuite/gdb.pascal/arrays.exp b/gdb/testsuite/gdb.pascal/arrays.exp
new file mode 100644 new file mode 100644
index 0000000..ccc6e1e index 0000000..ccc6e1e
@ -11885,7 +11846,7 @@ index 891da37..236c5ca 100644
set pascal_init_done 1 set pascal_init_done 1
} }
diff --git a/gdb/top.c b/gdb/top.c diff --git a/gdb/top.c b/gdb/top.c
index bba1a2d..5582f30 100644 index d14f308..7605f85 100644
--- a/gdb/top.c --- a/gdb/top.c
+++ b/gdb/top.c +++ b/gdb/top.c
@@ -343,6 +343,7 @@ void @@ -343,6 +343,7 @@ void
@ -11954,10 +11915,10 @@ index 03e6332..ce6d1e0 100644
static void static void
diff --git a/gdb/utils.c b/gdb/utils.c diff --git a/gdb/utils.c b/gdb/utils.c
index c23c4d4..60d55b7 100644 index 82e3adb..a5b9146 100644
--- a/gdb/utils.c --- a/gdb/utils.c
+++ b/gdb/utils.c +++ b/gdb/utils.c
@@ -2206,6 +2206,36 @@ set_batch_flag_and_make_cleanup_restore_page_info (void) @@ -2238,6 +2238,36 @@ set_batch_flag_and_make_cleanup_restore_page_info (void)
return back_to; return back_to;
} }
@ -12180,7 +12141,7 @@ index 19d5238..c9d721a 100644
{ {
int i; int i;
diff --git a/gdb/valprint.c b/gdb/valprint.c diff --git a/gdb/valprint.c b/gdb/valprint.c
index f65fe27..dd1aaee 100644 index c98e315..de9de10 100644
--- a/gdb/valprint.c --- a/gdb/valprint.c
+++ b/gdb/valprint.c +++ b/gdb/valprint.c
@@ -36,6 +36,7 @@ @@ -36,6 +36,7 @@
@ -12199,7 +12160,7 @@ index f65fe27..dd1aaee 100644
case TYPE_CODE_BITSTRING: case TYPE_CODE_BITSTRING:
return 0; return 0;
default: default:
@@ -1117,6 +1117,7 @@ val_print_array_elements (struct type *type, const gdb_byte *valaddr, @@ -1118,6 +1118,7 @@ val_print_array_elements (struct type *type,
{ {
unsigned int things_printed = 0; unsigned int things_printed = 0;
unsigned len; unsigned len;
@ -12207,7 +12168,7 @@ index f65fe27..dd1aaee 100644
struct type *elttype, *index_type; struct type *elttype, *index_type;
unsigned eltlen; unsigned eltlen;
/* Position of the array element we are examining to see /* Position of the array element we are examining to see
@@ -1125,9 +1126,33 @@ val_print_array_elements (struct type *type, const gdb_byte *valaddr, @@ -1126,9 +1127,33 @@ val_print_array_elements (struct type *type,
/* Number of repetitions we have detected so far. */ /* Number of repetitions we have detected so far. */
unsigned int reps; unsigned int reps;
LONGEST low_bound, high_bound; LONGEST low_bound, high_bound;
@ -12243,7 +12204,7 @@ index f65fe27..dd1aaee 100644
index_type = TYPE_INDEX_TYPE (type); index_type = TYPE_INDEX_TYPE (type);
if (get_array_bounds (type, &low_bound, &high_bound)) if (get_array_bounds (type, &low_bound, &high_bound))
@@ -1202,6 +1227,8 @@ val_print_array_elements (struct type *type, const gdb_byte *valaddr, @@ -1207,6 +1232,8 @@ val_print_array_elements (struct type *type,
{ {
fprintf_filtered (stream, "..."); fprintf_filtered (stream, "...");
} }

View File

@ -0,0 +1,52 @@
http://sourceware.org/ml/gdb-cvs/2011-01/msg00169.html
### src/gdb/ChangeLog 2011/01/25 17:00:23 1.12503
### src/gdb/ChangeLog 2011/01/25 17:25:10 1.12504
## -1,3 +1,8 @@
+2011-01-25 Jan Kratochvil <jan.kratochvil@redhat.com>
+
+ * dwarf2read.c (dwarf2_read_index, write_psymtabs_to_index)
+ (save_gdb_index_command): Switch to .gdb_index version 4.
+
2011-01-25 Pedro Alves <pedro@codesourcery.com>
* mi/mi-main.c (get_register): Use get_frame_register_value rather
--- src/gdb/dwarf2read.c 2011/01/12 16:16:20 1.495
+++ src/gdb/dwarf2read.c 2011/01/25 17:25:12 1.496
@@ -2024,13 +2024,14 @@
/* Version check. */
version = MAYBE_SWAP (*(offset_type *) addr);
/* Versions earlier than 3 emitted every copy of a psymbol. This
- causes the index to behave very poorly for certain requests. So,
- it seems better to just ignore such indices. */
- if (version < 3)
+ causes the index to behave very poorly for certain requests. Version 4
+ contained incomplete addrmap. So, it seems better to just ignore such
+ indices. */
+ if (version < 4)
return 0;
/* Indexes with higher version than the one supported by GDB may be no
longer backward compatible. */
- if (version > 3)
+ if (version > 4)
return 0;
map = OBSTACK_ZALLOC (&objfile->objfile_obstack, struct mapped_index);
@@ -15688,7 +15689,7 @@
total_len = size_of_contents;
/* The version number. */
- val = MAYBE_SWAP (3);
+ val = MAYBE_SWAP (4);
obstack_grow (&contents, &val, sizeof (val));
/* The offset of the CU list from the start of the file. */
@@ -15746,7 +15747,7 @@
1. The file header. This is a sequence of values, of offset_type
unless otherwise noted:
- [0] The version number, currently 3. Versions 1 and 2 are
+ [0] The version number, currently 4. Versions 1, 2 and 3 are
obsolete.
[1] The offset, from the start of the file, of the CU list.
[2] The offset, from the start of the file, of the types CU list.

View File

@ -23,11 +23,11 @@ Name: gdb%{?_with_debug:-debug}
# Set version to contents of gdb/version.in. # Set version to contents of gdb/version.in.
# NOTE: the FSF gdb versions are numbered N.M for official releases, like 6.3 # NOTE: the FSF gdb versions are numbered N.M for official releases, like 6.3
# and, since January 2005, X.Y.Z.date for daily snapshots, like 6.3.50.20050112 # (daily snapshot from mailine), or 6.3.0.20040112 (head of the release branch). # and, since January 2005, X.Y.Z.date for daily snapshots, like 6.3.50.20050112 # (daily snapshot from mailine), or 6.3.0.20040112 (head of the release branch).
Version: 7.2.50.20110117 Version: 7.2.50.20110125
# The release always contains a leading reserved number, start it at 1. # The release always contains a leading reserved number, start it at 1.
# `upstream' is not a part of `name' to stay fully rpm dependencies compatible for the testing. # `upstream' is not a part of `name' to stay fully rpm dependencies compatible for the testing.
Release: 13%{?_with_upstream:.upstream}%{?dist} Release: 14%{?_with_upstream:.upstream}%{?dist}
License: GPLv3+ and GPLv3+ with exceptions and GPLv2+ and GPLv2+ with exceptions and GPL+ and LGPLv2+ and GFDL and BSD and Public Domain License: GPLv3+ and GPLv3+ with exceptions and GPLv2+ and GPLv2+ with exceptions and GPL+ and LGPLv2+ and GFDL and BSD and Public Domain
Group: Development/Debuggers Group: Development/Debuggers
@ -536,6 +536,13 @@ Patch547: gdb-test-dw2-aranges.patch
# =fedoratest # =fedoratest
Patch548: gdb-test-expr-cumulative-archer.patch Patch548: gdb-test-expr-cumulative-archer.patch
# Fix discontiguous address ranges in .gdb_index - v3->v4 (BZ 672281).
# =push
Patch552: gdb-gdbindex-v4-2of3.patch
# Fix DWARF-3+ DW_AT_accessibility default assumption for F15 gcc-4.6.
Patch554: gdb-dwarf3-accessibility.patch
BuildRequires: ncurses-devel%{?_isa} texinfo gettext flex bison expat-devel%{?_isa} BuildRequires: ncurses-devel%{?_isa} texinfo gettext flex bison expat-devel%{?_isa}
Requires: readline%{?_isa} Requires: readline%{?_isa}
BuildRequires: readline-devel%{?_isa} BuildRequires: readline-devel%{?_isa}
@ -785,6 +792,8 @@ rm -f gdb/jv-exp.c gdb/m2-exp.c gdb/objc-exp.c gdb/p-exp.c
%patch542 -p1 %patch542 -p1
%patch547 -p1 %patch547 -p1
%patch548 -p1 %patch548 -p1
%patch552 -p1
%patch554 -p1
%patch390 -p1 %patch390 -p1
%patch393 -p1 %patch393 -p1
@ -1191,6 +1200,11 @@ fi
%endif %endif
%changelog %changelog
* Thu Jan 20 2011 Jan Kratochvil <jan.kratochvil@redhat.com> - 7.2.50.20110125-14.fc15
- Rebase to FSF GDB 7.2.50.20110125 (which is a 7.3 pre-release).
- Fix discontiguous address ranges in .gdb_index - v3->v4 (BZ 672281).
- Fix DWARF-3+ DW_AT_accessibility default assumption for F15 gcc-4.6.
* Thu Jan 20 2011 Jan Kratochvil <jan.kratochvil@redhat.com> - 7.2.50.20110117-13.fc15 * Thu Jan 20 2011 Jan Kratochvil <jan.kratochvil@redhat.com> - 7.2.50.20110117-13.fc15
- Use librpm.so.2 for rpm-4.9.0 in Fedora 15. - Use librpm.so.2 for rpm-4.9.0 in Fedora 15.

View File

@ -1,2 +1,2 @@
04e5c4b1b9e633422cc48990fe61958d libstdc++-v3-python-r155978.tar.bz2 04e5c4b1b9e633422cc48990fe61958d libstdc++-v3-python-r155978.tar.bz2
3cecba20b0efd51e5acb937f3abd2014 gdb-7.2.50.20110117.tar.bz2 525bcebaa799261486cb76ba9638636b gdb-7.2.50.20110125.tar.bz2