diff options
author | Bruno Larsen <blarsen@redhat.com> | 2022-04-20 14:41:11 -0300 |
---|---|---|
committer | Bruno Larsen <blarsen@redhat.com> | 2022-11-03 14:08:17 +0100 |
commit | e7e7469e7a31bd5a406a03aa83a1cd648f5ef30d (patch) | |
tree | 7ae6dc9bd3ce0a081b8fa5f549b506a4de450935 /gdb/producer.h | |
parent | 78cd9188d0fb3ab8b1c33b4cb54ad85ffa444192 (diff) | |
download | fsf-binutils-gdb-e7e7469e7a31bd5a406a03aa83a1cd648f5ef30d.zip fsf-binutils-gdb-e7e7469e7a31bd5a406a03aa83a1cd648f5ef30d.tar.gz fsf-binutils-gdb-e7e7469e7a31bd5a406a03aa83a1cd648f5ef30d.tar.bz2 |
gdb: Fix issue with Clang CLI macros
Clang up to version 15 (current) adds macros that were defined in the
command line or by "other means", according to the Dwarf specification,
after the last DW_MACRO_end_file, instead of before the first
DW_MACRO_start_file, as the specification dictates. When GDB reads the
macros after the last file is closed, the macros never end up "in scope"
and so we can't print them. This has been submitted as a bug to Clang
developers (https://github.com/llvm/llvm-project/issues/54506), and PR
macros/29034 was opened for GDB to keep track of this.
Seeing as there is no expected date for it to be fixed, add a workaround
for all current versions of Clang. The workaround detects when
the main file would be closed and if the producer is Clang, and turns
that operation into a noop, so we keep a reference to the current_file
as those macros are read.
A test case was added to confirm the functionality, and the KFAIL for
running gdb.base/macro-source-path when using clang.
Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=29034
Approved-By: Simon Marchi <simon.marchi@efficios.com>
Diffstat (limited to 'gdb/producer.h')
-rw-r--r-- | gdb/producer.h | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/gdb/producer.h b/gdb/producer.h index f7c1936..b75cfae 100644 --- a/gdb/producer.h +++ b/gdb/producer.h @@ -41,4 +41,8 @@ extern bool producer_is_icc (const char *producer, int *major, int *minor); false otherwise.*/ extern bool producer_is_llvm (const char *producer); +/* Returns true if the given PRODUCER string is clang, false otherwise. + Sets MAJOR and MINOR accordingly, if not NULL. */ +extern bool producer_is_clang (const char *producer, int *major, int *minor); + #endif |