diff options
-rw-r--r-- | lld/MinGW/Driver.cpp | 3 | ||||
-rw-r--r-- | lld/MinGW/Options.td | 3 | ||||
-rw-r--r-- | lld/test/MinGW/driver.test | 3 |
3 files changed, 9 insertions, 0 deletions
diff --git a/lld/MinGW/Driver.cpp b/lld/MinGW/Driver.cpp index 27a5550ec9c..dc9b046c5d1 100644 --- a/lld/MinGW/Driver.cpp +++ b/lld/MinGW/Driver.cpp @@ -212,6 +212,9 @@ bool mingw::link(ArrayRef<const char *> ArgsArr, raw_ostream &Diag) { else Add("-alternatename:__image_base__=__ImageBase"); + for (auto *A : Args.filtered(OPT_require_defined)) + Add("-include:" + StringRef(A->getValue())); + std::vector<StringRef> SearchPaths; for (auto *A : Args.filtered(OPT_L)) SearchPaths.push_back(A->getValue()); diff --git a/lld/MinGW/Options.td b/lld/MinGW/Options.td index ad699f71134..948faa68752 100644 --- a/lld/MinGW/Options.td +++ b/lld/MinGW/Options.td @@ -40,6 +40,9 @@ def strip_debug: F<"strip-debug">, def whole_archive: F<"whole-archive">, HelpText<"Include all object files for following archives">; def verbose: F<"verbose">, HelpText<"Verbose mode">; +def require_defined: S<"require-defined">, + HelpText<"Force symbol to be added to symbol table as an undefined one">; +def require_defined_eq: J<"require-defined=">, Alias<require_defined>; // LLD specific options def _HASH_HASH_HASH : Flag<["-"], "###">, diff --git a/lld/test/MinGW/driver.test b/lld/test/MinGW/driver.test index 35d3ccf97cc..58c589cf035 100644 --- a/lld/test/MinGW/driver.test +++ b/lld/test/MinGW/driver.test @@ -145,3 +145,6 @@ RUN: ld.lld -### foo.o -m i386pep --Map bar.map | FileCheck -check-prefix=MAP %s RUN: ld.lld -### foo.o -m i386pep -Map=bar.map | FileCheck -check-prefix=MAP %s RUN: ld.lld -### foo.o -m i386pep --Map=bar.map | FileCheck -check-prefix=MAP %s MAP: -lldmap:bar.map + +RUN: ld.lld -### foo.o -m i386pe -require-defined _foo --require-defined _bar -require-defined=_baz --require-defined=_foo2 | FileCheck -check-prefix=REQUIRE-DEFINED %s +REQUIRE-DEFINED: -include:_foo -include:_bar -include:_baz -include:_foo2 |