Add test case for testing InstCombine with arbitrary precision integer
[oota-llvm.git] / test / Transforms / InstCombine / apint-rem1.ll
1 ; This test makes sure that these instructions are properly eliminated.
2 ; This test is for Integer BitWidth < 64 && BitWidth % 2 != 0.
3 ;
4 ; RUN: llvm-as < %s | opt -instcombine -disable-output &&
5 ; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep rem
6
7 implementation
8
9 define i33 @test1(i33 %A) {
10     %B = urem i33 %A, 4096
11     ret i33 %B
12 }
13
14 define i49 @test2(i49 %A) {
15     %B = shl i49 4096, 11
16     %Y = urem i49 %A, %B
17     ret i49 %Y
18 }
19
20 define i59 @test3(i59 %X, i1 %C) {
21         %V = select i1 %C, i59 70368744177664, i59 4096
22         %R = urem i59 %X, %V
23         ret i59 %R
24 }