[PATCH] D46244: [LLD] [COFF] Allow specifying export forwarding in a def file

Martin Storsjö via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Wed May 9 11:23:22 PDT 2018


This revision was automatically updated to reflect the committed changes.
Closed by commit rLLD331900: [COFF] Allow specifying export forwarding in a def file (authored by mstorsjo, committed by ).

Changed prior to commit:
  https://reviews.llvm.org/D46244?vs=145630&id=145963#toc

Repository:
  rLLD LLVM Linker

https://reviews.llvm.org/D46244

Files:
  COFF/Driver.cpp
  test/COFF/export.test


Index: COFF/Driver.cpp
===================================================================
--- COFF/Driver.cpp
+++ COFF/Driver.cpp
@@ -625,6 +625,16 @@
 
   for (COFFShortExport E1 : M.Exports) {
     Export E2;
+    // In simple cases, only Name is set. Renamed exports are parsed
+    // and set as "ExtName = Name". If Name has the form "OtherDll.Func",
+    // it shouldn't be a normal exported function but a forward to another
+    // DLL instead. This is supported by both MS and GNU linkers.
+    if (E1.ExtName != E1.Name && StringRef(E1.Name).contains('.')) {
+      E2.Name = E1.ExtName;
+      E2.ForwardTo = E1.Name;
+      Config->Exports.push_back(E2);
+      continue;
+    }
     E2.Name = Saver.save(E1.Name);
     E2.ExtName = Saver.save(E1.ExtName);
     E2.Ordinal = E1.Ordinal;
Index: test/COFF/export.test
===================================================================
--- test/COFF/export.test
+++ test/COFF/export.test
@@ -86,6 +86,10 @@
 # RUN: lld-link /out:%t.dll /dll %t.obj /export:foo=kernel32.foobar
 # RUN: llvm-objdump -p %t.dll | FileCheck -check-prefix=FORWARDER %s
 
+# RUN: echo "EXPORTS foo=kernel32.foobar" > %t.def
+# RUN: lld-link /out:%t.dll /dll %t.obj /def:%t.def
+# RUN: llvm-objdump -p %t.dll | FileCheck -check-prefix=FORWARDER %s
+
 FORWARDER: Export Table:
 FORWARDER:  DLL name: export.test.tmp.dll
 FORWARDER:  Ordinal base: 0


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D46244.145963.patch
Type: text/x-patch
Size: 1384 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20180509/fdbd79c6/attachment.bin>


More information about the llvm-commits mailing list