From 8aabf36e777c93a6571f7b9f7e70688d13271e14 Mon Sep 17 00:00:00 2001 From: Jan Kratochvil Date: Sun, 15 Jul 2012 10:41:46 +0200 Subject: [PATCH] Rebase to FSF GDB 7.4.50.20120714. - Fix entryval feature crash on some .debug files optimized by dwz (BZ 839596). - Fix another stale frame_info * (PR 11914, like PR 13866). --- .gitignore | 2 +- ...heduler_locking-step-sw-watchpoints2.patch | 46 +- gdb-archer.patch | 409 +++++++++--------- gdb-attach-fail-reasons-5of5.patch | 72 +-- gdb-bz592031-siginfo-lost-5of5.patch | 141 ------ gdb-dlopen-stap-probe-test.patch | 65 ++- gdb-errno-func-datatype-revert.patch | 236 ---------- gdb-fortran-common.patch | 65 ++- gdb-index-assert.patch | 60 --- gdb-stale-frame_info-python.patch | 295 +++++++++++++ gdb-upstream.patch | 55 +++ gdb.spec | 29 +- sources | 2 +- 13 files changed, 695 insertions(+), 782 deletions(-) delete mode 100644 gdb-bz592031-siginfo-lost-5of5.patch delete mode 100644 gdb-errno-func-datatype-revert.patch delete mode 100644 gdb-index-assert.patch create mode 100644 gdb-stale-frame_info-python.patch diff --git a/.gitignore b/.gitignore index 2936f1c..643a15f 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1,2 @@ /libstdc++-v3-python-r155978.tar.bz2 -/gdb-7.4.50.20120703.tar.bz2 +/gdb-7.4.50.20120714.tar.bz2 diff --git a/gdb-6.6-scheduler_locking-step-sw-watchpoints2.patch b/gdb-6.6-scheduler_locking-step-sw-watchpoints2.patch index c5318e6..36b10a5 100644 --- a/gdb-6.6-scheduler_locking-step-sw-watchpoints2.patch +++ b/gdb-6.6-scheduler_locking-step-sw-watchpoints2.patch @@ -21,10 +21,10 @@ Port to GDB-6.8pre. -Index: gdb-7.4.50.20120602/gdb/inferior.h +Index: gdb-7.4.50.20120714/gdb/inferior.h =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/inferior.h 2012-05-24 18:39:09.000000000 +0200 -+++ gdb-7.4.50.20120602/gdb/inferior.h 2012-06-02 18:24:12.875274179 +0200 +--- gdb-7.4.50.20120714.orig/gdb/inferior.h 2012-06-13 20:15:05.000000000 +0200 ++++ gdb-7.4.50.20120714/gdb/inferior.h 2012-07-14 23:21:01.795161794 +0200 @@ -159,7 +159,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. */ @@ -42,10 +42,10 @@ Index: gdb-7.4.50.20120602/gdb/inferior.h extern ptid_t user_visible_resume_ptid (int step); -Index: gdb-7.4.50.20120602/gdb/infrun.c +Index: gdb-7.4.50.20120714/gdb/infrun.c =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/infrun.c 2012-05-28 22:43:26.000000000 +0200 -+++ gdb-7.4.50.20120602/gdb/infrun.c 2012-06-02 18:23:59.339278268 +0200 +--- gdb-7.4.50.20120714.orig/gdb/infrun.c 2012-07-01 12:37:04.000000000 +0200 ++++ gdb-7.4.50.20120714/gdb/infrun.c 2012-07-14 23:21:01.800161767 +0200 @@ -79,7 +79,7 @@ static int follow_fork (void); static void set_schedlock_func (char *args, int from_tty, struct cmd_list_element *c); @@ -55,7 +55,7 @@ Index: gdb-7.4.50.20120602/gdb/infrun.c static int currently_stepping_or_nexting_callback (struct thread_info *tp, void *data); -@@ -1687,7 +1687,8 @@ user_visible_resume_ptid (int step) +@@ -1672,7 +1672,8 @@ user_visible_resume_ptid (int step) } else if ((scheduler_mode == schedlock_on) || (scheduler_mode == schedlock_step @@ -65,7 +65,7 @@ Index: gdb-7.4.50.20120602/gdb/infrun.c { /* User-settable 'scheduler' mode requires solo thread resume. */ resume_ptid = inferior_ptid; -@@ -1705,7 +1706,7 @@ user_visible_resume_ptid (int step) +@@ -1690,7 +1691,7 @@ user_visible_resume_ptid (int step) STEP nonzero if we should step (zero to continue instead). SIG is the signal to give the inferior (zero for none). */ void @@ -74,7 +74,7 @@ Index: gdb-7.4.50.20120602/gdb/infrun.c { int should_resume = 1; struct cleanup *old_cleanups = make_cleanup (resume_cleanups, 0); -@@ -1738,9 +1739,13 @@ resume (int step, enum gdb_signal sig) +@@ -1723,9 +1724,13 @@ resume (int step, enum gdb_signal sig) if (debug_infrun) fprintf_unfiltered (gdb_stdlog, @@ -90,7 +90,7 @@ Index: gdb-7.4.50.20120602/gdb/infrun.c target_pid_to_str (inferior_ptid), paddress (gdbarch, pc)); -@@ -2117,7 +2122,7 @@ proceed (CORE_ADDR addr, enum gdb_signal +@@ -2102,7 +2107,7 @@ proceed (CORE_ADDR addr, enum gdb_signal struct thread_info *tp; CORE_ADDR pc; struct address_space *aspace; @@ -99,7 +99,7 @@ Index: gdb-7.4.50.20120602/gdb/infrun.c /* If we're stopped at a fork/vfork, follow the branch set by the "set follow-fork-mode" command; otherwise, we'll just proceed -@@ -2157,13 +2162,13 @@ proceed (CORE_ADDR addr, enum gdb_signal +@@ -2142,13 +2147,13 @@ proceed (CORE_ADDR addr, enum gdb_signal actually be executing the breakpoint insn anyway. We'll be (un-)executing the previous instruction. */ @@ -115,7 +115,7 @@ Index: gdb-7.4.50.20120602/gdb/infrun.c } else { -@@ -2194,13 +2199,13 @@ proceed (CORE_ADDR addr, enum gdb_signal +@@ -2179,13 +2184,13 @@ proceed (CORE_ADDR addr, enum gdb_signal is required it returns TRUE and sets the current thread to the old thread. */ if (prepare_to_proceed (step)) @@ -131,7 +131,7 @@ Index: gdb-7.4.50.20120602/gdb/infrun.c { tp->control.trap_expected = 1; /* If displaced stepping is enabled, we can step over the -@@ -2287,8 +2292,13 @@ proceed (CORE_ADDR addr, enum gdb_signal +@@ -2272,8 +2277,13 @@ proceed (CORE_ADDR addr, enum gdb_signal /* Reset to normal state. */ init_infwait_state (); @@ -146,7 +146,7 @@ Index: gdb-7.4.50.20120602/gdb/infrun.c /* Wait for it to stop (if not standalone) and in any case decode why it stopped, and act accordingly. */ -@@ -5249,13 +5259,18 @@ process_event_stop_test: +@@ -5205,13 +5215,18 @@ process_event_stop_test: /* Is thread TP in the middle of single-stepping? */ @@ -170,11 +170,11 @@ Index: gdb-7.4.50.20120602/gdb/infrun.c } /* Returns true if any thread *but* the one passed in "data" is in the -Index: gdb-7.4.50.20120602/gdb/linux-nat.c +Index: gdb-7.4.50.20120714/gdb/linux-nat.c =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/linux-nat.c 2012-05-24 18:51:34.000000000 +0200 -+++ gdb-7.4.50.20120602/gdb/linux-nat.c 2012-06-02 18:23:07.409293800 +0200 -@@ -3051,7 +3051,11 @@ static int +--- gdb-7.4.50.20120714.orig/gdb/linux-nat.c 2012-07-07 14:13:56.000000000 +0200 ++++ gdb-7.4.50.20120714/gdb/linux-nat.c 2012-07-14 23:21:01.803161750 +0200 +@@ -2982,7 +2982,11 @@ static int select_singlestep_lwp_callback (struct lwp_info *lp, void *data) { if (lp->last_resume_kind == resume_step @@ -187,10 +187,10 @@ Index: gdb-7.4.50.20120602/gdb/linux-nat.c return 1; else return 0; -Index: gdb-7.4.50.20120602/gdb/linux-nat.h +Index: gdb-7.4.50.20120714/gdb/linux-nat.h =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/linux-nat.h 2012-03-21 14:43:54.000000000 +0100 -+++ gdb-7.4.50.20120602/gdb/linux-nat.h 2012-06-02 18:23:07.411293798 +0200 +--- gdb-7.4.50.20120714.orig/gdb/linux-nat.h 2012-07-06 18:52:20.000000000 +0200 ++++ gdb-7.4.50.20120714/gdb/linux-nat.h 2012-07-14 23:21:17.414075355 +0200 @@ -73,8 +73,8 @@ struct lwp_info /* If non-zero, a pending wait status. */ int status; @@ -200,5 +200,5 @@ Index: gdb-7.4.50.20120602/gdb/linux-nat.h + /* 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. */ + /* STOPPED_BY_WATCHPOINT is non-zero if this LWP stopped with a data + watchpoint trap. */ diff --git a/gdb-archer.patch b/gdb-archer.patch index db9a9bb..3531ee0 100644 --- a/gdb-archer.patch +++ b/gdb-archer.patch @@ -2,7 +2,7 @@ http://sourceware.org/gdb/wiki/ProjectArcher http://sourceware.org/gdb/wiki/ArcherBranchManagement GIT snapshot: -commit b478323cbd38598902fa2efb1794192d7ba627b1 +commit 814db9ee87e8d609ce60324760cf80cd4e4ec43a branch `archer' - the merge of branches: archer-jankratochvil-vla @@ -152,10 +152,10 @@ index 99c4788..6ceb704 100644 + #endif /* BLOCK_H */ diff --git a/gdb/breakpoint.c b/gdb/breakpoint.c -index 555694e..9216405 100644 +index 6b9faf3..43ff16a 100644 --- a/gdb/breakpoint.c +++ b/gdb/breakpoint.c -@@ -15525,6 +15525,24 @@ all_tracepoints (void) +@@ -15508,6 +15508,24 @@ all_tracepoints (void) return tp_vec; } @@ -180,7 +180,7 @@ index 555694e..9216405 100644 /* This help string is used for the break, hbreak, tbreak and thbreak commands. It is defined as a macro to prevent duplication. -@@ -16490,4 +16508,7 @@ agent-printf \"printf format string\", arg1, arg2, arg3, ..., argn\n\ +@@ -16473,4 +16491,7 @@ agent-printf \"printf format string\", arg1, arg2, arg3, ..., argn\n\ automatic_hardware_breakpoints = 1; observer_attach_about_to_proceed (breakpoint_about_to_proceed); @@ -189,20 +189,19 @@ index 555694e..9216405 100644 +#endif } diff --git a/gdb/buildsym.c b/gdb/buildsym.c -index f1fb4be..54a0ea3 100644 +index d547012..e2f3192 100644 --- a/gdb/buildsym.c +++ b/gdb/buildsym.c -@@ -941,7 +941,8 @@ block_compar (const void *ap, const void *bp) - never know about this empty file (FIXME). */ +@@ -970,7 +970,7 @@ reset_symtab_globals (void) - struct symtab * --end_symtab (CORE_ADDR end_addr, struct objfile *objfile, int section) -+end_symtab_full (CORE_ADDR end_addr, struct objfile *objfile, int section, -+ int required) + struct block * + end_symtab_get_static_block (CORE_ADDR end_addr, struct objfile *objfile, +- int expandable) ++ int expandable, int required) { - struct symtab *symtab = NULL; - struct blockvector *blockvector; -@@ -1013,7 +1014,8 @@ end_symtab (CORE_ADDR end_addr, struct objfile *objfile, int section) + /* Finish the lexical context of the last function in the file; pop + the context stack. */ +@@ -1038,7 +1038,8 @@ end_symtab_get_static_block (CORE_ADDR end_addr, struct objfile *objfile, cleanup_undefined_stabs_types (objfile); finish_global_stabs (objfile); @@ -212,34 +211,37 @@ index f1fb4be..54a0ea3 100644 && file_symbols == NULL && global_symbols == NULL && have_line_numbers == 0 -@@ -1219,6 +1221,12 @@ end_symtab (CORE_ADDR end_addr, struct objfile *objfile, int section) - return symtab; +@@ -1296,7 +1297,7 @@ end_symtab (CORE_ADDR end_addr, struct objfile *objfile, int section) + { + struct block *static_block; + +- static_block = end_symtab_get_static_block (end_addr, objfile, 0); ++ static_block = end_symtab_get_static_block (end_addr, objfile, 0, 0); + return end_symtab_from_static_block (static_block, objfile, section, 0); + } + +@@ -1308,7 +1309,7 @@ end_expandable_symtab (CORE_ADDR end_addr, struct objfile *objfile, + { + struct block *static_block; + +- static_block = end_symtab_get_static_block (end_addr, objfile, 1); ++ static_block = end_symtab_get_static_block (end_addr, objfile, 1, 0); + return end_symtab_from_static_block (static_block, objfile, section, 1); } -+struct symtab * -+end_symtab (CORE_ADDR end_addr, struct objfile *objfile, int section) -+{ -+ return end_symtab_full (end_addr, objfile, section, 0); -+} -+ - /* Push a context block. Args are an identifying nesting level - (checkable when you pop it), and the starting PC address of this - context. */ diff --git a/gdb/buildsym.h b/gdb/buildsym.h -index 4448267..7d9b97c 100644 +index 162ee8c..2c1d179 100644 --- a/gdb/buildsym.h +++ b/gdb/buildsym.h -@@ -261,6 +261,10 @@ extern char *pop_subfile (void); - extern struct symtab *end_symtab (CORE_ADDR end_addr, - struct objfile *objfile, int section); +@@ -260,7 +260,7 @@ extern char *pop_subfile (void); -+extern struct symtab *end_symtab_full (CORE_ADDR end_addr, -+ struct objfile *objfile, int section, -+ int required); -+ - /* Defined in stabsread.c. */ + extern struct block *end_symtab_get_static_block (CORE_ADDR end_addr, + struct objfile *objfile, +- int expandable); ++ int expandable, int required); - extern void scan_file_globals (struct objfile *objfile); + extern struct symtab *end_symtab_from_static_block (struct block *static_block, + struct objfile *objfile, diff --git a/gdb/c-typeprint.c b/gdb/c-typeprint.c index a5892b5..2944c2d 100644 --- a/gdb/c-typeprint.c @@ -805,10 +807,10 @@ index 1c6fa79..ec08348 100644 extern char *xfullpath (const char *); diff --git a/gdb/doc/gdb.texinfo b/gdb/doc/gdb.texinfo -index d324a93..9ccf7f1 100644 +index a92df86..29a62ad 100644 --- a/gdb/doc/gdb.texinfo +++ b/gdb/doc/gdb.texinfo -@@ -1194,6 +1194,16 @@ for remote debugging. +@@ -1200,6 +1200,16 @@ for remote debugging. Run using @var{device} for your program's standard input and output. @c FIXME: kingdon thinks there is more to -tty. Investigate. @@ -825,7 +827,7 @@ index d324a93..9ccf7f1 100644 @c resolve the situation of these eventually @item -tui @cindex @code{--tui} -@@ -22541,8 +22551,6 @@ containing @code{end}. For example: +@@ -22548,8 +22558,6 @@ containing @code{end}. For example: @smallexample (@value{GDBP}) python @@ -834,7 +836,7 @@ index d324a93..9ccf7f1 100644 >print 23 >end 23 -@@ -22556,6 +22564,14 @@ controlled using @code{set python print-stack}: if @code{full}, then +@@ -22563,6 +22571,14 @@ controlled using @code{set python print-stack}: if @code{full}, then full Python stack printing is enabled; if @code{none}, then Python stack and message printing is disabled; if @code{message}, the default, only the message component of the error is printed. @@ -849,7 +851,7 @@ index d324a93..9ccf7f1 100644 @end table It is also possible to execute a Python script from the @value{GDBN} -@@ -22577,6 +22593,14 @@ and thus is always available. +@@ -22584,6 +22600,14 @@ and thus is always available. @cindex python api @cindex programming in python @@ -865,10 +867,10 @@ index d324a93..9ccf7f1 100644 @cindex python pagination At startup, @value{GDBN} overrides Python's @code{sys.stdout} and diff --git a/gdb/doc/gdbint.texinfo b/gdb/doc/gdbint.texinfo -index 9a440ef..dd04633 100644 +index 5e00f1f..c5c432b 100644 --- a/gdb/doc/gdbint.texinfo +++ b/gdb/doc/gdbint.texinfo -@@ -2103,6 +2103,18 @@ time, and so we attempt to handle symbols incrementally. For instance, +@@ -2102,6 +2102,18 @@ time, and so we attempt to handle symbols incrementally. For instance, we create @dfn{partial symbol tables} consisting of only selected symbols, and only expand them to full symbol tables when necessary. @@ -887,7 +889,7 @@ index 9a440ef..dd04633 100644 @section Symbol Reading @cindex symbol reading -@@ -2195,6 +2207,7 @@ symtab. Upon return, @code{pst->readin} should have been set to 1, and +@@ -2194,6 +2206,7 @@ symtab. Upon return, @code{pst->readin} should have been set to 1, and zero if there were no symbols in that part of the symbol file. @end table @@ -895,7 +897,7 @@ index 9a440ef..dd04633 100644 @section Partial Symbol Tables @value{GDBN} has three types of symbol tables: -@@ -2296,6 +2309,7 @@ and partial symbol tables behind a set of function pointers known as +@@ -2295,6 +2308,7 @@ and partial symbol tables behind a set of function pointers known as the @dfn{quick symbol functions}. These are documented in @file{symfile.h}. @@ -903,7 +905,7 @@ index 9a440ef..dd04633 100644 @section Types @unnumberedsubsec Fundamental Types (e.g., @code{FT_VOID}, @code{FT_BOOLEAN}). -@@ -2318,6 +2332,7 @@ types map to one @code{TYPE_CODE_*} type, and are distinguished by +@@ -2317,6 +2331,7 @@ types map to one @code{TYPE_CODE_*} type, and are distinguished by other members of the type struct, such as whether the type is signed or unsigned, and how many bits it uses. @@ -911,7 +913,7 @@ index 9a440ef..dd04633 100644 @unnumberedsubsec Builtin Types (e.g., @code{builtin_type_void}, @code{builtin_type_char}). These are instances of type structs that roughly correspond to -@@ -2332,6 +2347,7 @@ only one instance exists, while @file{c-lang.c} builds as many +@@ -2331,6 +2346,7 @@ only one instance exists, while @file{c-lang.c} builds as many @code{TYPE_CODE_INT} types as needed, with each one associated with some particular objfile. @@ -919,7 +921,7 @@ index 9a440ef..dd04633 100644 @section Object File Formats @cindex object file formats -@@ -2417,6 +2433,7 @@ SOM, which is a cross-language ABI). +@@ -2416,6 +2432,7 @@ SOM, which is a cross-language ABI). The SOM reader is in @file{somread.c}. @@ -927,7 +929,7 @@ index 9a440ef..dd04633 100644 @section Debugging File Formats This section describes characteristics of debugging information that -@@ -2488,6 +2505,7 @@ DWARF 3 is an improved version of DWARF 2. +@@ -2487,6 +2504,7 @@ DWARF 3 is an improved version of DWARF 2. @cindex SOM debugging info Like COFF, the SOM definition includes debugging information. @@ -935,7 +937,7 @@ index 9a440ef..dd04633 100644 @section Adding a New Symbol Reader to @value{GDBN} @cindex adding debugging info reader -@@ -2510,6 +2528,7 @@ will only ever be implemented by one object file format may be called +@@ -2509,6 +2527,7 @@ will only ever be implemented by one object file format may be called directly. This interface should be described in a file @file{bfd/lib@var{xyz}.h}, which is included by @value{GDBN}. @@ -943,7 +945,7 @@ index 9a440ef..dd04633 100644 @section Memory Management for Symbol Files Most memory associated with a loaded symbol file is stored on -@@ -2521,10 +2540,45 @@ released when the objfile is unloaded or reloaded. Therefore one +@@ -2520,10 +2539,45 @@ released when the objfile is unloaded or reloaded. Therefore one objfile must not reference symbol or type data from another objfile; they could be unloaded at different times. @@ -1073,10 +1075,10 @@ index 214b371..d9b3751 100644 error (_("Unhandled dwarf expression opcode 0x%x"), op); } diff --git a/gdb/dwarf2expr.h b/gdb/dwarf2expr.h -index db49b9c..3ae0be1 100644 +index 19efbfd..0e0e498 100644 --- a/gdb/dwarf2expr.h +++ b/gdb/dwarf2expr.h -@@ -91,12 +91,8 @@ struct dwarf_expr_context_funcs +@@ -78,12 +78,8 @@ struct dwarf_expr_context_funcs This can throw an exception if the index is out of range. */ CORE_ADDR (*get_addr_index) (void *baton, unsigned int index); @@ -1090,7 +1092,7 @@ index db49b9c..3ae0be1 100644 /* The location of a value. */ diff --git a/gdb/dwarf2loc.c b/gdb/dwarf2loc.c -index 6feeab6..80dd9bc 100644 +index 38e4814..46a033d 100644 --- a/gdb/dwarf2loc.c +++ b/gdb/dwarf2loc.c @@ -293,6 +293,9 @@ struct dwarf_expr_baton @@ -1421,7 +1423,7 @@ index 6feeab6..80dd9bc 100644 retval = allocate_value_lazy (type); VALUE_LVAL (retval) = lval_memory; if (in_stack_memory) -@@ -4124,8 +4286,7 @@ loclist_tracepoint_var_ref (struct symbol *symbol, struct gdbarch *gdbarch, +@@ -4130,8 +4292,7 @@ loclist_tracepoint_var_ref (struct symbol *symbol, struct gdbarch *gdbarch, dlbaton->per_cu); } @@ -1431,7 +1433,7 @@ index 6feeab6..80dd9bc 100644 const struct symbol_computed_ops dwarf2_loclist_funcs = { loclist_read_variable, loclist_read_variable_at_entry, -@@ -4134,6 +4295,48 @@ const struct symbol_computed_ops dwarf2_loclist_funcs = { +@@ -4140,6 +4301,48 @@ const struct symbol_computed_ops dwarf2_loclist_funcs = { loclist_tracepoint_var_ref }; @@ -1501,7 +1503,7 @@ index e9d06a3..bfa6776 100644 /* Compile a DWARF location expression to an agent expression. diff --git a/gdb/dwarf2read.c b/gdb/dwarf2read.c -index 52288e8..603b669 100644 +index 1d51db2..fe56709 100644 --- a/gdb/dwarf2read.c +++ b/gdb/dwarf2read.c @@ -64,20 +64,12 @@ @@ -1546,7 +1548,7 @@ index 52288e8..603b669 100644 /* True if we have tried to read this section. */ int readin; }; -@@ -226,6 +212,10 @@ struct dwarf2_per_objfile +@@ -247,6 +233,10 @@ struct dwarf2_per_objfile This is NULL if the table hasn't been allocated yet. */ htab_t dwo_files; @@ -1557,7 +1559,7 @@ index 52288e8..603b669 100644 /* A flag indicating wether this objfile has a section loaded at a VMA of 0. */ int has_section_at_zero; -@@ -484,15 +474,13 @@ struct dwarf2_cu +@@ -505,15 +495,13 @@ struct dwarf2_cu struct dwarf2_per_cu_data { @@ -1575,7 +1577,7 @@ index 52288e8..603b669 100644 /* Flag indicating this compilation unit will be read in before any of the current compilation units are processed. */ -@@ -507,6 +495,9 @@ struct dwarf2_per_cu_data +@@ -528,6 +516,9 @@ struct dwarf2_per_cu_data /* Non-zero if this CU is from .debug_types. */ unsigned int is_debug_types : 1; @@ -1585,7 +1587,7 @@ index 52288e8..603b669 100644 /* The section this CU/TU lives in. If the DIE refers to a DWO file, this is always the original die, not the DWO file. */ -@@ -625,6 +616,22 @@ struct dwo_file +@@ -695,6 +686,22 @@ struct dwo_file htab_t tus; }; @@ -1608,7 +1610,7 @@ index 52288e8..603b669 100644 /* Struct used to pass misc. parameters to read_die_and_children, et al. which are used for both .debug_info and .debug_types dies. All parameters here are unchanging for the life of the call. This -@@ -738,6 +745,12 @@ struct partial_die_info +@@ -808,6 +815,12 @@ struct partial_die_info /* Flag set if fixup_partial_die has been called on this die. */ unsigned int fixup_called : 1; @@ -1621,7 +1623,7 @@ index 52288e8..603b669 100644 /* The name of this DIE. Normally the value of DW_AT_name, but sometimes a default name for unnamed DIEs. */ char *name; -@@ -1121,7 +1134,7 @@ static gdb_byte *read_partial_die (const struct die_reader_specs *, +@@ -1193,7 +1206,7 @@ static gdb_byte *read_partial_die (const struct die_reader_specs *, unsigned int, gdb_byte *); @@ -1630,7 +1632,7 @@ index 52288e8..603b669 100644 struct dwarf2_cu *); static void fixup_partial_die (struct partial_die_info *, -@@ -1163,6 +1176,8 @@ static char *read_indirect_string (bfd *, gdb_byte *, +@@ -1238,6 +1251,8 @@ static char *read_indirect_string (bfd *, gdb_byte *, const struct comp_unit_head *, unsigned int *); @@ -1639,7 +1641,7 @@ index 52288e8..603b669 100644 static ULONGEST read_unsigned_leb128 (bfd *, gdb_byte *, unsigned int *); static LONGEST read_signed_leb128 (bfd *, gdb_byte *, unsigned int *); -@@ -1407,6 +1422,9 @@ static void fill_in_loclist_baton (struct dwarf2_cu *cu, +@@ -1489,6 +1504,9 @@ static void fill_in_loclist_baton (struct dwarf2_cu *cu, struct dwarf2_loclist_baton *baton, struct attribute *attr); @@ -1649,7 +1651,7 @@ index 52288e8..603b669 100644 static void dwarf2_symbol_mark_computed (struct attribute *attr, struct symbol *sym, struct dwarf2_cu *cu); -@@ -1422,7 +1440,7 @@ static hashval_t partial_die_hash (const void *item); +@@ -1504,7 +1522,7 @@ static hashval_t partial_die_hash (const void *item); static int partial_die_eq (const void *item_lhs, const void *item_rhs); static struct dwarf2_per_cu_data *dwarf2_find_containing_comp_unit @@ -1658,7 +1660,7 @@ index 52288e8..603b669 100644 static void init_one_comp_unit (struct dwarf2_cu *cu, struct dwarf2_per_cu_data *per_cu); -@@ -1439,6 +1457,9 @@ static void age_cached_comp_units (void); +@@ -1521,6 +1539,9 @@ static void age_cached_comp_units (void); static void free_one_cached_comp_unit (struct dwarf2_per_cu_data *); @@ -1668,7 +1670,7 @@ index 52288e8..603b669 100644 static struct type *set_die_type (struct die_info *, struct type *, struct dwarf2_cu *); -@@ -1464,6 +1485,9 @@ static struct type *get_die_type_at_offset (sect_offset, +@@ -1549,6 +1570,9 @@ static struct type *get_die_type_at_offset (sect_offset, static struct type *get_die_type (struct die_info *die, struct dwarf2_cu *cu); @@ -1678,7 +1680,7 @@ index 52288e8..603b669 100644 static void dwarf2_release_queue (void *dummy); static void queue_comp_unit (struct dwarf2_per_cu_data *per_cu, -@@ -1482,6 +1506,12 @@ static void find_file_and_directory (struct die_info *die, +@@ -1567,6 +1591,12 @@ static void find_file_and_directory (struct die_info *die, static char *file_full_name (int file, struct line_header *lh, const char *comp_dir); @@ -1689,9 +1691,9 @@ index 52288e8..603b669 100644 + int is_debug_types_section); + static void init_cutu_and_read_dies - (struct dwarf2_per_cu_data *this_cu, int use_existing_cu, int keep, - die_reader_func_ftype *die_reader_func, void *data); -@@ -1504,8 +1534,6 @@ static struct dwo_unit *lookup_dwo_type_unit + (struct dwarf2_per_cu_data *this_cu, struct abbrev_table *abbrev_table, + int use_existing_cu, int keep, +@@ -1588,8 +1618,6 @@ static struct dwo_unit *lookup_dwo_type_unit static void free_dwo_file_cleanup (void *); @@ -1700,7 +1702,7 @@ index 52288e8..603b669 100644 static void process_cu_includes (void); #if WORDS_BIGENDIAN -@@ -1675,85 +1703,6 @@ dwarf2_locate_sections (bfd *abfd, asection *sectp, void *vnames) +@@ -1759,85 +1787,6 @@ dwarf2_locate_sections (bfd *abfd, asection *sectp, void *vnames) dwarf2_per_objfile->has_section_at_zero = 1; } @@ -1786,7 +1788,7 @@ index 52288e8..603b669 100644 /* A helper function that decides whether a section is empty, or not present. */ -@@ -1780,56 +1729,27 @@ dwarf2_read_section (struct objfile *objfile, struct dwarf2_section_info *info) +@@ -1864,56 +1813,27 @@ dwarf2_read_section (struct objfile *objfile, struct dwarf2_section_info *info) if (info->readin) return; info->buffer = NULL; @@ -1853,7 +1855,7 @@ index 52288e8..603b669 100644 /* When debugging .o files, we may need to apply relocations; see http://sourceware.org/ml/gdb-patches/2002-04/msg00136.html . -@@ -1905,6 +1825,111 @@ dwarf2_get_section_info (struct objfile *objfile, +@@ -1989,6 +1909,111 @@ dwarf2_get_section_info (struct objfile *objfile, *sizep = info->size; } @@ -1965,7 +1967,7 @@ index 52288e8..603b669 100644 /* DWARF quick_symbols_functions support. */ -@@ -2101,23 +2126,19 @@ extract_cu_value (const char *bytes, ULONGEST *result) +@@ -2237,23 +2262,19 @@ extract_cu_value (const char *bytes, ULONGEST *result) return 1; } @@ -1997,7 +1999,7 @@ index 52288e8..603b669 100644 { struct dwarf2_per_cu_data *the_cu; ULONGEST offset, length; -@@ -2132,15 +2153,45 @@ create_cus_from_index (struct objfile *objfile, const gdb_byte *cu_list, +@@ -2268,15 +2289,45 @@ create_cus_from_index (struct objfile *objfile, const gdb_byte *cu_list, the_cu->offset.sect_off = offset; the_cu->length = length; the_cu->objfile = objfile; @@ -2045,7 +2047,7 @@ index 52288e8..603b669 100644 /* Create the signatured type hash table from the index. */ static int -@@ -2330,33 +2381,44 @@ find_slot_in_mapped_hash (struct mapped_index *index, const char *name, +@@ -2466,33 +2517,44 @@ find_slot_in_mapped_hash (struct mapped_index *index, const char *name, } } @@ -2103,7 +2105,7 @@ index 52288e8..603b669 100644 /* Version check. */ version = MAYBE_SWAP (*(offset_type *) addr); /* Versions earlier than 3 emitted every copy of a psymbol. This -@@ -2369,7 +2431,7 @@ dwarf2_read_index (struct objfile *objfile) +@@ -2505,7 +2567,7 @@ dwarf2_read_index (struct objfile *objfile) if (!warning_printed) { warning (_("Skipping obsolete .gdb_index section in %s."), @@ -2112,7 +2114,7 @@ index 52288e8..603b669 100644 warning_printed = 1; } return 0; -@@ -2382,14 +2444,14 @@ dwarf2_read_index (struct objfile *objfile) +@@ -2518,14 +2580,14 @@ dwarf2_read_index (struct objfile *objfile) set breakpoints on inlined functions by name, so we ignore these indices unless the --use-deprecated-index-sections command line option was supplied. */ @@ -2129,7 +2131,7 @@ index 52288e8..603b669 100644 warning_printed = 1; } return 0; -@@ -2399,22 +2461,21 @@ dwarf2_read_index (struct objfile *objfile) +@@ -2535,22 +2597,21 @@ dwarf2_read_index (struct objfile *objfile) if (version > 7) return 0; @@ -2160,7 +2162,7 @@ index 52288e8..603b669 100644 ++i; map->address_table = addr + MAYBE_SWAP (metadata[i]); -@@ -2430,11 +2491,55 @@ dwarf2_read_index (struct objfile *objfile) +@@ -2566,11 +2627,55 @@ dwarf2_read_index (struct objfile *objfile) map->constant_pool = addr + MAYBE_SWAP (metadata[i]); @@ -2218,7 +2220,7 @@ index 52288e8..603b669 100644 return 0; if (types_list_elements) -@@ -2455,7 +2560,10 @@ dwarf2_read_index (struct objfile *objfile) +@@ -2591,7 +2696,10 @@ dwarf2_read_index (struct objfile *objfile) return 0; } @@ -2230,7 +2232,7 @@ index 52288e8..603b669 100644 dwarf2_per_objfile->index_table = map; dwarf2_per_objfile->using_index = 1; -@@ -3442,6 +3550,22 @@ read_comp_unit_head (struct comp_unit_head *cu_header, +@@ -3624,6 +3732,22 @@ read_comp_unit_head (struct comp_unit_head *cu_header, return info_ptr; } @@ -2253,7 +2255,7 @@ index 52288e8..603b669 100644 /* Subroutine of read_and_check_comp_unit_head and read_and_check_type_unit_head to simplify them. Perform various error checking on the header. */ -@@ -3460,8 +3584,7 @@ error_check_comp_unit_head (struct comp_unit_head *header, +@@ -3642,8 +3766,7 @@ error_check_comp_unit_head (struct comp_unit_head *header, filename); if (header->abbrev_offset.sect_off @@ -2263,7 +2265,7 @@ index 52288e8..603b669 100644 error (_("Dwarf Error: bad offset (0x%lx) in compilation unit header " "(offset 0x%lx + 6) [in module %s]"), (long) header->abbrev_offset.sect_off, (long) header->offset.sect_off, -@@ -3678,6 +3801,7 @@ create_debug_types_hash_table (struct dwo_file *dwo_file, +@@ -3880,6 +4003,7 @@ create_debug_types_hash_table (struct dwo_file *dwo_file, { bfd *abfd; gdb_byte *info_ptr, *end_ptr; @@ -2271,7 +2273,7 @@ index 52288e8..603b669 100644 dwarf2_read_section (objfile, section); info_ptr = section->buffer; -@@ -3689,6 +3813,11 @@ create_debug_types_hash_table (struct dwo_file *dwo_file, +@@ -3891,6 +4015,11 @@ create_debug_types_hash_table (struct dwo_file *dwo_file, not present, in which case section->asection will be NULL. */ abfd = section->asection->owner; @@ -2283,7 +2285,7 @@ index 52288e8..603b669 100644 if (types_htab == NULL) { if (dwo_file) -@@ -3923,7 +4052,8 @@ init_cutu_and_read_dies (struct dwarf2_per_cu_data *this_cu, +@@ -4130,7 +4259,8 @@ init_cutu_and_read_dies (struct dwarf2_per_cu_data *this_cu, dwarf2_read_section (objfile, section); begin_info_ptr = info_ptr = section->buffer + this_cu->offset.sect_off; @@ -2293,7 +2295,7 @@ index 52288e8..603b669 100644 if (use_existing_cu && this_cu->cu != NULL) { -@@ -4290,7 +4420,7 @@ init_cutu_and_read_dies_simple (struct dwarf2_per_cu_data *this_cu, +@@ -4512,7 +4642,7 @@ init_cutu_and_read_dies_simple (struct dwarf2_per_cu_data *this_cu, void *data) { init_cutu_and_read_dies_no_follow (this_cu, @@ -2302,7 +2304,7 @@ index 52288e8..603b669 100644 NULL, die_reader_func, data); } -@@ -4537,6 +4667,9 @@ set_partial_user (struct objfile *objfile) +@@ -5132,6 +5262,9 @@ set_partial_user (struct objfile *objfile) struct partial_symtab *pst = per_cu->v.psymtab; int j; @@ -2312,8 +2314,8 @@ index 52288e8..603b669 100644 for (j = 0; j < pst->number_of_dependencies; ++j) { /* Set the 'user' field only if it is not already set. */ -@@ -4630,38 +4763,32 @@ load_partial_comp_unit (struct dwarf2_per_cu_data *this_cu) - init_cutu_and_read_dies (this_cu, 1, 1, load_partial_comp_unit_reader, NULL); +@@ -5226,38 +5359,32 @@ load_partial_comp_unit (struct dwarf2_per_cu_data *this_cu) + load_partial_comp_unit_reader, NULL); } -/* Create a list of all compilation units in OBJFILE. @@ -2363,7 +2365,7 @@ index 52288e8..603b669 100644 /* Save the compilation unit for later lookup. */ this_cu = obstack_alloc (&objfile->objfile_obstack, -@@ -4669,20 +4796,50 @@ create_all_comp_units (struct objfile *objfile) +@@ -5265,20 +5392,50 @@ create_all_comp_units (struct objfile *objfile) memset (this_cu, 0, sizeof (*this_cu)); this_cu->offset = offset; this_cu->length = length + initial_length_size; @@ -2421,15 +2423,15 @@ index 52288e8..603b669 100644 dwarf2_per_objfile->all_comp_units = obstack_alloc (&objfile->objfile_obstack, -@@ -4767,6 +4924,7 @@ scan_partial_symbols (struct partial_die_info *first_die, CORE_ADDR *lowpc, - struct dwarf2_per_cu_data *per_cu; +@@ -5371,6 +5528,7 @@ scan_partial_symbols (struct partial_die_info *first_die, CORE_ADDR *lowpc, + } per_cu = dwarf2_find_containing_comp_unit (pdi->d.offset, + pdi->is_dwz, cu->objfile); /* Go read the partial unit, if needed. */ -@@ -4824,7 +4982,8 @@ partial_die_parent_scope (struct partial_die_info *pdi, +@@ -5428,7 +5586,8 @@ partial_die_parent_scope (struct partial_die_info *pdi, real_pdi = pdi; while (real_pdi->has_specification) @@ -2439,7 +2441,7 @@ index 52288e8..603b669 100644 parent = real_pdi->die_parent; if (parent == NULL) -@@ -5324,6 +5483,9 @@ skip_one_die (const struct die_reader_specs *reader, gdb_byte *info_ptr, +@@ -5928,6 +6087,9 @@ skip_one_die (const struct die_reader_specs *reader, gdb_byte *info_ptr, else info_ptr += cu->header.offset_size; break; @@ -2449,7 +2451,7 @@ index 52288e8..603b669 100644 case DW_FORM_addr: info_ptr += cu->header.addr_size; break; -@@ -5353,6 +5515,7 @@ skip_one_die (const struct die_reader_specs *reader, gdb_byte *info_ptr, +@@ -5957,6 +6119,7 @@ skip_one_die (const struct die_reader_specs *reader, gdb_byte *info_ptr, break; case DW_FORM_sec_offset: case DW_FORM_strp: @@ -2457,18 +2459,17 @@ index 52288e8..603b669 100644 info_ptr += cu->header.offset_size; break; case DW_FORM_exprloc: -@@ -5999,7 +6162,9 @@ process_full_comp_unit (struct dwarf2_per_cu_data *per_cu, +@@ -6624,7 +6787,8 @@ process_full_comp_unit (struct dwarf2_per_cu_data *per_cu, it, by scanning the DIE's below the compilation unit. */ get_scope_pc_bounds (cu->dies, &lowpc, &highpc, cu); -- symtab = end_symtab (highpc + baseaddr, objfile, SECT_OFF_TEXT (objfile)); -+ symtab = end_symtab_full (highpc + baseaddr, objfile, -+ SECT_OFF_TEXT (objfile), -+ per_cu->imported_symtabs != NULL); +- static_block = end_symtab_get_static_block (highpc + baseaddr, objfile, 0); ++ static_block = end_symtab_get_static_block (highpc + baseaddr, objfile, 0, ++ per_cu->s.imported_symtabs != NULL); - if (symtab != NULL) - { -@@ -6068,9 +6233,11 @@ process_imported_unit_die (struct die_info *die, struct dwarf2_cu *cu) + /* If the comp unit has DW_AT_ranges, it may have discontiguous ranges. + Also, DW_AT_ranges may record ranges not belonging to any child DIEs +@@ -6775,9 +6939,11 @@ process_imported_unit_die (struct die_info *die, struct dwarf2_cu *cu) struct dwarf2_per_cu_data *per_cu; struct symtab *imported_symtab; sect_offset offset; @@ -2481,7 +2482,7 @@ index 52288e8..603b669 100644 /* Queue the unit, if needed. */ if (maybe_queue_comp_unit (cu, per_cu, cu->language)) -@@ -7284,24 +7451,22 @@ try_open_dwo_file (const char *file_name) +@@ -8046,24 +8212,22 @@ try_open_dwo_file (const char *file_name) if (desc < 0) return NULL; @@ -2510,7 +2511,7 @@ index 52288e8..603b669 100644 return sym_bfd; } -@@ -7493,20 +7658,7 @@ free_dwo_file (struct dwo_file *dwo_file, struct objfile *objfile) +@@ -8255,20 +8419,7 @@ free_dwo_file (struct dwo_file *dwo_file, struct objfile *objfile) struct dwarf2_section_info *section; gdb_assert (dwo_file->dwo_bfd != objfile->obfd); @@ -2532,7 +2533,7 @@ index 52288e8..603b669 100644 VEC_free (dwarf2_section_info_def, dwo_file->sections.types); } -@@ -9878,6 +10030,29 @@ process_enumeration_scope (struct die_info *die, struct dwarf2_cu *cu) +@@ -10651,6 +10802,29 @@ process_enumeration_scope (struct die_info *die, struct dwarf2_cu *cu) new_symbol (die, this_type, cu); } @@ -2562,7 +2563,7 @@ index 52288e8..603b669 100644 /* Extract all information from a DW_TAG_array_type DIE and put it in the DIE's type field. For now, this only handles one dimensional arrays. */ -@@ -9891,7 +10066,7 @@ read_array_type (struct die_info *die, struct dwarf2_cu *cu) +@@ -10664,7 +10838,7 @@ read_array_type (struct die_info *die, struct dwarf2_cu *cu) struct type *element_type, *range_type, *index_type; struct type **range_types = NULL; struct attribute *attr; @@ -2571,7 +2572,7 @@ index 52288e8..603b669 100644 struct cleanup *back_to; char *name; -@@ -9944,17 +10119,19 @@ read_array_type (struct die_info *die, struct dwarf2_cu *cu) +@@ -10717,17 +10891,19 @@ read_array_type (struct die_info *die, struct dwarf2_cu *cu) type = element_type; if (read_array_order (die, cu) == DW_ORD_col_major) @@ -2602,7 +2603,7 @@ index 52288e8..603b669 100644 /* Understand Dwarf2 support for vector types (like they occur on the PowerPC w/ AltiVec). Gcc just adds another attribute to the -@@ -10438,29 +10615,114 @@ read_tag_string_type (struct die_info *die, struct dwarf2_cu *cu) +@@ -11211,29 +11387,114 @@ read_tag_string_type (struct die_info *die, struct dwarf2_cu *cu) struct gdbarch *gdbarch = get_objfile_arch (objfile); struct type *type, *range_type, *index_type, *char_type; struct attribute *attr; @@ -2730,7 +2731,7 @@ index 52288e8..603b669 100644 char_type = language_string_char_type (cu->language_defn, gdbarch); type = create_string_type (NULL, char_type, range_type); -@@ -10764,7 +11026,7 @@ read_subrange_type (struct die_info *die, struct dwarf2_cu *cu) +@@ -11537,7 +11798,7 @@ read_subrange_type (struct die_info *die, struct dwarf2_cu *cu) struct type *base_type; struct type *range_type; struct attribute *attr; @@ -2739,7 +2740,7 @@ index 52288e8..603b669 100644 int low_default_is_valid; char *name; LONGEST negative_mask; -@@ -10820,42 +11082,6 @@ read_subrange_type (struct die_info *die, struct dwarf2_cu *cu) +@@ -11593,42 +11854,6 @@ read_subrange_type (struct die_info *die, struct dwarf2_cu *cu) "- DIE at 0x%x [in module %s]"), die->offset.sect_off, cu->objfile->name); @@ -2782,7 +2783,7 @@ index 52288e8..603b669 100644 /* Dwarf-2 specifications explicitly allows to create subrange types without specifying a base type. In that case, the base type must be set to the type of -@@ -10894,24 +11120,163 @@ read_subrange_type (struct die_info *die, struct dwarf2_cu *cu) +@@ -11667,24 +11892,163 @@ read_subrange_type (struct die_info *die, struct dwarf2_cu *cu) } } @@ -2960,7 +2961,7 @@ index 52288e8..603b669 100644 name = dwarf2_name (die, cu); if (name) -@@ -11685,6 +12050,8 @@ read_partial_die (const struct die_reader_specs *reader, +@@ -12474,6 +12838,8 @@ read_partial_die (const struct die_reader_specs *reader, case DW_AT_extension: part_die->has_specification = 1; part_die->spec_offset = dwarf2_get_ref_die_offset (&attr); @@ -2969,7 +2970,7 @@ index 52288e8..603b669 100644 break; case DW_AT_sibling: /* Ignore absolute siblings, they might point outside of -@@ -11731,7 +12098,11 @@ read_partial_die (const struct die_reader_specs *reader, +@@ -12520,7 +12886,11 @@ read_partial_die (const struct die_reader_specs *reader, case DW_AT_import: if (part_die->tag == DW_TAG_imported_unit) @@ -2982,7 +2983,7 @@ index 52288e8..603b669 100644 break; default: -@@ -11802,13 +12173,14 @@ find_partial_die_in_comp_unit (sect_offset offset, struct dwarf2_cu *cu) +@@ -12591,13 +12961,14 @@ find_partial_die_in_comp_unit (sect_offset offset, struct dwarf2_cu *cu) DW_FORM_ref_sig8). */ static struct partial_die_info * @@ -2999,7 +3000,7 @@ index 52288e8..603b669 100644 { pd = find_partial_die_in_comp_unit (offset, cu); if (pd != NULL) -@@ -11827,7 +12199,8 @@ find_partial_die (sect_offset offset, struct dwarf2_cu *cu) +@@ -12616,7 +12987,8 @@ find_partial_die (sect_offset offset, struct dwarf2_cu *cu) (long) cu->header.offset.sect_off, (long) offset.sect_off, bfd_get_filename (objfile->obfd)); } @@ -3009,7 +3010,7 @@ index 52288e8..603b669 100644 if (per_cu->cu == NULL || per_cu->cu->partial_dies == NULL) load_partial_comp_unit (per_cu); -@@ -11885,7 +12258,8 @@ guess_partial_die_structure_name (struct partial_die_info *struct_pdi, +@@ -12674,7 +13046,8 @@ guess_partial_die_structure_name (struct partial_die_info *struct_pdi, real_pdi = struct_pdi; while (real_pdi->has_specification) @@ -3019,7 +3020,7 @@ index 52288e8..603b669 100644 if (real_pdi->die_parent != NULL) return; -@@ -11933,7 +12307,8 @@ fixup_partial_die (struct partial_die_info *part_die, +@@ -12722,7 +13095,8 @@ fixup_partial_die (struct partial_die_info *part_die, { struct partial_die_info *spec_die; @@ -3029,7 +3030,7 @@ index 52288e8..603b669 100644 fixup_partial_die (spec_die, cu); -@@ -12021,6 +12396,10 @@ read_attribute_value (const struct die_reader_specs *reader, +@@ -12810,6 +13184,10 @@ read_attribute_value (const struct die_reader_specs *reader, &cu->header, &bytes_read); info_ptr += bytes_read; break; @@ -3040,7 +3041,7 @@ index 52288e8..603b669 100644 case DW_FORM_addr: DW_ADDR (attr) = read_address (abfd, info_ptr, cu, &bytes_read); info_ptr += bytes_read; -@@ -12063,10 +12442,25 @@ read_attribute_value (const struct die_reader_specs *reader, +@@ -12852,10 +13230,25 @@ read_attribute_value (const struct die_reader_specs *reader, info_ptr += bytes_read; break; case DW_FORM_strp: @@ -3070,7 +3071,7 @@ index 52288e8..603b669 100644 break; case DW_FORM_exprloc: case DW_FORM_block: -@@ -12178,6 +12572,10 @@ read_attribute_value (const struct die_reader_specs *reader, +@@ -12967,6 +13360,10 @@ read_attribute_value (const struct die_reader_specs *reader, bfd_get_filename (abfd)); } @@ -3081,7 +3082,7 @@ index 52288e8..603b669 100644 /* We have seen instances where the compiler tried to emit a byte size attribute of -1 which ended up being encoded as an unsigned 0xffffffff. Although 0xffffffff is technically a valid size value, -@@ -12474,6 +12872,30 @@ read_indirect_string_at_offset (bfd *abfd, LONGEST str_offset) +@@ -13263,6 +13660,30 @@ read_indirect_string_at_offset (bfd *abfd, LONGEST str_offset) return (char *) (dwarf2_per_objfile->str.buffer + str_offset); } @@ -3112,7 +3113,7 @@ index 52288e8..603b669 100644 static char * read_indirect_string (bfd *abfd, gdb_byte *buf, const struct comp_unit_head *cu_header, -@@ -12946,6 +13368,30 @@ add_file_name (struct line_header *lh, +@@ -13734,6 +14155,30 @@ add_file_name (struct line_header *lh, fe->symtab = NULL; } @@ -3143,7 +3144,7 @@ index 52288e8..603b669 100644 /* Read the statement program header starting at OFFSET in .debug_line, or .debug_line.dwo. Return a pointer to a struct line_header, allocated using xmalloc. -@@ -12966,13 +13412,7 @@ dwarf_decode_line_header (unsigned int offset, struct dwarf2_cu *cu) +@@ -13754,13 +14199,7 @@ dwarf_decode_line_header (unsigned int offset, struct dwarf2_cu *cu) struct dwarf2_section_info *section; bfd *abfd; @@ -3158,7 +3159,7 @@ index 52288e8..603b669 100644 dwarf2_read_section (dwarf2_per_objfile->objfile, section); if (section->buffer == NULL) { -@@ -13297,7 +13737,7 @@ dwarf_decode_lines_1 (struct line_header *lh, const char *comp_dir, +@@ -14085,7 +14524,7 @@ dwarf_decode_lines_1 (struct line_header *lh, const char *comp_dir, GCd by the linker. Ignore it. PR gdb/12528 */ long line_offset @@ -3167,7 +3168,7 @@ index 52288e8..603b669 100644 complaint (&symfile_complaints, _(".debug_line address at offset 0x%lx is 0 " -@@ -13659,10 +14099,12 @@ var_decode_location (struct attribute *attr, struct symbol *sym, +@@ -14464,10 +14903,12 @@ var_decode_location (struct attribute *attr, struct symbol *sym, (i.e. when the value of a register or memory location is referenced, or a thread-local block, etc.). Then again, it might not be worthwhile. I'm assuming that it isn't unless performance @@ -3182,7 +3183,7 @@ index 52288e8..603b669 100644 if (SYMBOL_COMPUTED_OPS (sym) == &dwarf2_loclist_funcs) cu->has_loclist = 1; -@@ -13703,6 +14145,8 @@ new_symbol_full (struct die_info *die, struct type *type, struct dwarf2_cu *cu, +@@ -14508,6 +14949,8 @@ new_symbol_full (struct die_info *die, struct type *type, struct dwarf2_cu *cu, else sym = OBSTACK_ZALLOC (&objfile->objfile_obstack, struct symbol); OBJSTAT (objfile, n_syms++); @@ -3191,7 +3192,7 @@ index 52288e8..603b669 100644 /* Cache this symbol's name and the name's demangled form (if any). */ SYMBOL_SET_LANGUAGE (sym, cu->language); -@@ -14126,6 +14570,7 @@ dwarf2_const_value_attr (struct attribute *attr, struct type *type, +@@ -14931,6 +15374,7 @@ dwarf2_const_value_attr (struct attribute *attr, struct type *type, case DW_FORM_string: case DW_FORM_strp: case DW_FORM_GNU_str_index: @@ -3199,7 +3200,7 @@ index 52288e8..603b669 100644 /* DW_STRING is already allocated on the objfile obstack, point directly to it. */ *bytes = (gdb_byte *) DW_STRING (attr); -@@ -14312,7 +14757,15 @@ lookup_die_type (struct die_info *die, struct attribute *attr, +@@ -15117,7 +15561,15 @@ lookup_die_type (struct die_info *die, struct attribute *attr, /* First see if we have it cached. */ @@ -3216,7 +3217,7 @@ index 52288e8..603b669 100644 { sect_offset offset = dwarf2_get_ref_die_offset (attr); -@@ -14477,6 +14930,9 @@ read_type_die_1 (struct die_info *die, struct dwarf2_cu *cu) +@@ -15282,6 +15734,9 @@ read_type_die_1 (struct die_info *die, struct dwarf2_cu *cu) break; } @@ -3226,7 +3227,7 @@ index 52288e8..603b669 100644 return this_type; } -@@ -15085,6 +15541,10 @@ dump_die_shallow (struct ui_file *f, int indent, struct die_info *die) +@@ -15890,6 +16345,10 @@ dump_die_shallow (struct ui_file *f, int indent, struct die_info *die) fprintf_unfiltered (f, "ref address: "); fputs_filtered (hex_string (DW_UNSND (&die->attrs[i])), f); break; @@ -3237,7 +3238,7 @@ index 52288e8..603b669 100644 case DW_FORM_ref1: case DW_FORM_ref2: case DW_FORM_ref4: -@@ -15116,6 +15576,7 @@ dump_die_shallow (struct ui_file *f, int indent, struct die_info *die) +@@ -15921,6 +16380,7 @@ dump_die_shallow (struct ui_file *f, int indent, struct die_info *die) case DW_FORM_string: case DW_FORM_strp: case DW_FORM_GNU_str_index: @@ -3245,7 +3246,7 @@ index 52288e8..603b669 100644 fprintf_unfiltered (f, "string: \"%s\" (%s canonicalized)", DW_STRING (&die->attrs[i]) ? DW_STRING (&die->attrs[i]) : "", -@@ -15219,6 +15680,7 @@ is_ref_attr (struct attribute *attr) +@@ -16024,6 +16484,7 @@ is_ref_attr (struct attribute *attr) case DW_FORM_ref4: case DW_FORM_ref8: case DW_FORM_ref_udata: @@ -3253,7 +3254,7 @@ index 52288e8..603b669 100644 return 1; default: return 0; -@@ -15296,7 +15758,8 @@ follow_die_ref_or_sig (struct die_info *src_die, struct attribute *attr, +@@ -16101,7 +16562,8 @@ follow_die_ref_or_sig (struct die_info *src_die, struct attribute *attr, Returns NULL if OFFSET is invalid. */ static struct die_info * @@ -3263,7 +3264,7 @@ index 52288e8..603b669 100644 { struct die_info temp_die; struct dwarf2_cu *target_cu, *cu = *ref_cu; -@@ -15313,11 +15776,13 @@ follow_die_offset (sect_offset offset, struct dwarf2_cu **ref_cu) +@@ -16118,11 +16580,13 @@ follow_die_offset (sect_offset offset, struct dwarf2_cu **ref_cu) if (! offset_in_cu_p (&cu->header, offset)) return NULL; } @@ -3279,7 +3280,7 @@ index 52288e8..603b669 100644 /* If necessary, add it to the queue and load its DIEs. */ if (maybe_queue_comp_unit (cu, per_cu, cu->language)) -@@ -15349,7 +15814,10 @@ follow_die_ref (struct die_info *src_die, struct attribute *attr, +@@ -16154,7 +16618,10 @@ follow_die_ref (struct die_info *src_die, struct attribute *attr, struct dwarf2_cu *cu = *ref_cu; struct die_info *die; @@ -3291,7 +3292,7 @@ index 52288e8..603b669 100644 if (!die) error (_("Dwarf Error: Cannot find DIE at 0x%x referenced from DIE " "at 0x%x [in module %s]"), -@@ -15380,7 +15848,7 @@ dwarf2_fetch_die_location_block (cu_offset offset_in_cu, +@@ -16185,7 +16652,7 @@ dwarf2_fetch_die_location_block (cu_offset offset_in_cu, load_cu (per_cu); cu = per_cu->cu; @@ -3300,7 +3301,7 @@ index 52288e8..603b669 100644 if (!die) error (_("Dwarf Error: Cannot find DIE at 0x%x referenced in module %s"), offset.sect_off, per_cu->objfile->name); -@@ -16179,6 +16647,7 @@ skip_form_bytes (bfd *abfd, gdb_byte *bytes, gdb_byte *buffer_end, +@@ -16979,6 +17446,7 @@ skip_form_bytes (bfd *abfd, gdb_byte *bytes, gdb_byte *buffer_end, case DW_FORM_sec_offset: case DW_FORM_strp: @@ -3308,7 +3309,7 @@ index 52288e8..603b669 100644 bytes += offset_size; break; -@@ -16334,7 +16803,7 @@ dwarf_decode_macro_bytes (bfd *abfd, gdb_byte *mac_ptr, gdb_byte *mac_end, +@@ -17134,7 +17602,7 @@ dwarf_decode_macro_bytes (bfd *abfd, gdb_byte *mac_ptr, gdb_byte *mac_end, struct macro_source_file *current_file, struct line_header *lh, char *comp_dir, struct dwarf2_section_info *section, @@ -3317,7 +3318,7 @@ index 52288e8..603b669 100644 unsigned int offset_size, struct objfile *objfile, htab_t include_hash) -@@ -16385,6 +16854,8 @@ dwarf_decode_macro_bytes (bfd *abfd, gdb_byte *mac_ptr, gdb_byte *mac_end, +@@ -17185,6 +17653,8 @@ dwarf_decode_macro_bytes (bfd *abfd, gdb_byte *mac_ptr, gdb_byte *mac_end, case DW_MACRO_GNU_undef: case DW_MACRO_GNU_define_indirect: case DW_MACRO_GNU_undef_indirect: @@ -3326,7 +3327,7 @@ index 52288e8..603b669 100644 { unsigned int bytes_read; int line; -@@ -16407,11 +16878,20 @@ dwarf_decode_macro_bytes (bfd *abfd, gdb_byte *mac_ptr, gdb_byte *mac_end, +@@ -17207,11 +17677,20 @@ dwarf_decode_macro_bytes (bfd *abfd, gdb_byte *mac_ptr, gdb_byte *mac_end, str_offset = read_offset_1 (abfd, mac_ptr, offset_size); mac_ptr += offset_size; @@ -3349,7 +3350,7 @@ index 52288e8..603b669 100644 if (! current_file) { /* DWARF violation as no main source is present. */ -@@ -16435,7 +16915,8 @@ dwarf_decode_macro_bytes (bfd *abfd, gdb_byte *mac_ptr, gdb_byte *mac_end, +@@ -17235,7 +17714,8 @@ dwarf_decode_macro_bytes (bfd *abfd, gdb_byte *mac_ptr, gdb_byte *mac_end, else { gdb_assert (macinfo_type == DW_MACRO_GNU_undef @@ -3359,7 +3360,7 @@ index 52288e8..603b669 100644 macro_undef (current_file, line, body); } } -@@ -16510,6 +16991,7 @@ dwarf_decode_macro_bytes (bfd *abfd, gdb_byte *mac_ptr, gdb_byte *mac_end, +@@ -17310,6 +17790,7 @@ dwarf_decode_macro_bytes (bfd *abfd, gdb_byte *mac_ptr, gdb_byte *mac_end, break; case DW_MACRO_GNU_transparent_include: @@ -3367,7 +3368,7 @@ index 52288e8..603b669 100644 { LONGEST offset; void **slot; -@@ -16528,13 +17010,32 @@ dwarf_decode_macro_bytes (bfd *abfd, gdb_byte *mac_ptr, gdb_byte *mac_end, +@@ -17328,13 +17809,32 @@ dwarf_decode_macro_bytes (bfd *abfd, gdb_byte *mac_ptr, gdb_byte *mac_end, } else { @@ -3404,7 +3405,7 @@ index 52288e8..603b669 100644 offset_size, objfile, include_hash); htab_remove_elt (include_hash, mac_ptr); -@@ -16753,7 +17254,8 @@ dwarf_decode_macros (struct dwarf2_cu *cu, unsigned int offset, +@@ -17553,7 +18053,8 @@ dwarf_decode_macros (struct dwarf2_cu *cu, unsigned int offset, slot = htab_find_slot (include_hash, mac_ptr, INSERT); *slot = mac_ptr; dwarf_decode_macro_bytes (abfd, mac_ptr, mac_end, @@ -3414,7 +3415,7 @@ index 52288e8..603b669 100644 offset_size, objfile, include_hash); do_cleanups (cleanup); } -@@ -16851,62 +17353,100 @@ fill_in_loclist_baton (struct dwarf2_cu *cu, +@@ -17651,62 +18152,100 @@ fill_in_loclist_baton (struct dwarf2_cu *cu, baton->from_dwo = cu->dwo_unit != NULL; } @@ -3553,7 +3554,7 @@ index 52288e8..603b669 100644 } } -@@ -17008,28 +17548,35 @@ dwarf2_per_cu_text_offset (struct dwarf2_per_cu_data *per_cu) +@@ -17808,28 +18347,35 @@ dwarf2_per_cu_text_offset (struct dwarf2_per_cu_data *per_cu) static struct dwarf2_per_cu_data * dwarf2_find_containing_comp_unit (sect_offset offset, @@ -3594,7 +3595,7 @@ index 52288e8..603b669 100644 error (_("Dwarf Error: could not find partial DIE containing " "offset 0x%lx [in module %s]"), (long) offset.sect_off, bfd_get_filename (objfile->obfd)); -@@ -17270,6 +17817,25 @@ per_cu_offset_and_type_eq (const void *item_lhs, const void *item_rhs) +@@ -18070,6 +18616,25 @@ per_cu_offset_and_type_eq (const void *item_lhs, const void *item_rhs) && ofs_lhs->offset.sect_off == ofs_rhs->offset.sect_off); } @@ -3620,7 +3621,7 @@ index 52288e8..603b669 100644 /* Set the type associated with DIE to TYPE. Save it in CU's hash table if necessary. For convenience, return TYPE. -@@ -17294,6 +17860,8 @@ set_die_type (struct die_info *die, struct type *type, struct dwarf2_cu *cu) +@@ -18094,6 +18659,8 @@ set_die_type (struct die_info *die, struct type *type, struct dwarf2_cu *cu) struct dwarf2_per_cu_offset_and_type **slot, ofs; struct objfile *objfile = cu->objfile; @@ -3629,7 +3630,7 @@ index 52288e8..603b669 100644 /* For Ada types, make sure that the gnat-specific data is always initialized (if not already set). There are a few types where we should not be doing so, because the type-specific area is -@@ -17471,53 +18039,13 @@ show_dwarf2_cmd (char *args, int from_tty) +@@ -18271,53 +18838,13 @@ show_dwarf2_cmd (char *args, int from_tty) cmd_show_list (show_dwarf2_cmdlist, from_tty, ""); } @@ -3684,7 +3685,7 @@ index 52288e8..603b669 100644 for (ix = 0; ix < dwarf2_per_objfile->n_comp_units; ++ix) VEC_free (dwarf2_per_cu_ptr, -@@ -17527,6 +18055,9 @@ dwarf2_per_objfile_free (struct objfile *objfile, void *d) +@@ -18327,6 +18854,9 @@ dwarf2_per_objfile_free (struct objfile *objfile, void *d) if (data->dwo_files) free_dwo_files (data->dwo_files, objfile); @@ -3716,7 +3717,7 @@ index 1edfb27..d9109cf 100644 xfree (found); diff --git a/gdb/eval.c b/gdb/eval.c -index 3d43406..5568b1c 100644 +index 7d3a8b9..f69dff0 100644 --- a/gdb/eval.c +++ b/gdb/eval.c @@ -41,6 +41,7 @@ @@ -3961,7 +3962,7 @@ index 3d43406..5568b1c 100644 } -@@ -801,6 +992,7 @@ evaluate_subexp_standard (struct type *expect_type, +@@ -818,6 +1009,7 @@ evaluate_subexp_standard (struct type *expect_type, int save_pos1; struct symbol *function = NULL; char *function_name = NULL; @@ -3969,7 +3970,7 @@ index 3d43406..5568b1c 100644 pc = (*pos)++; op = exp->elts[pc].opcode; -@@ -1875,6 +2067,8 @@ evaluate_subexp_standard (struct type *expect_type, +@@ -1892,6 +2084,8 @@ evaluate_subexp_standard (struct type *expect_type, /* First determine the type code we are dealing with. */ arg1 = evaluate_subexp (NULL_TYPE, exp, pos, noside); @@ -3978,7 +3979,7 @@ index 3d43406..5568b1c 100644 type = check_typedef (value_type (arg1)); code = TYPE_CODE (type); -@@ -1895,23 +2089,13 @@ evaluate_subexp_standard (struct type *expect_type, +@@ -1912,23 +2106,13 @@ evaluate_subexp_standard (struct type *expect_type, code = TYPE_CODE (type); } } @@ -4004,7 +4005,7 @@ index 3d43406..5568b1c 100644 case TYPE_CODE_PTR: case TYPE_CODE_FUNC: -@@ -2344,49 +2528,6 @@ evaluate_subexp_standard (struct type *expect_type, +@@ -2361,49 +2545,6 @@ evaluate_subexp_standard (struct type *expect_type, } return (arg1); @@ -4054,7 +4055,7 @@ index 3d43406..5568b1c 100644 case BINOP_LOGICAL_AND: arg1 = evaluate_subexp (NULL_TYPE, exp, pos, noside); if (noside == EVAL_SKIP) -@@ -2618,15 +2759,23 @@ evaluate_subexp_standard (struct type *expect_type, +@@ -2635,15 +2776,23 @@ evaluate_subexp_standard (struct type *expect_type, if (expect_type && TYPE_CODE (expect_type) == TYPE_CODE_PTR) expect_type = TYPE_TARGET_TYPE (check_typedef (expect_type)); arg1 = evaluate_subexp (expect_type, exp, pos, noside); @@ -4080,7 +4081,7 @@ index 3d43406..5568b1c 100644 else if (noside == EVAL_AVOID_SIDE_EFFECTS) { type = check_typedef (value_type (arg1)); -@@ -2635,12 +2784,18 @@ evaluate_subexp_standard (struct type *expect_type, +@@ -2652,12 +2801,18 @@ evaluate_subexp_standard (struct type *expect_type, /* In C you can dereference an array to get the 1st elt. */ || TYPE_CODE (type) == TYPE_CODE_ARRAY ) @@ -4104,7 +4105,7 @@ index 3d43406..5568b1c 100644 else error (_("Attempt to take contents of a non-pointer value.")); } -@@ -2650,9 +2805,14 @@ evaluate_subexp_standard (struct type *expect_type, +@@ -2667,9 +2822,14 @@ evaluate_subexp_standard (struct type *expect_type, do. "long long" variables are rare enough that BUILTIN_TYPE_LONGEST would seem to be a mistake. */ if (TYPE_CODE (type) == TYPE_CODE_INT) @@ -4122,7 +4123,7 @@ index 3d43406..5568b1c 100644 case UNOP_ADDR: /* C++: check for and handle pointer to members. */ -@@ -2994,7 +3154,7 @@ evaluate_subexp_with_coercion (struct expression *exp, +@@ -3011,7 +3171,7 @@ evaluate_subexp_with_coercion (struct expression *exp, { enum exp_opcode op; int pc; @@ -4131,7 +4132,7 @@ index 3d43406..5568b1c 100644 struct symbol *var; struct type *type; -@@ -3005,13 +3165,18 @@ evaluate_subexp_with_coercion (struct expression *exp, +@@ -3022,13 +3182,18 @@ evaluate_subexp_with_coercion (struct expression *exp, { case OP_VAR_VALUE: var = exp->elts[pc + 2].symbol; @@ -4151,7 +4152,7 @@ index 3d43406..5568b1c 100644 return value_cast (lookup_pointer_type (TYPE_TARGET_TYPE (type)), val); } -@@ -3063,9 +3228,13 @@ evaluate_subexp_for_sizeof (struct expression *exp, int *pos) +@@ -3080,9 +3245,13 @@ evaluate_subexp_for_sizeof (struct expression *exp, int *pos) case OP_VAR_VALUE: (*pos) += 4; @@ -4168,7 +4169,7 @@ index 3d43406..5568b1c 100644 default: val = evaluate_subexp (NULL_TYPE, exp, pos, EVAL_AVOID_SIDE_EFFECTS); -@@ -3096,18 +3265,25 @@ parse_and_eval_type (char *p, int length) +@@ -3113,18 +3282,25 @@ parse_and_eval_type (char *p, int length) int calc_f77_array_dims (struct type *array_type) { @@ -5280,7 +5281,7 @@ index 0000000..1dd82c3 + +#endif /* GDB_BFD_H */ diff --git a/gdb/gdbtypes.c b/gdb/gdbtypes.c -index 0eec874..7217639 100644 +index 8142ab9..a2953cc 100644 --- a/gdb/gdbtypes.c +++ b/gdb/gdbtypes.c @@ -37,6 +37,9 @@ @@ -5372,7 +5373,7 @@ index 0eec874..7217639 100644 if (typeptr) *typeptr = ntype; } -@@ -747,6 +796,7 @@ create_range_type (struct type *result_type, struct type *index_type, +@@ -784,6 +833,7 @@ create_range_type (struct type *result_type, struct type *index_type, TYPE_ZALLOC (result_type, sizeof (struct range_bounds)); TYPE_LOW_BOUND (result_type) = low_bound; TYPE_HIGH_BOUND (result_type) = high_bound; @@ -5380,7 +5381,7 @@ index 0eec874..7217639 100644 if (low_bound >= 0) TYPE_UNSIGNED (result_type) = 1; -@@ -890,26 +940,31 @@ create_array_type (struct type *result_type, +@@ -927,26 +977,31 @@ create_array_type (struct type *result_type, TYPE_CODE (result_type) = TYPE_CODE_ARRAY; TYPE_TARGET_TYPE (result_type) = element_type; @@ -5425,7 +5426,7 @@ index 0eec874..7217639 100644 return result_type; } -@@ -1431,6 +1486,105 @@ stub_noname_complaint (void) +@@ -1468,6 +1523,105 @@ stub_noname_complaint (void) complaint (&symfile_complaints, _("stub type has NULL name")); } @@ -5531,7 +5532,7 @@ index 0eec874..7217639 100644 /* Find the real type of TYPE. This function returns the real type, after removing all layers of typedefs, and completing opaque or stub types. Completion changes the TYPE argument, but stripping of -@@ -1597,52 +1751,37 @@ check_typedef (struct type *type) +@@ -1634,52 +1788,37 @@ check_typedef (struct type *type) } } @@ -5605,7 +5606,7 @@ index 0eec874..7217639 100644 TYPE_TARGET_STUB (type) = 0; } else if (TYPE_CODE (type) == TYPE_CODE_RANGE) -@@ -1650,6 +1789,7 @@ check_typedef (struct type *type) +@@ -1687,6 +1826,7 @@ check_typedef (struct type *type) TYPE_LENGTH (type) = TYPE_LENGTH (target_type); TYPE_TARGET_STUB (type) = 0; } @@ -5613,7 +5614,7 @@ index 0eec874..7217639 100644 } type = make_qualified_type (type, instance_flags, NULL); -@@ -3308,33 +3448,42 @@ type_pair_eq (const void *item_lhs, const void *item_rhs) +@@ -3345,33 +3485,42 @@ type_pair_eq (const void *item_lhs, const void *item_rhs) } /* Allocate the hash table used by copy_type_recursive to walk @@ -5671,7 +5672,7 @@ index 0eec874..7217639 100644 return type; /* This type shouldn't be pointing to any types in other objfiles; -@@ -3349,9 +3498,10 @@ copy_type_recursive (struct objfile *objfile, +@@ -3386,9 +3535,10 @@ copy_type_recursive (struct objfile *objfile, new_type = alloc_type_arch (get_type_arch (type)); /* We must add the new type to the hash table immediately, in case @@ -5685,7 +5686,7 @@ index 0eec874..7217639 100644 stored->old = type; stored->new = new_type; *slot = stored; -@@ -3362,6 +3512,21 @@ copy_type_recursive (struct objfile *objfile, +@@ -3399,6 +3549,21 @@ copy_type_recursive (struct objfile *objfile, TYPE_OBJFILE_OWNED (new_type) = 0; TYPE_OWNER (new_type).gdbarch = get_type_arch (type); @@ -5707,7 +5708,7 @@ index 0eec874..7217639 100644 if (TYPE_NAME (type)) TYPE_NAME (new_type) = xstrdup (TYPE_NAME (type)); if (TYPE_TAG_NAME (type)) -@@ -3370,12 +3535,48 @@ copy_type_recursive (struct objfile *objfile, +@@ -3407,12 +3572,48 @@ copy_type_recursive (struct objfile *objfile, TYPE_INSTANCE_FLAGS (new_type) = TYPE_INSTANCE_FLAGS (type); TYPE_LENGTH (new_type) = TYPE_LENGTH (type); @@ -5756,7 +5757,7 @@ index 0eec874..7217639 100644 TYPE_FIELDS (new_type) = XCALLOC (nfields, struct field); for (i = 0; i < nfields; i++) { -@@ -3384,8 +3585,8 @@ copy_type_recursive (struct objfile *objfile, +@@ -3421,8 +3622,8 @@ copy_type_recursive (struct objfile *objfile, TYPE_FIELD_BITSIZE (new_type, i) = TYPE_FIELD_BITSIZE (type, i); if (TYPE_FIELD_TYPE (type, i)) TYPE_FIELD_TYPE (new_type, i) @@ -5767,7 +5768,7 @@ index 0eec874..7217639 100644 if (TYPE_FIELD_NAME (type, i)) TYPE_FIELD_NAME (new_type, i) = xstrdup (TYPE_FIELD_NAME (type, i)); -@@ -3416,24 +3617,184 @@ copy_type_recursive (struct objfile *objfile, +@@ -3453,24 +3654,184 @@ copy_type_recursive (struct objfile *objfile, } } @@ -5959,7 +5960,7 @@ index 0eec874..7217639 100644 /* Maybe copy the type_specific bits. NOTE drow/2005-12-09: We do not copy the C++-specific bits like -@@ -3450,6 +3811,17 @@ copy_type_recursive (struct objfile *objfile, +@@ -3487,6 +3848,17 @@ copy_type_recursive (struct objfile *objfile, return new_type; } @@ -5977,7 +5978,7 @@ index 0eec874..7217639 100644 /* Make a copy of the given TYPE, except that the pointer & reference types are not preserved. -@@ -3472,6 +3844,201 @@ copy_type (const struct type *type) +@@ -3509,6 +3881,201 @@ copy_type (const struct type *type) return new_type; } @@ -6179,7 +6180,7 @@ index 0eec874..7217639 100644 /* Helper functions to initialize architecture-specific types. */ -@@ -4005,6 +4572,13 @@ void +@@ -4042,6 +4609,13 @@ void _initialize_gdbtypes (void) { gdbtypes_data = gdbarch_data_register_post_init (gdbtypes_post_init); @@ -6194,10 +6195,10 @@ index 0eec874..7217639 100644 add_setshow_zinteger_cmd ("overload", no_class, &overload_debug, diff --git a/gdb/gdbtypes.h b/gdb/gdbtypes.h -index cf7d398..a0f5b17 100644 +index 17bfbc5..72e9cc5 100644 --- a/gdb/gdbtypes.h +++ b/gdb/gdbtypes.h -@@ -214,6 +214,11 @@ enum type_instance_flag_value +@@ -228,6 +228,11 @@ enum type_instance_flag_value #define TYPE_TARGET_STUB(t) (TYPE_MAIN_TYPE (t)->flag_target_stub) @@ -6209,7 +6210,7 @@ index cf7d398..a0f5b17 100644 /* Static type. If this is set, the corresponding type had a static modifier. Note: This may be unnecessary, since static data members -@@ -297,6 +302,50 @@ enum type_instance_flag_value +@@ -311,6 +316,50 @@ enum type_instance_flag_value #define TYPE_FLAG_ENUM(t) (TYPE_MAIN_TYPE (t)->flag_flag_enum) @@ -6260,7 +6261,7 @@ index cf7d398..a0f5b17 100644 /* Constant type. If this is set, the corresponding type has a const modifier. */ -@@ -407,6 +456,15 @@ struct main_type +@@ -421,6 +470,15 @@ struct main_type /* True if this type was declared with "class" rather than "struct". */ unsigned int flag_declared_class : 1; @@ -6276,7 +6277,7 @@ index cf7d398..a0f5b17 100644 /* True if this is an enum type with disjoint values. This affects how the enum is printed. */ -@@ -487,6 +545,20 @@ struct main_type +@@ -501,6 +559,20 @@ struct main_type struct type *target_type; @@ -6297,7 +6298,7 @@ index cf7d398..a0f5b17 100644 /* For structure and union types, a description of each field. For set and pascal array types, there is one "field", whose type is the domain type of the set or array. -@@ -569,13 +641,34 @@ struct main_type +@@ -583,13 +655,34 @@ struct main_type struct range_bounds { @@ -6337,7 +6338,7 @@ index cf7d398..a0f5b17 100644 /* Flags indicating whether the values of low and high are valid. When true, the respective range value is -@@ -1040,9 +1133,9 @@ extern void allocate_gnat_aux_type (struct type *); +@@ -1054,9 +1147,9 @@ extern void allocate_gnat_aux_type (struct type *); #define TYPE_POINTER_TYPE(thistype) (thistype)->pointer_type #define TYPE_REFERENCE_TYPE(thistype) (thistype)->reference_type #define TYPE_CHAIN(thistype) (thistype)->chain @@ -6350,7 +6351,7 @@ index cf7d398..a0f5b17 100644 calls check_typedef, TYPE_LENGTH (VALUE_TYPE (X)) is safe. */ #define TYPE_LENGTH(thistype) (thistype)->length /* Note that TYPE_CODE can be TYPE_CODE_TYPEDEF, so if you want the real -@@ -1050,11 +1143,16 @@ extern void allocate_gnat_aux_type (struct type *); +@@ -1064,11 +1157,16 @@ extern void allocate_gnat_aux_type (struct type *); #define TYPE_CODE(thistype) TYPE_MAIN_TYPE(thistype)->code #define TYPE_NFIELDS(thistype) TYPE_MAIN_TYPE(thistype)->nfields #define TYPE_FIELDS(thistype) TYPE_MAIN_TYPE(thistype)->flds_bnds.fields @@ -6369,7 +6370,7 @@ index cf7d398..a0f5b17 100644 #define TYPE_LOW_BOUND_UNDEFINED(range_type) \ TYPE_RANGE_DATA(range_type)->low_undefined #define TYPE_HIGH_BOUND_UNDEFINED(range_type) \ -@@ -1071,7 +1169,14 @@ extern void allocate_gnat_aux_type (struct type *); +@@ -1085,7 +1183,14 @@ extern void allocate_gnat_aux_type (struct type *); (TYPE_HIGH_BOUND(TYPE_INDEX_TYPE((arraytype)))) #define TYPE_ARRAY_LOWER_BOUND_VALUE(arraytype) \ @@ -6385,7 +6386,7 @@ index cf7d398..a0f5b17 100644 /* C++ */ -@@ -1513,6 +1618,18 @@ extern struct type *create_array_type (struct type *, struct type *, +@@ -1531,6 +1636,18 @@ extern struct type *create_array_type (struct type *, struct type *, struct type *); extern struct type *lookup_array_range_type (struct type *, int, int); @@ -6404,7 +6405,7 @@ index cf7d398..a0f5b17 100644 extern struct type *create_string_type (struct type *, struct type *, struct type *); extern struct type *lookup_string_range_type (struct type *, int, int); -@@ -1558,6 +1675,10 @@ extern int is_public_ancestor (struct type *, struct type *); +@@ -1576,6 +1693,10 @@ extern int is_public_ancestor (struct type *, struct type *); extern int is_unique_ancestor (struct type *, struct value *); @@ -6415,7 +6416,7 @@ index cf7d398..a0f5b17 100644 /* Overload resolution */ #define LENGTH_MATCH(bv) ((bv)->rank[0]) -@@ -1633,10 +1754,13 @@ extern void maintenance_print_type (char *, int); +@@ -1651,10 +1772,13 @@ extern void maintenance_print_type (char *, int); extern htab_t create_copied_types_hash (struct objfile *objfile); @@ -7057,10 +7058,10 @@ index b8434ed..98a076d 100644 void diff --git a/gdb/parse.c b/gdb/parse.c -index c372f40..6707c9a 100644 +index 529c517..6326a01 100644 --- a/gdb/parse.c +++ b/gdb/parse.c -@@ -1584,6 +1584,7 @@ parser_fprintf (FILE *x, const char *y, ...) +@@ -1708,6 +1708,7 @@ parser_fprintf (FILE *x, const char *y, ...) int operator_check_standard (struct expression *exp, int pos, @@ -7068,7 +7069,7 @@ index c372f40..6707c9a 100644 int (*objfile_func) (struct objfile *objfile, void *data), void *data) -@@ -1625,7 +1626,7 @@ operator_check_standard (struct expression *exp, int pos, +@@ -1749,7 +1750,7 @@ operator_check_standard (struct expression *exp, int pos, struct type *type = elts[pos + 2 + arg].type; struct objfile *objfile = TYPE_OBJFILE (type); @@ -7077,7 +7078,7 @@ index c372f40..6707c9a 100644 return 1; } } -@@ -1643,7 +1644,8 @@ operator_check_standard (struct expression *exp, int pos, +@@ -1767,7 +1768,8 @@ operator_check_standard (struct expression *exp, int pos, /* Check objfile where the variable itself is placed. SYMBOL_OBJ_SECTION (symbol) may be NULL. */ @@ -7087,7 +7088,7 @@ index c372f40..6707c9a 100644 return 1; /* Check objfile where is placed the code touching the variable. */ -@@ -1656,24 +1658,27 @@ operator_check_standard (struct expression *exp, int pos, +@@ -1780,24 +1782,27 @@ operator_check_standard (struct expression *exp, int pos, /* Invoke callbacks for TYPE and OBJFILE if they were set as non-NULL. */ @@ -7123,7 +7124,7 @@ index c372f40..6707c9a 100644 int (*objfile_func) (struct objfile *objfile, void *data), void *data) { -@@ -1688,7 +1693,9 @@ exp_iterate (struct expression *exp, +@@ -1812,7 +1817,9 @@ exp_iterate (struct expression *exp, pos = endpos - oplen; if (exp->language_defn->la_exp_desc->operator_check (exp, pos, @@ -7134,7 +7135,7 @@ index c372f40..6707c9a 100644 return 1; endpos = pos; -@@ -1719,8 +1726,29 @@ exp_uses_objfile (struct expression *exp, struct objfile *objfile) +@@ -1843,8 +1850,29 @@ exp_uses_objfile (struct expression *exp, struct objfile *objfile) { gdb_assert (objfile->separate_debug_objfile_backlink == NULL); @@ -7166,10 +7167,10 @@ index c372f40..6707c9a 100644 void _initialize_parse (void) diff --git a/gdb/parser-defs.h b/gdb/parser-defs.h -index aa600a1..554c272 100644 +index 86f3bdf..f908a61 100644 --- a/gdb/parser-defs.h +++ b/gdb/parser-defs.h -@@ -217,6 +217,8 @@ extern void operator_length_standard (const struct expression *, int, int *, +@@ -245,6 +245,8 @@ extern void operator_length_standard (const struct expression *, int, int *, int *); extern int operator_check_standard (struct expression *exp, int pos, @@ -7178,7 +7179,7 @@ index aa600a1..554c272 100644 int (*objfile_func) (struct objfile *objfile, void *data), void *data); -@@ -303,6 +305,7 @@ struct exp_descriptor +@@ -331,6 +333,7 @@ struct exp_descriptor value should be immediately returned to the caller. Otherwise zero should be returned. */ int (*operator_check) (struct expression *exp, int pos, @@ -7186,7 +7187,7 @@ index aa600a1..554c272 100644 int (*objfile_func) (struct objfile *objfile, void *data), void *data); -@@ -341,4 +344,10 @@ extern void parser_fprintf (FILE *, const char *, ...) ATTRIBUTE_PRINTF (2, 3); +@@ -369,4 +372,10 @@ extern void parser_fprintf (FILE *, const char *, ...) ATTRIBUTE_PRINTF (2, 3); extern int exp_uses_objfile (struct expression *exp, struct objfile *objfile); @@ -12775,7 +12776,7 @@ index acfd89b..c77d9c2 100644 # Test either C or C++ values. test_subscript_regression "${binfile}" "c" diff --git a/gdb/testsuite/lib/gdb.exp b/gdb/testsuite/lib/gdb.exp -index 289d4d8..da0d089 100644 +index 4f2b7c9..0daef25 100644 --- a/gdb/testsuite/lib/gdb.exp +++ b/gdb/testsuite/lib/gdb.exp @@ -142,6 +142,11 @@ proc gdb_unload {} { diff --git a/gdb-attach-fail-reasons-5of5.patch b/gdb-attach-fail-reasons-5of5.patch index bf95e7c..a7400c7 100644 --- a/gdb-attach-fail-reasons-5of5.patch +++ b/gdb-attach-fail-reasons-5of5.patch @@ -37,13 +37,13 @@ gdb/gdbserver/ (linux_create_inferior, linux_tracefork_child): Call it instead of direct ptrace. -Index: gdb-7.4.50.20120602/gdb/common/linux-ptrace.c +Index: gdb-7.4.50.20120714/gdb/common/linux-ptrace.c =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/common/linux-ptrace.c 2012-03-13 16:02:23.000000000 +0100 -+++ gdb-7.4.50.20120602/gdb/common/linux-ptrace.c 2012-06-02 20:37:53.933828570 +0200 -@@ -27,6 +27,10 @@ - #include "linux-procfs.h" +--- gdb-7.4.50.20120714.orig/gdb/common/linux-ptrace.c 2012-07-07 14:13:56.000000000 +0200 ++++ gdb-7.4.50.20120714/gdb/common/linux-ptrace.c 2012-07-14 23:30:02.918167283 +0200 +@@ -28,6 +28,10 @@ #include "buffer.h" + #include "gdb_assert.h" +#ifdef HAVE_SELINUX_SELINUX_H +# include @@ -52,13 +52,19 @@ Index: gdb-7.4.50.20120602/gdb/common/linux-ptrace.c /* Find all possible reasons we could fail to attach PID and append these newline terminated reason strings to initialized BUFFER. '\0' termination of BUFFER must be done by the caller. */ -@@ -46,4 +50,22 @@ linux_ptrace_attach_warnings (pid_t pid, +@@ -47,6 +51,8 @@ linux_ptrace_attach_warnings (pid_t pid, buffer_xml_printf (buffer, _("warning: process %d is a zombie " "- the process has already terminated\n"), (int) pid); + + linux_ptrace_create_warnings (buffer); -+} + } + + #ifdef __i386__ +@@ -171,3 +177,19 @@ linux_ptrace_init_warnings (void) + + linux_ptrace_test_ret_to_nx (); + } + +/* Print all possible reasons we could fail to create a traced process. */ + @@ -74,23 +80,23 @@ Index: gdb-7.4.50.20120602/gdb/common/linux-ptrace.c + "you can disable this process attach protection by: " + "(gdb) shell sudo setsebool deny_ptrace=0")); +#endif /* HAVE_LIBSELINUX */ - } -Index: gdb-7.4.50.20120602/gdb/common/linux-ptrace.h ++} +Index: gdb-7.4.50.20120714/gdb/common/linux-ptrace.h =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/common/linux-ptrace.h 2012-03-13 16:02:23.000000000 +0100 -+++ gdb-7.4.50.20120602/gdb/common/linux-ptrace.h 2012-06-02 20:37:46.565831956 +0200 -@@ -68,5 +68,6 @@ struct buffer; - #endif +--- gdb-7.4.50.20120714.orig/gdb/common/linux-ptrace.h 2012-07-07 14:13:56.000000000 +0200 ++++ gdb-7.4.50.20120714/gdb/common/linux-ptrace.h 2012-07-14 23:29:20.927399812 +0200 +@@ -69,5 +69,6 @@ struct buffer; extern void linux_ptrace_attach_warnings (pid_t pid, struct buffer *buffer); + extern void linux_ptrace_init_warnings (void); +extern void linux_ptrace_create_warnings (struct buffer *buffer); #endif /* COMMON_LINUX_PTRACE_H */ -Index: gdb-7.4.50.20120602/gdb/configure.ac +Index: gdb-7.4.50.20120714/gdb/configure.ac =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/configure.ac 2012-06-02 20:05:08.000000000 +0200 -+++ gdb-7.4.50.20120602/gdb/configure.ac 2012-06-02 20:35:06.379798726 +0200 -@@ -2002,6 +2002,10 @@ then +--- gdb-7.4.50.20120714.orig/gdb/configure.ac 2012-07-14 23:28:57.000000000 +0200 ++++ gdb-7.4.50.20120714/gdb/configure.ac 2012-07-14 23:29:09.492462934 +0200 +@@ -2008,6 +2008,10 @@ then [Define if you support the personality syscall.]) fi @@ -101,10 +107,10 @@ Index: gdb-7.4.50.20120602/gdb/configure.ac dnl Handle optional features that can be enabled. # Support for --with-sysroot is a copy of GDB_AC_WITH_DIR, -Index: gdb-7.4.50.20120602/gdb/gdbserver/configure.ac +Index: gdb-7.4.50.20120714/gdb/gdbserver/configure.ac =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/gdbserver/configure.ac 2012-04-19 21:34:51.000000000 +0200 -+++ gdb-7.4.50.20120602/gdb/gdbserver/configure.ac 2012-06-02 20:35:06.408797663 +0200 +--- gdb-7.4.50.20120714.orig/gdb/gdbserver/configure.ac 2012-04-19 21:34:51.000000000 +0200 ++++ gdb-7.4.50.20120714/gdb/gdbserver/configure.ac 2012-07-14 23:29:09.492462934 +0200 @@ -438,6 +438,10 @@ if $want_ipa ; then fi fi @@ -116,10 +122,10 @@ Index: gdb-7.4.50.20120602/gdb/gdbserver/configure.ac AC_SUBST(GDBSERVER_DEPFILES) AC_SUBST(GDBSERVER_LIBS) AC_SUBST(USE_THREAD_DB) -Index: gdb-7.4.50.20120602/gdb/gdbserver/linux-low.c +Index: gdb-7.4.50.20120714/gdb/gdbserver/linux-low.c =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/gdbserver/linux-low.c 2012-05-30 21:51:38.000000000 +0200 -+++ gdb-7.4.50.20120602/gdb/gdbserver/linux-low.c 2012-06-02 20:39:49.886785355 +0200 +--- gdb-7.4.50.20120714.orig/gdb/gdbserver/linux-low.c 2012-07-07 14:13:57.000000000 +0200 ++++ gdb-7.4.50.20120714/gdb/gdbserver/linux-low.c 2012-07-14 23:29:09.496462912 +0200 @@ -601,6 +601,28 @@ add_lwp (ptid_t ptid) return lwp; } @@ -158,7 +164,7 @@ Index: gdb-7.4.50.20120602/gdb/gdbserver/linux-low.c #ifndef __ANDROID__ /* Bionic doesn't use SIGRTMIN the way glibc does. */ signal (__SIGRTMIN + 1, SIG_DFL); -@@ -4567,7 +4589,7 @@ linux_tracefork_grandchild (void *arg) +@@ -4572,7 +4594,7 @@ linux_tracefork_grandchild (void *arg) static int linux_tracefork_child (void *arg) { @@ -167,10 +173,10 @@ Index: gdb-7.4.50.20120602/gdb/gdbserver/linux-low.c kill (getpid (), SIGSTOP); #if !(defined(__UCLIBC__) && defined(HAS_NOMMU)) -Index: gdb-7.4.50.20120602/gdb/inf-ptrace.c +Index: gdb-7.4.50.20120714/gdb/inf-ptrace.c =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/inf-ptrace.c 2012-05-24 18:51:34.000000000 +0200 -+++ gdb-7.4.50.20120602/gdb/inf-ptrace.c 2012-06-02 20:35:06.428797311 +0200 +--- gdb-7.4.50.20120714.orig/gdb/inf-ptrace.c 2012-05-24 18:51:34.000000000 +0200 ++++ gdb-7.4.50.20120714/gdb/inf-ptrace.c 2012-07-14 23:29:09.496462912 +0200 @@ -105,7 +105,15 @@ static void inf_ptrace_me (void) { @@ -187,11 +193,11 @@ Index: gdb-7.4.50.20120602/gdb/inf-ptrace.c } /* Start a new inferior Unix child process. EXEC_FILE is the file to -Index: gdb-7.4.50.20120602/gdb/linux-nat.c +Index: gdb-7.4.50.20120714/gdb/linux-nat.c =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/linux-nat.c 2012-06-02 20:01:38.000000000 +0200 -+++ gdb-7.4.50.20120602/gdb/linux-nat.c 2012-06-02 20:41:18.101751186 +0200 -@@ -1572,6 +1572,7 @@ linux_nat_create_inferior (struct target +--- gdb-7.4.50.20120714.orig/gdb/linux-nat.c 2012-07-14 23:21:32.000000000 +0200 ++++ gdb-7.4.50.20120714/gdb/linux-nat.c 2012-07-14 23:29:09.497462907 +0200 +@@ -1574,6 +1574,7 @@ linux_nat_create_inferior (struct target #ifdef HAVE_PERSONALITY int personality_orig = 0, personality_set = 0; #endif /* HAVE_PERSONALITY */ @@ -199,7 +205,7 @@ Index: gdb-7.4.50.20120602/gdb/linux-nat.c /* The fork_child mechanism is synchronous and calls target_wait, so we have to mask the async mode. */ -@@ -1596,7 +1597,10 @@ linux_nat_create_inferior (struct target +@@ -1598,7 +1599,10 @@ linux_nat_create_inferior (struct target /* Make sure we report all signals during startup. */ linux_nat_pass_signals (0, NULL); @@ -211,7 +217,7 @@ Index: gdb-7.4.50.20120602/gdb/linux-nat.c #ifdef HAVE_PERSONALITY if (personality_set) -@@ -1608,6 +1612,24 @@ linux_nat_create_inferior (struct target +@@ -1610,6 +1614,24 @@ linux_nat_create_inferior (struct target safe_strerror (errno)); } #endif /* HAVE_PERSONALITY */ diff --git a/gdb-bz592031-siginfo-lost-5of5.patch b/gdb-bz592031-siginfo-lost-5of5.patch deleted file mode 100644 index 46cbdbc..0000000 --- a/gdb-bz592031-siginfo-lost-5of5.patch +++ /dev/null @@ -1,141 +0,0 @@ -http://sourceware.org/ml/gdb-patches/2010-09/msg00361.html -Subject: [patch 4/4]#3 Remove redundant lp->siginfo - -Hi, - -this is a simplification which should not affect GDB behavior. As linux-nat -now stops on each received signal without any reordering of them then -PTRACE_GETSIGINFO is enough to access siginfo, without any need to copy it in -advance. - - -Thanks, -Jan - - -gdb/ -2010-09-20 Jan Kratochvil - - * linux-nat.c (resume_callback) stopped && lp->status == 0> - (linux_nat_resume): Remove LP->SIGINFO clearing. - (save_siginfo): Remove. - (stop_wait_callback) - (linux_nat_filter_event) : Remove - the save_siginfo call. - (resume_stopped_resumed_lwps): Remove LP->SIGINFO clearing. - (linux_nat_set_siginfo_fixup): Use PTRACE_GETSIGINFO. - * linux-nat.h (struct lwp_info) : Remove. - -Index: gdb-7.4.50.20120703/gdb/linux-nat.c -=================================================================== ---- gdb-7.4.50.20120703.orig/gdb/linux-nat.c 2012-07-03 17:33:02.000000000 +0200 -+++ gdb-7.4.50.20120703/gdb/linux-nat.c 2012-07-03 17:38:36.738142509 +0200 -@@ -1933,7 +1933,6 @@ resume_lwp (struct lwp_info *lp, int ste - step, signo); - lp->stopped = 0; - lp->step = step; -- memset (&lp->siginfo, 0, sizeof (lp->siginfo)); - lp->stopped_by_watchpoint = 0; - } - else -@@ -2092,7 +2091,6 @@ linux_nat_resume (struct target_ops *ops - if (linux_nat_prepare_to_resume != NULL) - linux_nat_prepare_to_resume (lp); - linux_ops->to_resume (linux_ops, ptid, step, signo); -- memset (&lp->siginfo, 0, sizeof (lp->siginfo)); - lp->stopped_by_watchpoint = 0; - - if (debug_linux_nat) -@@ -2646,22 +2644,6 @@ wait_lwp (struct lwp_info *lp) - return status; - } - --/* Save the most recent siginfo for LP. This is currently only called -- for SIGTRAP; some ports use the si_addr field for -- target_stopped_data_address. In the future, it may also be used to -- restore the siginfo of requeued signals. */ -- --static void --save_siginfo (struct lwp_info *lp) --{ -- errno = 0; -- ptrace (PTRACE_GETSIGINFO, GET_LWP (lp->ptid), -- (PTRACE_TYPE_ARG3) 0, &lp->siginfo); -- -- if (errno != 0) -- memset (&lp->siginfo, 0, sizeof (lp->siginfo)); --} -- - /* Send a SIGSTOP to LP. */ - - static int -@@ -2904,9 +2886,6 @@ stop_wait_callback (struct lwp_info *lp, - { - /* The thread was stopped with a signal other than SIGSTOP. */ - -- /* Save the trap's siginfo in case we need it later. */ -- save_siginfo (lp); -- - save_sigtrap (lp); - - if (debug_linux_nat) -@@ -3288,12 +3267,7 @@ linux_nat_filter_event (int lwpid, int s - } - - if (linux_nat_status_is_event (status)) -- { -- /* Save the trap's siginfo in case we need it later. */ -- save_siginfo (lp); -- -- save_sigtrap (lp); -- } -+ save_sigtrap (lp); - - /* Check if the thread has exited. */ - if ((WIFEXITED (status) || WIFSIGNALED (status)) -@@ -3947,7 +3921,6 @@ resume_stopped_resumed_lwps (struct lwp_ - linux_ops->to_resume (linux_ops, pid_to_ptid (GET_LWP (lp->ptid)), - lp->step, GDB_SIGNAL_0); - lp->stopped = 0; -- memset (&lp->siginfo, 0, sizeof (lp->siginfo)); - lp->stopped_by_watchpoint = 0; - } - -@@ -5224,11 +5197,19 @@ linux_nat_set_prepare_to_resume (struct - siginfo_t * - linux_nat_get_siginfo (ptid_t ptid) - { -- struct lwp_info *lp = find_lwp_pid (ptid); -+ static siginfo_t siginfo; -+ int pid; - -- gdb_assert (lp != NULL); -+ pid = GET_LWP (ptid); -+ if (pid == 0) -+ pid = GET_PID (ptid); -+ -+ errno = 0; -+ ptrace (PTRACE_GETSIGINFO, pid, (PTRACE_TYPE_ARG3) 0, &siginfo); -+ if (errno != 0) -+ memset (&siginfo, 0, sizeof (siginfo)); - -- return &lp->siginfo; -+ return &siginfo; - } - - /* Provide a prototype to silence -Wmissing-prototypes. */ -Index: gdb-7.4.50.20120703/gdb/linux-nat.h -=================================================================== ---- gdb-7.4.50.20120703.orig/gdb/linux-nat.h 2012-07-03 17:30:09.000000000 +0200 -+++ gdb-7.4.50.20120703/gdb/linux-nat.h 2012-07-03 17:38:13.501170247 +0200 -@@ -76,10 +76,6 @@ struct lwp_info - /* 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. */ -- siginfo_t siginfo; -- - /* STOPPED_BY_WATCHPOINT is non-zero if this LWP stopped with a data - watchpoint trap. */ - int stopped_by_watchpoint; diff --git a/gdb-dlopen-stap-probe-test.patch b/gdb-dlopen-stap-probe-test.patch index 15f1c31..efd3683 100644 --- a/gdb-dlopen-stap-probe-test.patch +++ b/gdb-dlopen-stap-probe-test.patch @@ -4,10 +4,10 @@ Date: Mon Aug 8 12:08:53 2011 +0200 +testcase -Index: gdb-7.4.50.20120703/gdb/testsuite/gdb.threads/dlopen-libpthread-lib.c +Index: gdb-7.4.50.20120714/gdb/testsuite/gdb.threads/dlopen-libpthread-lib.c =================================================================== --- /dev/null 1970-01-01 00:00:00.000000000 +0000 -+++ gdb-7.4.50.20120703/gdb/testsuite/gdb.threads/dlopen-libpthread-lib.c 2012-07-03 17:44:45.797698656 +0200 ++++ gdb-7.4.50.20120714/gdb/testsuite/gdb.threads/dlopen-libpthread-lib.c 2012-07-15 08:51:38.238701282 +0200 @@ -0,0 +1,40 @@ +/* This testcase is part of GDB, the GNU debugger. + @@ -49,10 +49,10 @@ Index: gdb-7.4.50.20120703/gdb/testsuite/gdb.threads/dlopen-libpthread-lib.c + i = pthread_join (t, NULL); + assert (i == 0); +} -Index: gdb-7.4.50.20120703/gdb/testsuite/gdb.threads/dlopen-libpthread.c +Index: gdb-7.4.50.20120714/gdb/testsuite/gdb.threads/dlopen-libpthread.c =================================================================== --- /dev/null 1970-01-01 00:00:00.000000000 +0000 -+++ gdb-7.4.50.20120703/gdb/testsuite/gdb.threads/dlopen-libpthread.c 2012-07-03 17:44:45.798698655 +0200 ++++ gdb-7.4.50.20120714/gdb/testsuite/gdb.threads/dlopen-libpthread.c 2012-07-15 08:51:38.239701277 +0200 @@ -0,0 +1,46 @@ +/* This testcase is part of GDB, the GNU debugger. + @@ -100,10 +100,10 @@ Index: gdb-7.4.50.20120703/gdb/testsuite/gdb.threads/dlopen-libpthread.c + + return 0; +} -Index: gdb-7.4.50.20120703/gdb/testsuite/gdb.threads/dlopen-libpthread.exp +Index: gdb-7.4.50.20120714/gdb/testsuite/gdb.threads/dlopen-libpthread.exp =================================================================== --- /dev/null 1970-01-01 00:00:00.000000000 +0000 -+++ gdb-7.4.50.20120703/gdb/testsuite/gdb.threads/dlopen-libpthread.exp 2012-07-03 17:44:45.798698655 +0200 ++++ gdb-7.4.50.20120714/gdb/testsuite/gdb.threads/dlopen-libpthread.exp 2012-07-15 09:08:01.760258588 +0200 @@ -0,0 +1,74 @@ +# Copyright 2011 Free Software Foundation, Inc. +# @@ -148,12 +148,12 @@ Index: gdb-7.4.50.20120703/gdb/testsuite/gdb.threads/dlopen-libpthread.exp + return -1 +} + -+set test "print _dl_debug_notify" ++set test "info probes all rtld rtld_map_complete" +gdb_test_multiple $test $test { -+ -re " 0x\[0-9a-f\]+ <_dl_debug_notify>\r\n$gdb_prompt $" { ++ -re "\[ \t\]rtld_map_complete\[ \t\]+0x\[0-9a-f\]+.*\r\n$gdb_prompt $" { + pass $test + } -+ -re "No symbol \"_dl_debug_notify\" in current context\\.\r\n$gdb_prompt $" { ++ -re "No probes matched\\.\r\n$gdb_prompt $" { + xfail $test + untested ${testfile}.exp + return @@ -179,24 +179,23 @@ Index: gdb-7.4.50.20120703/gdb/testsuite/gdb.threads/dlopen-libpthread.exp +gdb_continue_to_breakpoint "notify" ".* notify-here .*" + +gdb_test "info sharedlibrary" {/libpthread\.so.*} "libpthread.so found" -Index: gdb-7.4.50.20120703/gdb/testsuite/lib/gdb.exp +Index: gdb-7.4.50.20120714/gdb/testsuite/lib/gdb.exp =================================================================== ---- gdb-7.4.50.20120703.orig/gdb/testsuite/lib/gdb.exp 2012-07-03 17:34:18.000000000 +0200 -+++ gdb-7.4.50.20120703/gdb/testsuite/lib/gdb.exp 2012-07-03 17:46:44.316514076 +0200 -@@ -3758,23 +3758,7 @@ proc build_executable { testname executa - set sources ${executable}.c - } +--- gdb-7.4.50.20120714.orig/gdb/testsuite/lib/gdb.exp 2012-07-15 08:51:36.803709222 +0200 ++++ gdb-7.4.50.20120714/gdb/testsuite/lib/gdb.exp 2012-07-15 09:02:41.983028197 +0200 +@@ -3774,22 +3774,6 @@ proc build_executable_from_specs {testna + + set binfile [standard_output_file $executable] -- set binfile [standard_output_file $executable] -- - set objects {} -- for {set i 0} "\$i<[llength $sources]" {incr i} { -- set s [lindex $sources $i] -- if { [gdb_compile "${srcdir}/${subdir}/${s}" "${binfile}${i}.o" object $options] != "" } { +- set i 0 +- foreach {s local_options} $args { +- if { [gdb_compile "${srcdir}/${subdir}/${s}" "${binfile}${i}.o" object $local_options] != "" } { - untested $testname - return -1 - } - lappend objects "${binfile}${i}.o" +- incr i - } - - if { [gdb_compile $objects "${binfile}" executable $options] != "" } { @@ -204,11 +203,10 @@ Index: gdb-7.4.50.20120703/gdb/testsuite/lib/gdb.exp - return -1 - } - -+ # get_compiler_info by gdb_compile_shlib and gdb_compile_shlib_pthreads. set info_options "" if { [lsearch -exact $options "c++"] >= 0 } { set info_options "c++" -@@ -3782,6 +3766,41 @@ proc build_executable { testname executa +@@ -3797,6 +3781,42 @@ proc build_executable_from_specs {testna if [get_compiler_info ${info_options}] { return -1 } @@ -223,22 +221,23 @@ Index: gdb-7.4.50.20120703/gdb/testsuite/lib/gdb.exp + + # gdb_compile_shlib and gdb_compile_shlib_pthreads do not use the 3rd + # parameter. They also requires $sources while gdb_compile and -+ # gdb_compile_pthreads require $objects. ++ # gdb_compile_pthreads require $objects. Moreover they ignore any options. + if [string match gdb_compile_shlib* $func] { + set sources_path {} -+ foreach s $sources { ++ foreach {s local_options} $args { + lappend sources_path "${srcdir}/${subdir}/${s}" + } + set ret [$func $sources_path "${binfile}" $options] + } else { + set objects {} -+ for {set i 0} "\$i<[llength $sources]" {incr i} { -+ set s [lindex $sources $i] -+ if { [gdb_compile "${srcdir}/${subdir}/${s}" "${binfile}${i}.o" object $options] != "" } { ++ set i 0 ++ foreach {s local_options} $args { ++ if { [gdb_compile "${srcdir}/${subdir}/${s}" "${binfile}${i}.o" object $local_options] != "" } { + untested $testname + return -1 + } + lappend objects "${binfile}${i}.o" ++ incr i + } + set ret [$func $objects "${binfile}" executable $options] + } @@ -250,10 +249,10 @@ Index: gdb-7.4.50.20120703/gdb/testsuite/lib/gdb.exp return 0 } -Index: gdb-7.4.50.20120703/gdb/testsuite/lib/prelink-support.exp +Index: gdb-7.4.50.20120714/gdb/testsuite/lib/prelink-support.exp =================================================================== ---- gdb-7.4.50.20120703.orig/gdb/testsuite/lib/prelink-support.exp 2012-01-04 09:27:56.000000000 +0100 -+++ gdb-7.4.50.20120703/gdb/testsuite/lib/prelink-support.exp 2012-07-03 17:44:45.803698648 +0200 +--- gdb-7.4.50.20120714.orig/gdb/testsuite/lib/prelink-support.exp 2012-01-04 09:27:56.000000000 +0100 ++++ gdb-7.4.50.20120714/gdb/testsuite/lib/prelink-support.exp 2012-07-15 08:51:38.243701254 +0200 @@ -95,8 +95,9 @@ proc file_copy {src dest} { # Wrap function build_executable so that the resulting executable is fully # self-sufficient (without dependencies on system libraries). Parameter @@ -306,10 +305,10 @@ Index: gdb-7.4.50.20120703/gdb/testsuite/lib/prelink-support.exp return $prelink_args } -Index: gdb-7.4.50.20120703/gdb/testsuite/gdb.base/break-interp.exp +Index: gdb-7.4.50.20120714/gdb/testsuite/gdb.base/break-interp.exp =================================================================== ---- gdb-7.4.50.20120703.orig/gdb/testsuite/gdb.base/break-interp.exp 2012-06-21 22:46:21.000000000 +0200 -+++ gdb-7.4.50.20120703/gdb/testsuite/gdb.base/break-interp.exp 2012-07-03 17:44:45.804698647 +0200 +--- gdb-7.4.50.20120714.orig/gdb/testsuite/gdb.base/break-interp.exp 2012-06-21 22:46:21.000000000 +0200 ++++ gdb-7.4.50.20120714/gdb/testsuite/gdb.base/break-interp.exp 2012-07-15 08:51:38.244701248 +0200 @@ -109,14 +109,21 @@ proc strip_debug {dest} { } } diff --git a/gdb-errno-func-datatype-revert.patch b/gdb-errno-func-datatype-revert.patch deleted file mode 100644 index 847d76f..0000000 --- a/gdb-errno-func-datatype-revert.patch +++ /dev/null @@ -1,236 +0,0 @@ -Regression: Invalid data type for function to be called. [Re: FYI: fix PR 9514] -http://sourceware.org/ml/gdb-patches/2012-07/msg00043.html - -reverted: -http://sourceware.org/ml/gdb-cvs/2012-06/msg00148.html - -diff -dup -rup gdb-7.4.50.20120703-orig/gdb/c-exp.y gdb-7.4.50.20120703/gdb/c-exp.y ---- gdb-7.4.50.20120703-orig/gdb/c-exp.y 2012-07-03 20:08:15.976418420 +0200 -+++ gdb-7.4.50.20120703/gdb/c-exp.y 2012-07-03 20:08:35.935390282 +0200 -@@ -172,10 +172,9 @@ static struct stoken operator_stoken (co - /* %type block */ - - /* Fancy type parsing. */ --%type func_mod direct_abs_decl abs_decl ptr_operator -+%type func_mod direct_abs_decl abs_decl - %type ptype - %type array_mod --%type conversion_type_id - - %token INT - %token FLOAT -@@ -932,7 +931,9 @@ variable: name_not_typename - ; - - space_identifier : '@' NAME -- { insert_type_address_space (copy_name ($2.stoken)); } -+ { push_type_address_space (copy_name ($2.stoken)); -+ push_type (tp_space_identifier); -+ } - ; - - const_or_volatile: const_or_volatile_noopt -@@ -951,23 +952,14 @@ const_or_volatile_or_space_identifier: - | - ; - --ptr_operator: -- ptr_operator '*' -- { insert_type (tp_pointer); } -- const_or_volatile_or_space_identifier -- { $$ = 0; } -- | '*' -- { insert_type (tp_pointer); } -- const_or_volatile_or_space_identifier -- { $$ = 0; } -+abs_decl: '*' -+ { push_type (tp_pointer); $$ = 0; } -+ | '*' abs_decl -+ { push_type (tp_pointer); $$ = $2; } - | '&' -- { insert_type (tp_reference); $$ = 0; } -- | '&' ptr_operator -- { insert_type (tp_reference); $$ = 0; } -- ; -- --abs_decl: ptr_operator direct_abs_decl -- | ptr_operator -+ { push_type (tp_reference); $$ = 0; } -+ | '&' abs_decl -+ { push_type (tp_reference); $$ = $2; } - | direct_abs_decl - ; - -@@ -1211,30 +1203,22 @@ nonempty_typelist - ; - - ptype : typebase -- | ptype abs_decl -- { $$ = follow_types ($1); } -- ; -- --conversion_type_id: typebase conversion_declarator -+ | ptype const_or_volatile_or_space_identifier abs_decl const_or_volatile_or_space_identifier - { $$ = follow_types ($1); } - ; - --conversion_declarator: /* Nothing. */ -- | ptr_operator conversion_declarator -- ; -- - const_and_volatile: CONST_KEYWORD VOLATILE_KEYWORD - | VOLATILE_KEYWORD CONST_KEYWORD - ; - - const_or_volatile_noopt: const_and_volatile -- { insert_type (tp_const); -- insert_type (tp_volatile); -+ { push_type (tp_const); -+ push_type (tp_volatile); - } - | CONST_KEYWORD -- { insert_type (tp_const); } -+ { push_type (tp_const); } - | VOLATILE_KEYWORD -- { insert_type (tp_volatile); } -+ { push_type (tp_volatile); } - ; - - operator: OPERATOR NEW -@@ -1341,7 +1325,7 @@ operator: OPERATOR NEW - { $$ = operator_stoken ("()"); } - | OPERATOR '[' ']' - { $$ = operator_stoken ("[]"); } -- | OPERATOR conversion_type_id -+ | OPERATOR ptype - { char *name; - long length; - struct ui_file *buf = mem_fileopen (); -diff -dup -rup gdb-7.4.50.20120703-orig/gdb/parse.c gdb-7.4.50.20120703/gdb/parse.c ---- gdb-7.4.50.20120703-orig/gdb/parse.c 2012-07-03 20:08:15.979418415 +0200 -+++ gdb-7.4.50.20120703/gdb/parse.c 2012-07-03 20:08:35.938390277 +0200 -@@ -1370,49 +1370,6 @@ check_type_stack_depth (void) - } - } - --/* A helper function for insert_type and insert_type_address_space. -- This does work of expanding the type stack and inserting the new -- element, ELEMENT, into the stack at location SLOT. */ -- --static void --insert_into_type_stack (int slot, union type_stack_elt element) --{ -- check_type_stack_depth (); -- -- if (slot < type_stack_depth) -- memmove (&type_stack[slot + 1], &type_stack[slot], -- (type_stack_depth - slot) * sizeof (union type_stack_elt)); -- type_stack[slot] = element; -- ++type_stack_depth; --} -- --/* Insert a new type, TP, at the bottom of the type stack. If TP is -- tp_pointer or tp_reference, it is inserted at the bottom. If TP is -- a qualifier, it is inserted at slot 1 (just above a previous -- tp_pointer) if there is anything on the stack, or simply pushed if -- the stack is empty. Other values for TP are invalid. */ -- --void --insert_type (enum type_pieces tp) --{ -- union type_stack_elt element; -- int slot; -- -- gdb_assert (tp == tp_pointer || tp == tp_reference -- || tp == tp_const || tp == tp_volatile); -- -- /* If there is anything on the stack (we know it will be a -- tp_pointer), insert the qualifier above it. Otherwise, simply -- push this on the top of the stack. */ -- if (type_stack_depth && (tp == tp_const || tp == tp_volatile)) -- slot = 1; -- else -- slot = 0; -- -- element.piece = tp; -- insert_into_type_stack (slot, element); --} -- - void - push_type (enum type_pieces tp) - { -@@ -1427,32 +1384,10 @@ push_type_int (int n) - type_stack[type_stack_depth++].int_val = n; - } - --/* Insert a tp_space_identifier and the corresponding address space -- value into the stack. STRING is the name of an address space, as -- recognized by address_space_name_to_int. If the stack is empty, -- the new elements are simply pushed. If the stack is not empty, -- this function assumes that the first item on the stack is a -- tp_pointer, and the new values are inserted above the first -- item. */ -- - void --insert_type_address_space (char *string) -+push_type_address_space (char *string) - { -- union type_stack_elt element; -- int slot; -- -- /* If there is anything on the stack (we know it will be a -- tp_pointer), insert the address space qualifier above it. -- Otherwise, simply push this on the top of the stack. */ -- if (type_stack_depth) -- slot = 1; -- else -- slot = 0; -- -- element.piece = tp_space_identifier; -- insert_into_type_stack (slot, element); -- element.int_val = address_space_name_to_int (parse_gdbarch, string); -- insert_into_type_stack (slot, element); -+ push_type_int (address_space_name_to_int (parse_gdbarch, string)); - } - - enum type_pieces -Only in gdb-7.4.50.20120703-orig/gdb: parse.c.orig -diff -dup -rup gdb-7.4.50.20120703-orig/gdb/parser-defs.h gdb-7.4.50.20120703/gdb/parser-defs.h ---- gdb-7.4.50.20120703-orig/gdb/parser-defs.h 2012-07-03 20:08:15.980418414 +0200 -+++ gdb-7.4.50.20120703/gdb/parser-defs.h 2012-07-03 20:08:35.939390275 +0200 -@@ -192,13 +192,11 @@ extern int end_arglist (void); - - extern char *copy_name (struct stoken); - --extern void insert_type (enum type_pieces); -- - extern void push_type (enum type_pieces); - - extern void push_type_int (int); - --extern void insert_type_address_space (char *); -+extern void push_type_address_space (char *); - - extern enum type_pieces pop_type (void); - -diff -dup -rup gdb-7.4.50.20120703-orig/gdb/testsuite/gdb.base/whatis.exp gdb-7.4.50.20120703/gdb/testsuite/gdb.base/whatis.exp ---- gdb-7.4.50.20120703-orig/gdb/testsuite/gdb.base/whatis.exp 2012-07-03 20:08:15.981418413 +0200 -+++ gdb-7.4.50.20120703/gdb/testsuite/gdb.base/whatis.exp 2012-07-03 20:08:35.940390273 +0200 -@@ -465,17 +465,3 @@ gdb_test "whatis char_addr" \ - gdb_test "whatis a_char_addr" \ - "type = char_addr" \ - "whatis applied to variable defined by typedef" -- --# Regression tests for PR 9514. -- --gdb_test "whatis void (**)()" \ -- "type = void \\(\\*\\*\\)\\(\\)" \ -- "whatis applied to pointer to pointer to function" -- --gdb_test "whatis void (** const)()" \ -- "type = void \\(\\*\\* const\\)\\(\\)" \ -- "whatis applied to const pointer to pointer to function" -- --gdb_test "whatis void (* const *)()" \ -- "type = void \\(\\* const \\*\\)\\(\\)" \ -- "whatis applied to pointer to const pointer to function" diff --git a/gdb-fortran-common.patch b/gdb-fortran-common.patch index 778c8cf..c8fb57b 100644 --- a/gdb-fortran-common.patch +++ b/gdb-fortran-common.patch @@ -1,8 +1,8 @@ -Index: gdb-7.4.50.20120602/gdb/dwarf2read.c +Index: gdb-7.4.50.20120714/gdb/dwarf2read.c =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/dwarf2read.c 2012-06-02 21:32:41.746567299 +0200 -+++ gdb-7.4.50.20120602/gdb/dwarf2read.c 2012-06-02 21:32:54.304562500 +0200 -@@ -9736,12 +9736,14 @@ read_set_type (struct die_info *die, str +--- gdb-7.4.50.20120714.orig/gdb/dwarf2read.c 2012-07-14 23:36:09.882136546 +0200 ++++ gdb-7.4.50.20120714/gdb/dwarf2read.c 2012-07-14 23:36:11.032130182 +0200 +@@ -11003,12 +11003,14 @@ read_set_type (struct die_info *die, str return set_die_type (die, set_type, cu); } @@ -19,7 +19,7 @@ Index: gdb-7.4.50.20120602/gdb/dwarf2read.c struct attribute *attr; struct symbol *sym; CORE_ADDR base = (CORE_ADDR) 0; -@@ -9766,20 +9768,67 @@ read_common_block (struct die_info *die, +@@ -11033,20 +11035,67 @@ read_common_block (struct die_info *die, } if (die->child != NULL) { @@ -87,7 +87,7 @@ Index: gdb-7.4.50.20120602/gdb/dwarf2read.c } } -@@ -13661,6 +13710,13 @@ new_symbol_full (struct die_info *die, s +@@ -15085,6 +15134,13 @@ new_symbol_full (struct die_info *die, s { var_decode_location (attr, sym, cu); attr2 = dwarf2_attr (die, DW_AT_external, cu); @@ -101,7 +101,7 @@ Index: gdb-7.4.50.20120602/gdb/dwarf2read.c if (SYMBOL_CLASS (sym) == LOC_STATIC && SYMBOL_VALUE_ADDRESS (sym) == 0 && !dwarf2_per_objfile->has_section_at_zero) -@@ -13825,6 +13881,11 @@ new_symbol_full (struct die_info *die, s +@@ -15249,6 +15305,11 @@ new_symbol_full (struct die_info *die, s SYMBOL_CLASS (sym) = LOC_TYPEDEF; list_to_add = &global_symbols; break; @@ -113,10 +113,10 @@ Index: gdb-7.4.50.20120602/gdb/dwarf2read.c default: /* Not a tag we recognize. Hopefully we aren't processing trash data, but since we must specifically ignore things -Index: gdb-7.4.50.20120602/gdb/f-lang.c +Index: gdb-7.4.50.20120714/gdb/f-lang.c =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/f-lang.c 2012-06-02 21:32:41.746567299 +0200 -+++ gdb-7.4.50.20120602/gdb/f-lang.c 2012-06-02 21:32:54.305562499 +0200 +--- gdb-7.4.50.20120714.orig/gdb/f-lang.c 2012-07-14 23:36:10.993130398 +0200 ++++ gdb-7.4.50.20120714/gdb/f-lang.c 2012-07-14 23:36:11.033130176 +0200 @@ -370,27 +370,3 @@ _initialize_f_language (void) add_language (&f_language_defn); @@ -145,10 +145,10 @@ Index: gdb-7.4.50.20120602/gdb/f-lang.c - } - return (NULL); -} -Index: gdb-7.4.50.20120602/gdb/f-lang.h +Index: gdb-7.4.50.20120714/gdb/f-lang.h =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/f-lang.h 2012-06-02 21:32:41.746567299 +0200 -+++ gdb-7.4.50.20120602/gdb/f-lang.h 2012-06-02 21:32:54.322562493 +0200 +--- gdb-7.4.50.20120714.orig/gdb/f-lang.h 2012-07-14 23:36:10.994130392 +0200 ++++ gdb-7.4.50.20120714/gdb/f-lang.h 2012-07-14 23:36:11.034130171 +0200 @@ -52,37 +52,8 @@ enum f90_range_type NONE_BOUND_DEFAULT /* "(low:high)" */ }; @@ -187,10 +187,10 @@ Index: gdb-7.4.50.20120602/gdb/f-lang.h /* When reasonable array bounds cannot be fetched, such as when you ask to 'mt print symbols' and there is no stack frame and -Index: gdb-7.4.50.20120602/gdb/f-valprint.c +Index: gdb-7.4.50.20120714/gdb/f-valprint.c =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/f-valprint.c 2012-06-02 21:32:41.746567299 +0200 -+++ gdb-7.4.50.20120602/gdb/f-valprint.c 2012-06-02 21:33:50.514541286 +0200 +--- gdb-7.4.50.20120714.orig/gdb/f-valprint.c 2012-07-14 23:36:10.995130387 +0200 ++++ gdb-7.4.50.20120714/gdb/f-valprint.c 2012-07-14 23:36:53.747893779 +0200 @@ -34,10 +34,11 @@ #include "gdbcore.h" #include "command.h" @@ -204,15 +204,14 @@ Index: gdb-7.4.50.20120602/gdb/f-valprint.c static void f77_create_arrayprint_offset_tbl (struct type *, struct ui_file *); static void f77_get_dynamic_length_of_aggregate (struct type *); -@@ -420,22 +421,54 @@ f_val_print (struct type *type, const gd +@@ -420,22 +421,53 @@ f_val_print (struct type *type, const gd gdb_flush (stream); } -static void -list_all_visible_commons (const char *funname) +static int -+info_common_command_for_block (struct block *block, struct frame_info *frame, -+ const char *comname) ++info_common_command_for_block (struct block *block, const char *comname) { - SAVED_F77_COMMON_PTR tmp; - @@ -272,7 +271,7 @@ Index: gdb-7.4.50.20120602/gdb/f-valprint.c } /* This function is used to print out the values in a given COMMON -@@ -445,11 +478,9 @@ list_all_visible_commons (const char *fu +@@ -445,11 +477,9 @@ list_all_visible_commons (const char *fu static void info_common_command (char *comname, int from_tty) { @@ -286,7 +285,7 @@ Index: gdb-7.4.50.20120602/gdb/f-valprint.c /* We have been told to display the contents of F77 COMMON block supposedly visible in this function. Let us -@@ -461,74 +492,31 @@ info_common_command (char *comname, int +@@ -461,74 +491,31 @@ info_common_command (char *comname, int /* The following is generally ripped off from stack.c's routine print_frame_info(). */ @@ -340,7 +339,7 @@ Index: gdb-7.4.50.20120602/gdb/f-valprint.c { - list_all_visible_commons (funname); - return; -+ if (info_common_command_for_block (block, fi, comname)) ++ if (info_common_command_for_block (block, comname)) + values_printed = 1; + /* After handling the function's top-level block, stop. Don't + continue to its superblock, the block of per-file symbols. */ @@ -377,10 +376,10 @@ Index: gdb-7.4.50.20120602/gdb/f-valprint.c } void -Index: gdb-7.4.50.20120602/gdb/stack.c +Index: gdb-7.4.50.20120714/gdb/stack.c =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/stack.c 2012-06-02 21:32:41.746567299 +0200 -+++ gdb-7.4.50.20120602/gdb/stack.c 2012-06-02 21:32:54.335562488 +0200 +--- gdb-7.4.50.20120714.orig/gdb/stack.c 2012-07-14 23:36:09.315139683 +0200 ++++ gdb-7.4.50.20120714/gdb/stack.c 2012-07-14 23:36:11.036130161 +0200 @@ -1838,6 +1838,8 @@ iterate_over_block_locals (struct block case LOC_COMPUTED: if (SYMBOL_IS_ARGUMENT (sym)) @@ -390,11 +389,11 @@ Index: gdb-7.4.50.20120602/gdb/stack.c (*cb) (SYMBOL_PRINT_NAME (sym), sym, cb_data); break; -Index: gdb-7.4.50.20120602/gdb/symtab.h +Index: gdb-7.4.50.20120714/gdb/symtab.h =================================================================== ---- gdb-7.4.50.20120602.orig/gdb/symtab.h 2012-06-02 21:32:41.746567299 +0200 -+++ gdb-7.4.50.20120602/gdb/symtab.h 2012-06-02 21:32:54.342562486 +0200 -@@ -389,7 +389,10 @@ typedef enum domain_enum_tag +--- gdb-7.4.50.20120714.orig/gdb/symtab.h 2012-06-30 00:46:46.000000000 +0200 ++++ gdb-7.4.50.20120714/gdb/symtab.h 2012-07-14 23:36:11.038130149 +0200 +@@ -394,7 +394,10 @@ typedef enum domain_enum_tag /* LABEL_DOMAIN may be used for names of labels (for gotos). */ @@ -406,10 +405,10 @@ Index: gdb-7.4.50.20120602/gdb/symtab.h } domain_enum; /* Searching domains, used for `search_symbols'. Element numbers are -Index: gdb-7.4.50.20120602/gdb/testsuite/gdb.fortran/common-block.exp +Index: gdb-7.4.50.20120714/gdb/testsuite/gdb.fortran/common-block.exp =================================================================== --- /dev/null 1970-01-01 00:00:00.000000000 +0000 -+++ gdb-7.4.50.20120602/gdb/testsuite/gdb.fortran/common-block.exp 2012-06-02 21:32:54.344562484 +0200 ++++ gdb-7.4.50.20120714/gdb/testsuite/gdb.fortran/common-block.exp 2012-07-14 23:36:11.038130149 +0200 @@ -0,0 +1,101 @@ +# Copyright 2008 Free Software Foundation, Inc. + @@ -512,10 +511,10 @@ Index: gdb-7.4.50.20120602/gdb/testsuite/gdb.fortran/common-block.exp +gdb_test "p ix_x" " = 1 *" "p ix_x in" +gdb_test "p iy_y" " = 2 *" "p iy_y in" +gdb_test "p iz_z2" " = 3 *" "p iz_z2 in" -Index: gdb-7.4.50.20120602/gdb/testsuite/gdb.fortran/common-block.f90 +Index: gdb-7.4.50.20120714/gdb/testsuite/gdb.fortran/common-block.f90 =================================================================== --- /dev/null 1970-01-01 00:00:00.000000000 +0000 -+++ gdb-7.4.50.20120602/gdb/testsuite/gdb.fortran/common-block.f90 2012-06-02 21:32:54.345562483 +0200 ++++ gdb-7.4.50.20120714/gdb/testsuite/gdb.fortran/common-block.f90 2012-07-14 23:36:11.038130149 +0200 @@ -0,0 +1,67 @@ +! Copyright 2008 Free Software Foundation, Inc. +! diff --git a/gdb-index-assert.patch b/gdb-index-assert.patch deleted file mode 100644 index 66bb106..0000000 --- a/gdb-index-assert.patch +++ /dev/null @@ -1,60 +0,0 @@ -http://sourceware.org/ml/gdb-patches/2012-06/msg00109.html -Subject: [RFA] Fix inconsistency in blockvector addrmap vs non-addrmap handling - -Hi. - -I was seeing the assert in dw2_find_pc_sect_psymtab trigger -and traced it to the fact that when pending_addrmap_interesting gets -set blockvector.map is used instead of blockvector.block. -The difference is that blockvector.block contains entries for the global -and static blocks whereas pending_addrmap doesn't. - -This patch fixes this by making them consistent. -I suspect more work is necessary (e.g. can symtabs "overlap" even though -the individual pieces do not?). -But I first want to fix the regression introduced by the change -to dw2_find_pc_sect_psymtab: There is more code in a symtab than is -documented by function and lexical block pc ranges (e.g. C++ method thunks). - -Regression tested on amd64-linux, and by verifying the assert no longer -triggers in the testcase I was using. - -Ok to commit? - -Note that this obviates the need for the patch in: -http://sourceware.org/ml/gdb-patches/2012-05/msg00958.html - -Also note that this accompanies this patch: -http://sourceware.org/ml/gdb-patches/2012-06/msg00105.html - -2012-06-04 Doug Evans - - * buildsym.c (end_symtab): Add the range of the static block to - the pending addrmap. - -Index: buildsym.c -=================================================================== -RCS file: /cvs/src/src/gdb/buildsym.c,v -retrieving revision 1.97 -diff -u -p -r1.97 buildsym.c ---- ./gdb/buildsym.c 29 May 2012 20:23:17 -0000 1.97 -+++ ./gdb/buildsym.c 5 Jun 2012 00:26:01 -0000 -@@ -1024,8 +1027,15 @@ end_symtab (CORE_ADDR end_addr, struct o - { - /* Define the STATIC_BLOCK & GLOBAL_BLOCK, and build the - blockvector. */ -- finish_block (0, &file_symbols, 0, last_source_start_addr, -- end_addr, objfile); -+ struct block *static_block; -+ -+ static_block = finish_block (0, &file_symbols, 0, -+ last_source_start_addr, end_addr, -+ objfile); -+ /* Mark the range of the static block so that if we end up using -+ blockvector.map then find_block_in_blockvector behaves identically -+ regardless of whether the addrmap is present. */ -+ record_block_range (static_block, last_source_start_addr, end_addr - 1); - finish_block_internal (0, &global_symbols, 0, last_source_start_addr, - end_addr, objfile, 1); - blockvector = make_blockvector (objfile); - diff --git a/gdb-stale-frame_info-python.patch b/gdb-stale-frame_info-python.patch new file mode 100644 index 0000000..ec42dfa --- /dev/null +++ b/gdb-stale-frame_info-python.patch @@ -0,0 +1,295 @@ +http://sourceware.org/ml/gdb-patches/2012-07/msg00197.html +Subject: [patch] Fix another stale frame_info * (PR 11914, like PR 13866) + +Hi, + +http://sourceware.org/bugzilla/show_bug.cgi?id=11914 + +has another case of stale frame_info *. Originally I found it unfixable with +the current struct frame_info * usage but Pedro has shown in PR 13866 it is +possible to fix the cases one by one so I have fixed also this one. + +It follows the path of valgrind backtrace showing where the memory is being +freed: + http://sourceware.org/bugzilla/show_bug.cgi?id=11914#c5 + +This message has been already present in GDB so I used it in more cases: ++ warning (_("Unable to restore previously selected frame.")); + +No regressions on {x86_64,x86_64-m32,i686}-fedorarawhide-linux-gnu. + +I will check it in soon for 7.5. + +I find it a bit difficult to reliably reproduce, this testcases mostly always +crashes for me (at least with -lmcheck). + + +Thanks, +Jan + + +gdb/ +2012-07-14 Jan Kratochvil + + PR 11914 + * f-valprint.c (info_common_command): New variable frame_id. + Reinitialize FI form FRAME_ID after each print_variable_and_value. + * printcmd.c (print_variable_and_value): Extend function comment. + Add comment for invalidated FRAME. + * stack.c (backtrace_command_1): New variable frame_id. Reinitialize + FI form FRAME_ID after each print_frame_local_vars. + (struct print_variable_and_value_data): Change frame to frame_id. + (do_print_variable_and_value): New variable frame, initialize it from + p->frame_id. Add comment for invalidated FRAME. + (print_frame_local_vars, print_frame_arg_vars): New function comment. + Update CB_DATA.FRAME to CB_DATA.FRAME_ID initialization. Add comment + for invalidated FRAME. + +gdb/testsuite/ +2012-07-14 Jan Kratochvil + + PR 11914 + * gdb.python/py-prettyprint.c (eval_func, eval_sub): New. + (main): Call eval_sub. + * gdb.python/py-prettyprint.exp: + (python execfile ('py-prettyprint.py')): Move it earlier. + New breakpoint for eval-break. + (continue to breakpoint: eval-break, info locals): New test. + (python execfile ('py-prettyprint.py')): Move it from here. + * gdb.python/py-prettyprint.py (class pp_eval_type): New. + (register_pretty_printers): Register pp_eval_type. + +diff --git a/gdb/printcmd.c b/gdb/printcmd.c +index 2a0a886..d5b5b63 100644 +--- a/gdb/printcmd.c ++++ b/gdb/printcmd.c +@@ -1961,7 +1961,9 @@ clear_dangling_display_expressions (struct so_list *solib) + struct symbol. NAME is the name to print; if NULL then VAR's print + name will be used. STREAM is the ui_file on which to print the + value. INDENT specifies the number of indent levels to print +- before printing the variable name. */ ++ before printing the variable name. ++ ++ This function invalidates FRAME. */ + + void + print_variable_and_value (const char *name, struct symbol *var, +@@ -1983,6 +1985,10 @@ print_variable_and_value (const char *name, struct symbol *var, + get_user_print_options (&opts); + opts.deref_ref = 1; + common_val_print (val, stream, indent, &opts, current_language); ++ ++ /* common_val_print invalidates FRAME when a pretty printer calls inferior ++ function. */ ++ frame = NULL; + } + if (except.reason < 0) + fprintf_filtered(stream, "", name, +diff --git a/gdb/stack.c b/gdb/stack.c +index 2520e2c..35d379d 100644 +--- a/gdb/stack.c ++++ b/gdb/stack.c +@@ -1727,7 +1727,20 @@ backtrace_command_1 (char *count_exp, int show_locals, int from_tty) + the frame->prev field gets set to NULL in that case). */ + print_frame_info (fi, 1, LOCATION, 1); + if (show_locals) +- print_frame_local_vars (fi, 1, gdb_stdout); ++ { ++ struct frame_id frame_id = get_frame_id (fi); ++ ++ print_frame_local_vars (fi, 1, gdb_stdout); ++ ++ /* print_frame_local_vars invalidates FI. */ ++ fi = frame_find_by_id (frame_id); ++ if (fi == NULL) ++ { ++ trailing = NULL; ++ warning (_("Unable to restore previously selected frame.")); ++ break; ++ } ++ } + + /* Save the last frame to check for error conditions. */ + trailing = fi; +@@ -1919,7 +1932,7 @@ iterate_over_block_local_vars (struct block *block, + + struct print_variable_and_value_data + { +- struct frame_info *frame; ++ struct frame_id frame_id; + int num_tabs; + struct ui_file *stream; + int values_printed; +@@ -1933,12 +1946,28 @@ do_print_variable_and_value (const char *print_name, + void *cb_data) + { + struct print_variable_and_value_data *p = cb_data; ++ struct frame_info *frame; ++ ++ frame = frame_find_by_id (p->frame_id); ++ if (frame == NULL) ++ { ++ warning (_("Unable to restore previously selected frame.")); ++ return; ++ } ++ ++ print_variable_and_value (print_name, sym, frame, p->stream, p->num_tabs); ++ ++ /* print_variable_and_value invalidates FRAME. */ ++ frame = NULL; + +- print_variable_and_value (print_name, sym, +- p->frame, p->stream, p->num_tabs); + p->values_printed = 1; + } + ++/* Print all variables from the innermost up to the function block of FRAME. ++ Print them with values to STREAM indented by NUM_TABS. ++ ++ This function will invalidate FRAME. */ ++ + static void + print_frame_local_vars (struct frame_info *frame, int num_tabs, + struct ui_file *stream) +@@ -1961,7 +1990,7 @@ print_frame_local_vars (struct frame_info *frame, int num_tabs, + return; + } + +- cb_data.frame = frame; ++ cb_data.frame_id = get_frame_id (frame); + cb_data.num_tabs = 4 * num_tabs; + cb_data.stream = stream; + cb_data.values_printed = 0; +@@ -1970,6 +1999,9 @@ print_frame_local_vars (struct frame_info *frame, int num_tabs, + do_print_variable_and_value, + &cb_data); + ++ /* do_print_variable_and_value invalidates FRAME. */ ++ frame = NULL; ++ + if (!cb_data.values_printed) + fprintf_filtered (stream, _("No locals.\n")); + } +@@ -2016,6 +2048,11 @@ iterate_over_block_arg_vars (struct block *b, + } + } + ++/* Print all argument variables of the function of FRAME. ++ Print them with values to STREAM. ++ ++ This function will invalidate FRAME. */ ++ + static void + print_frame_arg_vars (struct frame_info *frame, struct ui_file *stream) + { +@@ -2036,7 +2073,7 @@ print_frame_arg_vars (struct frame_info *frame, struct ui_file *stream) + return; + } + +- cb_data.frame = frame; ++ cb_data.frame_id = get_frame_id (frame); + cb_data.num_tabs = 0; + cb_data.stream = gdb_stdout; + cb_data.values_printed = 0; +@@ -2044,6 +2081,9 @@ print_frame_arg_vars (struct frame_info *frame, struct ui_file *stream) + iterate_over_block_arg_vars (SYMBOL_BLOCK_VALUE (func), + do_print_variable_and_value, &cb_data); + ++ /* do_print_variable_and_value invalidates FRAME. */ ++ frame = NULL; ++ + if (!cb_data.values_printed) + fprintf_filtered (stream, _("No arguments.\n")); + } +diff --git a/gdb/testsuite/gdb.python/py-prettyprint.c b/gdb/testsuite/gdb.python/py-prettyprint.c +index 0ff7b33..1ff9e05 100644 +--- a/gdb/testsuite/gdb.python/py-prettyprint.c ++++ b/gdb/testsuite/gdb.python/py-prettyprint.c +@@ -219,6 +219,22 @@ struct nullstr + struct string_repr string_1 = { { "one" } }; + struct string_repr string_2 = { { "two" } }; + ++static int ++eval_func (int p1, int p2, int p3, int p4, int p5, int p6, int p7, int p8) ++{ ++ return p1; ++} ++ ++static void ++eval_sub (void) ++{ ++ struct eval_type_s { int x; } eval1 = { 1 }, eval2 = { 2 }, eval3 = { 3 }, ++ eval4 = { 4 }, eval5 = { 5 }, eval6 = { 6 }, ++ eval7 = { 7 }, eval8 = { 8 }, eval9 = { 9 }; ++ ++ eval1.x++; /* eval-break */ ++} ++ + int + main () + { +@@ -309,5 +325,7 @@ main () + + nstype2 = nstype; + ++ eval_sub (); ++ + return 0; /* break to inspect struct and union */ + } +diff --git a/gdb/testsuite/gdb.python/py-prettyprint.exp b/gdb/testsuite/gdb.python/py-prettyprint.exp +index a6c241a..22af83c 100644 +--- a/gdb/testsuite/gdb.python/py-prettyprint.exp ++++ b/gdb/testsuite/gdb.python/py-prettyprint.exp +@@ -123,14 +123,19 @@ if ![runto_main ] then { + return + } + +-gdb_test "b [gdb_get_line_number {break to inspect} ${testfile}.c ]" \ +- ".*Breakpoint.*" +-gdb_test "continue" ".*Breakpoint.*" +- + set remote_python_file [remote_download host ${srcdir}/${subdir}/${testfile}.py] + + gdb_test_no_output "python execfile ('${remote_python_file}')" + ++gdb_breakpoint [gdb_get_line_number "eval-break"] ++gdb_continue_to_breakpoint "eval-break" ".* eval-break .*" ++ ++gdb_test "info locals" "eval9 = eval=<123456789>" ++ ++gdb_test "b [gdb_get_line_number {break to inspect} ${testfile}.c ]" \ ++ ".*Breakpoint.*" ++gdb_test "continue" ".*Breakpoint.*" ++ + gdb_test "print ss" " = a=< a=<1> b=<$hex>> b=< a=<2> b=<$hex>>" \ + "print ss enabled #1" + +diff --git a/gdb/testsuite/gdb.python/py-prettyprint.py b/gdb/testsuite/gdb.python/py-prettyprint.py +index 52ffd1a..b02b90f 100644 +--- a/gdb/testsuite/gdb.python/py-prettyprint.py ++++ b/gdb/testsuite/gdb.python/py-prettyprint.py +@@ -199,6 +199,14 @@ class MemoryErrorString: + def display_hint (self): + return 'string' + ++class pp_eval_type: ++ def __init__(self, val): ++ self.val = val ++ ++ def to_string(self): ++ gdb.execute("bt", to_string=True) ++ return "eval=<" + str(gdb.parse_and_eval("eval_func (123456789, 2, 3, 4, 5, 6, 7, 8)")) + ">" ++ + def lookup_function (val): + "Look-up and return a pretty-printer that can print val." + +@@ -276,6 +284,8 @@ def register_pretty_printers (): + + pretty_printers_dict[re.compile ('^memory_error$')] = MemoryErrorString + ++ pretty_printers_dict[re.compile ('^eval_type_s$')] = pp_eval_type ++ + pretty_printers_dict = {} + + register_pretty_printers () + diff --git a/gdb-upstream.patch b/gdb-upstream.patch index e69de29..7ac9b8d 100644 --- a/gdb-upstream.patch +++ b/gdb-upstream.patch @@ -0,0 +1,55 @@ +http://sourceware.org/ml/gdb-patches/2012-07/msg00200.html +Subject: [obv] testsuite: Fix fission-reread.S regression by me + +Hi Doug, + +I broke the testcase by patch + [patch 1/2] testcase: Make it -m32 compatible [Re: [commit] Fix rereading of DWO DIEs] + http://sourceware.org/ml/gdb-patches/2012-07/msg00009.html + +The testcase itself usually PASSes but sometimes it does not. It is more +clear with 'readelf -wi': + <7b> DW_AT_frame_base : 97 byte block: 7a 0 1 7 19 8b 7e ac ce f1 22 90 2 fb 1 0 0 0 0 0 0 0 0 0 0 0 0 0 51 cd 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 (DW_OP_breg10 (r10): 0; (Unknown location op)) + +Checked in. + + +Sorry, +Jan + + +http://sourceware.org/ml/gdb-cvs/2012-07/msg00102.html + +--- src/gdb/testsuite/ChangeLog 2012/07/13 20:26:10 1.3292 ++++ src/gdb/testsuite/ChangeLog 2012/07/15 08:34:55 1.3293 +@@ -1,3 +1,9 @@ ++2012-07-15 Jan Kratochvil ++ ++ Fix a testcase regression by me. ++ * gdb.dwarf2/fission-reread.S: Fix two DW_FORM_data8 to be ++ DW_FORM_data4. ++ + 2012-07-13 Jan Kratochvil + Doug Evans + +--- src/gdb/testsuite/gdb.dwarf2/fission-reread.S 2012/07/02 20:10:48 1.3 ++++ src/gdb/testsuite/gdb.dwarf2/fission-reread.S 2012/07/15 08:34:55 1.4 +@@ -231,7 +231,7 @@ + .uleb128 0x11 /* (DW_AT_low_pc) */ + .uleb128 0x1 /* (DW_FORM_addr) */ + .uleb128 0x12 /* (DW_AT_high_pc) */ +- .uleb128 0x7 /* (DW_FORM_data8) */ ++ .uleb128 0x6 /* (DW_FORM_data4) */ + .uleb128 0x10 /* (DW_AT_stmt_list) */ + .uleb128 0x17 /* (DW_FORM_sec_offset) */ + .uleb128 0x1b /* (DW_AT_comp_dir) */ +@@ -351,7 +351,7 @@ + .uleb128 0x11 /* (DW_AT_low_pc) */ + .uleb128 0x1f01 /* (DW_FORM_GNU_addr_index) */ + .uleb128 0x12 /* (DW_AT_high_pc) */ +- .uleb128 0x7 /* (DW_FORM_data8) */ ++ .uleb128 0x6 /* (DW_FORM_data4) */ + .uleb128 0x40 /* (DW_AT_frame_base) */ + .uleb128 0x18 /* (DW_FORM_exprloc) */ + .byte 0 + diff --git a/gdb.spec b/gdb.spec index 90b10b6..f63ca8c 100644 --- a/gdb.spec +++ b/gdb.spec @@ -30,12 +30,12 @@ Name: %{?scl_prefix}gdb # Set version to contents of gdb/version.in. # 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). -%global snap 20120703 +%global snap 20120714 Version: 7.4.50.%{snap} # 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. -Release: 13%{?dist} +Release: 14%{?dist} License: GPLv3+ and GPLv3+ with exceptions and GPLv2+ and GPLv2+ with exceptions and GPL+ and LGPLv2+ and BSD and Public Domain Group: Development/Debuggers @@ -479,10 +479,6 @@ Patch496: gdb-bz568248-oom-is-error.patch #=push: There is different patch on gdb-patches, waiting now for resolution in kernel. Patch504: gdb-bz623749-gcore-relro.patch -# Fix lost siginfo_t in linux-nat (BZ 592031). -#=push -Patch511: gdb-bz592031-siginfo-lost-5of5.patch - # Verify GDB Python built-in function gdb.solib_address exists (BZ # 634108). #=fedoratest Patch526: gdb-bz634108-solib_address.patch @@ -552,10 +548,6 @@ Patch690: gdb-glibc-strstr-workaround.patch #=fedora Patch694: gdb-disable-mcheck.patch -# Fix assertion on some files as glibc-2.15.90-8.fc18 (Doug Evans). -#=push -Patch695: gdb-index-assert.patch - # Include testcase for `Unable to see a variable inside a module (XLF)' (BZ 823789). #=fedoratest #+ppc @@ -565,14 +557,14 @@ Patch698: gdb-rhel5.9-testcase-xlf-var-inside-mod.patch #=fedoratest Patch703: gdb-rhbz-818343-set-solib-absolute-prefix-testcase.patch -# Revert function returning pointer fix (PR 9514) regressing Fedora errno patch. -#=push -Patch715: gdb-errno-func-datatype-revert.patch - # Implement MiniDebugInfo F-18 Feature consumer (Alexander Larsson, BZ 834068). #=fedora Patch716: gdb-minidebuginfo.patch +# Fix another stale frame_info * (PR 11914, like PR 13866). +#=push +Patch718: gdb-stale-frame_info-python.patch + %if 0%{!?rhel:1} || 0%{?rhel} > 6 # RL_STATE_FEDORA_GDB would not be found for: # Patch642: gdb-readline62-ask-more-rh.patch @@ -760,7 +752,6 @@ rm -f gdb/jv-exp.c gdb/m2-exp.c gdb/objc-exp.c gdb/p-exp.c %patch2 -p1 %patch232 -p1 -%patch715 -p1 %patch349 -p1 %patch1 -p1 %patch3 -p1 @@ -850,7 +841,6 @@ rm -f gdb/jv-exp.c gdb/m2-exp.c gdb/objc-exp.c gdb/p-exp.c %patch491 -p1 %patch496 -p1 %patch504 -p1 -%patch511 -p1 %patch526 -p1 %patch542 -p1 %patch547 -p1 @@ -866,10 +856,10 @@ rm -f gdb/jv-exp.c gdb/m2-exp.c gdb/objc-exp.c gdb/p-exp.c %patch661 -p1 %patch690 -p1 %patch694 -p1 -%patch695 -p1 %patch698 -p1 %patch703 -p1 %patch716 -p1 +%patch718 -p1 %patch393 -p1 %if 0%{!?el5:1} || 0%{?scl:1} @@ -1364,6 +1354,11 @@ fi %endif # 0%{!?el5:1} || "%{_target_cpu}" == "noarch" %changelog +* Sun Jul 15 2012 Jan Kratochvil - 7.4.50.20120714-14.fc18 +- Rebase to FSF GDB 7.4.50.20120714. + - Fix entryval feature crash on some .debug files optimized by dwz (BZ 839596). +- Fix another stale frame_info * (PR 11914, like PR 13866). + * Fri Jul 6 2012 Jan Kratochvil - 7.4.50.20120703-13.fc18 - [RHEL] Disable MiniDebugInfo F-18 feature on RHEL <= 6 (BZ 834068). diff --git a/sources b/sources index 09fc654..4ae659c 100644 --- a/sources +++ b/sources @@ -1,2 +1,2 @@ 04e5c4b1b9e633422cc48990fe61958d libstdc++-v3-python-r155978.tar.bz2 -91290d1034013db1fe035c081adde514 gdb-7.4.50.20120703.tar.bz2 +115a6a521aef2ce306fd3e7fadd79c02 gdb-7.4.50.20120714.tar.bz2