Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
F
flatpak-qt-creator
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Container Registry
Model registry
Operate
Environments
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Marco Bubke
flatpak-qt-creator
Commits
0e6226b0
Commit
0e6226b0
authored
14 years ago
by
hjk
Browse files
Options
Downloads
Patches
Plain Diff
debugger: add a gdb patch to our local patch list
Task-number: QTCREATORBUG-2004
parent
14ec1b79
No related branches found
No related tags found
No related merge requests found
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
share/qtcreator/patches/README
+7
-1
7 additions, 1 deletion
share/qtcreator/patches/README
share/qtcreator/patches/gdb-expand-line-sal-maybe.patch
+138
-0
138 additions, 0 deletions
share/qtcreator/patches/gdb-expand-line-sal-maybe.patch
with
145 additions
and
1 deletion
share/qtcreator/patches/README
+
7
−
1
View file @
0e6226b0
For Linux
, MinGW
:
For Linux:
FSF 7.1 release
FSF 7.1 release
+ gdb-increased-dcache-line-size.patch
+ gdb-increased-dcache-line-size.patch
For MinGW:
FSF 7.1 release
+ gdb-increased-dcache-line-size.patch
+ gdb-expand-line-sal-maybe.patch
For Maemo targets:
For Maemo targets:
(--target=arm-none-linux-gnueabi)
(--target=arm-none-linux-gnueabi)
...
...
This diff is collapsed.
Click to expand it.
share/qtcreator/patches/gdb-expand-line-sal-maybe.patch
0 → 100644
+
138
−
0
View file @
0e6226b0
This is fixing http://bugreports.qt.nokia.com/browse/QTCREATORBUG-2004
-----------------------------------------------------------------------------
* From: Jan Kratochvil <jan dot kratochvil at redhat dot com>
* To: gdb-patches at sourceware dot org
* Date: Thu, 29 Jul 2010 00:39:54 +0200
* Subject: [patch] Fix internal error on some -O2 -g breakpoints
Hi,
https://bugzilla.redhat.com/show_bug.cgi?id=612253
(gdb) file ./cc1plus
(gdb) break add_new_name_mapping
../../gdb/breakpoint.c:6594: internal-error: expand_line_sal_maybe: Assertion
`found' failed.
# Test various conditions of prologue analysis on -O2 -g code. Particularly
# when the first command of a function is an inlined function from a different
# symtab. The inlined function can have also multiple concrete instances.
# The next first line after the inlined function should have two PC ranges.
expand_line_sal_maybe processes already too complex data it cannot rely on the
exact input PC would be found between the output resolved results. There are
various bugs I was trying to fix which cause such incorrect multiple results
in this case. But even after fixing all of them the code would be too fragile
to stay relying on this conditional.
After this patch GDB will put the breakpoint only _after_ the initial inlined
call (=incorrectly) in the testcase; it will no longer crash on it, though.
The symtab.c==expand_line_sal change is optional. I believe it is a correct
change but I do not find it much important. With this change GDB will not
only no longer crash but it will even place the breakpoint correctly in the
real world cc1plus testcase from the downstream bug above.
Defining -DLEXICAL still crashes FSF GDB HEAD but just with the
symtab.c==expand_line_sal change it no longer crashes.
Defining -DINLINED crashes FSF GDB HEAD even with the
symtab.c==expand_line_sal change, therefore also
breakpoint.c==expand_line_sal_maybe is patches in this patches.
I can remove the LEXICAL part and keep there only the un-#ifdef-ed INLINED
one if anyone cares about.
<background>
There remain more issues to solve. skip_prologue_sal should be called for
each separate inlined instance (line number alias). It is called now first
and then the other instances are being found... Also skip_prologue_sal should
be able to _decrease_ the PC, not just increase it as it may be needed from
breakpoint_re_set. Just reread_symbols contains bugs causing common GDB
crashes on the reload so I did not try to fix skip_prologue_sal for it now.
Also there is a general problem that GDB now tries to heuristically guess some
expected defects of the debuginfo in -O2 -g cases (see "For optimized code" in
expand_line_sal), it is there because GCC does not generate proper is_stmt
(DW_LNS_negate_stmt). Moreover very magic skip_prologue_sal is there just
because GCC does not generate proper DW_LNS_set_prologue_end markers.
As GCC should produce these markers in a foreseeable future I did not want to
try to do anything with these GDB heuristics.
There remains a question whether the expand_line_sal_maybe patch part should
not possibly use just the first breakpoint if ORIGINAL_PC cannot be found.
I find it safer this way without much disadvantages, multi-PC breakpoints are
very transparent to the user, the other breakpoints are always somehow related
and more breakpoints is always better than less of them, IMO.
</background>
No regressions on {x86_64,x86_64-m32,i686}-fedora13-linux-gnu.
The testcase may not necessarily crash current FSF GDB HEAD on other arches.
Thanks,
Jan
-----------------------------------------------------------------------------
--- a/gdb/breakpoint.c
+++ b/gdb/breakpoint.c
@@ -7048,7 +7048,6 @@
expand_line_sal_maybe (struct symtab_and_line sal)
struct symtabs_and_lines expanded;
CORE_ADDR original_pc = sal.pc;
char *original_function = NULL;
- int found;
int i;
struct cleanup *old_chain;
@@ -7131,17 +7130,8 @@
expand_line_sal_maybe (struct symtab_and_line sal)
return expanded;
}
- if (original_pc)
- {
- found = 0;
- for (i = 0; i < expanded.nelts; ++i)
- if (expanded.sals[i].pc == original_pc)
- {
- found = 1;
- break;
- }
- gdb_assert (found);
- }
+ /* ORIGINAL_PC may not be found between EXPANDED.SALS. expand_line_sal may
+ have skipped too far. */
return expanded;
}
--- a/gdb/symtab.c
+++ b/gdb/symtab.c
@@ -4636,11 +4636,20 @@
expand_line_sal (struct symtab_and_line sal)
blocks = alloca (ret.nelts * sizeof (struct block *));
for (i = 0; i < ret.nelts; ++i)
{
+ struct block *bl;
+
set_current_program_space (ret.sals[i].pspace);
- filter[i] = 1;
- blocks[i] = block_for_pc_sect (ret.sals[i].pc, ret.sals[i].section);
+ /* Place breakpoint only to the first PC in a function, even if some of
+ them are in a lexical sub-block. Put it too all the function
+ instances incl. the inlined ones. */
+ bl = block_for_pc_sect (ret.sals[i].pc, ret.sals[i].section);
+ while (bl != NULL && BLOCK_FUNCTION (bl) == NULL)
+ bl = BLOCK_SUPERBLOCK (bl);
+
+ filter[i] = 1;
+ blocks[i] = bl;
}
do_cleanups (old_chain);
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment