diff options
author | Chris Lattner <sabre@nondot.org> | 2008-07-14 00:15:52 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-07-14 00:15:52 +0000 |
commit | fdb19e58877ef80c2bab9a2df82660f8b2b444f5 (patch) | |
tree | 19078ce4b138b10a744590a5cd8eb4affa36ab7c /test | |
parent | 093a4385027235459ab6972b2e2fdc79061773cf (diff) | |
download | external_llvm-fdb19e58877ef80c2bab9a2df82660f8b2b444f5.zip external_llvm-fdb19e58877ef80c2bab9a2df82660f8b2b444f5.tar.gz external_llvm-fdb19e58877ef80c2bab9a2df82660f8b2b444f5.tar.bz2 |
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
}
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@53534 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test')
-rw-r--r-- | test/Transforms/InstCombine/2008-07-13-DivZero.ll | 16 | ||||
-rw-r--r-- | test/Transforms/InstCombine/udiv_select_to_select_shift.ll | 6 |
2 files changed, 19 insertions, 3 deletions
diff --git a/test/Transforms/InstCombine/2008-07-13-DivZero.ll b/test/Transforms/InstCombine/2008-07-13-DivZero.ll new file mode 100644 index 0000000..85c3dbc --- /dev/null +++ b/test/Transforms/InstCombine/2008-07-13-DivZero.ll @@ -0,0 +1,16 @@ +; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep {lshr.*3} +; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep {call .*%cond} +; 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) diff --git a/test/Transforms/InstCombine/udiv_select_to_select_shift.ll b/test/Transforms/InstCombine/udiv_select_to_select_shift.ll index 277592c..614ae3d 100644 --- a/test/Transforms/InstCombine/udiv_select_to_select_shift.ll +++ b/test/Transforms/InstCombine/udiv_select_to_select_shift.ll @@ -2,13 +2,13 @@ ; udiv X, (Select Cond, C1, C2) --> Select Cond, (shr X, C1), (shr X, C2) ; ; RUN: llvm-as < %s | opt -instcombine | llvm-dis -f -o %t -; RUN: grep select %t | count 1 +; RUN: not grep select %t ; RUN: grep lshr %t | count 2 -; RUN: ignore grep udiv %t | count 0 +; RUN: not grep udiv %t define i64 @test(i64 %X, i1 %Cond ) { entry: - %divisor1 = select i1 %Cond, i64 8, i64 16 + %divisor1 = select i1 %Cond, i64 16, i64 8 %quotient1 = udiv i64 %X, %divisor1 %divisor2 = select i1 %Cond, i64 8, i64 0 %quotient2 = udiv i64 %X, %divisor2 |