[LLD][ELF] - Eliminate dead code from OffsetGetter::get().
authorGeorge Rimar <grimar@accesssoftek.com>
Tue, 14 Aug 2018 14:20:34 +0000 (14:20 +0000)
committerGeorge Rimar <grimar@accesssoftek.com>
Tue, 14 Aug 2018 14:20:34 +0000 (14:20 +0000)
We have a dead piece of code there which is impossible to trigger
using regular objects I believe.
Patch removes it and adds a test case showing how this condition
can be triggered with use of a broken object and crash the linker.

llvm-svn: 339680

lld/ELF/Relocations.cpp
lld/test/ELF/invalid/ehframe-broken-relocation.test [new file with mode: 0644]

index 68207d4..29fbf76 100644 (file)
@@ -692,7 +692,7 @@ public:
     while (I != Pieces.size() && Pieces[I].InputOff + Pieces[I].Size <= Off)
       ++I;
     if (I == Pieces.size())
-      return Off;
+      fatal(".eh_frame: relocation is not in any piece");
 
     // Pieces must be contiguous, so there must be no holes in between.
     assert(Pieces[I].InputOff <= Off && "Relocation not in any piece");
diff --git a/lld/test/ELF/invalid/ehframe-broken-relocation.test b/lld/test/ELF/invalid/ehframe-broken-relocation.test
new file mode 100644 (file)
index 0000000..1333a6d
--- /dev/null
@@ -0,0 +1,31 @@
+# RUN: yaml2obj %s -o %t.o
+# RUN: not ld.lld --icf=all %t.o -o /dev/null 2>&1 | FileCheck %s
+# CHECK: .eh_frame: relocation is not in any piece
+
+!ELF
+FileHeader:
+  Class:           ELFCLASS64
+  Data:            ELFDATA2LSB
+  OSABI:           ELFOSABI_FREEBSD
+  Type:            ET_REL
+  Machine:         EM_X86_64
+Sections:
+  - Name:            .eh_frame
+    Type:            SHT_PROGBITS
+    Flags:           [ SHF_ALLOC]
+    Content:         "1400000000000000017a5200017810011b0c070890010000140000001c00000000000000000000000000000000000000"
+  - Name:            .rela.eh_frame
+    Type:            SHT_RELA
+    Link:            .symtab
+    Info:            .eh_frame
+    Relocations:
+      - Offset:          0x99999999
+        Symbol:          zed
+        Type:            R_X86_64_64
+Symbols:
+  Global:
+    - Name:     zed
+      Type:     STT_FUNC
+      Section:  .eh_frame
+      Value:    0x0
+      Size:     8