aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
Diffstat (limited to 'gcc')
-rw-r--r--gcc/c-family/ChangeLog4
-rw-r--r--gcc/c/ChangeLog5
-rw-r--r--gcc/c/c-decl.c16
-rw-r--r--gcc/cp/ChangeLog6
-rw-r--r--gcc/testsuite/ChangeLog3
-rw-r--r--gcc/testsuite/c-c++-common/dwarf2/pr83550.c10
6 files changed, 31 insertions, 13 deletions
diff --git a/gcc/c-family/ChangeLog b/gcc/c-family/ChangeLog
index f4efa68..6dcabab 100644
--- a/gcc/c-family/ChangeLog
+++ b/gcc/c-family/ChangeLog
@@ -1875,7 +1875,7 @@
2016-08-22 Joseph Myers <joseph@codesourcery.com>
- * c-family/c-cppbuiltin.c (c_cpp_builtins): Check _FloatN and
+ * c-cppbuiltin.c (c_cpp_builtins): Check _FloatN and
_FloatNx types for suffixes for built-in functions.
2016-08-19 Joseph Myers <joseph@codesourcery.com>
@@ -2231,7 +2231,7 @@
2016-06-10 Martin Sebor <msebor@redhat.com>
PR c/71392
- * gcc/c-family/c-common.c (handle_nonnull_attribute): Accept
+ * c-common.c (handle_nonnull_attribute): Accept
the nonnull attribute in type-generic builtins.
2016-06-09 Martin Sebor <msebor@redhat.com>
diff --git a/gcc/c/ChangeLog b/gcc/c/ChangeLog
index 581f7df..504205d 100644
--- a/gcc/c/ChangeLog
+++ b/gcc/c/ChangeLog
@@ -1,5 +1,10 @@
2017-12-22 Jakub Jelinek <jakub@redhat.com>
+ PR debug/83550
+ * c-decl.c (finish_struct): Set DECL_SOURCE_LOCATION on
+ TYPE_STUB_DECL and call rest_of_type_compilation before processing
+ incomplete vars rather than after it.
+
PR debug/83547
* c-typeck.c (c_finish_stmt_expr): Ignore !TREE_SIDE_EFFECTS as
indicator of ({ }), instead skip all trailing DEBUG_BEGIN_STMTs first,
diff --git a/gcc/c/c-decl.c b/gcc/c/c-decl.c
index e37ae17..846098e 100644
--- a/gcc/c/c-decl.c
+++ b/gcc/c/c-decl.c
@@ -8199,6 +8199,14 @@ finish_struct (location_t loc, tree t, tree fieldlist, tree attributes,
warning_at (loc, 0, "union cannot be made transparent");
}
+ /* Update type location to the one of the definition, instead of e.g.
+ a forward declaration. */
+ if (TYPE_STUB_DECL (t))
+ DECL_SOURCE_LOCATION (TYPE_STUB_DECL (t)) = loc;
+
+ /* Finish debugging output for this type. */
+ rest_of_type_compilation (t, toplevel);
+
/* If this structure or union completes the type of any previous
variable declaration, lay it out and output its rtl. */
for (x = incomplete_vars; x; x = TREE_CHAIN (x))
@@ -8215,14 +8223,6 @@ finish_struct (location_t loc, tree t, tree fieldlist, tree attributes,
}
}
- /* Update type location to the one of the definition, instead of e.g.
- a forward declaration. */
- if (TYPE_STUB_DECL (t))
- DECL_SOURCE_LOCATION (TYPE_STUB_DECL (t)) = loc;
-
- /* Finish debugging output for this type. */
- rest_of_type_compilation (t, toplevel);
-
/* If we're inside a function proper, i.e. not file-scope and not still
parsing parameters, then arrange for the size of a variable sized type
to be bound now. */
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index fbffe0c..20b0349 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -5471,10 +5471,10 @@
2017-01-27 Adam Butcher <adam@jessamine.co.uk>
PR c++/64382
- * cp/parser.c (parsing_default_capturing_generic_lambda_in_template):
+ * parser.c (parsing_default_capturing_generic_lambda_in_template):
New function.
- * cp/cp-tree.h: Declare it.
- * cp/semantics.c (finish_id_expression): Resolve names within a default
+ * cp-tree.h: Declare it.
+ * semantics.c (finish_id_expression): Resolve names within a default
capturing generic lambda defined within a template prior to
instantiation to allow for captures to be added to the closure type.
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 0102564..c736ca2 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,8 @@
2017-12-22 Jakub Jelinek <jakub@redhat.com>
+ PR debug/83550
+ * c-c++-common/dwarf2/pr83550.c: New test.
+
PR debug/83547
* gcc.c-torture/compile/pr83547.c: New test.
diff --git a/gcc/testsuite/c-c++-common/dwarf2/pr83550.c b/gcc/testsuite/c-c++-common/dwarf2/pr83550.c
new file mode 100644
index 0000000..1d77e95
--- /dev/null
+++ b/gcc/testsuite/c-c++-common/dwarf2/pr83550.c
@@ -0,0 +1,10 @@
+/* PR debug/83550 */
+/* { dg-do compile } */
+/* { dg-options "-gdwarf -dA -fno-merge-debug-strings" } */
+
+struct my_struct;
+extern struct my_struct s;
+struct my_struct { int a, b; };
+struct my_struct q;
+
+/* { dg-final { scan-assembler "DW_TAG_structure_type\[^\\r\\n\]*\[\\r\\n\]+\[^\\r\\n\]*\"my_struct\[^\\r\\n\]*DW_AT_name(\[^\\r\\n\]*\[\\r\\n\]+\[^\\r\\n\]*DW_AT_)*\[^\\r\\n\]*\[\\r\\n\]+\[^\\r\\n\]*\[^0-9a-fA-FxX](0x)?7\[^0-9a-fA-FxX]\[^\\r\\n\]*DW_AT_decl_line" } } */