Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / Transforms / InstCombine / add2.ll
blob1cbdd3a3cd54ffb8d8ec1ef5ca0e2cf331a01af7
1 ; RUN: opt < %s -instcombine -S | not grep add
3 define i64 @test1(i64 %A, i32 %B) {
4         %tmp12 = zext i32 %B to i64
5         %tmp3 = shl i64 %tmp12, 32
6         %tmp5 = add i64 %tmp3, %A
7         %tmp6 = and i64 %tmp5, 123
8         ret i64 %tmp6
11 define i32 @test3(i32 %A) {
12   %B = and i32 %A, 7
13   %C = and i32 %A, 32
14   %F = add i32 %B, %C
15   ret i32 %F
18 define i32 @test4(i32 %A) {
19   %B = and i32 %A, 128
20   %C = lshr i32 %A, 30
21   %F = add i32 %B, %C
22   ret i32 %F