diff options
| author | Hans Wennborg <hans@hanshq.net> | 2013-09-24 18:17:21 +0000 |
|---|---|---|
| committer | Hans Wennborg <hans@hanshq.net> | 2013-09-24 18:17:21 +0000 |
| commit | b6331dcb5143b7895762db336a531a4f55f3a959 (patch) | |
| tree | e79ffee92553a8a582d304cde86c8971dc142692 /clang/lib/Driver/Tools.cpp | |
| parent | 6d5350cb7655e31676e497a46c6ab53fb1a9e21b (diff) | |
| download | bcm5719-llvm-b6331dcb5143b7895762db336a531a4f55f3a959.tar.gz bcm5719-llvm-b6331dcb5143b7895762db336a531a4f55f3a959.zip | |
clang-cl: fix passing optimization level to cl.exe in /fallback mode
We were previously mostly passing it through, but -O0 and -O3 are not valid
options to cl.exe.
We should translate -O0 to /Od and -O3 to /Ox. -O{1,2,s} get passed through.
llvm-svn: 191323
Diffstat (limited to 'clang/lib/Driver/Tools.cpp')
| -rw-r--r-- | clang/lib/Driver/Tools.cpp | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/clang/lib/Driver/Tools.cpp b/clang/lib/Driver/Tools.cpp index 5b96120df97..e5f2681f7b3 100644 --- a/clang/lib/Driver/Tools.cpp +++ b/clang/lib/Driver/Tools.cpp @@ -6712,7 +6712,19 @@ Command *visualstudio::Compile::GetCommand(Compilation &C, const JobAction &JA, // These are spelled the same way in clang and cl.exe,. Args.AddAllArgs(CmdArgs, options::OPT_D, options::OPT_U); Args.AddAllArgs(CmdArgs, options::OPT_I); - Args.AddLastArg(CmdArgs, options::OPT_O, options::OPT_O0); + + // Optimization level. + if (Arg *A = Args.getLastArg(options::OPT_O, options::OPT_O0)) { + if (A->getOption().getID() == options::OPT_O0) { + CmdArgs.push_back("/Od"); + } else { + StringRef OptLevel = A->getValue(); + if (OptLevel == "1" || OptLevel == "2" || OptLevel == "s") + A->render(Args, CmdArgs); + else if (OptLevel == "3") + CmdArgs.push_back("/Ox"); + } + } // Flags for which clang-cl have an alias. // FIXME: How can we ensure this stays in sync with relevant clang-cl options? |

