1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-25 12:12:47 +01:00
llvm-mirror/test/Transforms/InstCombine/not.ll
Dan Gohman 205b641954 Change tests from "opt %s" to "opt < %s" so that opt doesn't see the
input filename so that opt doesn't print the input filename in the
output so that grep lines in the tests don't unintentionally match
strings in the input filename.

llvm-svn: 81537
2009-09-11 18:01:28 +00:00

55 lines
1.7 KiB
LLVM

; This test makes sure that these instructions are properly eliminated.
;
; RUN: opt < %s -instcombine -S | not grep xor
define i32 @test1(i32 %A) {
%B = xor i32 %A, -1 ; <i32> [#uses=1]
%C = xor i32 %B, -1 ; <i32> [#uses=1]
ret i32 %C
}
define i1 @test2(i32 %A, i32 %B) {
; Can change into setge
%cond = icmp sle i32 %A, %B ; <i1> [#uses=1]
%Ret = xor i1 %cond, true ; <i1> [#uses=1]
ret i1 %Ret
}
; Test that demorgans law can be instcombined
define i32 @test3(i32 %A, i32 %B) {
%a = xor i32 %A, -1 ; <i32> [#uses=1]
%b = xor i32 %B, -1 ; <i32> [#uses=1]
%c = and i32 %a, %b ; <i32> [#uses=1]
%d = xor i32 %c, -1 ; <i32> [#uses=1]
ret i32 %d
}
; Test that demorgens law can work with constants
define i32 @test4(i32 %A, i32 %B) {
%a = xor i32 %A, -1 ; <i32> [#uses=1]
%c = and i32 %a, 5 ; <i32> [#uses=1]
%d = xor i32 %c, -1 ; <i32> [#uses=1]
ret i32 %d
}
; test the mirror of demorgans law...
define i32 @test5(i32 %A, i32 %B) {
%a = xor i32 %A, -1 ; <i32> [#uses=1]
%b = xor i32 %B, -1 ; <i32> [#uses=1]
%c = or i32 %a, %b ; <i32> [#uses=1]
%d = xor i32 %c, -1 ; <i32> [#uses=1]
ret i32 %d
}
; PR2298
define i8 @test6(i32 %a, i32 %b) zeroext nounwind {
entry:
%tmp1not = xor i32 %a, -1 ; <i32> [#uses=1]
%tmp2not = xor i32 %b, -1 ; <i32> [#uses=1]
%tmp3 = icmp slt i32 %tmp1not, %tmp2not ; <i1> [#uses=1]
%retval67 = zext i1 %tmp3 to i8 ; <i8> [#uses=1]
ret i8 %retval67
}