[PATCH] D108328: [lld/test/ELF] Test fetch from archive to resolve undefined symbols in shared libs

Pirama Arumuga Nainar via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Thu Aug 26 11:24:47 PDT 2021


pirama updated this revision to Diff 368946.
pirama added a comment.

Update with review comments.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D108328/new/

https://reviews.llvm.org/D108328

Files:
  lld/test/ELF/undef-in-shared-from-lazy.s


Index: lld/test/ELF/undef-in-shared-from-lazy.s
===================================================================
--- /dev/null
+++ lld/test/ELF/undef-in-shared-from-lazy.s
@@ -0,0 +1,40 @@
+# REQUIRES: x86
+# RUN: rm -fr %t && split-file %s %t
+
+## Build an object with a trivial main function
+# RUN: llvm-mc -filetype=obj -triple=x86_64 %t/main -o %t1.o
+
+## Build %t.a which defines a global 'foo'
+# RUN: llvm-mc -filetype=obj -triple=x86_64 %t/archive -o %t2.o
+# RUN: rm -f %t2.a
+# RUN: llvm-ar rc %t2.a %t2.o
+
+## Build %t.so that has a reference to 'foo'
+# RUN: llvm-mc -filetype=obj -triple=x86_64 %t/shlib -o %t3.o
+# RUN: ld.lld %t3.o -o %t3.so -shared
+
+## Test that 'foo' from %t2.a is fetched to define 'foo' needed by %t3.so.
+## Test both cases where the archive is before or after the shared library in
+## link order.
+
+# RUN: ld.lld %t1.o %t2.a %t3.so -o %t.exe
+# RUN: llvm-readelf --dyn-symbols %t.exe | FileCheck %s --check-prefix=CHECK-FETCH
+
+# RUN: ld.lld %t1.o %t3.so %t2.a -o %t.exe
+# RUN: llvm-readelf --dyn-symbols %t.exe | FileCheck %s --check-prefix=CHECK-FETCH
+
+# CHECK-FETCH: GLOBAL DEFAULT {{[0-9]+}} foo
+
+#--- main
+.text
+.globl _start
+.type _start, at function
+_start:
+  ret
+
+#--- archive
+.global foo
+foo:
+
+#--- shlib
+.global foo


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D108328.368946.patch
Type: text/x-patch
Size: 1290 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20210826/dbe1c883/attachment.bin>


More information about the llvm-commits mailing list