[llvm] r269508 - [LAA] Include MaxSafeDepDistBytes in the analysis print-out
Adam Nemet via llvm-commits
llvm-commits at lists.llvm.org
Fri May 13 15:49:13 PDT 2016
Author: anemet
Date: Fri May 13 17:49:13 2016
New Revision: 269508
URL: http://llvm.org/viewvc/llvm-project?rev=269508&view=rev
Log:
[LAA] Include MaxSafeDepDistBytes in the analysis print-out
Added:
llvm/trunk/test/Analysis/LoopAccessAnalysis/safe-with-dep-distance.ll
Modified:
llvm/trunk/lib/Analysis/LoopAccessAnalysis.cpp
Modified: llvm/trunk/lib/Analysis/LoopAccessAnalysis.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Analysis/LoopAccessAnalysis.cpp?rev=269508&r1=269507&r2=269508&view=diff
==============================================================================
--- llvm/trunk/lib/Analysis/LoopAccessAnalysis.cpp (original)
+++ llvm/trunk/lib/Analysis/LoopAccessAnalysis.cpp Fri May 13 17:49:13 2016
@@ -1874,6 +1874,9 @@ LoopAccessInfo::LoopAccessInfo(Loop *L,
void LoopAccessInfo::print(raw_ostream &OS, unsigned Depth) const {
if (CanVecMem) {
OS.indent(Depth) << "Memory dependences are safe";
+ if (MaxSafeDepDistBytes != -1U)
+ OS << " with a maximum dependence distance of " << MaxSafeDepDistBytes
+ << " bytes";
if (PtrRtChecking.Need)
OS << " with run-time checks";
OS << "\n";
Added: llvm/trunk/test/Analysis/LoopAccessAnalysis/safe-with-dep-distance.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Analysis/LoopAccessAnalysis/safe-with-dep-distance.ll?rev=269508&view=auto
==============================================================================
--- llvm/trunk/test/Analysis/LoopAccessAnalysis/safe-with-dep-distance.ll (added)
+++ llvm/trunk/test/Analysis/LoopAccessAnalysis/safe-with-dep-distance.ll Fri May 13 17:49:13 2016
@@ -0,0 +1,37 @@
+; RUN: opt -loop-accesses -analyze < %s | FileCheck %s
+
+; Analyze this loop:
+; for (i = 0; i < n; i++)
+; A[i + 4] = A[i] * 2;
+
+; CHECK: Memory dependences are safe with a maximum dependence distance of 8 bytes
+
+target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-apple-macosx10.10.0"
+
+ at A = common global i16* null, align 8
+
+define void @f() {
+entry:
+ %a = load i16*, i16** @A, align 8
+ br label %for.body
+
+for.body: ; preds = %for.body, %entry
+ %ind = phi i64 [ 0, %entry ], [ %add, %for.body ]
+
+ %arrayidxA = getelementptr inbounds i16, i16* %a, i64 %ind
+ %loadA = load i16, i16* %arrayidxA, align 2
+
+ %mul = mul i16 %loadA, 2
+
+ %next = add nuw nsw i64 %ind, 4
+ %arrayidxA_next = getelementptr inbounds i16, i16* %a, i64 %next
+ store i16 %mul, i16* %arrayidxA_next, align 2
+
+ %add = add nuw nsw i64 %ind, 1
+ %exitcond = icmp eq i64 %add, 20
+ br i1 %exitcond, label %for.end, label %for.body
+
+for.end: ; preds = %for.body
+ ret void
+}
More information about the llvm-commits
mailing list