Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / Integer / testarith_bt.ll
blob0820399a30929efd956f750df3c1f1225bc6cd70
1 ; RUN: llvm-as %s -o - | llvm-dis > %t1.ll
2 ; RUN: llvm-as %t1.ll -o - | llvm-dis > %t2.ll
3 ; RUN: diff %t1.ll %t2.ll
6 define i31 @"simpleArith"(i31 %i0, i31 %j0)
7 begin
8         %t1 = add i31 %i0, %j0
9         %t2 = sub i31 %i0, %j0
10         %t3 = mul i31 %t1, %t2
11         %t4 = udiv i31 %t1, %t2
12         %t5 = sdiv i31 %t1, %t2
13         %t6 = urem i31 %t1, %t2
14         %t7 = srem i31 %t1, %t2
15         %t8 = shl  i31 %t1, 9
16         %t9 = lshr i31 %t1, 9
17         %t10= ashr i31 %t1, 9
18         %f1 = sitofp i31 %t1 to float
19         %f2 = fdiv float 4.0, %f1
20         ret i31 %t3
21 end