1*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=hexagon -mcpu=hexagonv60 -enable-hexagon-hvx-double \ 2*9880d681SAndroid Build Coastguard Worker; RUN: -hexagon-bit=0 < %s | FileCheck %s 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker; This spill should be eliminated. 5*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: vmem(r29+#6) 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Workerdefine void @test(i8* noalias nocapture %key, i8* noalias nocapture %data1) #0 { 8*9880d681SAndroid Build Coastguard Workerentry: 9*9880d681SAndroid Build Coastguard Worker %0 = bitcast i8* %key to <32 x i32>* 10*9880d681SAndroid Build Coastguard Worker %1 = bitcast i8* %data1 to <32 x i32>* 11*9880d681SAndroid Build Coastguard Worker br label %for.body 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Workerfor.body: 14*9880d681SAndroid Build Coastguard Worker %pkey.0542 = phi <32 x i32>* [ %0, %entry ], [ null, %for.body ] 15*9880d681SAndroid Build Coastguard Worker %pdata0.0541 = phi <32 x i32>* [ null, %entry ], [ %add.ptr48, %for.body ] 16*9880d681SAndroid Build Coastguard Worker %pdata1.0540 = phi <32 x i32>* [ %1, %entry ], [ %add.ptr49, %for.body ] 17*9880d681SAndroid Build Coastguard Worker %dAccum0.0539 = phi <64 x i32> [ undef, %entry ], [ %86, %for.body ] 18*9880d681SAndroid Build Coastguard Worker %2 = load <32 x i32>, <32 x i32>* %pkey.0542, align 128 19*9880d681SAndroid Build Coastguard Worker %3 = load <32 x i32>, <32 x i32>* %pdata0.0541, align 128 20*9880d681SAndroid Build Coastguard Worker %4 = load <32 x i32>, <32 x i32>* undef, align 128 21*9880d681SAndroid Build Coastguard Worker %arrayidx4 = getelementptr inbounds <32 x i32>, <32 x i32>* %pdata0.0541, i32 2 22*9880d681SAndroid Build Coastguard Worker %5 = load <32 x i32>, <32 x i32>* %arrayidx4, align 128 23*9880d681SAndroid Build Coastguard Worker %arrayidx5 = getelementptr inbounds <32 x i32>, <32 x i32>* %pdata1.0540, i32 2 24*9880d681SAndroid Build Coastguard Worker %6 = load <32 x i32>, <32 x i32>* %arrayidx5, align 128 25*9880d681SAndroid Build Coastguard Worker %7 = load <32 x i32>, <32 x i32>* null, align 128 26*9880d681SAndroid Build Coastguard Worker %8 = load <32 x i32>, <32 x i32>* undef, align 128 27*9880d681SAndroid Build Coastguard Worker %9 = load <32 x i32>, <32 x i32>* null, align 128 28*9880d681SAndroid Build Coastguard Worker %arrayidx9 = getelementptr inbounds <32 x i32>, <32 x i32>* %pkey.0542, i32 3 29*9880d681SAndroid Build Coastguard Worker %arrayidx10 = getelementptr inbounds <32 x i32>, <32 x i32>* %pdata0.0541, i32 6 30*9880d681SAndroid Build Coastguard Worker %10 = load <32 x i32>, <32 x i32>* %arrayidx10, align 128 31*9880d681SAndroid Build Coastguard Worker %arrayidx12 = getelementptr inbounds <32 x i32>, <32 x i32>* %pkey.0542, i32 4 32*9880d681SAndroid Build Coastguard Worker %11 = load <32 x i32>, <32 x i32>* %arrayidx12, align 128 33*9880d681SAndroid Build Coastguard Worker %arrayidx13 = getelementptr inbounds <32 x i32>, <32 x i32>* %pdata0.0541, i32 8 34*9880d681SAndroid Build Coastguard Worker %arrayidx14 = getelementptr inbounds <32 x i32>, <32 x i32>* %pdata1.0540, i32 8 35*9880d681SAndroid Build Coastguard Worker %12 = load <32 x i32>, <32 x i32>* %arrayidx14, align 128 36*9880d681SAndroid Build Coastguard Worker %arrayidx15 = getelementptr inbounds <32 x i32>, <32 x i32>* %pkey.0542, i32 5 37*9880d681SAndroid Build Coastguard Worker %13 = load <32 x i32>, <32 x i32>* %arrayidx15, align 128 38*9880d681SAndroid Build Coastguard Worker %arrayidx16 = getelementptr inbounds <32 x i32>, <32 x i32>* %pdata0.0541, i32 10 39*9880d681SAndroid Build Coastguard Worker %arrayidx17 = getelementptr inbounds <32 x i32>, <32 x i32>* %pdata1.0540, i32 10 40*9880d681SAndroid Build Coastguard Worker %14 = load <32 x i32>, <32 x i32>* %arrayidx17, align 128 41*9880d681SAndroid Build Coastguard Worker %arrayidx18 = getelementptr inbounds <32 x i32>, <32 x i32>* %pkey.0542, i32 6 42*9880d681SAndroid Build Coastguard Worker %15 = load <32 x i32>, <32 x i32>* %arrayidx18, align 128 43*9880d681SAndroid Build Coastguard Worker %arrayidx19 = getelementptr inbounds <32 x i32>, <32 x i32>* %pdata0.0541, i32 12 44*9880d681SAndroid Build Coastguard Worker %16 = load <32 x i32>, <32 x i32>* %arrayidx19, align 128 45*9880d681SAndroid Build Coastguard Worker %arrayidx20 = getelementptr inbounds <32 x i32>, <32 x i32>* %pdata1.0540, i32 12 46*9880d681SAndroid Build Coastguard Worker %17 = load <32 x i32>, <32 x i32>* %arrayidx20, align 128 47*9880d681SAndroid Build Coastguard Worker %arrayidx22 = getelementptr inbounds <32 x i32>, <32 x i32>* %pdata0.0541, i32 14 48*9880d681SAndroid Build Coastguard Worker %18 = load <32 x i32>, <32 x i32>* %arrayidx22, align 128 49*9880d681SAndroid Build Coastguard Worker %arrayidx23 = getelementptr inbounds <32 x i32>, <32 x i32>* %pdata1.0540, i32 14 50*9880d681SAndroid Build Coastguard Worker %19 = load <32 x i32>, <32 x i32>* %arrayidx23, align 128 51*9880d681SAndroid Build Coastguard Worker %20 = tail call <1024 x i1> @llvm.hexagon.V6.vgtb.128B(<32 x i32> %2, <32 x i32> %11) 52*9880d681SAndroid Build Coastguard Worker %21 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %20, <32 x i32> %11, <32 x i32> %2) 53*9880d681SAndroid Build Coastguard Worker %22 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %20, <32 x i32> %2, <32 x i32> %11) 54*9880d681SAndroid Build Coastguard Worker %23 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %20, <32 x i32> undef, <32 x i32> %3) 55*9880d681SAndroid Build Coastguard Worker %24 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %20, <32 x i32> %12, <32 x i32> undef) 56*9880d681SAndroid Build Coastguard Worker %25 = tail call <1024 x i1> @llvm.hexagon.V6.vgtb.128B(<32 x i32> %7, <32 x i32> %15) 57*9880d681SAndroid Build Coastguard Worker %26 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %25, <32 x i32> %15, <32 x i32> %7) 58*9880d681SAndroid Build Coastguard Worker %27 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %25, <32 x i32> %7, <32 x i32> %15) 59*9880d681SAndroid Build Coastguard Worker %28 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %25, <32 x i32> %16, <32 x i32> %8) 60*9880d681SAndroid Build Coastguard Worker %29 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %25, <32 x i32> %8, <32 x i32> %16) 61*9880d681SAndroid Build Coastguard Worker %30 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %25, <32 x i32> %17, <32 x i32> %9) 62*9880d681SAndroid Build Coastguard Worker %31 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %25, <32 x i32> %9, <32 x i32> %17) 63*9880d681SAndroid Build Coastguard Worker %32 = tail call <1024 x i1> @llvm.hexagon.V6.vgtb.128B(<32 x i32> %4, <32 x i32> %13) 64*9880d681SAndroid Build Coastguard Worker %33 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %32, <32 x i32> %13, <32 x i32> %4) 65*9880d681SAndroid Build Coastguard Worker %34 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %32, <32 x i32> %4, <32 x i32> %13) 66*9880d681SAndroid Build Coastguard Worker %35 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %32, <32 x i32> undef, <32 x i32> %5) 67*9880d681SAndroid Build Coastguard Worker %36 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %32, <32 x i32> %5, <32 x i32> undef) 68*9880d681SAndroid Build Coastguard Worker %37 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %32, <32 x i32> %14, <32 x i32> %6) 69*9880d681SAndroid Build Coastguard Worker %38 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %32, <32 x i32> %6, <32 x i32> %14) 70*9880d681SAndroid Build Coastguard Worker %39 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> zeroinitializer, <32 x i32> zeroinitializer, <32 x i32> undef) 71*9880d681SAndroid Build Coastguard Worker %40 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> zeroinitializer, <32 x i32> undef, <32 x i32> zeroinitializer) 72*9880d681SAndroid Build Coastguard Worker %41 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> zeroinitializer, <32 x i32> %18, <32 x i32> %10) 73*9880d681SAndroid Build Coastguard Worker %42 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> zeroinitializer, <32 x i32> %10, <32 x i32> %18) 74*9880d681SAndroid Build Coastguard Worker %43 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> zeroinitializer, <32 x i32> %19, <32 x i32> undef) 75*9880d681SAndroid Build Coastguard Worker %44 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> zeroinitializer, <32 x i32> undef, <32 x i32> %19) 76*9880d681SAndroid Build Coastguard Worker %45 = tail call <1024 x i1> @llvm.hexagon.V6.vgtb.128B(<32 x i32> %21, <32 x i32> %26) 77*9880d681SAndroid Build Coastguard Worker %46 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %45, <32 x i32> %26, <32 x i32> %21) 78*9880d681SAndroid Build Coastguard Worker %47 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %45, <32 x i32> %21, <32 x i32> %26) 79*9880d681SAndroid Build Coastguard Worker %48 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %45, <32 x i32> %28, <32 x i32> %23) 80*9880d681SAndroid Build Coastguard Worker %49 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %45, <32 x i32> %23, <32 x i32> %28) 81*9880d681SAndroid Build Coastguard Worker %50 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %45, <32 x i32> %30, <32 x i32> %24) 82*9880d681SAndroid Build Coastguard Worker %51 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %45, <32 x i32> %24, <32 x i32> %30) 83*9880d681SAndroid Build Coastguard Worker %52 = tail call <1024 x i1> @llvm.hexagon.V6.vgtb.128B(<32 x i32> %22, <32 x i32> %27) 84*9880d681SAndroid Build Coastguard Worker %53 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %52, <32 x i32> %27, <32 x i32> %22) 85*9880d681SAndroid Build Coastguard Worker %54 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %52, <32 x i32> %22, <32 x i32> %27) 86*9880d681SAndroid Build Coastguard Worker %55 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %52, <32 x i32> %29, <32 x i32> undef) 87*9880d681SAndroid Build Coastguard Worker %56 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %52, <32 x i32> undef, <32 x i32> %31) 88*9880d681SAndroid Build Coastguard Worker %57 = tail call <1024 x i1> @llvm.hexagon.V6.vgtb.128B(<32 x i32> %33, <32 x i32> %39) 89*9880d681SAndroid Build Coastguard Worker %58 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %57, <32 x i32> %39, <32 x i32> %33) 90*9880d681SAndroid Build Coastguard Worker %59 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %57, <32 x i32> %33, <32 x i32> %39) 91*9880d681SAndroid Build Coastguard Worker %60 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %57, <32 x i32> %41, <32 x i32> %35) 92*9880d681SAndroid Build Coastguard Worker %61 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %57, <32 x i32> %43, <32 x i32> %37) 93*9880d681SAndroid Build Coastguard Worker %62 = tail call <1024 x i1> @llvm.hexagon.V6.vgtb.128B(<32 x i32> %34, <32 x i32> %40) 94*9880d681SAndroid Build Coastguard Worker %63 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %62, <32 x i32> %42, <32 x i32> %36) 95*9880d681SAndroid Build Coastguard Worker %64 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %62, <32 x i32> %38, <32 x i32> %44) 96*9880d681SAndroid Build Coastguard Worker %65 = tail call <1024 x i1> @llvm.hexagon.V6.vgtb.128B(<32 x i32> %46, <32 x i32> %58) 97*9880d681SAndroid Build Coastguard Worker %66 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %65, <32 x i32> %58, <32 x i32> %46) 98*9880d681SAndroid Build Coastguard Worker %67 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %65, <32 x i32> %60, <32 x i32> %48) 99*9880d681SAndroid Build Coastguard Worker %68 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %65, <32 x i32> %61, <32 x i32> %50) 100*9880d681SAndroid Build Coastguard Worker %69 = tail call <1024 x i1> @llvm.hexagon.V6.vgtb.128B(<32 x i32> %47, <32 x i32> %59) 101*9880d681SAndroid Build Coastguard Worker %70 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %69, <32 x i32> %51, <32 x i32> zeroinitializer) 102*9880d681SAndroid Build Coastguard Worker %71 = tail call <1024 x i1> @llvm.hexagon.V6.vgtb.128B(<32 x i32> %53, <32 x i32> zeroinitializer) 103*9880d681SAndroid Build Coastguard Worker %72 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %71, <32 x i32> %63, <32 x i32> %55) 104*9880d681SAndroid Build Coastguard Worker %73 = tail call <1024 x i1> @llvm.hexagon.V6.vgtb.128B(<32 x i32> %54, <32 x i32> undef) 105*9880d681SAndroid Build Coastguard Worker %74 = tail call <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1> %73, <32 x i32> %56, <32 x i32> %64) 106*9880d681SAndroid Build Coastguard Worker %75 = tail call <32 x i32> @llvm.hexagon.V6.vshuffeb.128B(<32 x i32> %68, <32 x i32> %67) 107*9880d681SAndroid Build Coastguard Worker %76 = tail call <32 x i32> @llvm.hexagon.V6.vshuffeb.128B(<32 x i32> %70, <32 x i32> undef) 108*9880d681SAndroid Build Coastguard Worker %77 = tail call <32 x i32> @llvm.hexagon.V6.vshuffeb.128B(<32 x i32> zeroinitializer, <32 x i32> %72) 109*9880d681SAndroid Build Coastguard Worker %78 = tail call <32 x i32> @llvm.hexagon.V6.vshuffeb.128B(<32 x i32> %74, <32 x i32> zeroinitializer) 110*9880d681SAndroid Build Coastguard Worker %79 = tail call <64 x i32> @llvm.hexagon.V6.vmpyuh.acc.128B(<64 x i32> %dAccum0.0539, <32 x i32> %75, i32 65537) 111*9880d681SAndroid Build Coastguard Worker %80 = tail call <64 x i32> @llvm.hexagon.V6.vmpyuh.acc.128B(<64 x i32> %79, <32 x i32> zeroinitializer, i32 65537) 112*9880d681SAndroid Build Coastguard Worker %81 = tail call <64 x i32> @llvm.hexagon.V6.vmpyuh.acc.128B(<64 x i32> %80, <32 x i32> zeroinitializer, i32 65537) 113*9880d681SAndroid Build Coastguard Worker %82 = tail call <64 x i32> @llvm.hexagon.V6.vmpyuh.acc.128B(<64 x i32> %81, <32 x i32> %76, i32 65537) 114*9880d681SAndroid Build Coastguard Worker %83 = tail call <64 x i32> @llvm.hexagon.V6.vmpyuh.acc.128B(<64 x i32> %82, <32 x i32> %77, i32 65537) 115*9880d681SAndroid Build Coastguard Worker %84 = tail call <64 x i32> @llvm.hexagon.V6.vmpyuh.acc.128B(<64 x i32> %83, <32 x i32> zeroinitializer, i32 65537) 116*9880d681SAndroid Build Coastguard Worker %85 = tail call <64 x i32> @llvm.hexagon.V6.vmpyuh.acc.128B(<64 x i32> %84, <32 x i32> undef, i32 65537) 117*9880d681SAndroid Build Coastguard Worker %86 = tail call <64 x i32> @llvm.hexagon.V6.vmpyuh.acc.128B(<64 x i32> %85, <32 x i32> %78, i32 65537) 118*9880d681SAndroid Build Coastguard Worker store <32 x i32> %66, <32 x i32>* %pkey.0542, align 128 119*9880d681SAndroid Build Coastguard Worker store <32 x i32> %75, <32 x i32>* %pdata0.0541, align 128 120*9880d681SAndroid Build Coastguard Worker store <32 x i32> zeroinitializer, <32 x i32>* %arrayidx4, align 128 121*9880d681SAndroid Build Coastguard Worker store <32 x i32> zeroinitializer, <32 x i32>* undef, align 128 122*9880d681SAndroid Build Coastguard Worker store <32 x i32> zeroinitializer, <32 x i32>* %arrayidx20, align 128 123*9880d681SAndroid Build Coastguard Worker store <32 x i32> zeroinitializer, <32 x i32>* null, align 128 124*9880d681SAndroid Build Coastguard Worker %add.ptr48 = getelementptr inbounds <32 x i32>, <32 x i32>* %pdata0.0541, i32 16 125*9880d681SAndroid Build Coastguard Worker %add.ptr49 = getelementptr inbounds <32 x i32>, <32 x i32>* %pdata1.0540, i32 16 126*9880d681SAndroid Build Coastguard Worker br i1 false, label %for.end, label %for.body 127*9880d681SAndroid Build Coastguard Worker 128*9880d681SAndroid Build Coastguard Workerfor.end: 129*9880d681SAndroid Build Coastguard Worker %87 = tail call <32 x i32> @llvm.hexagon.V6.hi.128B(<64 x i32> %86) 130*9880d681SAndroid Build Coastguard Worker ret void 131*9880d681SAndroid Build Coastguard Worker} 132*9880d681SAndroid Build Coastguard Worker 133*9880d681SAndroid Build Coastguard Workerdeclare <1024 x i1> @llvm.hexagon.V6.vgtb.128B(<32 x i32>, <32 x i32>) #1 134*9880d681SAndroid Build Coastguard Worker 135*9880d681SAndroid Build Coastguard Workerdeclare <32 x i32> @llvm.hexagon.V6.vmux.128B(<1024 x i1>, <32 x i32>, <32 x i32>) #1 136*9880d681SAndroid Build Coastguard Worker 137*9880d681SAndroid Build Coastguard Workerdeclare <32 x i32> @llvm.hexagon.V6.vshuffeb.128B(<32 x i32>, <32 x i32>) #1 138*9880d681SAndroid Build Coastguard Worker 139*9880d681SAndroid Build Coastguard Workerdeclare <64 x i32> @llvm.hexagon.V6.vmpyuh.acc.128B(<64 x i32>, <32 x i32>, i32) #1 140*9880d681SAndroid Build Coastguard Worker 141*9880d681SAndroid Build Coastguard Workerdeclare <32 x i32> @llvm.hexagon.V6.hi.128B(<64 x i32>) #1 142*9880d681SAndroid Build Coastguard Worker 143*9880d681SAndroid Build Coastguard Workerattributes #0 = { nounwind "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" } 144*9880d681SAndroid Build Coastguard Workerattributes #1 = { nounwind readnone } 145