2009-09-12 02:01:28 +08:00
|
|
|
; RUN: opt < %s -instcombine -S | grep {lshr.*3}
|
|
|
|
; RUN: opt < %s -instcombine -S | grep {call .*%cond}
|
Fix PR2506 by being a bit more careful about reverse fact propagation when
disproving a condition. This actually compiles the existing testcase
(udiv_select_to_select_shift) to:
define i64 @test(i64 %X, i1 %Cond) {
entry:
%divisor1.t = lshr i64 %X, 3 ; <i64> [#uses=1]
%quotient2 = lshr i64 %X, 3 ; <i64> [#uses=1]
%sum = add i64 %divisor1.t, %quotient2 ; <i64> [#uses=1]
ret i64 %sum
}
instead of:
define i64 @test(i64 %X, i1 %Cond) {
entry:
%quotient1.v = select i1 %Cond, i64 3, i64 4 ; <i64> [#uses=1]
%quotient1 = lshr i64 %X, %quotient1.v ; <i64> [#uses=1]
%quotient2 = lshr i64 %X, 3 ; <i64> [#uses=1]
%sum = add i64 %quotient1, %quotient2 ; <i64> [#uses=1]
ret i64 %sum
}
llvm-svn: 53534
2008-07-14 08:15:52 +08:00
|
|
|
; PR2506
|
|
|
|
|
|
|
|
; We can simplify the operand of udiv to '8', but not the operand to the
|
|
|
|
; call. If the callee never returns, we can't assume the div is reachable.
|
|
|
|
define i32 @a(i32 %x, i32 %y) {
|
|
|
|
entry:
|
|
|
|
%tobool = icmp ne i32 %y, 0 ; <i1> [#uses=1]
|
|
|
|
%cond = select i1 %tobool, i32 8, i32 0 ; <i32> [#uses=2]
|
|
|
|
%call = call i32 @b( i32 %cond ) ; <i32> [#uses=0]
|
|
|
|
%div = udiv i32 %x, %cond ; <i32> [#uses=1]
|
|
|
|
ret i32 %div
|
|
|
|
}
|
|
|
|
|
|
|
|
declare i32 @b(i32)
|