Reject .so files if -static is given.
authorRui Ueyama <ruiu@google.com>
Tue, 18 Dec 2018 22:30:23 +0000 (22:30 +0000)
committerRui Ueyama <ruiu@google.com>
Tue, 18 Dec 2018 22:30:23 +0000 (22:30 +0000)
Previously, if you pass -static to lld, lld searches for only foo.a
and skips foo.so for -lfoo option. However, it didn't reject .so files
if you directly pass their pathnames via the command line, which is a bug.

Differential Revision: https://reviews.llvm.org/D55845

llvm-svn: 349557

lld/ELF/Driver.cpp
lld/test/ELF/static-error.s [new file with mode: 0644]
lld/test/ELF/tls-static.s

index a858241..1da5574 100644 (file)
@@ -224,7 +224,7 @@ void LinkerDriver::addFile(StringRef Path, bool WithLOption) {
     return;
   }
   case file_magic::elf_shared_object:
-    if (Config->Relocatable) {
+    if (Config->Static || Config->Relocatable) {
       error("attempted static link of dynamic object " + Path);
       return;
     }
diff --git a/lld/test/ELF/static-error.s b/lld/test/ELF/static-error.s
new file mode 100644 (file)
index 0000000..1ae98ab
--- /dev/null
@@ -0,0 +1,13 @@
+// REQUIRES: x86
+// RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %S/Inputs/shared.s -o %t.o
+// RUN: ld.lld -shared -o %t.so %t.o
+
+// RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t.o
+// RUN: ld.lld -o /dev/null %t.o %t.so
+// RUN: not ld.lld -o /dev/null -static %t.o %t.so 2>&1 | FileCheck %s
+
+// CHECK: attempted static link of dynamic object
+
+.global _start
+_start:
+  nop
index 3e1aead..61d504b 100644 (file)
@@ -4,7 +4,6 @@
 // RUN: ld.lld -static %t -o %tout
 // RUN: ld.lld %t -o %tout
 // RUN: ld.lld -shared %tso -o %tshared
-// RUN: ld.lld -static %t %tshared -o %tout
 
 .global _start
 _start: