]> granicus.if.org Git - clang/commitdiff
[driver] Add a -Ofast option, which enables -O3, -ffast-math, and
authorChad Rosier <mcrosier@apple.com>
Wed, 10 Apr 2013 21:26:02 +0000 (21:26 +0000)
committerChad Rosier <mcrosier@apple.com>
Wed, 10 Apr 2013 21:26:02 +0000 (21:26 +0000)
-fstrict-aliasing.
rdar://13622687

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@179216 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/Driver/Options.td
lib/Frontend/CompilerInvocation.cpp

index b9cf026fee111a7f8d50109b0168fe5b526a8414..7997622d06d6248fdef8f0d838a3ae8e8b500713 100644 (file)
@@ -181,6 +181,7 @@ def ObjCXX : Flag<["-"], "ObjC++">, Flags<[DriverOption]>,
 def ObjC : Flag<["-"], "ObjC">, Flags<[DriverOption]>,
   HelpText<"Treat source input files as Objective-C inputs">;
 def O : Joined<["-"], "O">, Group<O_Group>, Flags<[CC1Option]>;
+def Ofast : Joined<["-"], "Ofast">, Group<O_Group>, Flags<[CC1Option]>;
 def P : Flag<["-"], "P">, Flags<[CC1Option]>,
   HelpText<"Disable linemarker output in -E mode">;
 def Qn : Flag<["-"], "Qn">;
index ed207e66fa97cbd276cc264d18d4bd51b09f6311..3281e36c450355b4c97b2899955a1646206462b3 100644 (file)
@@ -68,6 +68,9 @@ static unsigned getOptimizationLevel(ArgList &Args, InputKind IK,
     if (A->getOption().matches(options::OPT_O0))
       return 0;
 
+    if (A->getOption().matches(options::OPT_Ofast))
+      return 3;
+
     assert (A->getOption().matches(options::OPT_O));
 
     StringRef S(A->getValue());
@@ -97,6 +100,13 @@ static unsigned getOptimizationLevelSize(ArgList &Args, InputKind IK,
   return 0;
 }
 
+static bool isOptimizationLevelFast(ArgList &Args) {
+  if (Arg *A = Args.getLastArg(options::OPT_O_Group))
+    if (A->getOption().matches(options::OPT_Ofast))
+      return true;
+  return false;
+}
+
 static void addWarningArgs(ArgList &Args, std::vector<std::string> &Warnings) {
   for (arg_iterator I = Args.filtered_begin(OPT_W_Group),
          E = Args.filtered_end(); I != E; ++I) {
@@ -324,7 +334,8 @@ static bool ParseCodeGenArgs(CodeGenOptions &Opts, ArgList &Args, InputKind IK,
   Opts.ForbidGuardVariables = Args.hasArg(OPT_fforbid_guard_variables);
   Opts.UseRegisterSizedBitfieldAccess = Args.hasArg(
     OPT_fuse_register_sized_bitfield_access);
-  Opts.RelaxedAliasing = Args.hasArg(OPT_relaxed_aliasing);
+  Opts.RelaxedAliasing = Args.hasArg(OPT_relaxed_aliasing) ||
+    isOptimizationLevelFast(Args);
   Opts.StructPathTBAA = Args.hasArg(OPT_struct_path_tbaa);
   Opts.DwarfDebugFlags = Args.getLastArgValue(OPT_dwarf_debug_flags);
   Opts.MergeAllConstants = !Args.hasArg(OPT_fno_merge_all_constants);
@@ -1302,7 +1313,8 @@ static void ParseLangArgs(LangOptions &Opts, ArgList &Args, InputKind IK,
   // inlining enabled.
   Opts.NoInlineDefine = !Opt || Args.hasArg(OPT_fno_inline);
 
-  Opts.FastMath = Args.hasArg(OPT_ffast_math);
+  Opts.FastMath = Args.hasArg(OPT_ffast_math) ||
+    isOptimizationLevelFast(Args);
   Opts.FiniteMathOnly = Args.hasArg(OPT_ffinite_math_only);
 
   Opts.RetainCommentsFromSystemHeaders =