+2017-03-31 Jakub Jelinek <jakub@redhat.com>
+
+ PR debug/79255
+ * dwarf2out.c (decls_for_scope): If BLOCK_NONLOCALIZED_VAR is
+ a FUNCTION_DECL, pass it as decl instead of origin to
+ process_scope_var.
+
2017-03-31 Alexander Monakov <amonakov@ispras.ru>
* config/nvptx/nvptx.c (nvptx_output_softstack_switch): Correct format
if we've done it once already. */
if (! early_dwarf)
for (i = 0; i < BLOCK_NUM_NONLOCALIZED_VARS (stmt); i++)
- process_scope_var (stmt, NULL, BLOCK_NONLOCALIZED_VAR (stmt, i),
- context_die);
+ {
+ decl = BLOCK_NONLOCALIZED_VAR (stmt, i);
+ if (TREE_CODE (decl) == FUNCTION_DECL)
+ process_scope_var (stmt, decl, NULL_TREE, context_die);
+ else
+ process_scope_var (stmt, NULL_TREE, decl, context_die);
+ }
}
/* Even if we're at -g1, we need to process the subblocks in order to get
2017-03-31 Jakub Jelinek <jakub@redhat.com>
+ PR debug/79255
+ * gcc.dg/pr79255.c: New test.
+
PR c++/79572
* g++.dg/ubsan/null-8.C: New test.
--- /dev/null
+/* PR bootstrap/79255 */
+/* { dg-do compile } */
+/* { dg-options "-O2 -g -fno-toplevel-reorder -Wno-attributes" } */
+
+static inline __attribute__((always_inline)) int foo (int x);
+
+int
+baz (void)
+{
+ return foo (3) + foo (6) + foo (9);
+}
+
+static inline __attribute__((always_inline)) int
+foo (int x)
+{
+ auto inline int __attribute__((noinline)) bar (int x)
+ {
+ return x + 3;
+ }
+ return bar (x) + bar (x + 2);
+}