[llvm] cd474bb - [DA] Add test where access size differs from stride size (NFC) (#147715)
via llvm-commits
llvm-commits at lists.llvm.org
Thu Jul 10 06:08:54 PDT 2025
Author: Ryotaro Kasuga
Date: 2025-07-10T22:08:51+09:00
New Revision: cd474bb8015cfbd9dd5e5594978eccd9bd787e60
URL: https://github.com/llvm/llvm-project/commit/cd474bb8015cfbd9dd5e5594978eccd9bd787e60
DIFF: https://github.com/llvm/llvm-project/commit/cd474bb8015cfbd9dd5e5594978eccd9bd787e60.diff
LOG: [DA] Add test where access size differs from stride size (NFC) (#147715)
Add a test case that is mentioned in #144088 but not added yet.
Added:
Modified:
llvm/test/Analysis/DependenceAnalysis/DifferentOffsets.ll
Removed:
################################################################################
diff --git a/llvm/test/Analysis/DependenceAnalysis/DifferentOffsets.ll b/llvm/test/Analysis/DependenceAnalysis/DifferentOffsets.ll
index 05df105ef79c2..4f95da4f79c57 100644
--- a/llvm/test/Analysis/DependenceAnalysis/DifferentOffsets.ll
+++ b/llvm/test/Analysis/DependenceAnalysis/DifferentOffsets.ll
@@ -149,11 +149,11 @@ define void @multidim_accesses(ptr %A) {
; CHECK-NEXT: Src: store i32 1, ptr %idx0, align 4 --> Dst: store i32 1, ptr %idx0, align 4
; CHECK-NEXT: da analyze - none!
; CHECK-NEXT: Src: store i32 1, ptr %idx0, align 4 --> Dst: store i32 1, ptr %idx1, align 4
-; FIXME: the dependence distance is not constant. Distance vector should be [* * *|<]!
; CHECK-NEXT: da analyze - consistent output [0 0 0|<]!
; CHECK-NEXT: Src: store i32 1, ptr %idx1, align 4 --> Dst: store i32 1, ptr %idx1, align 4
; CHECK-NEXT: da analyze - none!
;
+; FIXME: the dependence distance is not constant. Distance vector should be [* * *|<]!
; for (i = 0; i < 256; i++)
; for (j = 0; j < 256; j++)
; for (k = 0; k < 256; k++) {
@@ -199,3 +199,49 @@ for.i.inc:
end:
ret void
}
+
+; for (int i = 0; i < 256; i++)
+; for (int j = 0; j < 256; j++)
+; for (int k = 0; k < 256; k++) {
+; int *idx = (int *)((int *)(A) + 256*256*i + 256*j + k);
+; *((long long *)idx) = 1;
+; }
+;
+; FIXME: There are loop-carried dependencies across iterations in the store.
+define void @multidim_accesses2(ptr %A) {
+; CHECK-LABEL: 'multidim_accesses2'
+; CHECK-NEXT: Src: store i64 1, ptr %idx, align 4 --> Dst: store i64 1, ptr %idx, align 4
+; CHECK-NEXT: da analyze - none!
+;
+entry:
+ br label %for.i
+
+for.i:
+ %i = phi i64 [ 0, %entry ], [ %i.inc, %for.i.inc ]
+ br label %for.j
+
+for.j:
+ %j = phi i64 [ 0, %for.i ], [ %j.inc, %for.j.inc ]
+ br label %for.k
+
+for.k:
+ %k = phi i64 [ 0, %for.j ], [ %k.inc, %for.k ]
+ %idx = getelementptr inbounds [256 x [256 x [256 x i32]]], ptr %A, i64 0, i64 %i, i64 %j, i64 %k
+ store i64 1, ptr %idx
+ %k.inc = add nsw i64 %k, 1
+ %k.exitcond = icmp eq i64 %k.inc, 256
+ br i1 %k.exitcond, label %for.j.inc, label %for.k
+
+for.j.inc:
+ %j.inc = add nsw i64 %j, 1
+ %j.exitcond = icmp eq i64 %j.inc, 256
+ br i1 %j.exitcond, label %for.i.inc, label %for.j
+
+for.i.inc:
+ %i.inc = add nsw i64 %i, 1
+ %i.exitcond = icmp eq i64 %i.inc, 256
+ br i1 %i.exitcond, label %end, label %for.i
+
+end:
+ ret void
+}
More information about the llvm-commits
mailing list