1 ; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -relocation-model=static < %s | FileCheck %s -check-prefix=stel 2 3 @x = common global float 0.000000e+00, align 4 4 @y = common global float 0.000000e+00, align 4 5 @xd = common global double 0.000000e+00, align 8 6 @yd = common global double 0.000000e+00, align 8 7 @xy = common global { float, float } zeroinitializer, align 4 8 @xyd = common global { double, double } zeroinitializer, align 8 9 @ret_sf = common global float 0.000000e+00, align 4 10 @ret_df = common global double 0.000000e+00, align 8 11 @ret_sc = common global { float, float } zeroinitializer, align 4 12 @ret_dc = common global { double, double } zeroinitializer, align 8 13 @lx = common global float 0.000000e+00, align 4 14 @ly = common global float 0.000000e+00, align 4 15 @lxd = common global double 0.000000e+00, align 8 16 @lyd = common global double 0.000000e+00, align 8 17 @lxy = common global { float, float } zeroinitializer, align 4 18 @lxyd = common global { double, double } zeroinitializer, align 8 19 @lret_sf = common global float 0.000000e+00, align 4 20 @lret_df = common global double 0.000000e+00, align 8 21 @lret_sc = common global { float, float } zeroinitializer, align 4 22 @lret_dc = common global { double, double } zeroinitializer, align 8 23 @.str = private unnamed_addr constant [10 x i8] c"%f %f %i\0A\00", align 1 24 @.str1 = private unnamed_addr constant [16 x i8] c"%f=%f %f=%f %i\0A\00", align 1 25 @.str2 = private unnamed_addr constant [22 x i8] c"%f=%f %f=%f %f=%f %i\0A\00", align 1 26 @.str3 = private unnamed_addr constant [18 x i8] c"%f+%fi=%f+%fi %i\0A\00", align 1 27 @.str4 = private unnamed_addr constant [24 x i8] c"%f+%fi=%f+%fi %f=%f %i\0A\00", align 1 28 29 ; Function Attrs: nounwind 30 define void @clear() #0 { 31 entry: 32 store float 1.000000e+00, float* @x, align 4 33 store float 1.000000e+00, float* @y, align 4 34 store double 1.000000e+00, double* @xd, align 8 35 store double 1.000000e+00, double* @yd, align 8 36 store float 1.000000e+00, float* getelementptr inbounds ({ float, float }, { float, float }* @xy, i32 0, i32 0) 37 store float 0.000000e+00, float* getelementptr inbounds ({ float, float }, { float, float }* @xy, i32 0, i32 1) 38 store double 1.000000e+00, double* getelementptr inbounds ({ double, double }, { double, double }* @xyd, i32 0, i32 0) 39 store double 0.000000e+00, double* getelementptr inbounds ({ double, double }, { double, double }* @xyd, i32 0, i32 1) 40 store float 1.000000e+00, float* @ret_sf, align 4 41 store double 1.000000e+00, double* @ret_df, align 8 42 store float 1.000000e+00, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 0) 43 store float 0.000000e+00, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 1) 44 store double 1.000000e+00, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 0) 45 store double 0.000000e+00, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 1) 46 store float 0.000000e+00, float* @lx, align 4 47 store float 0.000000e+00, float* @ly, align 4 48 store double 0.000000e+00, double* @lxd, align 8 49 store double 0.000000e+00, double* @lyd, align 8 50 store float 0.000000e+00, float* getelementptr inbounds ({ float, float }, { float, float }* @lxy, i32 0, i32 0) 51 store float 0.000000e+00, float* getelementptr inbounds ({ float, float }, { float, float }* @lxy, i32 0, i32 1) 52 store double 0.000000e+00, double* getelementptr inbounds ({ double, double }, { double, double }* @lxyd, i32 0, i32 0) 53 store double 0.000000e+00, double* getelementptr inbounds ({ double, double }, { double, double }* @lxyd, i32 0, i32 1) 54 store float 0.000000e+00, float* @lret_sf, align 4 55 store double 0.000000e+00, double* @lret_df, align 8 56 store float 0.000000e+00, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 0) 57 store float 0.000000e+00, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 1) 58 store double 0.000000e+00, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 0) 59 store double 0.000000e+00, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 1) 60 ret void 61 } 62 63 ; Function Attrs: nounwind 64 define i32 @main() #0 { 65 entry: 66 %retval = alloca i32, align 4 67 store i32 0, i32* %retval 68 call void @clear() 69 store float 1.500000e+00, float* @lx, align 4 70 %0 = load float, float* @lx, align 4 71 call void @v_sf(float %0) 72 %1 = load float, float* @x, align 4 73 %conv = fpext float %1 to double 74 %2 = load float, float* @lx, align 4 75 %conv1 = fpext float %2 to double 76 %3 = load float, float* @x, align 4 77 %4 = load float, float* @lx, align 4 78 %cmp = fcmp oeq float %3, %4 79 %conv2 = zext i1 %cmp to i32 80 %call = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([10 x i8], [10 x i8]* @.str, i32 0, i32 0), double %conv, double %conv1, i32 %conv2) 81 call void @clear() 82 store double 0x41678C29C0000000, double* @lxd, align 8 83 %5 = load double, double* @lxd, align 8 84 call void @v_df(double %5) 85 %6 = load double, double* @xd, align 8 86 %7 = load double, double* @lxd, align 8 87 %8 = load double, double* @xd, align 8 88 %9 = load double, double* @lxd, align 8 89 %cmp3 = fcmp oeq double %8, %9 90 %conv4 = zext i1 %cmp3 to i32 91 %call5 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([10 x i8], [10 x i8]* @.str, i32 0, i32 0), double %6, double %7, i32 %conv4) 92 call void @clear() 93 store float 9.000000e+00, float* @lx, align 4 94 store float 1.000000e+01, float* @ly, align 4 95 %10 = load float, float* @lx, align 4 96 %11 = load float, float* @ly, align 4 97 call void @v_sf_sf(float %10, float %11) 98 %12 = load float, float* @x, align 4 99 %conv6 = fpext float %12 to double 100 %13 = load float, float* @lx, align 4 101 %conv7 = fpext float %13 to double 102 %14 = load float, float* @y, align 4 103 %conv8 = fpext float %14 to double 104 %15 = load float, float* @ly, align 4 105 %conv9 = fpext float %15 to double 106 %16 = load float, float* @x, align 4 107 %17 = load float, float* @lx, align 4 108 %cmp10 = fcmp oeq float %16, %17 109 br i1 %cmp10, label %land.rhs, label %land.end 110 111 land.rhs: ; preds = %entry 112 %18 = load float, float* @y, align 4 113 %19 = load float, float* @ly, align 4 114 %cmp12 = fcmp oeq float %18, %19 115 br label %land.end 116 117 land.end: ; preds = %land.rhs, %entry 118 %20 = phi i1 [ false, %entry ], [ %cmp12, %land.rhs ] 119 %land.ext = zext i1 %20 to i32 120 %call14 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([16 x i8], [16 x i8]* @.str1, i32 0, i32 0), double %conv6, double %conv7, double %conv8, double %conv9, i32 %land.ext) 121 call void @clear() 122 store float 0x3FFE666660000000, float* @lx, align 4 123 store double 0x4007E613249FF279, double* @lyd, align 8 124 %21 = load float, float* @lx, align 4 125 %22 = load double, double* @lyd, align 8 126 call void @v_sf_df(float %21, double %22) 127 %23 = load float, float* @x, align 4 128 %conv15 = fpext float %23 to double 129 %24 = load float, float* @lx, align 4 130 %conv16 = fpext float %24 to double 131 %25 = load double, double* @yd, align 8 132 %26 = load double, double* @lyd, align 8 133 %27 = load float, float* @x, align 4 134 %28 = load float, float* @lx, align 4 135 %cmp17 = fcmp oeq float %27, %28 136 %conv18 = zext i1 %cmp17 to i32 137 %29 = load double, double* @yd, align 8 138 %30 = load double, double* @lyd, align 8 139 %cmp19 = fcmp oeq double %29, %30 140 %conv20 = zext i1 %cmp19 to i32 141 %and = and i32 %conv18, %conv20 142 %call21 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([16 x i8], [16 x i8]* @.str1, i32 0, i32 0), double %conv15, double %conv16, double %25, double %26, i32 %and) 143 call void @clear() 144 store double 0x4194E54F94000000, double* @lxd, align 8 145 store float 7.600000e+01, float* @ly, align 4 146 %31 = load double, double* @lxd, align 8 147 %32 = load float, float* @ly, align 4 148 call void @v_df_sf(double %31, float %32) 149 %33 = load double, double* @xd, align 8 150 %34 = load double, double* @lxd, align 8 151 %35 = load float, float* @y, align 4 152 %conv22 = fpext float %35 to double 153 %36 = load float, float* @ly, align 4 154 %conv23 = fpext float %36 to double 155 %37 = load double, double* @xd, align 8 156 %38 = load double, double* @lxd, align 8 157 %cmp24 = fcmp oeq double %37, %38 158 %conv25 = zext i1 %cmp24 to i32 159 %39 = load float, float* @y, align 4 160 %40 = load float, float* @ly, align 4 161 %cmp26 = fcmp oeq float %39, %40 162 %conv27 = zext i1 %cmp26 to i32 163 %and28 = and i32 %conv25, %conv27 164 %call29 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([16 x i8], [16 x i8]* @.str1, i32 0, i32 0), double %33, double %34, double %conv22, double %conv23, i32 %and28) 165 call void @clear() 166 store double 7.365198e+07, double* @lxd, align 8 167 store double 0x416536CD80000000, double* @lyd, align 8 168 %41 = load double, double* @lxd, align 8 169 %42 = load double, double* @lyd, align 8 170 call void @v_df_df(double %41, double %42) 171 %43 = load double, double* @xd, align 8 172 %44 = load double, double* @lxd, align 8 173 %45 = load double, double* @yd, align 8 174 %46 = load double, double* @lyd, align 8 175 %47 = load double, double* @xd, align 8 176 %48 = load double, double* @lxd, align 8 177 %cmp30 = fcmp oeq double %47, %48 178 %conv31 = zext i1 %cmp30 to i32 179 %49 = load double, double* @yd, align 8 180 %50 = load double, double* @lyd, align 8 181 %cmp32 = fcmp oeq double %49, %50 182 %conv33 = zext i1 %cmp32 to i32 183 %and34 = and i32 %conv31, %conv33 184 %call35 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([16 x i8], [16 x i8]* @.str1, i32 0, i32 0), double %43, double %44, double %45, double %46, i32 %and34) 185 call void @clear() 186 store float 0x4016666660000000, float* @ret_sf, align 4 187 %call36 = call float @sf_v() 188 store float %call36, float* @lret_sf, align 4 189 %51 = load float, float* @ret_sf, align 4 190 %conv37 = fpext float %51 to double 191 %52 = load float, float* @lret_sf, align 4 192 %conv38 = fpext float %52 to double 193 %53 = load float, float* @ret_sf, align 4 194 %54 = load float, float* @lret_sf, align 4 195 %cmp39 = fcmp oeq float %53, %54 196 %conv40 = zext i1 %cmp39 to i32 197 %call41 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([10 x i8], [10 x i8]* @.str, i32 0, i32 0), double %conv37, double %conv38, i32 %conv40) 198 call void @clear() 199 store float 4.587300e+06, float* @ret_sf, align 4 200 store float 3.420000e+02, float* @lx, align 4 201 %55 = load float, float* @lx, align 4 202 %call42 = call float @sf_sf(float %55) 203 store float %call42, float* @lret_sf, align 4 204 %56 = load float, float* @ret_sf, align 4 205 %conv43 = fpext float %56 to double 206 %57 = load float, float* @lret_sf, align 4 207 %conv44 = fpext float %57 to double 208 %58 = load float, float* @x, align 4 209 %conv45 = fpext float %58 to double 210 %59 = load float, float* @lx, align 4 211 %conv46 = fpext float %59 to double 212 %60 = load float, float* @ret_sf, align 4 213 %61 = load float, float* @lret_sf, align 4 214 %cmp47 = fcmp oeq float %60, %61 215 %conv48 = zext i1 %cmp47 to i32 216 %62 = load float, float* @x, align 4 217 %63 = load float, float* @lx, align 4 218 %cmp49 = fcmp oeq float %62, %63 219 %conv50 = zext i1 %cmp49 to i32 220 %and51 = and i32 %conv48, %conv50 221 %call52 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([16 x i8], [16 x i8]* @.str1, i32 0, i32 0), double %conv43, double %conv44, double %conv45, double %conv46, i32 %and51) 222 call void @clear() 223 store float 4.445910e+06, float* @ret_sf, align 4 224 store double 0x419A7DB294000000, double* @lxd, align 8 225 %64 = load double, double* @lxd, align 8 226 %call53 = call float @sf_df(double %64) 227 store float %call53, float* @lret_sf, align 4 228 %65 = load float, float* @ret_sf, align 4 229 %conv54 = fpext float %65 to double 230 %66 = load float, float* @lret_sf, align 4 231 %conv55 = fpext float %66 to double 232 %67 = load double, double* @xd, align 8 233 %68 = load double, double* @lxd, align 8 234 %69 = load float, float* @ret_sf, align 4 235 %70 = load float, float* @lret_sf, align 4 236 %cmp56 = fcmp oeq float %69, %70 237 %conv57 = zext i1 %cmp56 to i32 238 %71 = load double, double* @xd, align 8 239 %72 = load double, double* @lxd, align 8 240 %cmp58 = fcmp oeq double %71, %72 241 %conv59 = zext i1 %cmp58 to i32 242 %and60 = and i32 %conv57, %conv59 243 %call61 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([16 x i8], [16 x i8]* @.str1, i32 0, i32 0), double %conv54, double %conv55, double %67, double %68, i32 %and60) 244 call void @clear() 245 store float 0x3FFF4BC6A0000000, float* @ret_sf, align 4 246 store float 4.445500e+03, float* @lx, align 4 247 store float 0x4068ACCCC0000000, float* @ly, align 4 248 %73 = load float, float* @lx, align 4 249 %74 = load float, float* @ly, align 4 250 %call62 = call float @sf_sf_sf(float %73, float %74) 251 store float %call62, float* @lret_sf, align 4 252 %75 = load float, float* @ret_sf, align 4 253 %conv63 = fpext float %75 to double 254 %76 = load float, float* @lret_sf, align 4 255 %conv64 = fpext float %76 to double 256 %77 = load float, float* @x, align 4 257 %conv65 = fpext float %77 to double 258 %78 = load float, float* @lx, align 4 259 %conv66 = fpext float %78 to double 260 %79 = load float, float* @y, align 4 261 %conv67 = fpext float %79 to double 262 %80 = load float, float* @ly, align 4 263 %conv68 = fpext float %80 to double 264 %81 = load float, float* @ret_sf, align 4 265 %82 = load float, float* @lret_sf, align 4 266 %cmp69 = fcmp oeq float %81, %82 267 br i1 %cmp69, label %land.lhs.true, label %land.end76 268 269 land.lhs.true: ; preds = %land.end 270 %83 = load float, float* @x, align 4 271 %84 = load float, float* @lx, align 4 272 %cmp71 = fcmp oeq float %83, %84 273 br i1 %cmp71, label %land.rhs73, label %land.end76 274 275 land.rhs73: ; preds = %land.lhs.true 276 %85 = load float, float* @y, align 4 277 %86 = load float, float* @ly, align 4 278 %cmp74 = fcmp oeq float %85, %86 279 br label %land.end76 280 281 land.end76: ; preds = %land.rhs73, %land.lhs.true, %land.end 282 %87 = phi i1 [ false, %land.lhs.true ], [ false, %land.end ], [ %cmp74, %land.rhs73 ] 283 %land.ext77 = zext i1 %87 to i32 284 %call78 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([22 x i8], [22 x i8]* @.str2, i32 0, i32 0), double %conv63, double %conv64, double %conv65, double %conv66, double %conv67, double %conv68, i32 %land.ext77) 285 call void @clear() 286 store float 9.991300e+04, float* @ret_sf, align 4 287 store float 1.114500e+04, float* @lx, align 4 288 store double 9.994445e+07, double* @lyd, align 8 289 %88 = load float, float* @lx, align 4 290 %89 = load double, double* @lyd, align 8 291 %call79 = call float @sf_sf_df(float %88, double %89) 292 store float %call79, float* @lret_sf, align 4 293 %90 = load float, float* @ret_sf, align 4 294 %conv80 = fpext float %90 to double 295 %91 = load float, float* @lret_sf, align 4 296 %conv81 = fpext float %91 to double 297 %92 = load float, float* @x, align 4 298 %conv82 = fpext float %92 to double 299 %93 = load float, float* @lx, align 4 300 %conv83 = fpext float %93 to double 301 %94 = load double, double* @yd, align 8 302 %95 = load double, double* @lyd, align 8 303 %96 = load float, float* @ret_sf, align 4 304 %97 = load float, float* @lret_sf, align 4 305 %cmp84 = fcmp oeq float %96, %97 306 br i1 %cmp84, label %land.lhs.true86, label %land.end92 307 308 land.lhs.true86: ; preds = %land.end76 309 %98 = load float, float* @x, align 4 310 %99 = load float, float* @lx, align 4 311 %cmp87 = fcmp oeq float %98, %99 312 br i1 %cmp87, label %land.rhs89, label %land.end92 313 314 land.rhs89: ; preds = %land.lhs.true86 315 %100 = load double, double* @yd, align 8 316 %101 = load double, double* @lyd, align 8 317 %cmp90 = fcmp oeq double %100, %101 318 br label %land.end92 319 320 land.end92: ; preds = %land.rhs89, %land.lhs.true86, %land.end76 321 %102 = phi i1 [ false, %land.lhs.true86 ], [ false, %land.end76 ], [ %cmp90, %land.rhs89 ] 322 %land.ext93 = zext i1 %102 to i32 323 %call94 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([22 x i8], [22 x i8]* @.str2, i32 0, i32 0), double %conv80, double %conv81, double %conv82, double %conv83, double %94, double %95, i32 %land.ext93) 324 call void @clear() 325 store float 0x417CCC7A00000000, float* @ret_sf, align 4 326 store double 0x4172034530000000, double* @lxd, align 8 327 store float 4.456200e+04, float* @ly, align 4 328 %103 = load double, double* @lxd, align 8 329 %104 = load float, float* @ly, align 4 330 %call95 = call float @sf_df_sf(double %103, float %104) 331 store float %call95, float* @lret_sf, align 4 332 %105 = load float, float* @ret_sf, align 4 333 %conv96 = fpext float %105 to double 334 %106 = load float, float* @lret_sf, align 4 335 %conv97 = fpext float %106 to double 336 %107 = load double, double* @xd, align 8 337 %108 = load double, double* @lxd, align 8 338 %109 = load float, float* @y, align 4 339 %conv98 = fpext float %109 to double 340 %110 = load float, float* @ly, align 4 341 %conv99 = fpext float %110 to double 342 %111 = load float, float* @ret_sf, align 4 343 %112 = load float, float* @lret_sf, align 4 344 %cmp100 = fcmp oeq float %111, %112 345 br i1 %cmp100, label %land.lhs.true102, label %land.end108 346 347 land.lhs.true102: ; preds = %land.end92 348 %113 = load double, double* @xd, align 8 349 %114 = load double, double* @lxd, align 8 350 %cmp103 = fcmp oeq double %113, %114 351 br i1 %cmp103, label %land.rhs105, label %land.end108 352 353 land.rhs105: ; preds = %land.lhs.true102 354 %115 = load float, float* @y, align 4 355 %116 = load float, float* @ly, align 4 356 %cmp106 = fcmp oeq float %115, %116 357 br label %land.end108 358 359 land.end108: ; preds = %land.rhs105, %land.lhs.true102, %land.end92 360 %117 = phi i1 [ false, %land.lhs.true102 ], [ false, %land.end92 ], [ %cmp106, %land.rhs105 ] 361 %land.ext109 = zext i1 %117 to i32 362 %call110 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([22 x i8], [22 x i8]* @.str2, i32 0, i32 0), double %conv96, double %conv97, double %107, double %108, double %conv98, double %conv99, i32 %land.ext109) 363 call void @clear() 364 store float 3.987721e+06, float* @ret_sf, align 4 365 store double 0x3FF1F49F6DDDC2D8, double* @lxd, align 8 366 store double 0x409129F306A2B170, double* @lyd, align 8 367 %118 = load double, double* @lxd, align 8 368 %119 = load double, double* @lyd, align 8 369 %call111 = call float @sf_df_df(double %118, double %119) 370 store float %call111, float* @lret_sf, align 4 371 %120 = load float, float* @ret_sf, align 4 372 %conv112 = fpext float %120 to double 373 %121 = load float, float* @lret_sf, align 4 374 %conv113 = fpext float %121 to double 375 %122 = load double, double* @xd, align 8 376 %123 = load double, double* @lxd, align 8 377 %124 = load double, double* @yd, align 8 378 %125 = load double, double* @lyd, align 8 379 %126 = load float, float* @ret_sf, align 4 380 %127 = load float, float* @lret_sf, align 4 381 %cmp114 = fcmp oeq float %126, %127 382 br i1 %cmp114, label %land.lhs.true116, label %land.end122 383 384 land.lhs.true116: ; preds = %land.end108 385 %128 = load double, double* @xd, align 8 386 %129 = load double, double* @lxd, align 8 387 %cmp117 = fcmp oeq double %128, %129 388 br i1 %cmp117, label %land.rhs119, label %land.end122 389 390 land.rhs119: ; preds = %land.lhs.true116 391 %130 = load double, double* @yd, align 8 392 %131 = load double, double* @lyd, align 8 393 %cmp120 = fcmp oeq double %130, %131 394 br label %land.end122 395 396 land.end122: ; preds = %land.rhs119, %land.lhs.true116, %land.end108 397 %132 = phi i1 [ false, %land.lhs.true116 ], [ false, %land.end108 ], [ %cmp120, %land.rhs119 ] 398 %land.ext123 = zext i1 %132 to i32 399 %call124 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([22 x i8], [22 x i8]* @.str2, i32 0, i32 0), double %conv112, double %conv113, double %122, double %123, double %124, double %125, i32 %land.ext123) 400 call void @clear() 401 store double 1.561234e+01, double* @ret_df, align 8 402 %call125 = call double @df_v() 403 store double %call125, double* @lret_df, align 8 404 %133 = load double, double* @ret_df, align 8 405 %134 = load double, double* @lret_df, align 8 406 %135 = load double, double* @ret_df, align 8 407 %136 = load double, double* @lret_df, align 8 408 %cmp126 = fcmp oeq double %135, %136 409 %conv127 = zext i1 %cmp126 to i32 410 %call128 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([10 x i8], [10 x i8]* @.str, i32 0, i32 0), double %133, double %134, i32 %conv127) 411 call void @clear() 412 store double 1.345873e+01, double* @ret_df, align 8 413 store float 3.434520e+05, float* @lx, align 4 414 %137 = load float, float* @lx, align 4 415 %call129 = call double @df_sf(float %137) 416 store double %call129, double* @lret_df, align 8 417 %138 = load double, double* @ret_df, align 8 418 %139 = load double, double* @lret_df, align 8 419 %140 = load float, float* @x, align 4 420 %conv130 = fpext float %140 to double 421 %141 = load float, float* @lx, align 4 422 %conv131 = fpext float %141 to double 423 %142 = load double, double* @ret_df, align 8 424 %143 = load double, double* @lret_df, align 8 425 %cmp132 = fcmp oeq double %142, %143 426 %conv133 = zext i1 %cmp132 to i32 427 %144 = load float, float* @x, align 4 428 %145 = load float, float* @lx, align 4 429 %cmp134 = fcmp oeq float %144, %145 430 %conv135 = zext i1 %cmp134 to i32 431 %and136 = and i32 %conv133, %conv135 432 %call137 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([16 x i8], [16 x i8]* @.str1, i32 0, i32 0), double %138, double %139, double %conv130, double %conv131, i32 %and136) 433 call void @clear() 434 store double 0x4084F3AB7AA25D8D, double* @ret_df, align 8 435 store double 0x4114F671D2F1A9FC, double* @lxd, align 8 436 %146 = load double, double* @lxd, align 8 437 %call138 = call double @df_df(double %146) 438 store double %call138, double* @lret_df, align 8 439 %147 = load double, double* @ret_df, align 8 440 %148 = load double, double* @lret_df, align 8 441 %149 = load double, double* @xd, align 8 442 %150 = load double, double* @lxd, align 8 443 %151 = load double, double* @ret_df, align 8 444 %152 = load double, double* @lret_df, align 8 445 %cmp139 = fcmp oeq double %151, %152 446 %conv140 = zext i1 %cmp139 to i32 447 %153 = load double, double* @xd, align 8 448 %154 = load double, double* @lxd, align 8 449 %cmp141 = fcmp oeq double %153, %154 450 %conv142 = zext i1 %cmp141 to i32 451 %and143 = and i32 %conv140, %conv142 452 %call144 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([16 x i8], [16 x i8]* @.str1, i32 0, i32 0), double %147, double %148, double %149, double %150, i32 %and143) 453 call void @clear() 454 store double 6.781956e+03, double* @ret_df, align 8 455 store float 4.445500e+03, float* @lx, align 4 456 store float 0x4068ACCCC0000000, float* @ly, align 4 457 %155 = load float, float* @lx, align 4 458 %156 = load float, float* @ly, align 4 459 %call145 = call double @df_sf_sf(float %155, float %156) 460 store double %call145, double* @lret_df, align 8 461 %157 = load double, double* @ret_df, align 8 462 %158 = load double, double* @lret_df, align 8 463 %159 = load float, float* @x, align 4 464 %conv146 = fpext float %159 to double 465 %160 = load float, float* @lx, align 4 466 %conv147 = fpext float %160 to double 467 %161 = load float, float* @y, align 4 468 %conv148 = fpext float %161 to double 469 %162 = load float, float* @ly, align 4 470 %conv149 = fpext float %162 to double 471 %163 = load double, double* @ret_df, align 8 472 %164 = load double, double* @lret_df, align 8 473 %cmp150 = fcmp oeq double %163, %164 474 br i1 %cmp150, label %land.lhs.true152, label %land.end158 475 476 land.lhs.true152: ; preds = %land.end122 477 %165 = load float, float* @x, align 4 478 %166 = load float, float* @lx, align 4 479 %cmp153 = fcmp oeq float %165, %166 480 br i1 %cmp153, label %land.rhs155, label %land.end158 481 482 land.rhs155: ; preds = %land.lhs.true152 483 %167 = load float, float* @y, align 4 484 %168 = load float, float* @ly, align 4 485 %cmp156 = fcmp oeq float %167, %168 486 br label %land.end158 487 488 land.end158: ; preds = %land.rhs155, %land.lhs.true152, %land.end122 489 %169 = phi i1 [ false, %land.lhs.true152 ], [ false, %land.end122 ], [ %cmp156, %land.rhs155 ] 490 %land.ext159 = zext i1 %169 to i32 491 %call160 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([22 x i8], [22 x i8]* @.str2, i32 0, i32 0), double %157, double %158, double %conv146, double %conv147, double %conv148, double %conv149, i32 %land.ext159) 492 call void @clear() 493 store double 1.889130e+05, double* @ret_df, align 8 494 store float 9.111450e+05, float* @lx, align 4 495 store double 0x4185320A58000000, double* @lyd, align 8 496 %170 = load float, float* @lx, align 4 497 %171 = load double, double* @lyd, align 8 498 %call161 = call double @df_sf_df(float %170, double %171) 499 store double %call161, double* @lret_df, align 8 500 %172 = load double, double* @ret_df, align 8 501 %173 = load double, double* @lret_df, align 8 502 %174 = load float, float* @x, align 4 503 %conv162 = fpext float %174 to double 504 %175 = load float, float* @lx, align 4 505 %conv163 = fpext float %175 to double 506 %176 = load double, double* @yd, align 8 507 %177 = load double, double* @lyd, align 8 508 %178 = load double, double* @ret_df, align 8 509 %179 = load double, double* @lret_df, align 8 510 %cmp164 = fcmp oeq double %178, %179 511 br i1 %cmp164, label %land.lhs.true166, label %land.end172 512 513 land.lhs.true166: ; preds = %land.end158 514 %180 = load float, float* @x, align 4 515 %181 = load float, float* @lx, align 4 516 %cmp167 = fcmp oeq float %180, %181 517 br i1 %cmp167, label %land.rhs169, label %land.end172 518 519 land.rhs169: ; preds = %land.lhs.true166 520 %182 = load double, double* @yd, align 8 521 %183 = load double, double* @lyd, align 8 522 %cmp170 = fcmp oeq double %182, %183 523 br label %land.end172 524 525 land.end172: ; preds = %land.rhs169, %land.lhs.true166, %land.end158 526 %184 = phi i1 [ false, %land.lhs.true166 ], [ false, %land.end158 ], [ %cmp170, %land.rhs169 ] 527 %land.ext173 = zext i1 %184 to i32 528 %call174 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([22 x i8], [22 x i8]* @.str2, i32 0, i32 0), double %172, double %173, double %conv162, double %conv163, double %176, double %177, i32 %land.ext173) 529 call void @clear() 530 store double 0x418B2DB900000000, double* @ret_df, align 8 531 store double 0x41B1EF2ED3000000, double* @lxd, align 8 532 store float 1.244562e+06, float* @ly, align 4 533 %185 = load double, double* @lxd, align 8 534 %186 = load float, float* @ly, align 4 535 %call175 = call double @df_df_sf(double %185, float %186) 536 store double %call175, double* @lret_df, align 8 537 %187 = load double, double* @ret_df, align 8 538 %188 = load double, double* @lret_df, align 8 539 %189 = load double, double* @xd, align 8 540 %190 = load double, double* @lxd, align 8 541 %191 = load float, float* @y, align 4 542 %conv176 = fpext float %191 to double 543 %192 = load float, float* @ly, align 4 544 %conv177 = fpext float %192 to double 545 %193 = load double, double* @ret_df, align 8 546 %194 = load double, double* @lret_df, align 8 547 %cmp178 = fcmp oeq double %193, %194 548 br i1 %cmp178, label %land.lhs.true180, label %land.end186 549 550 land.lhs.true180: ; preds = %land.end172 551 %195 = load double, double* @xd, align 8 552 %196 = load double, double* @lxd, align 8 553 %cmp181 = fcmp oeq double %195, %196 554 br i1 %cmp181, label %land.rhs183, label %land.end186 555 556 land.rhs183: ; preds = %land.lhs.true180 557 %197 = load float, float* @y, align 4 558 %198 = load float, float* @ly, align 4 559 %cmp184 = fcmp oeq float %197, %198 560 br label %land.end186 561 562 land.end186: ; preds = %land.rhs183, %land.lhs.true180, %land.end172 563 %199 = phi i1 [ false, %land.lhs.true180 ], [ false, %land.end172 ], [ %cmp184, %land.rhs183 ] 564 %land.ext187 = zext i1 %199 to i32 565 %call188 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([22 x i8], [22 x i8]* @.str2, i32 0, i32 0), double %187, double %188, double %189, double %190, double %conv176, double %conv177, i32 %land.ext187) 566 call void @clear() 567 store double 3.987721e+06, double* @ret_df, align 8 568 store double 5.223560e+00, double* @lxd, align 8 569 store double 0x40B7D37CC1A8AC5C, double* @lyd, align 8 570 %200 = load double, double* @lxd, align 8 571 %201 = load double, double* @lyd, align 8 572 %call189 = call double @df_df_df(double %200, double %201) 573 store double %call189, double* @lret_df, align 8 574 %202 = load double, double* @ret_df, align 8 575 %203 = load double, double* @lret_df, align 8 576 %204 = load double, double* @xd, align 8 577 %205 = load double, double* @lxd, align 8 578 %206 = load double, double* @yd, align 8 579 %207 = load double, double* @lyd, align 8 580 %208 = load double, double* @ret_df, align 8 581 %209 = load double, double* @lret_df, align 8 582 %cmp190 = fcmp oeq double %208, %209 583 br i1 %cmp190, label %land.lhs.true192, label %land.end198 584 585 land.lhs.true192: ; preds = %land.end186 586 %210 = load double, double* @xd, align 8 587 %211 = load double, double* @lxd, align 8 588 %cmp193 = fcmp oeq double %210, %211 589 br i1 %cmp193, label %land.rhs195, label %land.end198 590 591 land.rhs195: ; preds = %land.lhs.true192 592 %212 = load double, double* @yd, align 8 593 %213 = load double, double* @lyd, align 8 594 %cmp196 = fcmp oeq double %212, %213 595 br label %land.end198 596 597 land.end198: ; preds = %land.rhs195, %land.lhs.true192, %land.end186 598 %214 = phi i1 [ false, %land.lhs.true192 ], [ false, %land.end186 ], [ %cmp196, %land.rhs195 ] 599 %land.ext199 = zext i1 %214 to i32 600 %call200 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([22 x i8], [22 x i8]* @.str2, i32 0, i32 0), double %202, double %203, double %204, double %205, double %206, double %207, i32 %land.ext199) 601 call void @clear() 602 store float 4.500000e+00, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 0) 603 store float 7.000000e+00, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 1) 604 %call201 = call { float, float } @sc_v() 605 %215 = extractvalue { float, float } %call201, 0 606 %216 = extractvalue { float, float } %call201, 1 607 store float %215, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 0) 608 store float %216, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 1) 609 %ret_sc.real = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 0) 610 %ret_sc.imag = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 1) 611 %conv202 = fpext float %ret_sc.real to double 612 %conv203 = fpext float %ret_sc.imag to double 613 %ret_sc.real204 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 0) 614 %ret_sc.imag205 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 1) 615 %conv206 = fpext float %ret_sc.real204 to double 616 %conv207 = fpext float %ret_sc.imag205 to double 617 %lret_sc.real = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 0) 618 %lret_sc.imag = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 1) 619 %conv208 = fpext float %lret_sc.real to double 620 %conv209 = fpext float %lret_sc.imag to double 621 %lret_sc.real210 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 0) 622 %lret_sc.imag211 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 1) 623 %conv212 = fpext float %lret_sc.real210 to double 624 %conv213 = fpext float %lret_sc.imag211 to double 625 %ret_sc.real214 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 0) 626 %ret_sc.imag215 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 1) 627 %lret_sc.real216 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 0) 628 %lret_sc.imag217 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 1) 629 %cmp.r = fcmp oeq float %ret_sc.real214, %lret_sc.real216 630 %cmp.i = fcmp oeq float %ret_sc.imag215, %lret_sc.imag217 631 %and.ri = and i1 %cmp.r, %cmp.i 632 %conv218 = zext i1 %and.ri to i32 633 %call219 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([18 x i8], [18 x i8]* @.str3, i32 0, i32 0), double %conv202, double %conv207, double %conv208, double %conv213, i32 %conv218) 634 call void @clear() 635 store float 0x3FF7A99300000000, float* @lx, align 4 636 store float 4.500000e+00, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 0) 637 store float 7.000000e+00, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 1) 638 %217 = load float, float* @lx, align 4 639 %call220 = call { float, float } @sc_sf(float %217) 640 %218 = extractvalue { float, float } %call220, 0 641 %219 = extractvalue { float, float } %call220, 1 642 store float %218, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 0) 643 store float %219, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 1) 644 %ret_sc.real221 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 0) 645 %ret_sc.imag222 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 1) 646 %conv223 = fpext float %ret_sc.real221 to double 647 %conv224 = fpext float %ret_sc.imag222 to double 648 %ret_sc.real225 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 0) 649 %ret_sc.imag226 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 1) 650 %conv227 = fpext float %ret_sc.real225 to double 651 %conv228 = fpext float %ret_sc.imag226 to double 652 %lret_sc.real229 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 0) 653 %lret_sc.imag230 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 1) 654 %conv231 = fpext float %lret_sc.real229 to double 655 %conv232 = fpext float %lret_sc.imag230 to double 656 %lret_sc.real233 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 0) 657 %lret_sc.imag234 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 1) 658 %conv235 = fpext float %lret_sc.real233 to double 659 %conv236 = fpext float %lret_sc.imag234 to double 660 %220 = load float, float* @x, align 4 661 %conv237 = fpext float %220 to double 662 %221 = load float, float* @lx, align 4 663 %conv238 = fpext float %221 to double 664 %ret_sc.real239 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 0) 665 %ret_sc.imag240 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @ret_sc, i32 0, i32 1) 666 %lret_sc.real241 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 0) 667 %lret_sc.imag242 = load float, float* getelementptr inbounds ({ float, float }, { float, float }* @lret_sc, i32 0, i32 1) 668 %cmp.r243 = fcmp oeq float %ret_sc.real239, %lret_sc.real241 669 %cmp.i244 = fcmp oeq float %ret_sc.imag240, %lret_sc.imag242 670 %and.ri245 = and i1 %cmp.r243, %cmp.i244 671 br i1 %and.ri245, label %land.rhs247, label %land.end250 672 673 land.rhs247: ; preds = %land.end198 674 %222 = load float, float* @x, align 4 675 %223 = load float, float* @lx, align 4 676 %cmp248 = fcmp oeq float %222, %223 677 br label %land.end250 678 679 land.end250: ; preds = %land.rhs247, %land.end198 680 %224 = phi i1 [ false, %land.end198 ], [ %cmp248, %land.rhs247 ] 681 %land.ext251 = zext i1 %224 to i32 682 %call252 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([24 x i8], [24 x i8]* @.str4, i32 0, i32 0), double %conv223, double %conv228, double %conv231, double %conv236, double %conv237, double %conv238, i32 %land.ext251) 683 call void @clear() 684 store double 1.234500e+03, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 0) 685 store double 7.677000e+03, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 1) 686 %call253 = call { double, double } @dc_v() 687 %225 = extractvalue { double, double } %call253, 0 688 %226 = extractvalue { double, double } %call253, 1 689 store double %225, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 0) 690 store double %226, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 1) 691 %ret_dc.real = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 0) 692 %ret_dc.imag = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 1) 693 %ret_dc.real254 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 0) 694 %ret_dc.imag255 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 1) 695 %lret_dc.real = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 0) 696 %lret_dc.imag = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 1) 697 %lret_dc.real256 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 0) 698 %lret_dc.imag257 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 1) 699 %ret_dc.real258 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 0) 700 %ret_dc.imag259 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 1) 701 %lret_dc.real260 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 0) 702 %lret_dc.imag261 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 1) 703 %cmp.r262 = fcmp oeq double %ret_dc.real258, %lret_dc.real260 704 %cmp.i263 = fcmp oeq double %ret_dc.imag259, %lret_dc.imag261 705 %and.ri264 = and i1 %cmp.r262, %cmp.i263 706 %conv265 = zext i1 %and.ri264 to i32 707 %call266 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([18 x i8], [18 x i8]* @.str3, i32 0, i32 0), double %ret_dc.real, double %ret_dc.imag255, double %lret_dc.real, double %lret_dc.imag257, i32 %conv265) 708 call void @clear() 709 store double 0x40AAF6F532617C1C, double* @lxd, align 8 710 store double 4.444500e+03, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 0) 711 store double 7.888000e+03, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 1) 712 %227 = load float, float* @lx, align 4 713 %call267 = call { double, double } @dc_sf(float %227) 714 %228 = extractvalue { double, double } %call267, 0 715 %229 = extractvalue { double, double } %call267, 1 716 store double %228, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 0) 717 store double %229, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 1) 718 %ret_dc.real268 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 0) 719 %ret_dc.imag269 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 1) 720 %ret_dc.real270 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 0) 721 %ret_dc.imag271 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 1) 722 %lret_dc.real272 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 0) 723 %lret_dc.imag273 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 1) 724 %lret_dc.real274 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 0) 725 %lret_dc.imag275 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 1) 726 %230 = load float, float* @x, align 4 727 %conv276 = fpext float %230 to double 728 %231 = load float, float* @lx, align 4 729 %conv277 = fpext float %231 to double 730 %ret_dc.real278 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 0) 731 %ret_dc.imag279 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @ret_dc, i32 0, i32 1) 732 %lret_dc.real280 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 0) 733 %lret_dc.imag281 = load double, double* getelementptr inbounds ({ double, double }, { double, double }* @lret_dc, i32 0, i32 1) 734 %cmp.r282 = fcmp oeq double %ret_dc.real278, %lret_dc.real280 735 %cmp.i283 = fcmp oeq double %ret_dc.imag279, %lret_dc.imag281 736 %and.ri284 = and i1 %cmp.r282, %cmp.i283 737 br i1 %and.ri284, label %land.rhs286, label %land.end289 738 739 land.rhs286: ; preds = %land.end250 740 %232 = load float, float* @x, align 4 741 %233 = load float, float* @lx, align 4 742 %cmp287 = fcmp oeq float %232, %233 743 br label %land.end289 744 745 land.end289: ; preds = %land.rhs286, %land.end250 746 %234 = phi i1 [ false, %land.end250 ], [ %cmp287, %land.rhs286 ] 747 %land.ext290 = zext i1 %234 to i32 748 %call291 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([24 x i8], [24 x i8]* @.str4, i32 0, i32 0), double %ret_dc.real268, double %ret_dc.imag271, double %lret_dc.real272, double %lret_dc.imag275, double %conv276, double %conv277, i32 %land.ext290) 749 %235 = load i32, i32* %retval 750 ret i32 %235 751 } 752 753 declare void @v_sf(float) #1 754 ; stel: .section .mips16.call.fp.v_sf,"ax",@progbits 755 ; stel: .ent __call_stub_fp_v_sf 756 ; stel: mtc1 $4, $f12 757 ; stel: lui $25, %hi(v_sf) 758 ; stel: addiu $25, $25, %lo(v_sf) 759 ; stel: jr $25 760 ; stel: .end __call_stub_fp_v_sf 761 762 declare i32 @printf(i8*, ...) #1 763 764 declare void @v_df(double) #1 765 ; stel: .section .mips16.call.fp.v_df,"ax",@progbits 766 ; stel: .ent __call_stub_fp_v_df 767 ; stel: #APP 768 ; stel: .set reorder 769 ; stel: mtc1 $4, $f12 770 ; stel: mtc1 $5, $f13 771 ; stel: lui $25, %hi(v_df) 772 ; stel: addiu $25, $25, %lo(v_df) 773 ; stel: jr $25 774 ; stel: .end __call_stub_fp_v_df 775 776 declare void @v_sf_sf(float, float) #1 777 ; stel: .section .mips16.call.fp.v_sf_sf,"ax",@progbits 778 ; stel: .ent __call_stub_fp_v_sf_sf 779 ; stel: mtc1 $4, $f12 780 ; stel: mtc1 $5, $f14 781 ; stel: lui $25, %hi(v_sf_sf) 782 ; stel: addiu $25, $25, %lo(v_sf_sf) 783 ; stel: jr $25 784 ; stel: .end __call_stub_fp_v_sf_sf 785 786 declare void @v_sf_df(float, double) #1 787 ; stel: .section .mips16.call.fp.v_sf_df,"ax",@progbits 788 ; stel: .ent __call_stub_fp_v_sf_df 789 ; stel: mtc1 $4, $f12 790 ; stel: mtc1 $6, $f14 791 ; stel: mtc1 $7, $f15 792 ; stel: lui $25, %hi(v_sf_df) 793 ; stel: addiu $25, $25, %lo(v_sf_df) 794 ; stel: jr $25 795 ; stel: .end __call_stub_fp_v_sf_df 796 797 declare void @v_df_sf(double, float) #1 798 ; stel: .section .mips16.call.fp.v_df_sf,"ax",@progbits 799 ; stel: .ent __call_stub_fp_v_df_sf 800 ; stel: mtc1 $4, $f12 801 ; stel: mtc1 $5, $f13 802 ; stel: mtc1 $6, $f14 803 ; stel: lui $25, %hi(v_df_sf) 804 ; stel: addiu $25, $25, %lo(v_df_sf) 805 ; stel: jr $25 806 ; stel: .end __call_stub_fp_v_df_sf 807 808 declare void @v_df_df(double, double) #1 809 ; stel: .section .mips16.call.fp.v_df_df,"ax",@progbits 810 ; stel: .ent __call_stub_fp_v_df_df 811 ; stel: mtc1 $4, $f12 812 ; stel: mtc1 $5, $f13 813 ; stel: mtc1 $6, $f14 814 ; stel: mtc1 $7, $f15 815 ; stel: lui $25, %hi(v_df_df) 816 ; stel: addiu $25, $25, %lo(v_df_df) 817 ; stel: jr $25 818 ; stel: .end __call_stub_fp_v_df_df 819 820 declare float @sf_v() #1 821 ; stel: .section .mips16.call.fp.sf_v,"ax",@progbits 822 ; stel: .ent __call_stub_fp_sf_v 823 ; stel: move $18, $31 824 ; stel: jal sf_v 825 ; stel: mfc1 $2, $f0 826 ; stel: jr $18 827 ; stel: .end __call_stub_fp_sf_v 828 829 declare float @sf_sf(float) #1 830 ; stel: .section .mips16.call.fp.sf_sf,"ax",@progbits 831 ; stel: .ent __call_stub_fp_sf_sf 832 ; stel: mtc1 $4, $f12 833 ; stel: move $18, ${{31|ra}} 834 ; stel: jal sf_sf 835 ; stel: mfc1 $2, $f0 836 ; stel: jr $18 837 ; stel: .end __call_stub_fp_sf_sf 838 839 declare float @sf_df(double) #1 840 ; stel: .section .mips16.call.fp.sf_df,"ax",@progbits 841 ; stel: .ent __call_stub_fp_sf_df 842 ; stel: mtc1 $4, $f12 843 ; stel: mtc1 $5, $f13 844 ; stel: move $18, ${{31|ra}} 845 ; stel: jal sf_df 846 ; stel: mfc1 $2, $f0 847 ; stel: jr $18 848 ; stel: .end __call_stub_fp_sf_df 849 850 declare float @sf_sf_sf(float, float) #1 851 ; stel: .section .mips16.call.fp.sf_sf_sf,"ax",@progbits 852 ; stel: .ent __call_stub_fp_sf_sf_sf 853 ; stel: mtc1 $4, $f12 854 ; stel: mtc1 $5, $f14 855 ; stel: move $18, ${{31|ra}} 856 ; stel: jal sf_sf_sf 857 ; stel: mfc1 $2, $f0 858 ; stel: jr $18 859 ; stel: .end __call_stub_fp_sf_sf_sf 860 861 declare float @sf_sf_df(float, double) #1 862 ; stel: .section .mips16.call.fp.sf_sf_df,"ax",@progbits 863 ; stel: .ent __call_stub_fp_sf_sf_df 864 ; stel: mtc1 $4, $f12 865 ; stel: mtc1 $6, $f14 866 ; stel: mtc1 $7, $f15 867 ; stel: move $18, ${{31|ra}} 868 ; stel: jal sf_sf_df 869 ; stel: mfc1 $2, $f0 870 ; stel: jr $18 871 ; stel: .end __call_stub_fp_sf_sf_df 872 873 declare float @sf_df_sf(double, float) #1 874 ; stel: .section .mips16.call.fp.sf_df_sf,"ax",@progbits 875 ; stel: .ent __call_stub_fp_sf_df_sf 876 ; stel: mtc1 $4, $f12 877 ; stel: mtc1 $5, $f13 878 ; stel: mtc1 $6, $f14 879 ; stel: move $18, ${{31|ra}} 880 ; stel: jal sf_df_sf 881 ; stel: mfc1 $2, $f0 882 ; stel: jr $18 883 ; stel: .end __call_stub_fp_sf_df_sf 884 885 declare float @sf_df_df(double, double) #1 886 ; stel: .section .mips16.call.fp.sf_df_df,"ax",@progbits 887 ; stel: .ent __call_stub_fp_sf_df_df 888 ; stel: mtc1 $4, $f12 889 ; stel: mtc1 $5, $f13 890 ; stel: mtc1 $6, $f14 891 ; stel: mtc1 $7, $f15 892 ; stel: move $18, ${{31|ra}} 893 ; stel: jal sf_df_df 894 ; stel: mfc1 $2, $f0 895 ; stel: jr $18 896 ; stel: .end __call_stub_fp_sf_df_df 897 898 declare double @df_v() #1 899 ; stel: .section .mips16.call.fp.df_v,"ax",@progbits 900 ; stel: .ent __call_stub_fp_df_v 901 ; stel: move $18, $31 902 ; stel: jal df_v 903 ; stel: mfc1 $2, $f0 904 ; stel: mfc1 $3, $f1 905 ; stel: jr $18 906 ; stel: .end __call_stub_fp_df_v 907 908 declare double @df_sf(float) #1 909 ; stel: .section .mips16.call.fp.df_sf,"ax",@progbits 910 ; stel: .ent __call_stub_fp_df_sf 911 ; stel: mtc1 $4, $f12 912 ; stel: move $18, ${{31|ra}} 913 ; stel: jal df_sf 914 ; stel: mfc1 $2, $f0 915 ; stel: mfc1 $3, $f1 916 ; stel: jr $18 917 ; stel: .end __call_stub_fp_df_sf 918 919 declare double @df_df(double) #1 920 ; stel: .section .mips16.call.fp.df_df,"ax",@progbits 921 ; stel: .ent __call_stub_fp_df_df 922 ; stel: mtc1 $4, $f12 923 ; stel: mtc1 $5, $f13 924 ; stel: move $18, ${{31|ra}} 925 ; stel: jal df_df 926 ; stel: mfc1 $2, $f0 927 ; stel: mfc1 $3, $f1 928 ; stel: jr $18 929 ; stel: .end __call_stub_fp_df_df 930 931 declare double @df_sf_sf(float, float) #1 932 ; stel: .section .mips16.call.fp.df_sf_sf,"ax",@progbits 933 ; stel: .ent __call_stub_fp_df_sf_sf 934 ; stel: mtc1 $4, $f12 935 ; stel: mtc1 $5, $f14 936 ; stel: move $18, ${{31|ra}} 937 ; stel: jal df_sf_sf 938 ; stel: mfc1 $2, $f0 939 ; stel: mfc1 $3, $f1 940 ; stel: jr $18 941 ; stel: .end __call_stub_fp_df_sf_sf 942 943 declare double @df_sf_df(float, double) #1 944 ; stel: .section .mips16.call.fp.df_sf_df,"ax",@progbits 945 ; stel: .ent __call_stub_fp_df_sf_df 946 ; stel: mtc1 $4, $f12 947 ; stel: mtc1 $6, $f14 948 ; stel: mtc1 $7, $f15 949 ; stel: move $18, ${{31|ra}} 950 ; stel: jal df_sf_df 951 ; stel: mfc1 $2, $f0 952 ; stel: mfc1 $3, $f1 953 ; stel: jr $18 954 ; stel: .end __call_stub_fp_df_sf_df 955 956 declare double @df_df_sf(double, float) #1 957 ; stel: .section .mips16.call.fp.df_df_sf,"ax",@progbits 958 ; stel: .ent __call_stub_fp_df_df_sf 959 ; stel: mtc1 $4, $f12 960 ; stel: mtc1 $5, $f13 961 ; stel: mtc1 $6, $f14 962 ; stel: move $18, ${{31|ra}} 963 ; stel: jal df_df_sf 964 ; stel: mfc1 $2, $f0 965 ; stel: mfc1 $3, $f1 966 ; stel: jr $18 967 ; stel: .end __call_stub_fp_df_df_sf 968 969 declare double @df_df_df(double, double) #1 970 ; stel: .section .mips16.call.fp.df_df_df,"ax",@progbits 971 ; stel: .ent __call_stub_fp_df_df_df 972 ; stel: mtc1 $4, $f12 973 ; stel: mtc1 $5, $f13 974 ; stel: mtc1 $6, $f14 975 ; stel: mtc1 $7, $f15 976 ; stel: move $18, ${{31|ra}} 977 ; stel: jal df_df_df 978 ; stel: mfc1 $2, $f0 979 ; stel: mfc1 $3, $f1 980 ; stel: jr $18 981 ; stel: .end __call_stub_fp_df_df_df 982 983 declare { float, float } @sc_v() #1 984 ; stel: .section .mips16.call.fp.sc_v,"ax",@progbits 985 ; stel: .ent __call_stub_fp_sc_v 986 ; stel: move $18, $31 987 ; stel: jal sc_v 988 ; stel: mfc1 $2, $f0 989 ; stel: mfc1 $3, $f2 990 ; stel: jr $18 991 ; stel: .end __call_stub_fp_sc_v 992 993 declare { float, float } @sc_sf(float) #1 994 ; stel: .section .mips16.call.fp.sc_sf,"ax",@progbits 995 ; stel: .ent __call_stub_fp_sc_sf 996 ; stel: mtc1 $4, $f12 997 ; stel: move $18, ${{31|ra}} 998 ; stel: jal sc_sf 999 ; stel: mfc1 $2, $f0 1000 ; stel: mfc1 $3, $f2 1001 ; stel: jr $18 1002 ; stel: .end __call_stub_fp_sc_sf 1003 1004 declare { double, double } @dc_v() #1 1005 ; stel: .section .mips16.call.fp.dc_v,"ax",@progbits 1006 ; stel: .ent __call_stub_fp_dc_v 1007 ; stel: move $18, $31 1008 ; stel: jal dc_v 1009 ; stel: mfc1 $4, $f2 1010 ; stel: mfc1 $5, $f3 1011 ; stel: mfc1 $2, $f0 1012 ; stel: mfc1 $3, $f1 1013 ; stel: jr $18 1014 ; stel: .end __call_stub_fp_dc_v 1015 1016 declare { double, double } @dc_sf(float) #1 1017 ; stel: .section .mips16.call.fp.dc_sf,"ax",@progbits 1018 ; stel: .ent __call_stub_fp_dc_sf 1019 ; stel: mtc1 $4, $f12 1020 ; stel: move $18, ${{31|ra}} 1021 ; stel: jal dc_sf 1022 ; stel: mfc1 $4, $f2 1023 ; stel: mfc1 $5, $f3 1024 ; stel: mfc1 $2, $f0 1025 ; stel: mfc1 $3, $f1 1026 ; stel: jr $18 1027 ; stel: .end __call_stub_fp_dc_sf 1028 1029 attributes #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" "unsafe-fp-math"="false" "use-soft-float"="false" } 1030 attributes #1 = { "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" "unsafe-fp-math"="false" "use-soft-float"="false" } 1031