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