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