[lld] r316928 - Skip abs symbols when handling copy reloc aliases.

Rafael Espindola via llvm-commits llvm-commits at lists.llvm.org
Mon Oct 30 10:26:12 PDT 2017


Author: rafael
Date: Mon Oct 30 10:26:12 2017
New Revision: 316928

URL: http://llvm.org/viewvc/llvm-project?rev=316928&view=rev
Log:
Skip abs symbols when handling copy reloc aliases.

Since we now only check st_value, we have to consider the case where
the section index is special.

Added:
    lld/trunk/test/ELF/Inputs/copy-rel-abs.s
    lld/trunk/test/ELF/copy-rel-abs.s
Modified:
    lld/trunk/ELF/Relocations.cpp

Modified: lld/trunk/ELF/Relocations.cpp
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/Relocations.cpp?rev=316928&r1=316927&r2=316928&view=diff
==============================================================================
--- lld/trunk/ELF/Relocations.cpp (original)
+++ lld/trunk/ELF/Relocations.cpp Mon Oct 30 10:26:12 2017
@@ -469,7 +469,8 @@ static std::vector<SharedSymbol *> getSy
 
   std::vector<SharedSymbol *> Ret;
   for (const Elf_Sym &S : File->getGlobalELFSyms()) {
-    if (S.st_shndx == 0 || S.st_value != SS->Value)
+    if (S.st_shndx == SHN_UNDEF || S.st_shndx == SHN_ABS ||
+        S.st_value != SS->Value)
       continue;
     StringRef Name = check(S.getName(File->getStringTable()));
     SymbolBody *Sym = Symtab->find(Name);

Added: lld/trunk/test/ELF/Inputs/copy-rel-abs.s
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/test/ELF/Inputs/copy-rel-abs.s?rev=316928&view=auto
==============================================================================
--- lld/trunk/test/ELF/Inputs/copy-rel-abs.s (added)
+++ lld/trunk/test/ELF/Inputs/copy-rel-abs.s Mon Oct 30 10:26:12 2017
@@ -0,0 +1,13 @@
+        .global foo
+        .type foo, @object
+        .size foo, 4
+foo:
+        .weak bar
+        .type bar, @object
+        .size bar, 4
+bar:
+        .long 42
+
+        .weak zed
+        .type zed, @object
+        zed = 0x1000

Added: lld/trunk/test/ELF/copy-rel-abs.s
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/test/ELF/copy-rel-abs.s?rev=316928&view=auto
==============================================================================
--- lld/trunk/test/ELF/copy-rel-abs.s (added)
+++ lld/trunk/test/ELF/copy-rel-abs.s Mon Oct 30 10:26:12 2017
@@ -0,0 +1,47 @@
+// REQUIRES: x86
+// RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %p/Inputs/copy-rel-abs.s -o %t1.o
+// RUN: ld.lld --hash-style=gnu -shared %t1.o -o %t1.so
+// RUN: llvm-readelf --dyn-symbols %t1.so | FileCheck --check-prefix=SYMS %s
+
+// The symbols have the same st_value, but one is ABS.
+// SYMS: 0000000000001000 {{.*}}   4 bar
+// SYMS: 0000000000001000 {{.*}}   4 foo
+// SYMS: 0000000000001000 {{.*}} ABS zed
+
+// RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t2.o
+// RUN: ld.lld %t2.o %t1.so -o %t2
+// RUN: llvm-readobj --dyn-symbols %t2 | FileCheck %s
+
+// CHECK:      DynamicSymbols [
+// CHECK-NEXT:   Symbol {
+// CHECK-NEXT:     Name:
+// CHECK-NEXT:     Value:
+// CHECK-NEXT:     Size:
+// CHECK-NEXT:     Binding:
+// CHECK-NEXT:     Type:
+// CHECK-NEXT:     Other:
+// CHECK-NEXT:     Section:
+// CHECK-NEXT:   }
+// CHECK-NEXT:   Symbol {
+// CHECK-NEXT:     Name: foo
+// CHECK-NEXT:     Value:
+// CHECK-NEXT:     Size:
+// CHECK-NEXT:     Binding:
+// CHECK-NEXT:     Type:
+// CHECK-NEXT:     Other:
+// CHECK-NEXT:     Section: .bss.rel.ro
+// CHECK-NEXT:   }
+// CHECK-NEXT:   Symbol {
+// CHECK-NEXT:     Name: bar
+// CHECK-NEXT:     Value:
+// CHECK-NEXT:     Size:
+// CHECK-NEXT:     Binding:
+// CHECK-NEXT:     Type:
+// CHECK-NEXT:     Other:
+// CHECK-NEXT:     Section: .bss.rel.ro
+// CHECK-NEXT:   }
+// CHECK-NEXT: ]
+
+.global _start
+_start:
+.quad foo




More information about the llvm-commits mailing list