diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-03-24 20:17:30 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-03-24 20:17:30 +0000 |
commit | 337a6271b98c4c183f7eaad1563a75260b4f2871 (patch) | |
tree | f9e5fed2fa784931122f02ae0f2a59d42ee38628 /lib/Driver/Tools.cpp | |
parent | 8dcb29db8483d4dcaeeecc0e653b642b0a41cd2c (diff) |
Driver: Handle -flto, -O4, and tweak -emit-llvm to match llvm-gcc.
- -emit-llvm no longer changes what compilation steps are done.
- -emit-llvm and -emit-llvm -S write output files with .o and .s
suffixes, respectively.
- <rdar://problem/6714125> clang-driver should support -O4 and -flto,
like llvm-gcc
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67645 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Driver/Tools.cpp')
-rw-r--r-- | lib/Driver/Tools.cpp | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/lib/Driver/Tools.cpp b/lib/Driver/Tools.cpp index bc5a7cf860..afb02fa49b 100644 --- a/lib/Driver/Tools.cpp +++ b/lib/Driver/Tools.cpp @@ -278,9 +278,12 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA, A->render(Args, CmdArgs); } - // Manually translate -O to -O1; let clang reject others. - if (Arg *A = Args.getLastArg(options::OPT_O)) { - if (A->getValue(Args)[0] == '\0') + // Manually translate -O to -O1 and -O4 to -O3; let clang reject + // others. + if (Arg *A = Args.getLastArg(options::OPT_O_Group)) { + if (A->getOption().getId() == options::OPT_O4) + CmdArgs.push_back("-O3"); + else if (A->getValue(Args)[0] == '\0') CmdArgs.push_back("-O1"); else A->render(Args, CmdArgs); |