Blame SOURCES/gcc48-pr79969.patch

25c7f1
2017-03-09  Jakub Jelinek  <jakub@redhat.com>
25c7f1
25c7f1
	PR c/79969
25c7f1
	* c-decl.c (start_enum): Adjust DECL_SOURCE_LOCATION of
25c7f1
	TYPE_STUB_DECL.
25c7f1
25c7f1
	* gcc.dg/debug/dwarf2/enum-loc1.c: New test.
25c7f1
25c7f1
--- gcc/c/c-decl.c.jj	2017-03-05 22:39:45.000000000 +0100
25c7f1
+++ gcc/c/c-decl.c	2017-03-09 08:19:33.100042166 +0100
25c7f1
@@ -8201,6 +8201,10 @@ start_enum (location_t loc, struct c_enu
25c7f1
       enumtype = make_node (ENUMERAL_TYPE);
25c7f1
       pushtag (loc, name, enumtype);
25c7f1
     }
25c7f1
+  /* Update type location to the one of the definition, instead of e.g.
25c7f1
+     a forward declaration.  */
25c7f1
+  else if (TYPE_STUB_DECL (enumtype))
25c7f1
+    DECL_SOURCE_LOCATION (TYPE_STUB_DECL (enumtype)) = loc;
25c7f1
 
25c7f1
   if (C_TYPE_BEING_DEFINED (enumtype))
25c7f1
     error_at (loc, "nested redefinition of %<enum %E%>", name);
25c7f1
--- gcc/testsuite/gcc.dg/debug/dwarf2/enum-loc1.c.jj	2017-03-09 08:09:30.742037844 +0100
25c7f1
+++ gcc/testsuite/gcc.dg/debug/dwarf2/enum-loc1.c	2017-03-09 08:16:45.202268438 +0100
25c7f1
@@ -0,0 +1,19 @@
25c7f1
+/* PR c/79969 */
25c7f1
+/* { dg-do compile } */
25c7f1
+/* { dg-options "-gdwarf-2 -dA -fno-merge-debug-strings" } */
25c7f1
+
25c7f1
+enum ENUMTAG;
25c7f1
+
25c7f1
+enum ENUMTAG
25c7f1
+{
25c7f1
+  B = 1,
25c7f1
+  C = 2
25c7f1
+};
25c7f1
+
25c7f1
+void
25c7f1
+bar (void)
25c7f1
+{
25c7f1
+  enum ENUMTAG a = C;
25c7f1
+}
25c7f1
+
25c7f1
+/* { dg-final { scan-assembler "DW_TAG_enumeration_type\[^\\r\\n\]*\[\\r\\n\]+\[^\\r\\n\]*\"ENUMTAG\[^\\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" } } */