1; RUN: llc -march=mipsel -mcpu=mips16 -relocation-model=pic -O3 < %s | FileCheck %s -check-prefix=1 2; RUN: llc -march=mipsel -mcpu=mips16 -relocation-model=pic -O3 < %s | FileCheck %s -check-prefix=2 3 4 5@x = common global float 0.000000e+00, align 4 6@xd = common global double 0.000000e+00, align 8 7@y = common global float 0.000000e+00, align 4 8@yd = common global double 0.000000e+00, align 8 9@xy = common global { float, float } zeroinitializer, align 4 10@xyd = common global { double, double } zeroinitializer, align 8 11 12define void @foo() nounwind { 13entry: 14 %0 = load float, float* @x, align 4 15 call void @v_sf(float %0) 16 %1 = load double, double* @xd, align 8 17 call void @v_df(double %1) 18 %2 = load float, float* @x, align 4 19 %3 = load float, float* @y, align 4 20 call void @v_sf_sf(float %2, float %3) 21 %4 = load double, double* @xd, align 8 22 %5 = load float, float* @x, align 4 23 call void @v_df_sf(double %4, float %5) 24 %6 = load double, double* @xd, align 8 25 %7 = load double, double* @yd, align 8 26 call void @v_df_df(double %6, double %7) 27 %call = call float @sf_v() 28 %8 = load float, float* @x, align 4 29 %call1 = call float @sf_sf(float %8) 30 %9 = load double, double* @xd, align 8 31 %call2 = call float @sf_df(double %9) 32 %10 = load float, float* @x, align 4 33 %11 = load float, float* @y, align 4 34 %call3 = call float @sf_sf_sf(float %10, float %11) 35 %12 = load double, double* @xd, align 8 36 %13 = load float, float* @x, align 4 37 %call4 = call float @sf_df_sf(double %12, float %13) 38 %14 = load double, double* @xd, align 8 39 %15 = load double, double* @yd, align 8 40 %call5 = call float @sf_df_df(double %14, double %15) 41 %call6 = call double @df_v() 42 %16 = load float, float* @x, align 4 43 %call7 = call double @df_sf(float %16) 44 %17 = load double, double* @xd, align 8 45 %call8 = call double @df_df(double %17) 46 %18 = load float, float* @x, align 4 47 %19 = load float, float* @y, align 4 48 %call9 = call double @df_sf_sf(float %18, float %19) 49 %20 = load double, double* @xd, align 8 50 %21 = load float, float* @x, align 4 51 %call10 = call double @df_df_sf(double %20, float %21) 52 %22 = load double, double* @xd, align 8 53 %23 = load double, double* @yd, align 8 54 %call11 = call double @df_df_df(double %22, double %23) 55 %call12 = call { float, float } @sc_v() 56 %24 = extractvalue { float, float } %call12, 0 57 %25 = extractvalue { float, float } %call12, 1 58 %26 = load float, float* @x, align 4 59 %call13 = call { float, float } @sc_sf(float %26) 60 %27 = extractvalue { float, float } %call13, 0 61 %28 = extractvalue { float, float } %call13, 1 62 %29 = load double, double* @xd, align 8 63 %call14 = call { float, float } @sc_df(double %29) 64 %30 = extractvalue { float, float } %call14, 0 65 %31 = extractvalue { float, float } %call14, 1 66 %32 = load float, float* @x, align 4 67 %33 = load float, float* @y, align 4 68 %call15 = call { float, float } @sc_sf_sf(float %32, float %33) 69 %34 = extractvalue { float, float } %call15, 0 70 %35 = extractvalue { float, float } %call15, 1 71 %36 = load double, double* @xd, align 8 72 %37 = load float, float* @x, align 4 73 %call16 = call { float, float } @sc_df_sf(double %36, float %37) 74 %38 = extractvalue { float, float } %call16, 0 75 %39 = extractvalue { float, float } %call16, 1 76 %40 = load double, double* @xd, align 8 77 %41 = load double, double* @yd, align 8 78 %call17 = call { float, float } @sc_df_df(double %40, double %41) 79 %42 = extractvalue { float, float } %call17, 0 80 %43 = extractvalue { float, float } %call17, 1 81 %call18 = call { double, double } @dc_v() 82 %44 = extractvalue { double, double } %call18, 0 83 %45 = extractvalue { double, double } %call18, 1 84 %46 = load float, float* @x, align 4 85 %call19 = call { double, double } @dc_sf(float %46) 86 %47 = extractvalue { double, double } %call19, 0 87 %48 = extractvalue { double, double } %call19, 1 88 %49 = load double, double* @xd, align 8 89 %call20 = call { double, double } @dc_df(double %49) 90 %50 = extractvalue { double, double } %call20, 0 91 %51 = extractvalue { double, double } %call20, 1 92 %52 = load float, float* @x, align 4 93 %53 = load float, float* @y, align 4 94 %call21 = call { double, double } @dc_sf_sf(float %52, float %53) 95 %54 = extractvalue { double, double } %call21, 0 96 %55 = extractvalue { double, double } %call21, 1 97 %56 = load double, double* @xd, align 8 98 %57 = load float, float* @x, align 4 99 %call22 = call { double, double } @dc_df_sf(double %56, float %57) 100 %58 = extractvalue { double, double } %call22, 0 101 %59 = extractvalue { double, double } %call22, 1 102 %60 = load double, double* @xd, align 8 103 %61 = load double, double* @yd, align 8 104 %call23 = call { double, double } @dc_df_df(double %60, double %61) 105 %62 = extractvalue { double, double } %call23, 0 106 %63 = extractvalue { double, double } %call23, 1 107 ret void 108} 109 110declare void @v_sf(float) 111 112declare void @v_df(double) 113 114declare void @v_sf_sf(float, float) 115 116declare void @v_df_sf(double, float) 117 118declare void @v_df_df(double, double) 119 120declare float @sf_v() 121 122declare float @sf_sf(float) 123 124declare float @sf_df(double) 125 126declare float @sf_sf_sf(float, float) 127 128declare float @sf_df_sf(double, float) 129 130declare float @sf_df_df(double, double) 131 132declare double @df_v() 133 134declare double @df_sf(float) 135 136declare double @df_df(double) 137 138declare double @df_sf_sf(float, float) 139 140declare double @df_df_sf(double, float) 141 142declare double @df_df_df(double, double) 143 144declare { float, float } @sc_v() 145 146declare { float, float } @sc_sf(float) 147 148declare { float, float } @sc_df(double) 149 150declare { float, float } @sc_sf_sf(float, float) 151 152declare { float, float } @sc_df_sf(double, float) 153 154declare { float, float } @sc_df_df(double, double) 155 156declare { double, double } @dc_v() 157 158declare { double, double } @dc_sf(float) 159 160declare { double, double } @dc_df(double) 161 162declare { double, double } @dc_sf_sf(float, float) 163 164declare { double, double } @dc_df_sf(double, float) 165 166declare { double, double } @dc_df_df(double, double) 167 168; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_1)(${{[0-9]+}}) 169; 2: lw ${{[0-9]+}}, %call16(v_sf)(${{[0-9]+}}) 170 171; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_2)(${{[0-9]+}}) 172; 2: lw ${{[0-9]+}}, %call16(v_df)(${{[0-9]+}}) 173 174; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_5)(${{[0-9]+}}) 175; 2: lw ${{[0-9]+}}, %call16(v_sf_sf)(${{[0-9]+}}) 176 177; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_6)(${{[0-9]+}}) 178; 2: lw ${{[0-9]+}}, %call16(v_df_sf)(${{[0-9]+}}) 179 180; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_10)(${{[0-9]+}}) 181; 2: lw ${{[0-9]+}}, %call16(v_df_df)(${{[0-9]+}}) 182 183; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_sf_0)(${{[0-9]+}}) 184; 2: lw ${{[0-9]+}}, %call16(sf_v)(${{[0-9]+}}) 185 186; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_sf_1)(${{[0-9]+}}) 187; 2: lw ${{[0-9]+}}, %call16(sf_sf)(${{[0-9]+}}) 188 189; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_sf_2)(${{[0-9]+}}) 190; 2: lw ${{[0-9]+}}, %call16(sf_df)(${{[0-9]+}}) 191 192; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_sf_5)(${{[0-9]+}}) 193; 2: lw ${{[0-9]+}}, %call16(sf_sf_sf)(${{[0-9]+}}) 194 195; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_sf_6)(${{[0-9]+}}) 196; 2: lw ${{[0-9]+}}, %call16(sf_df_sf)(${{[0-9]+}}) 197 198; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_sf_10)(${{[0-9]+}}) 199; 2: lw ${{[0-9]+}}, %call16(sf_df_df)(${{[0-9]+}}) 200 201; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_df_0)(${{[0-9]+}}) 202; 2: lw ${{[0-9]+}}, %call16(df_v)(${{[0-9]+}}) 203 204; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_df_1)(${{[0-9]+}}) 205; 2: lw ${{[0-9]+}}, %call16(df_sf)(${{[0-9]+}}) 206 207; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_df_2)(${{[0-9]+}}) 208; 2: lw ${{[0-9]+}}, %call16(df_df)(${{[0-9]+}}) 209 210; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_df_5)(${{[0-9]+}}) 211; 2: lw ${{[0-9]+}}, %call16(df_sf_sf)(${{[0-9]+}}) 212 213; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_df_6)(${{[0-9]+}}) 214; 2: lw ${{[0-9]+}}, %call16(df_df_sf)(${{[0-9]+}}) 215 216; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_df_10)(${{[0-9]+}}) 217; 2: lw ${{[0-9]+}}, %call16(df_df_df)(${{[0-9]+}}) 218 219; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_sc_0)(${{[0-9]+}}) 220; 2: lw ${{[0-9]+}}, %call16(sc_v)(${{[0-9]+}}) 221 222; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_sc_1)(${{[0-9]+}}) 223; 2: lw ${{[0-9]+}}, %call16(sc_sf)(${{[0-9]+}}) 224 225; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_sc_2)(${{[0-9]+}}) 226; 2: lw ${{[0-9]+}}, %call16(sc_df)(${{[0-9]+}}) 227 228; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_sc_5)(${{[0-9]+}}) 229; 2: lw ${{[0-9]+}}, %call16(sc_sf_sf)(${{[0-9]+}}) 230 231; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_sc_6)(${{[0-9]+}}) 232; 2: lw ${{[0-9]+}}, %call16(sc_df_sf)(${{[0-9]+}}) 233 234; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_sc_10)(${{[0-9]+}}) 235; 2: lw ${{[0-9]+}}, %call16(sc_df_df)(${{[0-9]+}}) 236 237; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_dc_0)(${{[0-9]+}}) 238; 2: lw ${{[0-9]+}}, %call16(dc_v)(${{[0-9]+}}) 239 240; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_dc_1)(${{[0-9]+}}) 241; 2: lw ${{[0-9]+}}, %call16(dc_sf)(${{[0-9]+}}) 242 243; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_dc_2)(${{[0-9]+}}) 244; 2: lw ${{[0-9]+}}, %call16(dc_df)(${{[0-9]+}}) 245 246; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_dc_5)(${{[0-9]+}}) 247; 2: lw ${{[0-9]+}}, %call16(dc_sf_sf)(${{[0-9]+}}) 248 249; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_dc_6)(${{[0-9]+}}) 250; 2: lw ${{[0-9]+}}, %call16(dc_df_sf)(${{[0-9]+}}) 251 252; 1: lw ${{[0-9]+}}, %got(__mips16_call_stub_dc_10)(${{[0-9]+}}) 253; 2: lw ${{[0-9]+}}, %call16(dc_df_df)(${{[0-9]+}}) 254 255 256 257