Blame SOURCES/dwz-rh1949185.patch

6b8961
X-Git-Url: https://sourceware.org/git/?p=dwz.git;a=blobdiff_plain;f=dwz.c;h=9e39824d0f1fec950c811357c62e6a0caa1880d7;hp=6f34a0c7f84d00aa74750ea7d60c882967d252c0;hb=4a89e2c78e57b1b05ff71a8e32b2219e02d30425;hpb=815ac613209fa8cbcdda57302a0a1ab0366923ad
6b8961
6b8961
diff --git a/dwz.c b/dwz.c
6b8961
index 6f34a0c..9e39824 100644
6b8961
--- a/dwz.c
6b8961
+++ b/dwz.c
6b8961
@@ -2357,10 +2357,33 @@ checksum_die (DSO *dso, dw_cu_ref cu, dw_die_ref top_die, dw_die_ref die)
6b8961
 		}
6b8961
 	      if (unlikely (op_multifile) && ref->die_collapsed_child)
6b8961
 		ref = ref->die_parent;
6b8961
-	      assert (((!op_multifile && !rd_multifile && !fi_multifile)
6b8961
-		       || cu != die_cu (ref))
6b8961
-		      && (!op_multifile
6b8961
-			  || cu->cu_chunk == die_cu (ref)->cu_chunk));
6b8961
+	      if (cu == die_cu (ref))
6b8961
+		{
6b8961
+		  /* The reference was encoded using a section-relative
6b8961
+		     encoding, while if it could have been encoded using
6b8961
+		     CU-relative encoding.  Typically, the latter is used,
6b8961
+		     because:
6b8961
+		     - it's potentially smaller, and
6b8961
+		     - it doesn't require a link-time relocation.  */
6b8961
+
6b8961
+		  /* Assert that the multifile only contains section-relative
6b8961
+		     encoding when necessary.  */
6b8961
+		  assert (!op_multifile && !rd_multifile);
6b8961
+
6b8961
+		  if (fi_multifile)
6b8961
+		    {
6b8961
+		      /* It's possible that the input DWARF contains this
6b8961
+			 sub-optimal reference.  We currently don't optimize
6b8961
+			 this during single-file optimization, so it will still
6b8961
+			 be there during finalize_multifile.  Bail out to handle
6b8961
+			 this conservatively.  */
6b8961
+		      die->die_ck_state = CK_BAD;
6b8961
+		      return 0;
6b8961
+		    }
6b8961
+		}
6b8961
+	      /* Assert that during op_multifile, die belongs to the same object
6b8961
+		 as ref.  */
6b8961
+	      assert (!op_multifile || cu->cu_chunk == die_cu (ref)->cu_chunk);
6b8961
 	      handled = true;
6b8961
 	      break;
6b8961
 	    }