xref: /aosp_15_r20/external/llvm/test/CodeGen/Hexagon/eliminate-pred-spill.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
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