1*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -instcombine -S | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128:n8:16:32:64" 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Workerdefine i32 @test1(i32 %x) { 6*9880d681SAndroid Build Coastguard Worker %tmp.1 = and i32 %x, 65535 ; <i32> [#uses=1] 7*9880d681SAndroid Build Coastguard Worker %tmp.2 = xor i32 %tmp.1, -32768 ; <i32> [#uses=1] 8*9880d681SAndroid Build Coastguard Worker %tmp.3 = add i32 %tmp.2, 32768 ; <i32> [#uses=1] 9*9880d681SAndroid Build Coastguard Worker ret i32 %tmp.3 10*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test1( 11*9880d681SAndroid Build Coastguard Worker; CHECK: %sext = shl i32 %x, 16 12*9880d681SAndroid Build Coastguard Worker; CHECK: %tmp.3 = ashr exact i32 %sext, 16 13*9880d681SAndroid Build Coastguard Worker; CHECK: ret i32 %tmp.3 14*9880d681SAndroid Build Coastguard Worker} 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Workerdefine i32 @test2(i32 %x) { 17*9880d681SAndroid Build Coastguard Worker %tmp.1 = and i32 %x, 65535 ; <i32> [#uses=1] 18*9880d681SAndroid Build Coastguard Worker %tmp.2 = xor i32 %tmp.1, 32768 ; <i32> [#uses=1] 19*9880d681SAndroid Build Coastguard Worker %tmp.3 = add i32 %tmp.2, -32768 ; <i32> [#uses=1] 20*9880d681SAndroid Build Coastguard Worker ret i32 %tmp.3 21*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test2( 22*9880d681SAndroid Build Coastguard Worker; CHECK: %sext = shl i32 %x, 16 23*9880d681SAndroid Build Coastguard Worker; CHECK: %tmp.3 = ashr exact i32 %sext, 16 24*9880d681SAndroid Build Coastguard Worker; CHECK: ret i32 %tmp.3 25*9880d681SAndroid Build Coastguard Worker} 26*9880d681SAndroid Build Coastguard Worker 27*9880d681SAndroid Build Coastguard Workerdefine i32 @test3(i16 %P) { 28*9880d681SAndroid Build Coastguard Worker %tmp.1 = zext i16 %P to i32 ; <i32> [#uses=1] 29*9880d681SAndroid Build Coastguard Worker %tmp.4 = xor i32 %tmp.1, 32768 ; <i32> [#uses=1] 30*9880d681SAndroid Build Coastguard Worker %tmp.5 = add i32 %tmp.4, -32768 ; <i32> [#uses=1] 31*9880d681SAndroid Build Coastguard Worker ret i32 %tmp.5 32*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test3( 33*9880d681SAndroid Build Coastguard Worker; CHECK: %tmp.5 = sext i16 %P to i32 34*9880d681SAndroid Build Coastguard Worker; CHECK: ret i32 %tmp.5 35*9880d681SAndroid Build Coastguard Worker} 36*9880d681SAndroid Build Coastguard Worker 37*9880d681SAndroid Build Coastguard Workerdefine i32 @test4(i32 %x) { 38*9880d681SAndroid Build Coastguard Worker %tmp.1 = and i32 %x, 255 ; <i32> [#uses=1] 39*9880d681SAndroid Build Coastguard Worker %tmp.2 = xor i32 %tmp.1, 128 ; <i32> [#uses=1] 40*9880d681SAndroid Build Coastguard Worker %tmp.3 = add i32 %tmp.2, -128 ; <i32> [#uses=1] 41*9880d681SAndroid Build Coastguard Worker ret i32 %tmp.3 42*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test4( 43*9880d681SAndroid Build Coastguard Worker; CHECK: %sext = shl i32 %x, 24 44*9880d681SAndroid Build Coastguard Worker; CHECK: %tmp.3 = ashr exact i32 %sext, 24 45*9880d681SAndroid Build Coastguard Worker; CHECK: ret i32 %tmp.3 46*9880d681SAndroid Build Coastguard Worker} 47*9880d681SAndroid Build Coastguard Worker 48*9880d681SAndroid Build Coastguard Workerdefine i32 @test5(i32 %x) { 49*9880d681SAndroid Build Coastguard Worker %tmp.2 = shl i32 %x, 16 ; <i32> [#uses=1] 50*9880d681SAndroid Build Coastguard Worker %tmp.4 = ashr i32 %tmp.2, 16 ; <i32> [#uses=1] 51*9880d681SAndroid Build Coastguard Worker ret i32 %tmp.4 52*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test5( 53*9880d681SAndroid Build Coastguard Worker; CHECK: %tmp.2 = shl i32 %x, 16 54*9880d681SAndroid Build Coastguard Worker; CHECK: %tmp.4 = ashr exact i32 %tmp.2, 16 55*9880d681SAndroid Build Coastguard Worker; CHECK: ret i32 %tmp.4 56*9880d681SAndroid Build Coastguard Worker} 57*9880d681SAndroid Build Coastguard Worker 58*9880d681SAndroid Build Coastguard Workerdefine i32 @test6(i16 %P) { 59*9880d681SAndroid Build Coastguard Worker %tmp.1 = zext i16 %P to i32 ; <i32> [#uses=1] 60*9880d681SAndroid Build Coastguard Worker %sext1 = shl i32 %tmp.1, 16 ; <i32> [#uses=1] 61*9880d681SAndroid Build Coastguard Worker %tmp.5 = ashr i32 %sext1, 16 ; <i32> [#uses=1] 62*9880d681SAndroid Build Coastguard Worker ret i32 %tmp.5 63*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test6( 64*9880d681SAndroid Build Coastguard Worker; CHECK: %tmp.5 = sext i16 %P to i32 65*9880d681SAndroid Build Coastguard Worker; CHECK: ret i32 %tmp.5 66*9880d681SAndroid Build Coastguard Worker} 67*9880d681SAndroid Build Coastguard Worker 68*9880d681SAndroid Build Coastguard Workerdefine i32 @test7(i32 %x) nounwind readnone { 69*9880d681SAndroid Build Coastguard Workerentry: 70*9880d681SAndroid Build Coastguard Worker %shr = lshr i32 %x, 5 ; <i32> [#uses=1] 71*9880d681SAndroid Build Coastguard Worker %xor = xor i32 %shr, 67108864 ; <i32> [#uses=1] 72*9880d681SAndroid Build Coastguard Worker %sub = add i32 %xor, -67108864 ; <i32> [#uses=1] 73*9880d681SAndroid Build Coastguard Worker ret i32 %sub 74*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test7( 75*9880d681SAndroid Build Coastguard Worker; CHECK: %sub = ashr i32 %x, 5 76*9880d681SAndroid Build Coastguard Worker; CHECK: ret i32 %sub 77*9880d681SAndroid Build Coastguard Worker} 78*9880d681SAndroid Build Coastguard Worker 79