; RUN: opt %s -instcombine | llvm-dis | \ ; RUN: egrep {shl|lshr|ashr} | count 3 define i32 @test0(i32 %A, i32 %B, i32 %C) { %X = shl i32 %A, %C %Y = shl i32 %B, %C %Z = and i32 %X, %Y ret i32 %Z } define i32 @test1(i32 %A, i32 %B, i32 %C) { %X = lshr i32 %A, %C %Y = lshr i32 %B, %C %Z = or i32 %X, %Y ret i32 %Z } define i32 @test2(i32 %A, i32 %B, i32 %C) { %X = ashr i32 %A, %C %Y = ashr i32 %B, %C %Z = xor i32 %X, %Y ret i32 %Z } define i1 @test3(i32 %X) { %tmp1 = shl i32 %X, 7 %tmp2 = icmp slt i32 %tmp1, 0 ret i1 %tmp2 } define i1 @test4(i32 %X) { %tmp1 = lshr i32 %X, 7 %tmp2 = icmp slt i32 %tmp1, 0 ret i1 %tmp2 } define i1 @test5(i32 %X) { %tmp1 = ashr i32 %X, 7 %tmp2 = icmp slt i32 %tmp1, 0 ret i1 %tmp2 }