mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 03:02:36 +01:00
[LoopRotation] Allow loop header duplication if vectorization is forced.
-Oz normally does not allow loop header duplication so this loop wouldn't be vectorized. However the vectorization pragma should override this and allow for loop rotation. rdar://problem/49281061 Original patch by Adam Nemet. Reviewed By: Meinersbur Differential Revision: https://reviews.llvm.org/D59832
This commit is contained in:
parent
a094c34600
commit
5d85b8dafe
@ -39,7 +39,13 @@ LoopRotatePass::LoopRotatePass(bool EnableHeaderDuplication)
|
||||
PreservedAnalyses LoopRotatePass::run(Loop &L, LoopAnalysisManager &AM,
|
||||
LoopStandardAnalysisResults &AR,
|
||||
LPMUpdater &) {
|
||||
int Threshold = EnableHeaderDuplication ? DefaultRotationThreshold : 0;
|
||||
// Vectorization requires loop-rotation. Use default threshold for loops the
|
||||
// user explicitly marked for vectorization, even when header duplication is
|
||||
// disabled.
|
||||
int Threshold = EnableHeaderDuplication ||
|
||||
hasVectorizeTransformation(&L) == TM_ForcedByUser
|
||||
? DefaultRotationThreshold
|
||||
: 0;
|
||||
const DataLayout &DL = L.getHeader()->getModule()->getDataLayout();
|
||||
const SimplifyQuery SQ = getBestSimplifyQuery(AR, DL);
|
||||
|
||||
@ -105,9 +111,16 @@ public:
|
||||
if (MSSAA)
|
||||
MSSAU = MemorySSAUpdater(&MSSAA->getMSSA());
|
||||
}
|
||||
// Vectorization requires loop-rotation. Use default threshold for loops the
|
||||
// user explicitly marked for vectorization, even when header duplication is
|
||||
// disabled.
|
||||
int Threshold = hasVectorizeTransformation(L) == TM_ForcedByUser
|
||||
? DefaultRotationThreshold
|
||||
: MaxHeaderSize;
|
||||
|
||||
return LoopRotation(L, LI, TTI, AC, &DT, &SE,
|
||||
MSSAU.hasValue() ? MSSAU.getPointer() : nullptr, SQ,
|
||||
false, MaxHeaderSize, false);
|
||||
false, Threshold, false);
|
||||
}
|
||||
};
|
||||
} // end namespace
|
||||
|
@ -0,0 +1,38 @@
|
||||
; RUN: opt -Oz -S -enable-new-pm=0 < %s | FileCheck %s
|
||||
; RUN: opt -passes='default<Oz>' -S < %s | FileCheck %s
|
||||
|
||||
; Forcing vectorization should allow for more aggressive loop-rotation with
|
||||
; -Oz, because LV requires rotated loops. Make sure the loop in @foo is
|
||||
; vectorized with -Oz.
|
||||
|
||||
target datalayout = "e-m:o-i64:64-i128:128-n32:64-S128"
|
||||
target triple = "arm64-apple-ios5.0.0"
|
||||
|
||||
define void @foo(float* noalias nocapture %ptrA, float* noalias nocapture readonly %ptrB, i64 %size) {
|
||||
; CHECK-LABEL: @foo(
|
||||
; CHECK: fmul <4 x float>
|
||||
;
|
||||
entry:
|
||||
br label %for.cond
|
||||
|
||||
for.cond: ; preds = %for.body, %entry
|
||||
%indvars.iv = phi i64 [ %indvars.iv.next, %for.body ], [ 0, %entry ]
|
||||
%exitcond = icmp eq i64 %indvars.iv, %size
|
||||
br i1 %exitcond, label %for.cond.cleanup, label %for.body
|
||||
|
||||
for.body: ; preds = %for.cond
|
||||
%arrayidx = getelementptr inbounds float, float* %ptrB, i64 %indvars.iv
|
||||
%0 = load float, float* %arrayidx, align 4
|
||||
%arrayidx2 = getelementptr inbounds float, float* %ptrA, i64 %indvars.iv
|
||||
%1 = load float, float* %arrayidx2, align 4
|
||||
%mul3 = fmul float %0, %1
|
||||
store float %mul3, float* %arrayidx2, align 4
|
||||
%indvars.iv.next = add nuw nsw i64 %indvars.iv, 1
|
||||
br label %for.cond, !llvm.loop !0
|
||||
|
||||
for.cond.cleanup: ; preds = %for.cond
|
||||
ret void
|
||||
}
|
||||
|
||||
!0 = distinct !{!0, !1}
|
||||
!1 = !{!"llvm.loop.vectorize.enable", i1 true}
|
Loading…
Reference in New Issue
Block a user