Blame SOURCES/binutils-ignore-duplicate-FDE-entries.patch

8c00d6
--- binutils-2.32.orig/bfd/elf-eh-frame.c	2019-06-26 07:05:43.839194746 -0400
8c00d6
+++ binutils-2.32/bfd/elf-eh-frame.c	2019-06-26 07:32:37.124219479 -0400
8c00d6
@@ -2478,11 +2478,16 @@ write_dwarf_eh_frame_hdr (bfd *abfd, str
8c00d6
 		  != sec->output_section->vma + val))
8c00d6
 	    overflow = TRUE;
8c00d6
 	  bfd_put_32 (abfd, val, contents + EH_FRAME_HDR_SIZE + i * 8 + 8);
8c00d6
-	  if (i != 0
8c00d6
-	      && (hdr_info->u.dwarf.array[i].initial_loc
8c00d6
-		  < (hdr_info->u.dwarf.array[i - 1].initial_loc
8c00d6
-		     + hdr_info->u.dwarf.array[i - 1].range)))
8c00d6
-	    overlap = TRUE;
8c00d6
+	  if (i != 0)
8c00d6
+	    {
8c00d6
+	      struct eh_frame_array_ent * this_entry = hdr_info->u.dwarf.array + i;
8c00d6
+	      struct eh_frame_array_ent * prev_entry = hdr_info->u.dwarf.array + (i - 1);
8c00d6
+
8c00d6
+	      if (this_entry->initial_loc < prev_entry->initial_loc + prev_entry->range
8c00d6
+		  && (this_entry->initial_loc != prev_entry->initial_loc
8c00d6
+		      || this_entry->range != prev_entry->range))
8c00d6
+		overlap = TRUE;
8c00d6
+	    }
8c00d6
 	}
8c00d6
       if (overflow)
8c00d6
 	_bfd_error_handler (_(".eh_frame_hdr entry overflow"));