diff options
author | Bob Wilson <bob.wilson@apple.com> | 2011-04-29 22:49:50 +0000 |
---|---|---|
committer | Bob Wilson <bob.wilson@apple.com> | 2011-04-29 22:49:50 +0000 |
commit | 9a5f84facbb7ecf11f37011bf0314543a126cc0d (patch) | |
tree | 4f5712317f3c049f17d791a8775595ac53b84f06 /clang/lib/Frontend/CompilerInvocation.cpp | |
parent | 328bad02fa805bdd01c95a44853ce180bc42bc5d (diff) | |
download | bcm5719-llvm-9a5f84facbb7ecf11f37011bf0314543a126cc0d.tar.gz bcm5719-llvm-9a5f84facbb7ecf11f37011bf0314543a126cc0d.zip |
Add -Oz option and use it to set the inline threshold to 25.
Radar 9333566. Patch by Chad Rosier!
llvm-svn: 130554
Diffstat (limited to 'clang/lib/Frontend/CompilerInvocation.cpp')
-rw-r--r-- | clang/lib/Frontend/CompilerInvocation.cpp | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/clang/lib/Frontend/CompilerInvocation.cpp b/clang/lib/Frontend/CompilerInvocation.cpp index 998ca8aa4ad..841a2311d08 100644 --- a/clang/lib/Frontend/CompilerInvocation.cpp +++ b/clang/lib/Frontend/CompilerInvocation.cpp @@ -139,7 +139,7 @@ static void CodeGenOptsToArgs(const CodeGenOptions &Opts, Res.push_back("-momit-leaf-frame-pointer"); if (Opts.OptimizeSize) { assert(Opts.OptimizationLevel == 2 && "Invalid options!"); - Res.push_back("-Os"); + Opts.OptimizeSize == 1 ? Res.push_back("-Os") : Res.push_back("-Oz"); } else if (Opts.OptimizationLevel != 0) Res.push_back("-O" + llvm::utostr(Opts.OptimizationLevel)); if (!Opts.MainFileName.empty()) { @@ -815,8 +815,8 @@ static unsigned getOptimizationLevel(ArgList &Args, InputKind IK, unsigned DefaultOpt = 0; if (IK == IK_OpenCL && !Args.hasArg(OPT_cl_opt_disable)) DefaultOpt = 2; - // -Os implies -O2 - return Args.hasArg(OPT_Os) ? 2 : + // -Os/-Oz implies -O2 + return (Args.hasArg(OPT_Os) || Args.hasArg (OPT_Oz)) ? 2 : Args.getLastArgIntValue(OPT_O, DefaultOpt, Diags); } @@ -931,6 +931,7 @@ static void ParseCodeGenArgs(CodeGenOptions &Opts, ArgList &Args, InputKind IK, Opts.NoCommon = Args.hasArg(OPT_fno_common); Opts.NoImplicitFloat = Args.hasArg(OPT_no_implicit_float); Opts.OptimizeSize = Args.hasArg(OPT_Os); + Opts.OptimizeSize = Args.hasArg(OPT_Oz) ? 2 : Opts.OptimizeSize; Opts.SimplifyLibCalls = !(Args.hasArg(OPT_fno_builtin) || Args.hasArg(OPT_ffreestanding)); Opts.UnrollLoops = Args.hasArg(OPT_funroll_loops) || |