1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-01 00:12:50 +01:00
llvm-mirror/test/Transforms/InstCombine/apint-and-xor-merge.ll
Reid Spencer eebf90ce0b Add test case for testing InstCombine with arbitrary precision integer
types. These tests mimic the integer test cases in the normal InstCombine
test suite but use "strange" integer bit widths.

Most tests written by Zhou Sheng, a few by me.

llvm-svn: 35284
2007-03-23 20:48:34 +00:00

23 lines
654 B
LLVM

; This test case checks that the merge of and/xor can work on arbitrary
; precision integers.
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep and | wc -l | grep 1 &&
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep xor | wc -l | grep 2
; (x &z ) ^ (y & z) -> (x ^ y) & z
define i57 @test1(i57 %x, i57 %y, i57 %z) {
%tmp3 = and i57 %z, %x
%tmp6 = and i57 %z, %y
%tmp7 = xor i57 %tmp3, %tmp6
ret i57 %tmp7
}
; (x & y) ^ (x | y) -> x ^ y
define i23 @test2(i23 %x, i23 %y, i23 %z) {
%tmp3 = and i23 %y, %x
%tmp6 = or i23 %y, %x
%tmp7 = xor i23 %tmp3, %tmp6
ret i23 %tmp7
}