[lld] d649faf - [LLD][COFF] Support GNU style == aliases

Ayke van Laethem via llvm-commits llvm-commits at lists.llvm.org
Wed Jan 19 05:22:20 PST 2022


Author: Ayke van Laethem
Date: 2022-01-19T14:22:13+01:00
New Revision: d649faff9c0ca87fd5a00a7f1056071fd46432ea

URL: https://github.com/llvm/llvm-project/commit/d649faff9c0ca87fd5a00a7f1056071fd46432ea
DIFF: https://github.com/llvm/llvm-project/commit/d649faff9c0ca87fd5a00a7f1056071fd46432ea.diff

LOG: [LLD][COFF] Support GNU style == aliases

D46245 added support for this in llvm-libtool, but while lld-link can
also create .lib files from .def files it didn't support aliases.

I compared the Inputs/library.def test against the output from
llvm-libtool and it matches, except for the fact that lld-link reorders
functions for some reason.

I have also verified that this fixes a bug I was running into while
trying to compile .def files to .lib files in MinGW-w64 (using lld-link
instead of llvm-libtool).

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

Added: 
    

Modified: 
    lld/COFF/Config.h
    lld/COFF/Driver.cpp
    lld/test/COFF/Inputs/library.def
    lld/test/COFF/lib.test

Removed: 
    


################################################################################
diff  --git a/lld/COFF/Config.h b/lld/COFF/Config.h
index 5597389b42264..4bb42c88aa936 100644
--- a/lld/COFF/Config.h
+++ b/lld/COFF/Config.h
@@ -43,6 +43,7 @@ static const auto I386 = llvm::COFF::IMAGE_FILE_MACHINE_I386;
 struct Export {
   StringRef name;       // N in /export:N or /export:E=N
   StringRef extName;    // E in /export:E=N
+  StringRef aliasTarget; // GNU specific: N in "alias == N"
   Symbol *sym = nullptr;
   uint16_t ordinal = 0;
   bool noname = false;
@@ -63,6 +64,7 @@ struct Export {
 
   bool operator==(const Export &e) {
     return (name == e.name && extName == e.extName &&
+            aliasTarget == e.aliasTarget &&
             ordinal == e.ordinal && noname == e.noname &&
             data == e.data && isPrivate == e.isPrivate);
   }

diff  --git a/lld/COFF/Driver.cpp b/lld/COFF/Driver.cpp
index f8da63c5edbfb..3076871fd98b5 100644
--- a/lld/COFF/Driver.cpp
+++ b/lld/COFF/Driver.cpp
@@ -810,6 +810,7 @@ static void createImportLibrary(bool asLib) {
     e2.Name = std::string(e1.name);
     e2.SymbolName = std::string(e1.symbolName);
     e2.ExtName = std::string(e1.extName);
+    e2.AliasTarget = std::string(e1.aliasTarget);
     e2.Ordinal = e1.ordinal;
     e2.Noname = e1.noname;
     e2.Data = e1.data;
@@ -908,6 +909,7 @@ static void parseModuleDefs(StringRef path) {
     }
     e2.name = saver.save(e1.Name);
     e2.extName = saver.save(e1.ExtName);
+    e2.aliasTarget = saver.save(e1.AliasTarget);
     e2.ordinal = e1.Ordinal;
     e2.noname = e1.Noname;
     e2.data = e1.Data;

diff  --git a/lld/test/COFF/Inputs/library.def b/lld/test/COFF/Inputs/library.def
index 6c6880ffa18e6..5c81351596eec 100644
--- a/lld/test/COFF/Inputs/library.def
+++ b/lld/test/COFF/Inputs/library.def
@@ -1,5 +1,6 @@
 LIBRARY library
 EXPORTS
   function
+  alias == function
   data DATA
   constant CONSTANT

diff  --git a/lld/test/COFF/lib.test b/lld/test/COFF/lib.test
index 2d63ed6c23243..7525ef4226cda 100644
--- a/lld/test/COFF/lib.test
+++ b/lld/test/COFF/lib.test
@@ -1,6 +1,16 @@
 # RUN: lld-link /machine:x64 /def:%S/Inputs/library.def /out:%t.lib
 # RUN: llvm-nm %t.lib | FileCheck %s
 
+CHECK: 00000000 a @comp.id
+CHECK: 00000000 a @feat.00
+CHECK: 00000000 W alias
+CHECK:          U function
+
+CHECK: 00000000 a @comp.id
+CHECK: 00000000 a @feat.00
+CHECK: 00000000 W __imp_alias
+CHECK:          U __imp_function
+
 CHECK: 00000000 R __imp_constant
 CHECK: 00000000 R constant
 


        


More information about the llvm-commits mailing list