From: Joseph Huber Date: Wed, 1 Feb 2023 19:48:27 +0000 (-0600) Subject: [LinkerWrapper] Adjust placement of input files for the linker X-Git-Tag: upstream/17.0.6~18904 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=fa5209ce4060f659aeb9c0e70ca4cf908c788fff;p=platform%2Fupstream%2Fllvm.git [LinkerWrapper] Adjust placement of input files for the linker Summary: The placement of input files can change the result of the linker. We should put the input files earlier to avoid this. --- diff --git a/clang/tools/clang-linker-wrapper/ClangLinkerWrapper.cpp b/clang/tools/clang-linker-wrapper/ClangLinkerWrapper.cpp index 2980044..6ec089a 100644 --- a/clang/tools/clang-linker-wrapper/ClangLinkerWrapper.cpp +++ b/clang/tools/clang-linker-wrapper/ClangLinkerWrapper.cpp @@ -391,6 +391,9 @@ Expected clang(ArrayRef InputFiles, const ArgList &Args) { "-Wl,--no-undefined", }; + for (StringRef InputFile : InputFiles) + CmdArgs.push_back(InputFile); + // If this is CPU offloading we copy the input libraries. if (!Triple.isAMDGPU() && !Triple.isNVPTX()) { CmdArgs.push_back("-Wl,-Bsymbolic"); @@ -423,9 +426,6 @@ Expected clang(ArrayRef InputFiles, const ArgList &Args) { for (StringRef Arg : Args.getAllArgValues(OPT_linker_arg_EQ)) CmdArgs.push_back(Args.MakeArgString("-Wl," + Arg)); - for (StringRef InputFile : InputFiles) - CmdArgs.push_back(InputFile); - if (Error Err = executeCommands(*ClangPath, CmdArgs)) return std::move(Err);