[llvm-branch-commits] [llvm] [LoopInterchange] Add test for multiple accesses to same base ptr (NFC) (PR #193476)
Ryotaro Kasuga via llvm-branch-commits
llvm-branch-commits at lists.llvm.org
Fri May 15 06:30:52 PDT 2026
https://github.com/kasuga-fj updated https://github.com/llvm/llvm-project/pull/193476
>From 28a107b8518428b04c8b7f6811a9c47365da63ad Mon Sep 17 00:00:00 2001
From: Ryotaro Kasuga <kasuga.ryotaro at fujitsu.com>
Date: Wed, 22 Apr 2026 10:26:38 +0000
Subject: [PATCH] [LoopInterchange] Add test for multiple accesses to same base
ptr (NFC)
---
.../profitability-instorder.ll | 88 ++++++++++++++++++-
1 file changed, 86 insertions(+), 2 deletions(-)
diff --git a/llvm/test/Transforms/LoopInterchange/profitability-instorder.ll b/llvm/test/Transforms/LoopInterchange/profitability-instorder.ll
index 36834fe2fd070..92d56b98e2591 100644
--- a/llvm/test/Transforms/LoopInterchange/profitability-instorder.ll
+++ b/llvm/test/Transforms/LoopInterchange/profitability-instorder.ll
@@ -141,8 +141,8 @@ exit:
;
; The above loop should NOT be interchanged in terms of locality of reference.
;
-define void @unprofitable(ptr %A) {
-; CHECK-LABEL: define void @unprofitable(
+define void @unprofitable0(ptr %A) {
+; CHECK-LABEL: define void @unprofitable0(
; CHECK-SAME: ptr [[A:%.*]]) {
; CHECK-NEXT: [[ENTRY:.*]]:
; CHECK-NEXT: br label %[[LOOP_I_HEADER:.*]]
@@ -188,3 +188,87 @@ loop.i.latch:
exit:
ret void
}
+
+; for (i = 0; i < 10; i++)
+; for (j = 0; j < 10; j++)
+; A[100*i + j] = B[100*i + j] + C[i + 100*j] + C[i + 99*j] + C[i + 98*j];
+;
+; The above loop should NOT be interchanged in terms of locality of reference.
+;
+define void @unprofitable1(ptr noalias %A, ptr noalias %B, ptr noalias %C) {
+; CHECK-LABEL: define void @unprofitable1(
+; CHECK-SAME: ptr noalias [[A:%.*]], ptr noalias [[B:%.*]], ptr noalias [[C:%.*]]) {
+; CHECK-NEXT: [[ENTRY:.*:]]
+; CHECK-NEXT: br label %[[LOOP_J_PREHEADER:.*]]
+; CHECK: [[LOOP_I_HEADER_PREHEADER:.*]]:
+; CHECK-NEXT: br label %[[LOOP_I_HEADER:.*]]
+; CHECK: [[LOOP_I_HEADER]]:
+; CHECK-NEXT: [[I:%.*]] = phi i64 [ [[I_INC:%.*]], %[[LOOP_I_LATCH:.*]] ], [ 0, %[[LOOP_I_HEADER_PREHEADER]] ]
+; CHECK-NEXT: br label %[[LOOP_J_SPLIT1:.*]]
+; CHECK: [[LOOP_J_PREHEADER]]:
+; CHECK-NEXT: br label %[[LOOP_J:.*]]
+; CHECK: [[LOOP_J]]:
+; CHECK-NEXT: [[J:%.*]] = phi i64 [ [[TMP0:%.*]], %[[LOOP_J_SPLIT:.*]] ], [ 0, %[[LOOP_J_PREHEADER]] ]
+; CHECK-NEXT: br label %[[LOOP_I_HEADER_PREHEADER]]
+; CHECK: [[LOOP_J_SPLIT1]]:
+; CHECK-NEXT: [[GEP_A:%.*]] = getelementptr inbounds [100 x i8], ptr [[A]], i64 [[I]], i64 [[J]]
+; CHECK-NEXT: [[GEP_B:%.*]] = getelementptr inbounds [100 x i8], ptr [[B]], i64 [[I]], i64 [[J]]
+; CHECK-NEXT: [[GEP_C0:%.*]] = getelementptr inbounds [100 x i8], ptr [[C]], i64 [[J]], i64 [[I]]
+; CHECK-NEXT: [[GEP_C1:%.*]] = getelementptr inbounds [99 x i8], ptr [[C]], i64 [[J]], i64 [[I]]
+; CHECK-NEXT: [[GEP_C2:%.*]] = getelementptr inbounds [98 x i8], ptr [[C]], i64 [[J]], i64 [[I]]
+; CHECK-NEXT: [[VAL_B:%.*]] = load i8, ptr [[GEP_B]], align 1
+; CHECK-NEXT: [[VAL_C0:%.*]] = load i8, ptr [[GEP_C0]], align 1
+; CHECK-NEXT: [[VAL_C1:%.*]] = load i8, ptr [[GEP_C1]], align 1
+; CHECK-NEXT: [[VAL_C2:%.*]] = load i8, ptr [[GEP_C2]], align 1
+; CHECK-NEXT: [[SUM_0:%.*]] = add i8 [[VAL_B]], [[VAL_C0]]
+; CHECK-NEXT: [[SUM_1:%.*]] = add i8 [[SUM_0]], [[VAL_C1]]
+; CHECK-NEXT: [[SUM_2:%.*]] = add i8 [[SUM_1]], [[VAL_C2]]
+; CHECK-NEXT: store i8 [[SUM_2]], ptr [[GEP_A]], align 1
+; CHECK-NEXT: [[J_INC:%.*]] = add i64 [[J]], 1
+; CHECK-NEXT: [[EC_J:%.*]] = icmp eq i64 [[J_INC]], 10
+; CHECK-NEXT: br label %[[LOOP_I_LATCH]]
+; CHECK: [[LOOP_J_SPLIT]]:
+; CHECK-NEXT: [[TMP0]] = add i64 [[J]], 1
+; CHECK-NEXT: [[TMP1:%.*]] = icmp eq i64 [[TMP0]], 10
+; CHECK-NEXT: br i1 [[TMP1]], label %[[EXIT:.*]], label %[[LOOP_J]]
+; CHECK: [[LOOP_I_LATCH]]:
+; CHECK-NEXT: [[I_INC]] = add i64 [[I]], 1
+; CHECK-NEXT: [[EC_I:%.*]] = icmp eq i64 [[I_INC]], 10
+; CHECK-NEXT: br i1 [[EC_I]], label %[[LOOP_J_SPLIT]], label %[[LOOP_I_HEADER]]
+; CHECK: [[EXIT]]:
+; CHECK-NEXT: ret void
+;
+entry:
+ br label %loop.i.header
+
+loop.i.header:
+ %i = phi i64 [ 0, %entry ], [ %i.inc, %loop.i.latch ]
+ br label %loop.j
+
+loop.j:
+ %j = phi i64 [ 0, %loop.i.header ], [ %j.inc, %loop.j ]
+ %gep.A = getelementptr inbounds [100 x i8], ptr %A, i64 %i, i64 %j
+ %gep.B = getelementptr inbounds [100 x i8], ptr %B, i64 %i, i64 %j
+ %gep.C0 = getelementptr inbounds [100 x i8], ptr %C, i64 %j, i64 %i
+ %gep.C1 = getelementptr inbounds [99 x i8], ptr %C, i64 %j, i64 %i
+ %gep.C2 = getelementptr inbounds [98 x i8], ptr %C, i64 %j, i64 %i
+ %val.B = load i8, ptr %gep.B
+ %val.C0 = load i8, ptr %gep.C0
+ %val.C1 = load i8, ptr %gep.C1
+ %val.C2 = load i8, ptr %gep.C2
+ %sum.0 = add i8 %val.B, %val.C0
+ %sum.1 = add i8 %sum.0, %val.C1
+ %sum.2 = add i8 %sum.1, %val.C2
+ store i8 %sum.2, ptr %gep.A
+ %j.inc = add i64 %j, 1
+ %ec.j = icmp eq i64 %j.inc, 10
+ br i1 %ec.j, label %loop.i.latch, label %loop.j
+
+loop.i.latch:
+ %i.inc = add i64 %i, 1
+ %ec.i = icmp eq i64 %i.inc, 10
+ br i1 %ec.i, label %exit, label %loop.i.header
+
+exit:
+ ret void
+}
More information about the llvm-branch-commits
mailing list