1; RUN: opt -S -disable-output -passes="print<demanded-bits>" < %s 2>&1 | FileCheck %s 2 3; CHECK-LABEL: Printing analysis 'Demanded Bits Analysis' for function 'test_basic': 4; CHECK-DAG: DemandedBits: 0xff00 for %x = or <2 x i32> %a, zeroinitializer 5; CHECK-DAG: DemandedBits: 0xff00 for %y = or <2 x i32> %b, zeroinitializer 6; CHECK-DAG: DemandedBits: 0xff00 for %z = or <2 x i32> %x, %y 7; CHECK-DAG: DemandedBits: 0xff for %u = lshr <2 x i32> %z, splat (i32 8) 8; CHECK-DAG: DemandedBits: 0xff for %r = trunc <2 x i32> %u to <2 x i8> 9define <2 x i8> @test_basic(<2 x i32> %a, <2 x i32> %b) { 10 %x = or <2 x i32> %a, zeroinitializer 11 %y = or <2 x i32> %b, zeroinitializer 12 %z = or <2 x i32> %x, %y 13 %u = lshr <2 x i32> %z, <i32 8, i32 8> 14 %r = trunc <2 x i32> %u to <2 x i8> 15 ret <2 x i8> %r 16} 17 18; Vector-specific instructions 19 20; CHECK-LABEL: Printing analysis 'Demanded Bits Analysis' for function 'test_extractelement': 21; CHECK-DAG: DemandedBits: 0xff for %x = or <2 x i32> %a, zeroinitializer 22; CHECK-DAG: DemandedBits: 0xf0 for %z = extractelement <2 x i32> %x, i32 1 23; CHECK-DAG: DemandedBits: 0xf for %y = extractelement <2 x i32> %x, i32 0 24; CHECK-DAG: DemandedBits: 0xffffffff for %u = and i32 %y, 15 25; CHECK-DAG: DemandedBits: 0xffffffff for %v = and i32 %z, 240 26; CHECK-DAG: DemandedBits: 0xffffffff for %r = or i32 %u, %v 27define i32 @test_extractelement(<2 x i32> %a) { 28 %x = or <2 x i32> %a, zeroinitializer 29 %y = extractelement <2 x i32> %x, i32 0 30 %z = extractelement <2 x i32> %x, i32 1 31 %u = and i32 %y, 15 32 %v = and i32 %z, 240 33 %r = or i32 %u, %v 34 ret i32 %r 35} 36 37; CHECK-LABEL: Printing analysis 'Demanded Bits Analysis' for function 'test_insertelement': 38; CHECK-DAG: DemandedBits: 0xff for %x = or i32 %a, 0 39; CHECK-DAG: DemandedBits: 0xff for %y = or i32 %b, 0 40; CHECK-DAG: DemandedBits: 0xff for %z = insertelement <2 x i32> undef, i32 %x, i32 0 41; CHECK-DAG: DemandedBits: 0xff for %u = insertelement <2 x i32> %z, i32 %y, i32 1 42; CHECK-DAG: DemandedBits: 0xffffffff for %r = and <2 x i32> %u, <i32 255, i32 127> 43define <2 x i32> @test_insertelement(i32 %a, i32 %b) { 44 %x = or i32 %a, 0 45 %y = or i32 %b, 0 46 %z = insertelement <2 x i32> undef, i32 %x, i32 0 47 %u = insertelement <2 x i32> %z, i32 %y, i32 1 48 %r = and <2 x i32> %u, <i32 255, i32 127> 49 ret <2 x i32> %r 50} 51 52; CHECK-LABEL: Printing analysis 'Demanded Bits Analysis' for function 'test_shufflevector': 53; CHECK-DAG: DemandedBits: 0xff for %x = or <2 x i32> %a, zeroinitializer 54; CHECK-DAG: DemandedBits: 0xff for %y = or <2 x i32> %b, zeroinitializer 55; CHECK-DAG: DemandedBits: 0xff for %z = shufflevector <2 x i32> %x, <2 x i32> %y, <3 x i32> <i32 0, i32 3, i32 1> 56; CHECK-DAG: DemandedBits: 0xffffffff for %r = and <3 x i32> %z, <i32 255, i32 127, i32 0> 57define <3 x i32> @test_shufflevector(<2 x i32> %a, <2 x i32> %b) { 58 %x = or <2 x i32> %a, zeroinitializer 59 %y = or <2 x i32> %b, zeroinitializer 60 %z = shufflevector <2 x i32> %x, <2 x i32> %y, <3 x i32> <i32 0, i32 3, i32 1> 61 %r = and <3 x i32> %z, <i32 255, i32 127, i32 0> 62 ret <3 x i32> %r 63} 64 65; Shifts with splat shift amounts 66 67; CHECK-LABEL: Printing analysis 'Demanded Bits Analysis' for function 'test_shl': 68; CHECK-DAG: DemandedBits: 0xf for %x = or <2 x i32> %a, zeroinitializer 69; CHECK-DAG: DemandedBits: 0xf0 for %y = shl <2 x i32> %x, splat (i32 4) 70; CHECK-DAG: DemandedBits: 0xffffffff for %r = and <2 x i32> %y, splat (i32 240) 71define <2 x i32> @test_shl(<2 x i32> %a) { 72 %x = or <2 x i32> %a, zeroinitializer 73 %y = shl <2 x i32> %x, <i32 4, i32 4> 74 %r = and <2 x i32> %y, <i32 240, i32 240> 75 ret <2 x i32> %r 76} 77 78; CHECK-LABEL: Printing analysis 'Demanded Bits Analysis' for function 'test_ashr': 79; CHECK-DAG: DemandedBits: 0xf00 for %x = or <2 x i32> %a, zeroinitializer 80; CHECK-DAG: DemandedBits: 0xf0 for %y = ashr <2 x i32> %x, splat (i32 4) 81; CHECK-DAG: DemandedBits: 0xffffffff for %r = and <2 x i32> %y, splat (i32 240) 82define <2 x i32> @test_ashr(<2 x i32> %a) { 83 %x = or <2 x i32> %a, zeroinitializer 84 %y = ashr <2 x i32> %x, <i32 4, i32 4> 85 %r = and <2 x i32> %y, <i32 240, i32 240> 86 ret <2 x i32> %r 87} 88 89; CHECK-LABEL: Printing analysis 'Demanded Bits Analysis' for function 'test_lshr': 90; CHECK-DAG: DemandedBits: 0xf00 for %x = or <2 x i32> %a, zeroinitializer 91; CHECK-DAG: DemandedBits: 0xf0 for %y = lshr <2 x i32> %x, splat (i32 4) 92; CHECK-DAG: DemandedBits: 0xffffffff for %r = and <2 x i32> %y, splat (i32 240) 93define <2 x i32> @test_lshr(<2 x i32> %a) { 94 %x = or <2 x i32> %a, zeroinitializer 95 %y = lshr <2 x i32> %x, <i32 4, i32 4> 96 %r = and <2 x i32> %y, <i32 240, i32 240> 97 ret <2 x i32> %r 98} 99 100declare <2 x i32> @llvm.fshl.i32(<2 x i32>, <2 x i32>, <2 x i32>) 101declare <2 x i32> @llvm.fshr.i32(<2 x i32>, <2 x i32>, <2 x i32>) 102 103; CHECK-LABEL: Printing analysis 'Demanded Bits Analysis' for function 'test_fshl': 104; CHECK-DAG: DemandedBits: 0xf for %x = or <2 x i32> %a, zeroinitializer 105; CHECK-DAG: DemandedBits: 0xf0000000 for %y = or <2 x i32> %b, zeroinitializer 106; CHECK-DAG: DemandedBits: 0xff for %z = call <2 x i32> @llvm.fshl.v2i32(<2 x i32> %x, <2 x i32> %y, <2 x i32> splat (i32 4)) 107; CHECK-DAG: DemandedBits: 0xffffffff for %r = and <2 x i32> %z, splat (i32 255) 108define <2 x i32> @test_fshl(<2 x i32> %a, <2 x i32> %b) { 109 %x = or <2 x i32> %a, zeroinitializer 110 %y = or <2 x i32> %b, zeroinitializer 111 %z = call <2 x i32> @llvm.fshl.i32(<2 x i32> %x, <2 x i32> %y, <2 x i32> <i32 4, i32 4>) 112 %r = and <2 x i32> %z, <i32 255, i32 255> 113 ret <2 x i32> %r 114} 115 116; CHECK-LABEL: Printing analysis 'Demanded Bits Analysis' for function 'test_fshr': 117; CHECK-DAG: DemandedBits: 0xf for %x = or <2 x i32> %a, zeroinitializer 118; CHECK-DAG: DemandedBits: 0xf0000000 for %y = or <2 x i32> %b, zeroinitializer 119; CHECK-DAG: DemandedBits: 0xff for %z = call <2 x i32> @llvm.fshr.v2i32(<2 x i32> %x, <2 x i32> %y, <2 x i32> splat (i32 28)) 120; CHECK-DAG: DemandedBits: 0xffffffff for %r = and <2 x i32> %z, splat (i32 255) 121define <2 x i32> @test_fshr(<2 x i32> %a, <2 x i32> %b) { 122 %x = or <2 x i32> %a, zeroinitializer 123 %y = or <2 x i32> %b, zeroinitializer 124 %z = call <2 x i32> @llvm.fshr.i32(<2 x i32> %x, <2 x i32> %y, <2 x i32> <i32 28, i32 28>) 125 %r = and <2 x i32> %z, <i32 255, i32 255> 126 ret <2 x i32> %r 127} 128 129; FP / Int conversion. These have different input / output types. 130 131; CHECK-LABEL: Printing analysis 'Demanded Bits Analysis' for function 'test_uitofp': 132; CHECK-DAG: DemandedBits: 0xffffffff for %x = or <2 x i32> %a, zeroinitializer 133define <2 x float> @test_uitofp(<2 x i32> %a) { 134 %x = or <2 x i32> %a, zeroinitializer 135 %r = uitofp <2 x i32> %x to <2 x float> 136 ret <2 x float> %r 137} 138 139; CHECK-LABEL: Printing analysis 'Demanded Bits Analysis' for function 'test_fptoui': 140; CHECK-DAG: DemandedBits: 0xffffffff for %y = fptoui <2 x float> %x to <2 x i32> 141define <2 x i32> @test_fptoui(<2 x float> %a) { 142 %x = fadd <2 x float> %a, <float 1.0, float 1.0> 143 %y = fptoui <2 x float> %x to <2 x i32> 144 %r = and <2 x i32> %y, <i32 255, i32 255> 145 ret <2 x i32> %y 146} 147