1 ; RUN: llc -march=mips < %s 2 ; RUN: llc -march=mips -mattr=+msa,+fp64 < %s 3 ; RUN: llc -march=mipsel < %s 4 ; RUN: llc -march=mipsel -mattr=+msa,+fp64 < %s 5 6 ; This test originally failed to select instructions for extract_vector_elt for 7 ; v4f32 on MSA. 8 ; It should at least successfully build. 9 10 define void @autogen_SD3997499501(i8*, i32*, i64*, i32, i64, i8) { 11 BB: 12 %A4 = alloca <1 x double> 13 %A3 = alloca double 14 %A2 = alloca float 15 %A1 = alloca double 16 %A = alloca double 17 %L = load i8, i8* %0 18 store i8 97, i8* %0 19 %E = extractelement <16 x i64> <i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1>, i32 14 20 %Shuff = shufflevector <2 x i1> zeroinitializer, <2 x i1> zeroinitializer, <2 x i32> <i32 1, i32 3> 21 %I = insertelement <4 x i64> zeroinitializer, i64 0, i32 3 22 %Tr = trunc <1 x i64> zeroinitializer to <1 x i8> 23 %Sl = select i1 false, double* %A1, double* %A 24 %Cmp = icmp ne <2 x i64> zeroinitializer, zeroinitializer 25 %L5 = load double, double* %Sl 26 store float -4.374162e+06, float* %A2 27 %E6 = extractelement <4 x i64> zeroinitializer, i32 3 28 %Shuff7 = shufflevector <4 x i64> zeroinitializer, <4 x i64> %I, <4 x i32> <i32 2, i32 4, i32 6, i32 undef> 29 %I8 = insertelement <2 x i1> %Shuff, i1 false, i32 0 30 %B = ashr <4 x i32> <i32 -1, i32 -1, i32 -1, i32 -1>, <i32 -1, i32 -1, i32 -1, i32 -1> 31 %PC = bitcast float* %A2 to float* 32 %Sl9 = select i1 false, i32 82299, i32 0 33 %Cmp10 = icmp slt i8 97, %5 34 br label %CF72 35 36 CF72: ; preds = %CF72, %CF80, %CF78, %BB 37 %L11 = load double, double* %Sl 38 store double 0.000000e+00, double* %Sl 39 %E12 = extractelement <2 x i1> zeroinitializer, i32 0 40 br i1 %E12, label %CF72, label %CF80 41 42 CF80: ; preds = %CF72 43 %Shuff13 = shufflevector <2 x i1> zeroinitializer, <2 x i1> zeroinitializer, <2 x i32> <i32 3, i32 1> 44 %I14 = insertelement <2 x i64> zeroinitializer, i64 %4, i32 1 45 %B15 = fadd double %L5, 0.000000e+00 46 %BC = bitcast i32 0 to float 47 %Sl16 = select i1 %E12, float 0xC7957ED940000000, float %BC 48 %Cmp17 = icmp eq i32 136082, 471909 49 br i1 %Cmp17, label %CF72, label %CF77 50 51 CF77: ; preds = %CF77, %CF80 52 %L18 = load double, double* %Sl 53 store double 0.000000e+00, double* %Sl 54 %E19 = extractelement <2 x i1> zeroinitializer, i32 0 55 br i1 %E19, label %CF77, label %CF78 56 57 CF78: ; preds = %CF77 58 %Shuff20 = shufflevector <2 x i1> zeroinitializer, <2 x i1> zeroinitializer, <2 x i32> <i32 1, i32 3> 59 %I21 = insertelement <8 x i1> zeroinitializer, i1 %Cmp10, i32 7 60 %B22 = sdiv <4 x i64> %Shuff7, zeroinitializer 61 %FC = uitofp i8 97 to double 62 %Sl23 = select i1 %Cmp10, <2 x i1> zeroinitializer, <2 x i1> zeroinitializer 63 %L24 = load double, double* %Sl 64 store float %Sl16, float* %PC 65 %E25 = extractelement <2 x i1> %Shuff, i32 1 66 br i1 %E25, label %CF72, label %CF76 67 68 CF76: ; preds = %CF78 69 %Shuff26 = shufflevector <4 x i64> zeroinitializer, <4 x i64> %B22, <4 x i32> <i32 undef, i32 undef, i32 0, i32 undef> 70 %I27 = insertelement <4 x i64> zeroinitializer, i64 %E, i32 2 71 %B28 = mul <4 x i64> %I27, zeroinitializer 72 %ZE = zext <8 x i1> zeroinitializer to <8 x i64> 73 %Sl29 = select i1 %Cmp17, float -4.374162e+06, float -4.374162e+06 74 %L30 = load i8, i8* %0 75 store double %L5, double* %Sl 76 %E31 = extractelement <8 x i1> zeroinitializer, i32 5 77 br label %CF 78 79 CF: ; preds = %CF, %CF81, %CF76 80 %Shuff32 = shufflevector <16 x i64> <i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1>, <16 x i64> <i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1>, <16 x i32> <i32 8, i32 undef, i32 12, i32 14, i32 16, i32 18, i32 20, i32 22, i32 undef, i32 26, i32 28, i32 30, i32 undef, i32 2, i32 4, i32 6> 81 %I33 = insertelement <8 x i1> zeroinitializer, i1 false, i32 2 82 %BC34 = bitcast <4 x i32> <i32 -1, i32 -1, i32 -1, i32 -1> to <4 x float> 83 %Sl35 = select i1 %E12, <2 x i1> %I8, <2 x i1> zeroinitializer 84 %Cmp36 = fcmp oge double 0xC2C3BAE2D5C18360, 0xC2C3BAE2D5C18360 85 br i1 %Cmp36, label %CF, label %CF74 86 87 CF74: ; preds = %CF74, %CF 88 %L37 = load float, float* %PC 89 store double 0.000000e+00, double* %Sl 90 %E38 = extractelement <2 x i1> %Sl23, i32 1 91 br i1 %E38, label %CF74, label %CF75 92 93 CF75: ; preds = %CF75, %CF82, %CF74 94 %Shuff39 = shufflevector <2 x i1> %Shuff13, <2 x i1> zeroinitializer, <2 x i32> <i32 undef, i32 2> 95 %I40 = insertelement <4 x i64> zeroinitializer, i64 %4, i32 2 96 %Sl41 = select i1 %Cmp10, i32 0, i32 %3 97 %Cmp42 = icmp ne <1 x i64> zeroinitializer, zeroinitializer 98 %L43 = load double, double* %Sl 99 store i64 %4, i64* %2 100 %E44 = extractelement <2 x i1> %Shuff20, i32 1 101 br i1 %E44, label %CF75, label %CF82 102 103 CF82: ; preds = %CF75 104 %Shuff45 = shufflevector <2 x i1> %Sl23, <2 x i1> %Sl23, <2 x i32> <i32 2, i32 0> 105 %I46 = insertelement <4 x i64> zeroinitializer, i64 0, i32 0 106 %B47 = sub i64 %E, %E6 107 %Sl48 = select i1 %Cmp10, double %L5, double %L43 108 %Cmp49 = icmp uge i64 %4, %B47 109 br i1 %Cmp49, label %CF75, label %CF81 110 111 CF81: ; preds = %CF82 112 %L50 = load i8, i8* %0 113 store double %L43, double* %Sl 114 %E51 = extractelement <4 x i64> %Shuff7, i32 3 115 %Shuff52 = shufflevector <4 x float> %BC34, <4 x float> %BC34, <4 x i32> <i32 2, i32 4, i32 6, i32 0> 116 %I53 = insertelement <2 x i1> %Cmp, i1 %E25, i32 0 117 %B54 = fdiv double %L24, %L43 118 %BC55 = bitcast <4 x i64> zeroinitializer to <4 x double> 119 %Sl56 = select i1 false, i8 %5, i8 97 120 %L57 = load i8, i8* %0 121 store i8 %L50, i8* %0 122 %E58 = extractelement <2 x i1> %Shuff20, i32 1 123 br i1 %E58, label %CF, label %CF73 124 125 CF73: ; preds = %CF73, %CF81 126 %Shuff59 = shufflevector <2 x i1> %Shuff13, <2 x i1> %Shuff45, <2 x i32> <i32 undef, i32 0> 127 %I60 = insertelement <4 x float> %Shuff52, float -4.374162e+06, i32 0 128 %B61 = mul <4 x i64> %I46, zeroinitializer 129 %PC62 = bitcast double* %A3 to float* 130 %Sl63 = select i1 %Cmp10, <1 x i64> zeroinitializer, <1 x i64> zeroinitializer 131 %Cmp64 = icmp ne <2 x i1> %Cmp, %Shuff 132 %L65 = load double, double* %A1 133 store float -4.374162e+06, float* %PC62 134 %E66 = extractelement <8 x i1> %I21, i32 3 135 br i1 %E66, label %CF73, label %CF79 136 137 CF79: ; preds = %CF79, %CF73 138 %Shuff67 = shufflevector <8 x i1> %I21, <8 x i1> %I21, <8 x i32> <i32 6, i32 8, i32 10, i32 12, i32 14, i32 0, i32 undef, i32 4> 139 %I68 = insertelement <1 x i1> %Cmp42, i1 %E25, i32 0 140 %B69 = sdiv <16 x i64> <i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1>, <i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1, i64 -1> 141 %Sl70 = select i1 %Cmp49, <2 x i1> %Sl23, <2 x i1> %Shuff45 142 %Cmp71 = icmp ne i1 false, false 143 br i1 %Cmp71, label %CF79, label %CF83 144 145 CF83: ; preds = %CF79 146 store double 0.000000e+00, double* %Sl 147 store float %BC, float* %PC62 148 store double %Sl48, double* %Sl 149 store double %FC, double* %Sl 150 store float %BC, float* %PC62 151 ret void 152 } 153