diff options
-rw-r--r-- | lld/MinGW/Driver.cpp | 2 | ||||
-rw-r--r-- | lld/MinGW/Options.td | 2 | ||||
-rw-r--r-- | lld/test/MinGW/driver.test | 6 |
3 files changed, 10 insertions, 0 deletions
diff --git a/lld/MinGW/Driver.cpp b/lld/MinGW/Driver.cpp index 01cd3b26f93..3e285e72a8a 100644 --- a/lld/MinGW/Driver.cpp +++ b/lld/MinGW/Driver.cpp @@ -136,6 +136,8 @@ bool mingw::link(ArrayRef<const char *> ArgsArr, raw_ostream &Diag) { Add("-output-def:" + StringRef(A->getValue())); if (auto *A = Args.getLastArg(OPT_image_base)) Add("-base:" + StringRef(A->getValue())); + if (auto *A = Args.getLastArg(OPT_map)) + Add("-lldmap:" + StringRef(A->getValue())); if (auto *A = Args.getLastArg(OPT_o)) Add("-out:" + StringRef(A->getValue())); diff --git a/lld/MinGW/Options.td b/lld/MinGW/Options.td index d963f82771a..7e15bcd504d 100644 --- a/lld/MinGW/Options.td +++ b/lld/MinGW/Options.td @@ -18,6 +18,8 @@ def kill_at: F<"kill-at">, HelpText<"Remove @n from exported symbols">; def l: JoinedOrSeparate<["-"], "l">, MetaVarName<"<libName>">, HelpText<"Root name of library to use">; def m: JoinedOrSeparate<["-"], "m">, HelpText<"Set target emulation">; +def map: S<"Map">, HelpText<"Output a linker map">; +def map_eq: J<"Map=">, Alias<map>; def no_whole_archive: F<"no-whole-archive">, HelpText<"No longer include all object files for following archives">; def large_address_aware: Flag<["--"], "large-address-aware">, diff --git a/lld/test/MinGW/driver.test b/lld/test/MinGW/driver.test index 14593d0df80..e7c608ad219 100644 --- a/lld/test/MinGW/driver.test +++ b/lld/test/MinGW/driver.test @@ -134,3 +134,9 @@ RUN: ld.lld -### -m i386pep --start-group foo.o --end-group RUN: ld.lld -### foo.o -m i386pe -shared --kill-at | FileCheck -check-prefix=KILL-AT %s RUN: ld.lld -### foo.o -m i386pe -shared -kill-at | FileCheck -check-prefix=KILL-AT %s KILL-AT: -kill-at + +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 +RUN: ld.lld -### foo.o -m i386pep --Map=bar.map | FileCheck -check-prefix=MAP %s +MAP: -lldmap:bar.map |