[PATCH] D89927: [LoopRotate][NPM] Disable header duplication under -Oz
Arthur Eubanks via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Oct 22 08:28:42 PDT 2020
aeubanks updated this revision to Diff 299986.
aeubanks added a comment.
add comments
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D89927/new/
https://reviews.llvm.org/D89927
Files:
llvm/lib/Passes/PassBuilder.cpp
llvm/test/Transforms/LoopRotate/oz-disable.ll
Index: llvm/test/Transforms/LoopRotate/oz-disable.ll
===================================================================
--- llvm/test/Transforms/LoopRotate/oz-disable.ll
+++ llvm/test/Transforms/LoopRotate/oz-disable.ll
@@ -1,6 +1,8 @@
; REQUIRES: asserts
; RUN: opt < %s -S -Os -debug -debug-only=loop-rotate 2>&1 | FileCheck %s -check-prefix=OS
; RUN: opt < %s -S -Oz -debug -debug-only=loop-rotate 2>&1 | FileCheck %s -check-prefix=OZ
+; RUN: opt < %s -S -passes='default<Os>' -debug -debug-only=loop-rotate 2>&1 | FileCheck %s -check-prefix=OS
+; RUN: opt < %s -S -passes='default<Oz>' -debug -debug-only=loop-rotate 2>&1 | FileCheck %s -check-prefix=OZ
; Loop should be rotated for -Os but not for -Oz.
; OS: rotating Loop at depth 1
Index: llvm/lib/Passes/PassBuilder.cpp
===================================================================
--- llvm/lib/Passes/PassBuilder.cpp
+++ llvm/lib/Passes/PassBuilder.cpp
@@ -677,7 +677,7 @@
LPM1.addPass(LoopInstSimplifyPass());
LPM1.addPass(LoopSimplifyCFGPass());
- // Rotate Loop - disable header duplication at -Oz
+ // Disable header duplication in loop rotation at -Oz.
LPM1.addPass(LoopRotatePass(Level != OptimizationLevel::Oz));
// TODO: Investigate promotion cap for O1.
LPM1.addPass(LICMPass(PTO.LicmMssaOptCap, PTO.LicmMssaNoAccForPromotionCap));
@@ -833,8 +833,9 @@
MPM.addPass(PGOInstrumentationGen(IsCS));
FunctionPassManager FPM;
+ // Disable header duplication in loop rotation at -Oz.
FPM.addPass(createFunctionToLoopPassAdaptor(
- LoopRotatePass(), EnableMSSALoopDependency,
+ LoopRotatePass(Level != OptimizationLevel::Oz), EnableMSSALoopDependency,
/*UseBlockFrequencyInfo=*/false, DebugLogging));
MPM.addPass(createModuleToFunctionPassAdaptor(std::move(FPM)));
@@ -1164,8 +1165,9 @@
C(OptimizePM, Level);
// First rotate loops that may have been un-rotated by prior passes.
+ // Disable header duplication at -Oz.
OptimizePM.addPass(createFunctionToLoopPassAdaptor(
- LoopRotatePass(), EnableMSSALoopDependency,
+ LoopRotatePass(Level != OptimizationLevel::Oz), EnableMSSALoopDependency,
/*UseBlockFrequencyInfo=*/false, DebugLogging));
// Distribute loops to allow partial vectorization. I.e. isolate dependences
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D89927.299986.patch
Type: text/x-patch
Size: 2281 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20201022/db082c0a/attachment.bin>
More information about the llvm-commits
mailing list