Add an explicit test that we now fold cttz.i32(..., true) >> 5 -> 0.

This is a result of Benjamin's work on ValueTracking.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@147259 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chandler Carruth 2011-12-24 22:34:15 +00:00
parent 49064ff770
commit d62414c654

View File

@ -201,16 +201,22 @@ entry:
; CHECK-NEXT: store volatile i1 %pop.cmp, i1* %c ; CHECK-NEXT: store volatile i1 %pop.cmp, i1* %c
} }
define i32 @cttz_simplify1a(i32 %x) nounwind readnone ssp {
define i32 @cttz_simplify1(i32 %x) nounwind readnone ssp { %tmp1 = tail call i32 @llvm.ctlz.i32(i32 %x, i1 false)
%tmp1 = tail call i32 @llvm.ctlz.i32(i32 %x, i1 false) ; <i32> [#uses=1] %shr3 = lshr i32 %tmp1, 5
%shr3 = lshr i32 %tmp1, 5 ; <i32> [#uses=1]
ret i32 %shr3 ret i32 %shr3
; CHECK: @cttz_simplify1 ; CHECK: @cttz_simplify1a
; CHECK: icmp eq i32 %x, 0 ; CHECK: icmp eq i32 %x, 0
; CHECK-NEXT: zext i1 ; CHECK-NEXT: zext i1
; CHECK-NEXT: ret i32 ; CHECK-NEXT: ret i32
} }
define i32 @cttz_simplify1b(i32 %x) nounwind readnone ssp {
%tmp1 = tail call i32 @llvm.ctlz.i32(i32 %x, i1 true)
%shr3 = lshr i32 %tmp1, 5
ret i32 %shr3
; CHECK: @cttz_simplify1b
; CHECK-NEXT: ret i32 0
}