[llvm] f25b091 - ValueTracking/test: increase recurrence coverage (#108836)
via llvm-commits
llvm-commits at lists.llvm.org
Tue Sep 17 01:03:05 PDT 2024
Author: Ramkumar Ramachandra
Date: 2024-09-17T09:03:02+01:00
New Revision: f25b09199ab8026bf50364cfc8d49a860fb9a760
URL: https://github.com/llvm/llvm-project/commit/f25b09199ab8026bf50364cfc8d49a860fb9a760
DIFF: https://github.com/llvm/llvm-project/commit/f25b09199ab8026bf50364cfc8d49a860fb9a760.diff
LOG: ValueTracking/test: increase recurrence coverage (#108836)
The shift-recurrence-knownbits.ll test file only covers shift
instructions while testing recurrence patterns with knownbits. Add tests
for add, sub, mul, and, and or as well, and rename the file
recurrence-knownbits.ll.
Added:
llvm/test/Analysis/ValueTracking/recurrence-knownbits.ll
Modified:
Removed:
llvm/test/Analysis/ValueTracking/shift-recurrence-knownbits.ll
################################################################################
diff --git a/llvm/test/Analysis/ValueTracking/shift-recurrence-knownbits.ll b/llvm/test/Analysis/ValueTracking/recurrence-knownbits.ll
similarity index 65%
rename from llvm/test/Analysis/ValueTracking/shift-recurrence-knownbits.ll
rename to llvm/test/Analysis/ValueTracking/recurrence-knownbits.ll
index 5e9084aac31a38..3355328cad9ecf 100644
--- a/llvm/test/Analysis/ValueTracking/shift-recurrence-knownbits.ll
+++ b/llvm/test/Analysis/ValueTracking/recurrence-knownbits.ll
@@ -21,6 +21,106 @@ exit:
ret i64 %res
}
+define i64 @test_add(i1 %c) {
+; CHECK-LABEL: @test_add(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: br label [[LOOP:%.*]]
+; CHECK: loop:
+; CHECK-NEXT: br i1 [[C:%.*]], label [[EXIT:%.*]], label [[LOOP]]
+; CHECK: exit:
+; CHECK-NEXT: ret i64 0
+;
+entry:
+ br label %loop
+loop:
+ %iv = phi i64 [8, %entry], [%iv.next, %loop]
+ %iv.next = add nuw i64 %iv, 4
+ br i1 %c, label %exit, label %loop
+exit:
+ %res = and i64 %iv, 1
+ ret i64 %res
+}
+
+define i64 @test_sub(i1 %c) {
+; CHECK-LABEL: @test_sub(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: br label [[LOOP:%.*]]
+; CHECK: loop:
+; CHECK-NEXT: br i1 [[C:%.*]], label [[EXIT:%.*]], label [[LOOP]]
+; CHECK: exit:
+; CHECK-NEXT: ret i64 0
+;
+entry:
+ br label %loop
+loop:
+ %iv = phi i64 [8, %entry], [%iv.next, %loop]
+ %iv.next = sub nuw i64 %iv, 4
+ br i1 %c, label %exit, label %loop
+exit:
+ %res = and i64 %iv, 1
+ ret i64 %res
+}
+
+define i64 @test_mul(i1 %c) {
+; CHECK-LABEL: @test_mul(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: br label [[LOOP:%.*]]
+; CHECK: loop:
+; CHECK-NEXT: br i1 [[C:%.*]], label [[EXIT:%.*]], label [[LOOP]]
+; CHECK: exit:
+; CHECK-NEXT: ret i64 0
+;
+entry:
+ br label %loop
+loop:
+ %iv = phi i64 [8, %entry], [%iv.next, %loop]
+ %iv.next = mul i64 %iv, 2
+ br i1 %c, label %exit, label %loop
+exit:
+ %res = and i64 %iv, 2
+ ret i64 %res
+}
+
+define i64 @test_and(i1 %c) {
+; CHECK-LABEL: @test_and(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: br label [[LOOP:%.*]]
+; CHECK: loop:
+; CHECK-NEXT: br i1 [[C:%.*]], label [[EXIT:%.*]], label [[LOOP]]
+; CHECK: exit:
+; CHECK-NEXT: ret i64 2047
+;
+entry:
+ br label %loop
+loop:
+ %iv = phi i64 [1025, %entry], [%iv.next, %loop]
+ %iv.next = and i64 %iv, 1024
+ br i1 %c, label %exit, label %loop
+exit:
+ %res = or i64 %iv, 1023
+ ret i64 %res
+}
+
+define i64 @test_or(i1 %c) {
+; CHECK-LABEL: @test_or(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: br label [[LOOP:%.*]]
+; CHECK: loop:
+; CHECK-NEXT: br i1 [[C:%.*]], label [[EXIT:%.*]], label [[LOOP]]
+; CHECK: exit:
+; CHECK-NEXT: ret i64 2047
+;
+entry:
+ br label %loop
+loop:
+ %iv = phi i64 [1025, %entry], [%iv.next, %loop]
+ %iv.next = or i64 %iv, 1024
+ br i1 %c, label %exit, label %loop
+exit:
+ %res = or i64 %iv, 1023
+ ret i64 %res
+}
+
define i64 @test_ashr_zeros(i1 %c) {
; CHECK-LABEL: @test_ashr_zeros(
; CHECK-NEXT: entry:
More information about the llvm-commits
mailing list