aboutsummaryrefslogtreecommitdiff
path: root/flang/lib/Frontend/CompilerInvocation.cpp
diff options
context:
space:
mode:
authorTom Eccles <tom.eccles@arm.com>2023-11-27 15:10:21 +0000
committerGitHub <noreply@github.com>2023-11-27 15:10:21 +0000
commitcaba0314cf631a3ba3e982cbcdc455224046c7a8 (patch)
treefc60707758d55eacb9f6624e1689af4a288d43ed /flang/lib/Frontend/CompilerInvocation.cpp
parent9539cbf03304b0f36f95414d40b3c8ecce42eb70 (diff)
downloadllvm-caba0314cf631a3ba3e982cbcdc455224046c7a8.zip
llvm-caba0314cf631a3ba3e982cbcdc455224046c7a8.tar.gz
llvm-caba0314cf631a3ba3e982cbcdc455224046c7a8.tar.bz2
[flang] Enable alias tags pass by default (#73111)
Enable by default for optimization levels higher than 0 (same behavior as clang). For simplicity, only forward the flag to the frontend driver when it contradicts what is implied by the optimization level. Since https://github.com/llvm/llvm-project/pull/72903 there are now no known performance regressions.
Diffstat (limited to 'flang/lib/Frontend/CompilerInvocation.cpp')
-rw-r--r--flang/lib/Frontend/CompilerInvocation.cpp10
1 files changed, 6 insertions, 4 deletions
diff --git a/flang/lib/Frontend/CompilerInvocation.cpp b/flang/lib/Frontend/CompilerInvocation.cpp
index cb4f2d6..1c09ae9 100644
--- a/flang/lib/Frontend/CompilerInvocation.cpp
+++ b/flang/lib/Frontend/CompilerInvocation.cpp
@@ -242,10 +242,12 @@ static void parseCodeGenArgs(Fortran::frontend::CodeGenOptions &opts,
clang::driver::options::OPT_fno_loop_versioning, false))
opts.LoopVersioning = 1;
- opts.AliasAnalysis =
- args.hasFlag(clang::driver::options::OPT_falias_analysis,
- clang::driver::options::OPT_fno_alias_analysis,
- /*default=*/false);
+ opts.AliasAnalysis = opts.OptimizationLevel > 0;
+ if (auto *arg =
+ args.getLastArg(clang::driver::options::OPT_falias_analysis,
+ clang::driver::options::OPT_fno_alias_analysis))
+ opts.AliasAnalysis =
+ arg->getOption().matches(clang::driver::options::OPT_falias_analysis);
for (auto *a : args.filtered(clang::driver::options::OPT_fpass_plugin_EQ))
opts.LLVMPassPlugins.push_back(a->getValue());