mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 03:02:36 +01:00
One more test case inspired by PR50191
This commit is contained in:
parent
f5c6ef2e13
commit
b123d90a62
@ -1715,6 +1715,7 @@ exit:
|
|||||||
ret i1 %res
|
ret i1 %res
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
define i1 @mutual_recurrence_neq(i8 %A) {
|
define i1 @mutual_recurrence_neq(i8 %A) {
|
||||||
; CHECK-LABEL: @mutual_recurrence_neq(
|
; CHECK-LABEL: @mutual_recurrence_neq(
|
||||||
; CHECK-NEXT: entry:
|
; CHECK-NEXT: entry:
|
||||||
@ -1779,5 +1780,42 @@ exit:
|
|||||||
ret i1 %res
|
ret i1 %res
|
||||||
}
|
}
|
||||||
|
|
||||||
|
; Illustrate a case where A_IV_i == B_IV_i for all i > 0, but A_IV_0 != B_IV_0.
|
||||||
|
; (E.g. This pair of mutually defined recurrences are not invertible.)
|
||||||
|
define i1 @recurrence_collapse(i8 %A) {
|
||||||
|
; CHECK-LABEL: @recurrence_collapse(
|
||||||
|
; CHECK-NEXT: entry:
|
||||||
|
; CHECK-NEXT: [[B:%.*]] = add i8 [[A:%.*]], 1
|
||||||
|
; CHECK-NEXT: br label [[LOOP:%.*]]
|
||||||
|
; CHECK: loop:
|
||||||
|
; CHECK-NEXT: [[IV:%.*]] = phi i64 [ 0, [[ENTRY:%.*]] ], [ [[IV_NEXT:%.*]], [[LOOP]] ]
|
||||||
|
; CHECK-NEXT: [[A_IV:%.*]] = phi i8 [ [[A]], [[ENTRY]] ], [ [[A_IV_NEXT:%.*]], [[LOOP]] ]
|
||||||
|
; CHECK-NEXT: [[B_IV:%.*]] = phi i8 [ [[B]], [[ENTRY]] ], [ [[B_IV_NEXT:%.*]], [[LOOP]] ]
|
||||||
|
; CHECK-NEXT: [[IV_NEXT]] = add i64 [[IV]], 1
|
||||||
|
; CHECK-NEXT: [[A_IV_NEXT]] = sub i8 [[A_IV]], [[B_IV]]
|
||||||
|
; CHECK-NEXT: [[B_IV_NEXT]] = sub i8 [[A_IV]], [[B_IV]]
|
||||||
|
; CHECK-NEXT: [[CMP:%.*]] = icmp ne i64 [[IV_NEXT]], 10
|
||||||
|
; CHECK-NEXT: br i1 [[CMP]], label [[LOOP]], label [[EXIT:%.*]]
|
||||||
|
; CHECK: exit:
|
||||||
|
; CHECK-NEXT: [[RES:%.*]] = icmp eq i8 [[A_IV]], [[B_IV]]
|
||||||
|
; CHECK-NEXT: ret i1 [[RES]]
|
||||||
|
;
|
||||||
|
entry:
|
||||||
|
%B = add i8 %A, 1
|
||||||
|
br label %loop
|
||||||
|
loop:
|
||||||
|
%iv = phi i64 [0, %entry], [%iv.next, %loop]
|
||||||
|
%A.iv = phi i8 [%A, %entry], [%A.iv.next, %loop]
|
||||||
|
%B.iv = phi i8 [%B, %entry], [%B.iv.next, %loop]
|
||||||
|
%iv.next = add i64 %iv, 1
|
||||||
|
%A.iv.next = sub i8 %A.iv, %B.iv
|
||||||
|
%B.iv.next = sub i8 %A.iv, %B.iv
|
||||||
|
%cmp = icmp ne i64 %iv.next, 10
|
||||||
|
br i1 %cmp, label %loop, label %exit
|
||||||
|
exit:
|
||||||
|
%res = icmp eq i8 %A.iv, %B.iv
|
||||||
|
ret i1 %res
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
!0 = !{ i8 1, i8 5 }
|
!0 = !{ i8 1, i8 5 }
|
||||||
|
Loading…
Reference in New Issue
Block a user