xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/remat-scalar-zero.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; XFAIL: *
2*9880d681SAndroid Build Coastguard Worker; ...should pass. See PR12324: misched bringup
3*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-unknown-linux-gnu > %t
4*9880d681SAndroid Build Coastguard Worker; RUN: not grep xor %t
5*9880d681SAndroid Build Coastguard Worker; RUN: not grep movap %t
6*9880d681SAndroid Build Coastguard Worker; RUN: grep "\.quad.*0" %t
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker; Remat should be able to fold the zero constant into the div instructions
9*9880d681SAndroid Build Coastguard Worker; as a constant-pool load.
10*9880d681SAndroid Build Coastguard Worker
11*9880d681SAndroid Build Coastguard Workerdefine void @foo(double* nocapture %x, double* nocapture %y) nounwind {
12*9880d681SAndroid Build Coastguard Workerentry:
13*9880d681SAndroid Build Coastguard Worker  %tmp1 = load double, double* %x                         ; <double> [#uses=1]
14*9880d681SAndroid Build Coastguard Worker  %arrayidx4 = getelementptr inbounds double, double* %x, i64 1 ; <double*> [#uses=1]
15*9880d681SAndroid Build Coastguard Worker  %tmp5 = load double, double* %arrayidx4                 ; <double> [#uses=1]
16*9880d681SAndroid Build Coastguard Worker  %arrayidx8 = getelementptr inbounds double, double* %x, i64 2 ; <double*> [#uses=1]
17*9880d681SAndroid Build Coastguard Worker  %tmp9 = load double, double* %arrayidx8                 ; <double> [#uses=1]
18*9880d681SAndroid Build Coastguard Worker  %arrayidx12 = getelementptr inbounds double, double* %x, i64 3 ; <double*> [#uses=1]
19*9880d681SAndroid Build Coastguard Worker  %tmp13 = load double, double* %arrayidx12               ; <double> [#uses=1]
20*9880d681SAndroid Build Coastguard Worker  %arrayidx16 = getelementptr inbounds double, double* %x, i64 4 ; <double*> [#uses=1]
21*9880d681SAndroid Build Coastguard Worker  %tmp17 = load double, double* %arrayidx16               ; <double> [#uses=1]
22*9880d681SAndroid Build Coastguard Worker  %arrayidx20 = getelementptr inbounds double, double* %x, i64 5 ; <double*> [#uses=1]
23*9880d681SAndroid Build Coastguard Worker  %tmp21 = load double, double* %arrayidx20               ; <double> [#uses=1]
24*9880d681SAndroid Build Coastguard Worker  %arrayidx24 = getelementptr inbounds double, double* %x, i64 6 ; <double*> [#uses=1]
25*9880d681SAndroid Build Coastguard Worker  %tmp25 = load double, double* %arrayidx24               ; <double> [#uses=1]
26*9880d681SAndroid Build Coastguard Worker  %arrayidx28 = getelementptr inbounds double, double* %x, i64 7 ; <double*> [#uses=1]
27*9880d681SAndroid Build Coastguard Worker  %tmp29 = load double, double* %arrayidx28               ; <double> [#uses=1]
28*9880d681SAndroid Build Coastguard Worker  %arrayidx32 = getelementptr inbounds double, double* %x, i64 8 ; <double*> [#uses=1]
29*9880d681SAndroid Build Coastguard Worker  %tmp33 = load double, double* %arrayidx32               ; <double> [#uses=1]
30*9880d681SAndroid Build Coastguard Worker  %arrayidx36 = getelementptr inbounds double, double* %x, i64 9 ; <double*> [#uses=1]
31*9880d681SAndroid Build Coastguard Worker  %tmp37 = load double, double* %arrayidx36               ; <double> [#uses=1]
32*9880d681SAndroid Build Coastguard Worker  %arrayidx40 = getelementptr inbounds double, double* %x, i64 10 ; <double*> [#uses=1]
33*9880d681SAndroid Build Coastguard Worker  %tmp41 = load double, double* %arrayidx40               ; <double> [#uses=1]
34*9880d681SAndroid Build Coastguard Worker  %arrayidx44 = getelementptr inbounds double, double* %x, i64 11 ; <double*> [#uses=1]
35*9880d681SAndroid Build Coastguard Worker  %tmp45 = load double, double* %arrayidx44               ; <double> [#uses=1]
36*9880d681SAndroid Build Coastguard Worker  %arrayidx48 = getelementptr inbounds double, double* %x, i64 12 ; <double*> [#uses=1]
37*9880d681SAndroid Build Coastguard Worker  %tmp49 = load double, double* %arrayidx48               ; <double> [#uses=1]
38*9880d681SAndroid Build Coastguard Worker  %arrayidx52 = getelementptr inbounds double, double* %x, i64 13 ; <double*> [#uses=1]
39*9880d681SAndroid Build Coastguard Worker  %tmp53 = load double, double* %arrayidx52               ; <double> [#uses=1]
40*9880d681SAndroid Build Coastguard Worker  %arrayidx56 = getelementptr inbounds double, double* %x, i64 14 ; <double*> [#uses=1]
41*9880d681SAndroid Build Coastguard Worker  %tmp57 = load double, double* %arrayidx56               ; <double> [#uses=1]
42*9880d681SAndroid Build Coastguard Worker  %arrayidx60 = getelementptr inbounds double, double* %x, i64 15 ; <double*> [#uses=1]
43*9880d681SAndroid Build Coastguard Worker  %tmp61 = load double, double* %arrayidx60               ; <double> [#uses=1]
44*9880d681SAndroid Build Coastguard Worker  %arrayidx64 = getelementptr inbounds double, double* %x, i64 16 ; <double*> [#uses=1]
45*9880d681SAndroid Build Coastguard Worker  %tmp65 = load double, double* %arrayidx64               ; <double> [#uses=1]
46*9880d681SAndroid Build Coastguard Worker  %div = fdiv double %tmp1, 0.000000e+00          ; <double> [#uses=1]
47*9880d681SAndroid Build Coastguard Worker  store double %div, double* %y
48*9880d681SAndroid Build Coastguard Worker  %div70 = fdiv double %tmp5, 2.000000e-01        ; <double> [#uses=1]
49*9880d681SAndroid Build Coastguard Worker  %arrayidx72 = getelementptr inbounds double, double* %y, i64 1 ; <double*> [#uses=1]
50*9880d681SAndroid Build Coastguard Worker  store double %div70, double* %arrayidx72
51*9880d681SAndroid Build Coastguard Worker  %div74 = fdiv double %tmp9, 2.000000e-01        ; <double> [#uses=1]
52*9880d681SAndroid Build Coastguard Worker  %arrayidx76 = getelementptr inbounds double, double* %y, i64 2 ; <double*> [#uses=1]
53*9880d681SAndroid Build Coastguard Worker  store double %div74, double* %arrayidx76
54*9880d681SAndroid Build Coastguard Worker  %div78 = fdiv double %tmp13, 2.000000e-01       ; <double> [#uses=1]
55*9880d681SAndroid Build Coastguard Worker  %arrayidx80 = getelementptr inbounds double, double* %y, i64 3 ; <double*> [#uses=1]
56*9880d681SAndroid Build Coastguard Worker  store double %div78, double* %arrayidx80
57*9880d681SAndroid Build Coastguard Worker  %div82 = fdiv double %tmp17, 2.000000e-01       ; <double> [#uses=1]
58*9880d681SAndroid Build Coastguard Worker  %arrayidx84 = getelementptr inbounds double, double* %y, i64 4 ; <double*> [#uses=1]
59*9880d681SAndroid Build Coastguard Worker  store double %div82, double* %arrayidx84
60*9880d681SAndroid Build Coastguard Worker  %div86 = fdiv double %tmp21, 2.000000e-01       ; <double> [#uses=1]
61*9880d681SAndroid Build Coastguard Worker  %arrayidx88 = getelementptr inbounds double, double* %y, i64 5 ; <double*> [#uses=1]
62*9880d681SAndroid Build Coastguard Worker  store double %div86, double* %arrayidx88
63*9880d681SAndroid Build Coastguard Worker  %div90 = fdiv double %tmp25, 2.000000e-01       ; <double> [#uses=1]
64*9880d681SAndroid Build Coastguard Worker  %arrayidx92 = getelementptr inbounds double, double* %y, i64 6 ; <double*> [#uses=1]
65*9880d681SAndroid Build Coastguard Worker  store double %div90, double* %arrayidx92
66*9880d681SAndroid Build Coastguard Worker  %div94 = fdiv double %tmp29, 2.000000e-01       ; <double> [#uses=1]
67*9880d681SAndroid Build Coastguard Worker  %arrayidx96 = getelementptr inbounds double, double* %y, i64 7 ; <double*> [#uses=1]
68*9880d681SAndroid Build Coastguard Worker  store double %div94, double* %arrayidx96
69*9880d681SAndroid Build Coastguard Worker  %div98 = fdiv double %tmp33, 2.000000e-01       ; <double> [#uses=1]
70*9880d681SAndroid Build Coastguard Worker  %arrayidx100 = getelementptr inbounds double, double* %y, i64 8 ; <double*> [#uses=1]
71*9880d681SAndroid Build Coastguard Worker  store double %div98, double* %arrayidx100
72*9880d681SAndroid Build Coastguard Worker  %div102 = fdiv double %tmp37, 2.000000e-01      ; <double> [#uses=1]
73*9880d681SAndroid Build Coastguard Worker  %arrayidx104 = getelementptr inbounds double, double* %y, i64 9 ; <double*> [#uses=1]
74*9880d681SAndroid Build Coastguard Worker  store double %div102, double* %arrayidx104
75*9880d681SAndroid Build Coastguard Worker  %div106 = fdiv double %tmp41, 2.000000e-01      ; <double> [#uses=1]
76*9880d681SAndroid Build Coastguard Worker  %arrayidx108 = getelementptr inbounds double, double* %y, i64 10 ; <double*> [#uses=1]
77*9880d681SAndroid Build Coastguard Worker  store double %div106, double* %arrayidx108
78*9880d681SAndroid Build Coastguard Worker  %div110 = fdiv double %tmp45, 2.000000e-01      ; <double> [#uses=1]
79*9880d681SAndroid Build Coastguard Worker  %arrayidx112 = getelementptr inbounds double, double* %y, i64 11 ; <double*> [#uses=1]
80*9880d681SAndroid Build Coastguard Worker  store double %div110, double* %arrayidx112
81*9880d681SAndroid Build Coastguard Worker  %div114 = fdiv double %tmp49, 2.000000e-01      ; <double> [#uses=1]
82*9880d681SAndroid Build Coastguard Worker  %arrayidx116 = getelementptr inbounds double, double* %y, i64 12 ; <double*> [#uses=1]
83*9880d681SAndroid Build Coastguard Worker  store double %div114, double* %arrayidx116
84*9880d681SAndroid Build Coastguard Worker  %div118 = fdiv double %tmp53, 2.000000e-01      ; <double> [#uses=1]
85*9880d681SAndroid Build Coastguard Worker  %arrayidx120 = getelementptr inbounds double, double* %y, i64 13 ; <double*> [#uses=1]
86*9880d681SAndroid Build Coastguard Worker  store double %div118, double* %arrayidx120
87*9880d681SAndroid Build Coastguard Worker  %div122 = fdiv double %tmp57, 2.000000e-01      ; <double> [#uses=1]
88*9880d681SAndroid Build Coastguard Worker  %arrayidx124 = getelementptr inbounds double, double* %y, i64 14 ; <double*> [#uses=1]
89*9880d681SAndroid Build Coastguard Worker  store double %div122, double* %arrayidx124
90*9880d681SAndroid Build Coastguard Worker  %div126 = fdiv double %tmp61, 2.000000e-01      ; <double> [#uses=1]
91*9880d681SAndroid Build Coastguard Worker  %arrayidx128 = getelementptr inbounds double, double* %y, i64 15 ; <double*> [#uses=1]
92*9880d681SAndroid Build Coastguard Worker  store double %div126, double* %arrayidx128
93*9880d681SAndroid Build Coastguard Worker  %div130 = fdiv double %tmp65, 0.000000e+00      ; <double> [#uses=1]
94*9880d681SAndroid Build Coastguard Worker  %arrayidx132 = getelementptr inbounds double, double* %y, i64 16 ; <double*> [#uses=1]
95*9880d681SAndroid Build Coastguard Worker  store double %div130, double* %arrayidx132
96*9880d681SAndroid Build Coastguard Worker  ret void
97*9880d681SAndroid Build Coastguard Worker}
98