[llvm] fdeafaf - [GVN] Add pre-commit tests for address translation through select (D142705)
Sergey Kachkov via llvm-commits
llvm-commits at lists.llvm.org
Wed Feb 1 05:27:01 PST 2023
Author: Sergey Kachkov
Date: 2023-02-01T16:25:46+03:00
New Revision: fdeafafe49006ec309dcb196df4a7df9c24b3fe1
URL: https://github.com/llvm/llvm-project/commit/fdeafafe49006ec309dcb196df4a7df9c24b3fe1
DIFF: https://github.com/llvm/llvm-project/commit/fdeafafe49006ec309dcb196df4a7df9c24b3fe1.diff
LOG: [GVN] Add pre-commit tests for address translation through select (D142705)
Differential Revision: https://reviews.llvm.org/D142706
Added:
Modified:
llvm/test/Transforms/GVN/PRE/pre-load-through-select.ll
Removed:
################################################################################
diff --git a/llvm/test/Transforms/GVN/PRE/pre-load-through-select.ll b/llvm/test/Transforms/GVN/PRE/pre-load-through-select.ll
index 7b95257ac4800..4de69cc94e37a 100644
--- a/llvm/test/Transforms/GVN/PRE/pre-load-through-select.ll
+++ b/llvm/test/Transforms/GVN/PRE/pre-load-through-select.ll
@@ -830,3 +830,101 @@ entry:
store i32 99, ptr %c
ret i32 %res.0
}
+
+define i32 @test_phi_select_index_non_local(ptr %A, i32 %N, i32 %i) {
+; CHECK-LABEL: @test_phi_select_index_non_local(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[CMP:%.*]] = icmp slt i32 [[I:%.*]], [[N:%.*]]
+; CHECK-NEXT: br i1 [[CMP]], label [[LAND_LHS_TRUE:%.*]], label [[IF_END:%.*]]
+; CHECK: land.lhs.true:
+; CHECK-NEXT: [[IDXPROM:%.*]] = sext i32 [[I]] to i64
+; CHECK-NEXT: [[ARRAYIDX:%.*]] = getelementptr inbounds i32, ptr [[A:%.*]], i64 [[IDXPROM]]
+; CHECK-NEXT: [[TMP0:%.*]] = load i32, ptr [[ARRAYIDX]], align 4
+; CHECK-NEXT: [[ADD:%.*]] = add nsw i32 [[I]], 1
+; CHECK-NEXT: [[IDXPROM1:%.*]] = sext i32 [[ADD]] to i64
+; CHECK-NEXT: [[ARRAYIDX2:%.*]] = getelementptr inbounds i32, ptr [[A]], i64 [[IDXPROM1]]
+; CHECK-NEXT: [[TMP1:%.*]] = load i32, ptr [[ARRAYIDX2]], align 4
+; CHECK-NEXT: [[CMP3:%.*]] = icmp slt i32 [[TMP0]], [[TMP1]]
+; CHECK-NEXT: [[SPEC_SELECT:%.*]] = select i1 [[CMP3]], i32 [[ADD]], i32 [[I]]
+; CHECK-NEXT: br label [[IF_END]]
+; CHECK: if.end:
+; CHECK-NEXT: [[I_ADDR_0:%.*]] = phi i32 [ [[I]], [[ENTRY:%.*]] ], [ [[SPEC_SELECT]], [[LAND_LHS_TRUE]] ]
+; CHECK-NEXT: [[IDXPROM5:%.*]] = sext i32 [[I_ADDR_0]] to i64
+; CHECK-NEXT: [[ARRAYIDX6:%.*]] = getelementptr inbounds i32, ptr [[A]], i64 [[IDXPROM5]]
+; CHECK-NEXT: [[TMP2:%.*]] = load i32, ptr [[ARRAYIDX6]], align 4
+; CHECK-NEXT: ret i32 [[TMP2]]
+;
+entry:
+ %cmp = icmp slt i32 %i, %N
+ br i1 %cmp, label %land.lhs.true, label %if.end
+
+land.lhs.true:
+ %idxprom = sext i32 %i to i64
+ %arrayidx = getelementptr inbounds i32, ptr %A, i64 %idxprom
+ %0 = load i32, ptr %arrayidx, align 4
+ %add = add nsw i32 %i, 1
+ %idxprom1 = sext i32 %add to i64
+ %arrayidx2 = getelementptr inbounds i32, ptr %A, i64 %idxprom1
+ %1 = load i32, ptr %arrayidx2, align 4
+ %cmp3 = icmp slt i32 %0, %1
+ %spec.select = select i1 %cmp3, i32 %add, i32 %i
+ br label %if.end
+
+if.end:
+ %i.addr.0 = phi i32 [ %i, %entry ], [ %spec.select, %land.lhs.true ]
+ %idxprom5 = sext i32 %i.addr.0 to i64
+ %arrayidx6 = getelementptr inbounds i32, ptr %A, i64 %idxprom5
+ %2 = load i32, ptr %arrayidx6, align 4
+ ret i32 %2
+}
+
+define i32 @test_phi_select_index_loop(ptr %A, i32 %N) {
+; CHECK-LABEL: @test_phi_select_index_loop(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i32 [[N:%.*]], 1
+; CHECK-NEXT: br i1 [[CMP]], label [[FOR_BODY_PREHEADER:%.*]], label [[FOR_COND_CLEANUP:%.*]]
+; CHECK: for.body.preheader:
+; CHECK-NEXT: br label [[FOR_BODY:%.*]]
+; CHECK: for.body:
+; CHECK-NEXT: [[IDX:%.*]] = phi i32 [ [[IDX_NEXT:%.*]], [[FOR_BODY]] ], [ 1, [[FOR_BODY_PREHEADER]] ]
+; CHECK-NEXT: [[RES:%.*]] = phi i32 [ [[SPEC_SELECT:%.*]], [[FOR_BODY]] ], [ 0, [[FOR_BODY_PREHEADER]] ]
+; CHECK-NEXT: [[IDXPROM:%.*]] = sext i32 [[IDX]] to i64
+; CHECK-NEXT: [[ARRAYIDX:%.*]] = getelementptr inbounds i32, ptr [[A:%.*]], i64 [[IDXPROM]]
+; CHECK-NEXT: [[TMP0:%.*]] = load i32, ptr [[ARRAYIDX]], align 4
+; CHECK-NEXT: [[IDXPROM1:%.*]] = sext i32 [[RES]] to i64
+; CHECK-NEXT: [[ARRAYIDX1:%.*]] = getelementptr inbounds i32, ptr [[A]], i64 [[IDXPROM1]]
+; CHECK-NEXT: [[TMP1:%.*]] = load i32, ptr [[ARRAYIDX1]], align 4
+; CHECK-NEXT: [[CMP1:%.*]] = icmp slt i32 [[TMP0]], [[TMP1]]
+; CHECK-NEXT: [[SPEC_SELECT]] = select i1 [[CMP1]], i32 [[IDX]], i32 [[RES]]
+; CHECK-NEXT: [[IDX_NEXT]] = add nsw i32 [[IDX]], 1
+; CHECK-NEXT: [[EXITCOND_NOT:%.*]] = icmp eq i32 [[IDX_NEXT]], [[N]]
+; CHECK-NEXT: br i1 [[EXITCOND_NOT]], label [[FOR_COND_CLEANUP_LOOPEXIT:%.*]], label [[FOR_BODY]]
+; CHECK: for.cond.cleanup.loopexit:
+; CHECK-NEXT: br label [[FOR_COND_CLEANUP]]
+; CHECK: for.cond.cleanup:
+; CHECK-NEXT: [[RES_0_LCSSA:%.*]] = phi i32 [ 0, [[ENTRY:%.*]] ], [ [[SPEC_SELECT]], [[FOR_COND_CLEANUP_LOOPEXIT]] ]
+; CHECK-NEXT: ret i32 [[RES_0_LCSSA]]
+;
+entry:
+ %cmp = icmp sgt i32 %N, 1
+ br i1 %cmp, label %for.body, label %for.cond.cleanup
+
+for.body:
+ %idx = phi i32 [ 1, %entry ], [ %idx.next, %for.body ]
+ %res = phi i32 [ 0, %entry ], [ %spec.select, %for.body ]
+ %idxprom = sext i32 %idx to i64
+ %arrayidx = getelementptr inbounds i32, ptr %A, i64 %idxprom
+ %0 = load i32, ptr %arrayidx, align 4
+ %idxprom1 = sext i32 %res to i64
+ %arrayidx1 = getelementptr inbounds i32, ptr %A, i64 %idxprom1
+ %1 = load i32, ptr %arrayidx1, align 4
+ %cmp1 = icmp slt i32 %0, %1
+ %spec.select = select i1 %cmp1, i32 %idx, i32 %res
+ %idx.next = add nsw i32 %idx, 1
+ %exitcond.not = icmp eq i32 %idx.next, %N
+ br i1 %exitcond.not, label %for.cond.cleanup, label %for.body
+
+ for.cond.cleanup:
+ %res.0.lcssa = phi i32 [ 0, %entry ], [ %spec.select, %for.body ]
+ ret i32 %res.0.lcssa
+}
More information about the llvm-commits
mailing list