| ; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -relocation-model=static < %s | FileCheck %s -check-prefix=stel |
| |
| @x = common global float 0.000000e+00, align 4 |
| @y = common global float 0.000000e+00, align 4 |
| @xd = common global double 0.000000e+00, align 8 |
| @yd = common global double 0.000000e+00, align 8 |
| @xy = common global { float, float } zeroinitializer, align 4 |
| @xyd = common global { double, double } zeroinitializer, align 8 |
| @ret_sf = common global float 0.000000e+00, align 4 |
| @ret_df = common global double 0.000000e+00, align 8 |
| @ret_sc = common global { float, float } zeroinitializer, align 4 |
| @ret_dc = common global { double, double } zeroinitializer, align 8 |
| @lx = common global float 0.000000e+00, align 4 |
| @ly = common global float 0.000000e+00, align 4 |
| @lxd = common global double 0.000000e+00, align 8 |
| @lyd = common global double 0.000000e+00, align 8 |
| @lxy = common global { float, float } zeroinitializer, align 4 |
| @lxyd = common global { double, double } zeroinitializer, align 8 |
| @lret_sf = common global float 0.000000e+00, align 4 |
| @lret_df = common global double 0.000000e+00, align 8 |
| @lret_sc = common global { float, float } zeroinitializer, align 4 |
| @lret_dc = common global { double, double } zeroinitializer, align 8 |
| @.str = private unnamed_addr constant [10 x i8] c"%f %f %i\0A\00", align 1 |
| @.str1 = private unnamed_addr constant [16 x i8] c"%f=%f %f=%f %i\0A\00", align 1 |
| @.str2 = private unnamed_addr constant [22 x i8] c"%f=%f %f=%f %f=%f %i\0A\00", align 1 |
| @.str3 = private unnamed_addr constant [18 x i8] c"%f+%fi=%f+%fi %i\0A\00", align 1 |
| @.str4 = private unnamed_addr constant [24 x i8] c"%f+%fi=%f+%fi %f=%f %i\0A\00", align 1 |
| |
| ; Function Attrs: nounwind |
| define void @clear() #0 { |
| entry: |
| store float 1.000000e+00, ptr @x, align 4 |
| store float 1.000000e+00, ptr @y, align 4 |
| store double 1.000000e+00, ptr @xd, align 8 |
| store double 1.000000e+00, ptr @yd, align 8 |
| store float 1.000000e+00, ptr getelementptr inbounds ({ float, float }, ptr @xy, i32 0, i32 0) |
| store float 0.000000e+00, ptr getelementptr inbounds ({ float, float }, ptr @xy, i32 0, i32 1) |
| store double 1.000000e+00, ptr getelementptr inbounds ({ double, double }, ptr @xyd, i32 0, i32 0) |
| store double 0.000000e+00, ptr getelementptr inbounds ({ double, double }, ptr @xyd, i32 0, i32 1) |
| store float 1.000000e+00, ptr @ret_sf, align 4 |
| store double 1.000000e+00, ptr @ret_df, align 8 |
| store float 1.000000e+00, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 0) |
| store float 0.000000e+00, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 1) |
| store double 1.000000e+00, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 0) |
| store double 0.000000e+00, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 1) |
| store float 0.000000e+00, ptr @lx, align 4 |
| store float 0.000000e+00, ptr @ly, align 4 |
| store double 0.000000e+00, ptr @lxd, align 8 |
| store double 0.000000e+00, ptr @lyd, align 8 |
| store float 0.000000e+00, ptr getelementptr inbounds ({ float, float }, ptr @lxy, i32 0, i32 0) |
| store float 0.000000e+00, ptr getelementptr inbounds ({ float, float }, ptr @lxy, i32 0, i32 1) |
| store double 0.000000e+00, ptr getelementptr inbounds ({ double, double }, ptr @lxyd, i32 0, i32 0) |
| store double 0.000000e+00, ptr getelementptr inbounds ({ double, double }, ptr @lxyd, i32 0, i32 1) |
| store float 0.000000e+00, ptr @lret_sf, align 4 |
| store double 0.000000e+00, ptr @lret_df, align 8 |
| store float 0.000000e+00, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 0) |
| store float 0.000000e+00, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 1) |
| store double 0.000000e+00, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 0) |
| store double 0.000000e+00, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 1) |
| ret void |
| } |
| |
| ; Function Attrs: nounwind |
| define i32 @main() #0 { |
| entry: |
| %retval = alloca i32, align 4 |
| store i32 0, ptr %retval |
| call void @clear() |
| store float 1.500000e+00, ptr @lx, align 4 |
| %0 = load float, ptr @lx, align 4 |
| call void @v_sf(float %0) |
| %1 = load float, ptr @x, align 4 |
| %conv = fpext float %1 to double |
| %2 = load float, ptr @lx, align 4 |
| %conv1 = fpext float %2 to double |
| %3 = load float, ptr @x, align 4 |
| %4 = load float, ptr @lx, align 4 |
| %cmp = fcmp oeq float %3, %4 |
| %conv2 = zext i1 %cmp to i32 |
| %call = call i32 (ptr, ...) @printf(ptr @.str, double %conv, double %conv1, i32 %conv2) |
| call void @clear() |
| store double 0x41678C29C0000000, ptr @lxd, align 8 |
| %5 = load double, ptr @lxd, align 8 |
| call void @v_df(double %5) |
| %6 = load double, ptr @xd, align 8 |
| %7 = load double, ptr @lxd, align 8 |
| %8 = load double, ptr @xd, align 8 |
| %9 = load double, ptr @lxd, align 8 |
| %cmp3 = fcmp oeq double %8, %9 |
| %conv4 = zext i1 %cmp3 to i32 |
| %call5 = call i32 (ptr, ...) @printf(ptr @.str, double %6, double %7, i32 %conv4) |
| call void @clear() |
| store float 9.000000e+00, ptr @lx, align 4 |
| store float 1.000000e+01, ptr @ly, align 4 |
| %10 = load float, ptr @lx, align 4 |
| %11 = load float, ptr @ly, align 4 |
| call void @v_sf_sf(float %10, float %11) |
| %12 = load float, ptr @x, align 4 |
| %conv6 = fpext float %12 to double |
| %13 = load float, ptr @lx, align 4 |
| %conv7 = fpext float %13 to double |
| %14 = load float, ptr @y, align 4 |
| %conv8 = fpext float %14 to double |
| %15 = load float, ptr @ly, align 4 |
| %conv9 = fpext float %15 to double |
| %16 = load float, ptr @x, align 4 |
| %17 = load float, ptr @lx, align 4 |
| %cmp10 = fcmp oeq float %16, %17 |
| br i1 %cmp10, label %land.rhs, label %land.end |
| |
| land.rhs: ; preds = %entry |
| %18 = load float, ptr @y, align 4 |
| %19 = load float, ptr @ly, align 4 |
| %cmp12 = fcmp oeq float %18, %19 |
| br label %land.end |
| |
| land.end: ; preds = %land.rhs, %entry |
| %20 = phi i1 [ false, %entry ], [ %cmp12, %land.rhs ] |
| %land.ext = zext i1 %20 to i32 |
| %call14 = call i32 (ptr, ...) @printf(ptr @.str1, double %conv6, double %conv7, double %conv8, double %conv9, i32 %land.ext) |
| call void @clear() |
| store float 0x3FFE666660000000, ptr @lx, align 4 |
| store double 0x4007E613249FF279, ptr @lyd, align 8 |
| %21 = load float, ptr @lx, align 4 |
| %22 = load double, ptr @lyd, align 8 |
| call void @v_sf_df(float %21, double %22) |
| %23 = load float, ptr @x, align 4 |
| %conv15 = fpext float %23 to double |
| %24 = load float, ptr @lx, align 4 |
| %conv16 = fpext float %24 to double |
| %25 = load double, ptr @yd, align 8 |
| %26 = load double, ptr @lyd, align 8 |
| %27 = load float, ptr @x, align 4 |
| %28 = load float, ptr @lx, align 4 |
| %cmp17 = fcmp oeq float %27, %28 |
| %conv18 = zext i1 %cmp17 to i32 |
| %29 = load double, ptr @yd, align 8 |
| %30 = load double, ptr @lyd, align 8 |
| %cmp19 = fcmp oeq double %29, %30 |
| %conv20 = zext i1 %cmp19 to i32 |
| %and = and i32 %conv18, %conv20 |
| %call21 = call i32 (ptr, ...) @printf(ptr @.str1, double %conv15, double %conv16, double %25, double %26, i32 %and) |
| call void @clear() |
| store double 0x4194E54F94000000, ptr @lxd, align 8 |
| store float 7.600000e+01, ptr @ly, align 4 |
| %31 = load double, ptr @lxd, align 8 |
| %32 = load float, ptr @ly, align 4 |
| call void @v_df_sf(double %31, float %32) |
| %33 = load double, ptr @xd, align 8 |
| %34 = load double, ptr @lxd, align 8 |
| %35 = load float, ptr @y, align 4 |
| %conv22 = fpext float %35 to double |
| %36 = load float, ptr @ly, align 4 |
| %conv23 = fpext float %36 to double |
| %37 = load double, ptr @xd, align 8 |
| %38 = load double, ptr @lxd, align 8 |
| %cmp24 = fcmp oeq double %37, %38 |
| %conv25 = zext i1 %cmp24 to i32 |
| %39 = load float, ptr @y, align 4 |
| %40 = load float, ptr @ly, align 4 |
| %cmp26 = fcmp oeq float %39, %40 |
| %conv27 = zext i1 %cmp26 to i32 |
| %and28 = and i32 %conv25, %conv27 |
| %call29 = call i32 (ptr, ...) @printf(ptr @.str1, double %33, double %34, double %conv22, double %conv23, i32 %and28) |
| call void @clear() |
| store double 7.365198e+07, ptr @lxd, align 8 |
| store double 0x416536CD80000000, ptr @lyd, align 8 |
| %41 = load double, ptr @lxd, align 8 |
| %42 = load double, ptr @lyd, align 8 |
| call void @v_df_df(double %41, double %42) |
| %43 = load double, ptr @xd, align 8 |
| %44 = load double, ptr @lxd, align 8 |
| %45 = load double, ptr @yd, align 8 |
| %46 = load double, ptr @lyd, align 8 |
| %47 = load double, ptr @xd, align 8 |
| %48 = load double, ptr @lxd, align 8 |
| %cmp30 = fcmp oeq double %47, %48 |
| %conv31 = zext i1 %cmp30 to i32 |
| %49 = load double, ptr @yd, align 8 |
| %50 = load double, ptr @lyd, align 8 |
| %cmp32 = fcmp oeq double %49, %50 |
| %conv33 = zext i1 %cmp32 to i32 |
| %and34 = and i32 %conv31, %conv33 |
| %call35 = call i32 (ptr, ...) @printf(ptr @.str1, double %43, double %44, double %45, double %46, i32 %and34) |
| call void @clear() |
| store float 0x4016666660000000, ptr @ret_sf, align 4 |
| %call36 = call float @sf_v() |
| store float %call36, ptr @lret_sf, align 4 |
| %51 = load float, ptr @ret_sf, align 4 |
| %conv37 = fpext float %51 to double |
| %52 = load float, ptr @lret_sf, align 4 |
| %conv38 = fpext float %52 to double |
| %53 = load float, ptr @ret_sf, align 4 |
| %54 = load float, ptr @lret_sf, align 4 |
| %cmp39 = fcmp oeq float %53, %54 |
| %conv40 = zext i1 %cmp39 to i32 |
| %call41 = call i32 (ptr, ...) @printf(ptr @.str, double %conv37, double %conv38, i32 %conv40) |
| call void @clear() |
| store float 4.587300e+06, ptr @ret_sf, align 4 |
| store float 3.420000e+02, ptr @lx, align 4 |
| %55 = load float, ptr @lx, align 4 |
| %call42 = call float @sf_sf(float %55) |
| store float %call42, ptr @lret_sf, align 4 |
| %56 = load float, ptr @ret_sf, align 4 |
| %conv43 = fpext float %56 to double |
| %57 = load float, ptr @lret_sf, align 4 |
| %conv44 = fpext float %57 to double |
| %58 = load float, ptr @x, align 4 |
| %conv45 = fpext float %58 to double |
| %59 = load float, ptr @lx, align 4 |
| %conv46 = fpext float %59 to double |
| %60 = load float, ptr @ret_sf, align 4 |
| %61 = load float, ptr @lret_sf, align 4 |
| %cmp47 = fcmp oeq float %60, %61 |
| %conv48 = zext i1 %cmp47 to i32 |
| %62 = load float, ptr @x, align 4 |
| %63 = load float, ptr @lx, align 4 |
| %cmp49 = fcmp oeq float %62, %63 |
| %conv50 = zext i1 %cmp49 to i32 |
| %and51 = and i32 %conv48, %conv50 |
| %call52 = call i32 (ptr, ...) @printf(ptr @.str1, double %conv43, double %conv44, double %conv45, double %conv46, i32 %and51) |
| call void @clear() |
| store float 4.445910e+06, ptr @ret_sf, align 4 |
| store double 0x419A7DB294000000, ptr @lxd, align 8 |
| %64 = load double, ptr @lxd, align 8 |
| %call53 = call float @sf_df(double %64) |
| store float %call53, ptr @lret_sf, align 4 |
| %65 = load float, ptr @ret_sf, align 4 |
| %conv54 = fpext float %65 to double |
| %66 = load float, ptr @lret_sf, align 4 |
| %conv55 = fpext float %66 to double |
| %67 = load double, ptr @xd, align 8 |
| %68 = load double, ptr @lxd, align 8 |
| %69 = load float, ptr @ret_sf, align 4 |
| %70 = load float, ptr @lret_sf, align 4 |
| %cmp56 = fcmp oeq float %69, %70 |
| %conv57 = zext i1 %cmp56 to i32 |
| %71 = load double, ptr @xd, align 8 |
| %72 = load double, ptr @lxd, align 8 |
| %cmp58 = fcmp oeq double %71, %72 |
| %conv59 = zext i1 %cmp58 to i32 |
| %and60 = and i32 %conv57, %conv59 |
| %call61 = call i32 (ptr, ...) @printf(ptr @.str1, double %conv54, double %conv55, double %67, double %68, i32 %and60) |
| call void @clear() |
| store float 0x3FFF4BC6A0000000, ptr @ret_sf, align 4 |
| store float 4.445500e+03, ptr @lx, align 4 |
| store float 0x4068ACCCC0000000, ptr @ly, align 4 |
| %73 = load float, ptr @lx, align 4 |
| %74 = load float, ptr @ly, align 4 |
| %call62 = call float @sf_sf_sf(float %73, float %74) |
| store float %call62, ptr @lret_sf, align 4 |
| %75 = load float, ptr @ret_sf, align 4 |
| %conv63 = fpext float %75 to double |
| %76 = load float, ptr @lret_sf, align 4 |
| %conv64 = fpext float %76 to double |
| %77 = load float, ptr @x, align 4 |
| %conv65 = fpext float %77 to double |
| %78 = load float, ptr @lx, align 4 |
| %conv66 = fpext float %78 to double |
| %79 = load float, ptr @y, align 4 |
| %conv67 = fpext float %79 to double |
| %80 = load float, ptr @ly, align 4 |
| %conv68 = fpext float %80 to double |
| %81 = load float, ptr @ret_sf, align 4 |
| %82 = load float, ptr @lret_sf, align 4 |
| %cmp69 = fcmp oeq float %81, %82 |
| br i1 %cmp69, label %land.lhs.true, label %land.end76 |
| |
| land.lhs.true: ; preds = %land.end |
| %83 = load float, ptr @x, align 4 |
| %84 = load float, ptr @lx, align 4 |
| %cmp71 = fcmp oeq float %83, %84 |
| br i1 %cmp71, label %land.rhs73, label %land.end76 |
| |
| land.rhs73: ; preds = %land.lhs.true |
| %85 = load float, ptr @y, align 4 |
| %86 = load float, ptr @ly, align 4 |
| %cmp74 = fcmp oeq float %85, %86 |
| br label %land.end76 |
| |
| land.end76: ; preds = %land.rhs73, %land.lhs.true, %land.end |
| %87 = phi i1 [ false, %land.lhs.true ], [ false, %land.end ], [ %cmp74, %land.rhs73 ] |
| %land.ext77 = zext i1 %87 to i32 |
| %call78 = call i32 (ptr, ...) @printf(ptr @.str2, double %conv63, double %conv64, double %conv65, double %conv66, double %conv67, double %conv68, i32 %land.ext77) |
| call void @clear() |
| store float 9.991300e+04, ptr @ret_sf, align 4 |
| store float 1.114500e+04, ptr @lx, align 4 |
| store double 9.994445e+07, ptr @lyd, align 8 |
| %88 = load float, ptr @lx, align 4 |
| %89 = load double, ptr @lyd, align 8 |
| %call79 = call float @sf_sf_df(float %88, double %89) |
| store float %call79, ptr @lret_sf, align 4 |
| %90 = load float, ptr @ret_sf, align 4 |
| %conv80 = fpext float %90 to double |
| %91 = load float, ptr @lret_sf, align 4 |
| %conv81 = fpext float %91 to double |
| %92 = load float, ptr @x, align 4 |
| %conv82 = fpext float %92 to double |
| %93 = load float, ptr @lx, align 4 |
| %conv83 = fpext float %93 to double |
| %94 = load double, ptr @yd, align 8 |
| %95 = load double, ptr @lyd, align 8 |
| %96 = load float, ptr @ret_sf, align 4 |
| %97 = load float, ptr @lret_sf, align 4 |
| %cmp84 = fcmp oeq float %96, %97 |
| br i1 %cmp84, label %land.lhs.true86, label %land.end92 |
| |
| land.lhs.true86: ; preds = %land.end76 |
| %98 = load float, ptr @x, align 4 |
| %99 = load float, ptr @lx, align 4 |
| %cmp87 = fcmp oeq float %98, %99 |
| br i1 %cmp87, label %land.rhs89, label %land.end92 |
| |
| land.rhs89: ; preds = %land.lhs.true86 |
| %100 = load double, ptr @yd, align 8 |
| %101 = load double, ptr @lyd, align 8 |
| %cmp90 = fcmp oeq double %100, %101 |
| br label %land.end92 |
| |
| land.end92: ; preds = %land.rhs89, %land.lhs.true86, %land.end76 |
| %102 = phi i1 [ false, %land.lhs.true86 ], [ false, %land.end76 ], [ %cmp90, %land.rhs89 ] |
| %land.ext93 = zext i1 %102 to i32 |
| %call94 = call i32 (ptr, ...) @printf(ptr @.str2, double %conv80, double %conv81, double %conv82, double %conv83, double %94, double %95, i32 %land.ext93) |
| call void @clear() |
| store float 0x417CCC7A00000000, ptr @ret_sf, align 4 |
| store double 0x4172034530000000, ptr @lxd, align 8 |
| store float 4.456200e+04, ptr @ly, align 4 |
| %103 = load double, ptr @lxd, align 8 |
| %104 = load float, ptr @ly, align 4 |
| %call95 = call float @sf_df_sf(double %103, float %104) |
| store float %call95, ptr @lret_sf, align 4 |
| %105 = load float, ptr @ret_sf, align 4 |
| %conv96 = fpext float %105 to double |
| %106 = load float, ptr @lret_sf, align 4 |
| %conv97 = fpext float %106 to double |
| %107 = load double, ptr @xd, align 8 |
| %108 = load double, ptr @lxd, align 8 |
| %109 = load float, ptr @y, align 4 |
| %conv98 = fpext float %109 to double |
| %110 = load float, ptr @ly, align 4 |
| %conv99 = fpext float %110 to double |
| %111 = load float, ptr @ret_sf, align 4 |
| %112 = load float, ptr @lret_sf, align 4 |
| %cmp100 = fcmp oeq float %111, %112 |
| br i1 %cmp100, label %land.lhs.true102, label %land.end108 |
| |
| land.lhs.true102: ; preds = %land.end92 |
| %113 = load double, ptr @xd, align 8 |
| %114 = load double, ptr @lxd, align 8 |
| %cmp103 = fcmp oeq double %113, %114 |
| br i1 %cmp103, label %land.rhs105, label %land.end108 |
| |
| land.rhs105: ; preds = %land.lhs.true102 |
| %115 = load float, ptr @y, align 4 |
| %116 = load float, ptr @ly, align 4 |
| %cmp106 = fcmp oeq float %115, %116 |
| br label %land.end108 |
| |
| land.end108: ; preds = %land.rhs105, %land.lhs.true102, %land.end92 |
| %117 = phi i1 [ false, %land.lhs.true102 ], [ false, %land.end92 ], [ %cmp106, %land.rhs105 ] |
| %land.ext109 = zext i1 %117 to i32 |
| %call110 = call i32 (ptr, ...) @printf(ptr @.str2, double %conv96, double %conv97, double %107, double %108, double %conv98, double %conv99, i32 %land.ext109) |
| call void @clear() |
| store float 3.987721e+06, ptr @ret_sf, align 4 |
| store double 0x3FF1F49F6DDDC2D8, ptr @lxd, align 8 |
| store double 0x409129F306A2B170, ptr @lyd, align 8 |
| %118 = load double, ptr @lxd, align 8 |
| %119 = load double, ptr @lyd, align 8 |
| %call111 = call float @sf_df_df(double %118, double %119) |
| store float %call111, ptr @lret_sf, align 4 |
| %120 = load float, ptr @ret_sf, align 4 |
| %conv112 = fpext float %120 to double |
| %121 = load float, ptr @lret_sf, align 4 |
| %conv113 = fpext float %121 to double |
| %122 = load double, ptr @xd, align 8 |
| %123 = load double, ptr @lxd, align 8 |
| %124 = load double, ptr @yd, align 8 |
| %125 = load double, ptr @lyd, align 8 |
| %126 = load float, ptr @ret_sf, align 4 |
| %127 = load float, ptr @lret_sf, align 4 |
| %cmp114 = fcmp oeq float %126, %127 |
| br i1 %cmp114, label %land.lhs.true116, label %land.end122 |
| |
| land.lhs.true116: ; preds = %land.end108 |
| %128 = load double, ptr @xd, align 8 |
| %129 = load double, ptr @lxd, align 8 |
| %cmp117 = fcmp oeq double %128, %129 |
| br i1 %cmp117, label %land.rhs119, label %land.end122 |
| |
| land.rhs119: ; preds = %land.lhs.true116 |
| %130 = load double, ptr @yd, align 8 |
| %131 = load double, ptr @lyd, align 8 |
| %cmp120 = fcmp oeq double %130, %131 |
| br label %land.end122 |
| |
| land.end122: ; preds = %land.rhs119, %land.lhs.true116, %land.end108 |
| %132 = phi i1 [ false, %land.lhs.true116 ], [ false, %land.end108 ], [ %cmp120, %land.rhs119 ] |
| %land.ext123 = zext i1 %132 to i32 |
| %call124 = call i32 (ptr, ...) @printf(ptr @.str2, double %conv112, double %conv113, double %122, double %123, double %124, double %125, i32 %land.ext123) |
| call void @clear() |
| store double 1.561234e+01, ptr @ret_df, align 8 |
| %call125 = call double @df_v() |
| store double %call125, ptr @lret_df, align 8 |
| %133 = load double, ptr @ret_df, align 8 |
| %134 = load double, ptr @lret_df, align 8 |
| %135 = load double, ptr @ret_df, align 8 |
| %136 = load double, ptr @lret_df, align 8 |
| %cmp126 = fcmp oeq double %135, %136 |
| %conv127 = zext i1 %cmp126 to i32 |
| %call128 = call i32 (ptr, ...) @printf(ptr @.str, double %133, double %134, i32 %conv127) |
| call void @clear() |
| store double 1.345873e+01, ptr @ret_df, align 8 |
| store float 3.434520e+05, ptr @lx, align 4 |
| %137 = load float, ptr @lx, align 4 |
| %call129 = call double @df_sf(float %137) |
| store double %call129, ptr @lret_df, align 8 |
| %138 = load double, ptr @ret_df, align 8 |
| %139 = load double, ptr @lret_df, align 8 |
| %140 = load float, ptr @x, align 4 |
| %conv130 = fpext float %140 to double |
| %141 = load float, ptr @lx, align 4 |
| %conv131 = fpext float %141 to double |
| %142 = load double, ptr @ret_df, align 8 |
| %143 = load double, ptr @lret_df, align 8 |
| %cmp132 = fcmp oeq double %142, %143 |
| %conv133 = zext i1 %cmp132 to i32 |
| %144 = load float, ptr @x, align 4 |
| %145 = load float, ptr @lx, align 4 |
| %cmp134 = fcmp oeq float %144, %145 |
| %conv135 = zext i1 %cmp134 to i32 |
| %and136 = and i32 %conv133, %conv135 |
| %call137 = call i32 (ptr, ...) @printf(ptr @.str1, double %138, double %139, double %conv130, double %conv131, i32 %and136) |
| call void @clear() |
| store double 0x4084F3AB7AA25D8D, ptr @ret_df, align 8 |
| store double 0x4114F671D2F1A9FC, ptr @lxd, align 8 |
| %146 = load double, ptr @lxd, align 8 |
| %call138 = call double @df_df(double %146) |
| store double %call138, ptr @lret_df, align 8 |
| %147 = load double, ptr @ret_df, align 8 |
| %148 = load double, ptr @lret_df, align 8 |
| %149 = load double, ptr @xd, align 8 |
| %150 = load double, ptr @lxd, align 8 |
| %151 = load double, ptr @ret_df, align 8 |
| %152 = load double, ptr @lret_df, align 8 |
| %cmp139 = fcmp oeq double %151, %152 |
| %conv140 = zext i1 %cmp139 to i32 |
| %153 = load double, ptr @xd, align 8 |
| %154 = load double, ptr @lxd, align 8 |
| %cmp141 = fcmp oeq double %153, %154 |
| %conv142 = zext i1 %cmp141 to i32 |
| %and143 = and i32 %conv140, %conv142 |
| %call144 = call i32 (ptr, ...) @printf(ptr @.str1, double %147, double %148, double %149, double %150, i32 %and143) |
| call void @clear() |
| store double 6.781956e+03, ptr @ret_df, align 8 |
| store float 4.445500e+03, ptr @lx, align 4 |
| store float 0x4068ACCCC0000000, ptr @ly, align 4 |
| %155 = load float, ptr @lx, align 4 |
| %156 = load float, ptr @ly, align 4 |
| %call145 = call double @df_sf_sf(float %155, float %156) |
| store double %call145, ptr @lret_df, align 8 |
| %157 = load double, ptr @ret_df, align 8 |
| %158 = load double, ptr @lret_df, align 8 |
| %159 = load float, ptr @x, align 4 |
| %conv146 = fpext float %159 to double |
| %160 = load float, ptr @lx, align 4 |
| %conv147 = fpext float %160 to double |
| %161 = load float, ptr @y, align 4 |
| %conv148 = fpext float %161 to double |
| %162 = load float, ptr @ly, align 4 |
| %conv149 = fpext float %162 to double |
| %163 = load double, ptr @ret_df, align 8 |
| %164 = load double, ptr @lret_df, align 8 |
| %cmp150 = fcmp oeq double %163, %164 |
| br i1 %cmp150, label %land.lhs.true152, label %land.end158 |
| |
| land.lhs.true152: ; preds = %land.end122 |
| %165 = load float, ptr @x, align 4 |
| %166 = load float, ptr @lx, align 4 |
| %cmp153 = fcmp oeq float %165, %166 |
| br i1 %cmp153, label %land.rhs155, label %land.end158 |
| |
| land.rhs155: ; preds = %land.lhs.true152 |
| %167 = load float, ptr @y, align 4 |
| %168 = load float, ptr @ly, align 4 |
| %cmp156 = fcmp oeq float %167, %168 |
| br label %land.end158 |
| |
| land.end158: ; preds = %land.rhs155, %land.lhs.true152, %land.end122 |
| %169 = phi i1 [ false, %land.lhs.true152 ], [ false, %land.end122 ], [ %cmp156, %land.rhs155 ] |
| %land.ext159 = zext i1 %169 to i32 |
| %call160 = call i32 (ptr, ...) @printf(ptr @.str2, double %157, double %158, double %conv146, double %conv147, double %conv148, double %conv149, i32 %land.ext159) |
| call void @clear() |
| store double 1.889130e+05, ptr @ret_df, align 8 |
| store float 9.111450e+05, ptr @lx, align 4 |
| store double 0x4185320A58000000, ptr @lyd, align 8 |
| %170 = load float, ptr @lx, align 4 |
| %171 = load double, ptr @lyd, align 8 |
| %call161 = call double @df_sf_df(float %170, double %171) |
| store double %call161, ptr @lret_df, align 8 |
| %172 = load double, ptr @ret_df, align 8 |
| %173 = load double, ptr @lret_df, align 8 |
| %174 = load float, ptr @x, align 4 |
| %conv162 = fpext float %174 to double |
| %175 = load float, ptr @lx, align 4 |
| %conv163 = fpext float %175 to double |
| %176 = load double, ptr @yd, align 8 |
| %177 = load double, ptr @lyd, align 8 |
| %178 = load double, ptr @ret_df, align 8 |
| %179 = load double, ptr @lret_df, align 8 |
| %cmp164 = fcmp oeq double %178, %179 |
| br i1 %cmp164, label %land.lhs.true166, label %land.end172 |
| |
| land.lhs.true166: ; preds = %land.end158 |
| %180 = load float, ptr @x, align 4 |
| %181 = load float, ptr @lx, align 4 |
| %cmp167 = fcmp oeq float %180, %181 |
| br i1 %cmp167, label %land.rhs169, label %land.end172 |
| |
| land.rhs169: ; preds = %land.lhs.true166 |
| %182 = load double, ptr @yd, align 8 |
| %183 = load double, ptr @lyd, align 8 |
| %cmp170 = fcmp oeq double %182, %183 |
| br label %land.end172 |
| |
| land.end172: ; preds = %land.rhs169, %land.lhs.true166, %land.end158 |
| %184 = phi i1 [ false, %land.lhs.true166 ], [ false, %land.end158 ], [ %cmp170, %land.rhs169 ] |
| %land.ext173 = zext i1 %184 to i32 |
| %call174 = call i32 (ptr, ...) @printf(ptr @.str2, double %172, double %173, double %conv162, double %conv163, double %176, double %177, i32 %land.ext173) |
| call void @clear() |
| store double 0x418B2DB900000000, ptr @ret_df, align 8 |
| store double 0x41B1EF2ED3000000, ptr @lxd, align 8 |
| store float 1.244562e+06, ptr @ly, align 4 |
| %185 = load double, ptr @lxd, align 8 |
| %186 = load float, ptr @ly, align 4 |
| %call175 = call double @df_df_sf(double %185, float %186) |
| store double %call175, ptr @lret_df, align 8 |
| %187 = load double, ptr @ret_df, align 8 |
| %188 = load double, ptr @lret_df, align 8 |
| %189 = load double, ptr @xd, align 8 |
| %190 = load double, ptr @lxd, align 8 |
| %191 = load float, ptr @y, align 4 |
| %conv176 = fpext float %191 to double |
| %192 = load float, ptr @ly, align 4 |
| %conv177 = fpext float %192 to double |
| %193 = load double, ptr @ret_df, align 8 |
| %194 = load double, ptr @lret_df, align 8 |
| %cmp178 = fcmp oeq double %193, %194 |
| br i1 %cmp178, label %land.lhs.true180, label %land.end186 |
| |
| land.lhs.true180: ; preds = %land.end172 |
| %195 = load double, ptr @xd, align 8 |
| %196 = load double, ptr @lxd, align 8 |
| %cmp181 = fcmp oeq double %195, %196 |
| br i1 %cmp181, label %land.rhs183, label %land.end186 |
| |
| land.rhs183: ; preds = %land.lhs.true180 |
| %197 = load float, ptr @y, align 4 |
| %198 = load float, ptr @ly, align 4 |
| %cmp184 = fcmp oeq float %197, %198 |
| br label %land.end186 |
| |
| land.end186: ; preds = %land.rhs183, %land.lhs.true180, %land.end172 |
| %199 = phi i1 [ false, %land.lhs.true180 ], [ false, %land.end172 ], [ %cmp184, %land.rhs183 ] |
| %land.ext187 = zext i1 %199 to i32 |
| %call188 = call i32 (ptr, ...) @printf(ptr @.str2, double %187, double %188, double %189, double %190, double %conv176, double %conv177, i32 %land.ext187) |
| call void @clear() |
| store double 3.987721e+06, ptr @ret_df, align 8 |
| store double 5.223560e+00, ptr @lxd, align 8 |
| store double 0x40B7D37CC1A8AC5C, ptr @lyd, align 8 |
| %200 = load double, ptr @lxd, align 8 |
| %201 = load double, ptr @lyd, align 8 |
| %call189 = call double @df_df_df(double %200, double %201) |
| store double %call189, ptr @lret_df, align 8 |
| %202 = load double, ptr @ret_df, align 8 |
| %203 = load double, ptr @lret_df, align 8 |
| %204 = load double, ptr @xd, align 8 |
| %205 = load double, ptr @lxd, align 8 |
| %206 = load double, ptr @yd, align 8 |
| %207 = load double, ptr @lyd, align 8 |
| %208 = load double, ptr @ret_df, align 8 |
| %209 = load double, ptr @lret_df, align 8 |
| %cmp190 = fcmp oeq double %208, %209 |
| br i1 %cmp190, label %land.lhs.true192, label %land.end198 |
| |
| land.lhs.true192: ; preds = %land.end186 |
| %210 = load double, ptr @xd, align 8 |
| %211 = load double, ptr @lxd, align 8 |
| %cmp193 = fcmp oeq double %210, %211 |
| br i1 %cmp193, label %land.rhs195, label %land.end198 |
| |
| land.rhs195: ; preds = %land.lhs.true192 |
| %212 = load double, ptr @yd, align 8 |
| %213 = load double, ptr @lyd, align 8 |
| %cmp196 = fcmp oeq double %212, %213 |
| br label %land.end198 |
| |
| land.end198: ; preds = %land.rhs195, %land.lhs.true192, %land.end186 |
| %214 = phi i1 [ false, %land.lhs.true192 ], [ false, %land.end186 ], [ %cmp196, %land.rhs195 ] |
| %land.ext199 = zext i1 %214 to i32 |
| %call200 = call i32 (ptr, ...) @printf(ptr @.str2, double %202, double %203, double %204, double %205, double %206, double %207, i32 %land.ext199) |
| call void @clear() |
| store float 4.500000e+00, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 0) |
| store float 7.000000e+00, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 1) |
| %call201 = call { float, float } @sc_v() |
| %215 = extractvalue { float, float } %call201, 0 |
| %216 = extractvalue { float, float } %call201, 1 |
| store float %215, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 0) |
| store float %216, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 1) |
| %ret_sc.real = load float, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 0) |
| %ret_sc.imag = load float, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 1) |
| %conv202 = fpext float %ret_sc.real to double |
| %conv203 = fpext float %ret_sc.imag to double |
| %ret_sc.real204 = load float, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 0) |
| %ret_sc.imag205 = load float, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 1) |
| %conv206 = fpext float %ret_sc.real204 to double |
| %conv207 = fpext float %ret_sc.imag205 to double |
| %lret_sc.real = load float, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 0) |
| %lret_sc.imag = load float, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 1) |
| %conv208 = fpext float %lret_sc.real to double |
| %conv209 = fpext float %lret_sc.imag to double |
| %lret_sc.real210 = load float, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 0) |
| %lret_sc.imag211 = load float, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 1) |
| %conv212 = fpext float %lret_sc.real210 to double |
| %conv213 = fpext float %lret_sc.imag211 to double |
| %ret_sc.real214 = load float, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 0) |
| %ret_sc.imag215 = load float, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 1) |
| %lret_sc.real216 = load float, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 0) |
| %lret_sc.imag217 = load float, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 1) |
| %cmp.r = fcmp oeq float %ret_sc.real214, %lret_sc.real216 |
| %cmp.i = fcmp oeq float %ret_sc.imag215, %lret_sc.imag217 |
| %and.ri = and i1 %cmp.r, %cmp.i |
| %conv218 = zext i1 %and.ri to i32 |
| %call219 = call i32 (ptr, ...) @printf(ptr @.str3, double %conv202, double %conv207, double %conv208, double %conv213, i32 %conv218) |
| call void @clear() |
| store float 0x3FF7A99300000000, ptr @lx, align 4 |
| store float 4.500000e+00, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 0) |
| store float 7.000000e+00, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 1) |
| %217 = load float, ptr @lx, align 4 |
| %call220 = call { float, float } @sc_sf(float %217) |
| %218 = extractvalue { float, float } %call220, 0 |
| %219 = extractvalue { float, float } %call220, 1 |
| store float %218, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 0) |
| store float %219, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 1) |
| %ret_sc.real221 = load float, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 0) |
| %ret_sc.imag222 = load float, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 1) |
| %conv223 = fpext float %ret_sc.real221 to double |
| %conv224 = fpext float %ret_sc.imag222 to double |
| %ret_sc.real225 = load float, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 0) |
| %ret_sc.imag226 = load float, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 1) |
| %conv227 = fpext float %ret_sc.real225 to double |
| %conv228 = fpext float %ret_sc.imag226 to double |
| %lret_sc.real229 = load float, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 0) |
| %lret_sc.imag230 = load float, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 1) |
| %conv231 = fpext float %lret_sc.real229 to double |
| %conv232 = fpext float %lret_sc.imag230 to double |
| %lret_sc.real233 = load float, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 0) |
| %lret_sc.imag234 = load float, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 1) |
| %conv235 = fpext float %lret_sc.real233 to double |
| %conv236 = fpext float %lret_sc.imag234 to double |
| %220 = load float, ptr @x, align 4 |
| %conv237 = fpext float %220 to double |
| %221 = load float, ptr @lx, align 4 |
| %conv238 = fpext float %221 to double |
| %ret_sc.real239 = load float, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 0) |
| %ret_sc.imag240 = load float, ptr getelementptr inbounds ({ float, float }, ptr @ret_sc, i32 0, i32 1) |
| %lret_sc.real241 = load float, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 0) |
| %lret_sc.imag242 = load float, ptr getelementptr inbounds ({ float, float }, ptr @lret_sc, i32 0, i32 1) |
| %cmp.r243 = fcmp oeq float %ret_sc.real239, %lret_sc.real241 |
| %cmp.i244 = fcmp oeq float %ret_sc.imag240, %lret_sc.imag242 |
| %and.ri245 = and i1 %cmp.r243, %cmp.i244 |
| br i1 %and.ri245, label %land.rhs247, label %land.end250 |
| |
| land.rhs247: ; preds = %land.end198 |
| %222 = load float, ptr @x, align 4 |
| %223 = load float, ptr @lx, align 4 |
| %cmp248 = fcmp oeq float %222, %223 |
| br label %land.end250 |
| |
| land.end250: ; preds = %land.rhs247, %land.end198 |
| %224 = phi i1 [ false, %land.end198 ], [ %cmp248, %land.rhs247 ] |
| %land.ext251 = zext i1 %224 to i32 |
| %call252 = call i32 (ptr, ...) @printf(ptr @.str4, double %conv223, double %conv228, double %conv231, double %conv236, double %conv237, double %conv238, i32 %land.ext251) |
| call void @clear() |
| store double 1.234500e+03, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 0) |
| store double 7.677000e+03, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 1) |
| %call253 = call { double, double } @dc_v() |
| %225 = extractvalue { double, double } %call253, 0 |
| %226 = extractvalue { double, double } %call253, 1 |
| store double %225, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 0) |
| store double %226, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 1) |
| %ret_dc.real = load double, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 0) |
| %ret_dc.imag = load double, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 1) |
| %ret_dc.real254 = load double, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 0) |
| %ret_dc.imag255 = load double, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 1) |
| %lret_dc.real = load double, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 0) |
| %lret_dc.imag = load double, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 1) |
| %lret_dc.real256 = load double, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 0) |
| %lret_dc.imag257 = load double, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 1) |
| %ret_dc.real258 = load double, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 0) |
| %ret_dc.imag259 = load double, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 1) |
| %lret_dc.real260 = load double, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 0) |
| %lret_dc.imag261 = load double, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 1) |
| %cmp.r262 = fcmp oeq double %ret_dc.real258, %lret_dc.real260 |
| %cmp.i263 = fcmp oeq double %ret_dc.imag259, %lret_dc.imag261 |
| %and.ri264 = and i1 %cmp.r262, %cmp.i263 |
| %conv265 = zext i1 %and.ri264 to i32 |
| %call266 = call i32 (ptr, ...) @printf(ptr @.str3, double %ret_dc.real, double %ret_dc.imag255, double %lret_dc.real, double %lret_dc.imag257, i32 %conv265) |
| call void @clear() |
| store double 0x40AAF6F532617C1C, ptr @lxd, align 8 |
| store double 4.444500e+03, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 0) |
| store double 7.888000e+03, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 1) |
| %227 = load float, ptr @lx, align 4 |
| %call267 = call { double, double } @dc_sf(float %227) |
| %228 = extractvalue { double, double } %call267, 0 |
| %229 = extractvalue { double, double } %call267, 1 |
| store double %228, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 0) |
| store double %229, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 1) |
| %ret_dc.real268 = load double, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 0) |
| %ret_dc.imag269 = load double, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 1) |
| %ret_dc.real270 = load double, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 0) |
| %ret_dc.imag271 = load double, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 1) |
| %lret_dc.real272 = load double, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 0) |
| %lret_dc.imag273 = load double, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 1) |
| %lret_dc.real274 = load double, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 0) |
| %lret_dc.imag275 = load double, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 1) |
| %230 = load float, ptr @x, align 4 |
| %conv276 = fpext float %230 to double |
| %231 = load float, ptr @lx, align 4 |
| %conv277 = fpext float %231 to double |
| %ret_dc.real278 = load double, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 0) |
| %ret_dc.imag279 = load double, ptr getelementptr inbounds ({ double, double }, ptr @ret_dc, i32 0, i32 1) |
| %lret_dc.real280 = load double, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 0) |
| %lret_dc.imag281 = load double, ptr getelementptr inbounds ({ double, double }, ptr @lret_dc, i32 0, i32 1) |
| %cmp.r282 = fcmp oeq double %ret_dc.real278, %lret_dc.real280 |
| %cmp.i283 = fcmp oeq double %ret_dc.imag279, %lret_dc.imag281 |
| %and.ri284 = and i1 %cmp.r282, %cmp.i283 |
| br i1 %and.ri284, label %land.rhs286, label %land.end289 |
| |
| land.rhs286: ; preds = %land.end250 |
| %232 = load float, ptr @x, align 4 |
| %233 = load float, ptr @lx, align 4 |
| %cmp287 = fcmp oeq float %232, %233 |
| br label %land.end289 |
| |
| land.end289: ; preds = %land.rhs286, %land.end250 |
| %234 = phi i1 [ false, %land.end250 ], [ %cmp287, %land.rhs286 ] |
| %land.ext290 = zext i1 %234 to i32 |
| %call291 = call i32 (ptr, ...) @printf(ptr @.str4, double %ret_dc.real268, double %ret_dc.imag271, double %lret_dc.real272, double %lret_dc.imag275, double %conv276, double %conv277, i32 %land.ext290) |
| %235 = load i32, ptr %retval |
| ret i32 %235 |
| } |
| |
| declare void @v_sf(float) #1 |
| ; stel: .section .mips16.call.fp.v_sf,"ax",@progbits |
| ; stel: .ent __call_stub_fp_v_sf |
| ; stel: mtc1 $4, $f12 |
| ; stel: lui $25, %hi(v_sf) |
| ; stel: addiu $25, $25, %lo(v_sf) |
| ; stel: jr $25 |
| ; stel: .end __call_stub_fp_v_sf |
| |
| declare i32 @printf(ptr, ...) #1 |
| |
| declare void @v_df(double) #1 |
| ; stel: .section .mips16.call.fp.v_df,"ax",@progbits |
| ; stel: .ent __call_stub_fp_v_df |
| ; stel: #APP |
| ; stel: .set reorder |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $5, $f13 |
| ; stel: lui $25, %hi(v_df) |
| ; stel: addiu $25, $25, %lo(v_df) |
| ; stel: jr $25 |
| ; stel: .end __call_stub_fp_v_df |
| |
| declare void @v_sf_sf(float, float) #1 |
| ; stel: .section .mips16.call.fp.v_sf_sf,"ax",@progbits |
| ; stel: .ent __call_stub_fp_v_sf_sf |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $5, $f14 |
| ; stel: lui $25, %hi(v_sf_sf) |
| ; stel: addiu $25, $25, %lo(v_sf_sf) |
| ; stel: jr $25 |
| ; stel: .end __call_stub_fp_v_sf_sf |
| |
| declare void @v_sf_df(float, double) #1 |
| ; stel: .section .mips16.call.fp.v_sf_df,"ax",@progbits |
| ; stel: .ent __call_stub_fp_v_sf_df |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $6, $f14 |
| ; stel: mtc1 $7, $f15 |
| ; stel: lui $25, %hi(v_sf_df) |
| ; stel: addiu $25, $25, %lo(v_sf_df) |
| ; stel: jr $25 |
| ; stel: .end __call_stub_fp_v_sf_df |
| |
| declare void @v_df_sf(double, float) #1 |
| ; stel: .section .mips16.call.fp.v_df_sf,"ax",@progbits |
| ; stel: .ent __call_stub_fp_v_df_sf |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $5, $f13 |
| ; stel: mtc1 $6, $f14 |
| ; stel: lui $25, %hi(v_df_sf) |
| ; stel: addiu $25, $25, %lo(v_df_sf) |
| ; stel: jr $25 |
| ; stel: .end __call_stub_fp_v_df_sf |
| |
| declare void @v_df_df(double, double) #1 |
| ; stel: .section .mips16.call.fp.v_df_df,"ax",@progbits |
| ; stel: .ent __call_stub_fp_v_df_df |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $5, $f13 |
| ; stel: mtc1 $6, $f14 |
| ; stel: mtc1 $7, $f15 |
| ; stel: lui $25, %hi(v_df_df) |
| ; stel: addiu $25, $25, %lo(v_df_df) |
| ; stel: jr $25 |
| ; stel: .end __call_stub_fp_v_df_df |
| |
| declare float @sf_v() #1 |
| ; stel: .section .mips16.call.fp.sf_v,"ax",@progbits |
| ; stel: .ent __call_stub_fp_sf_v |
| ; stel: move $18, $ra |
| ; stel: jal sf_v |
| ; stel: mfc1 $2, $f0 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_sf_v |
| |
| declare float @sf_sf(float) #1 |
| ; stel: .section .mips16.call.fp.sf_sf,"ax",@progbits |
| ; stel: .ent __call_stub_fp_sf_sf |
| ; stel: mtc1 $4, $f12 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal sf_sf |
| ; stel: mfc1 $2, $f0 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_sf_sf |
| |
| declare float @sf_df(double) #1 |
| ; stel: .section .mips16.call.fp.sf_df,"ax",@progbits |
| ; stel: .ent __call_stub_fp_sf_df |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $5, $f13 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal sf_df |
| ; stel: mfc1 $2, $f0 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_sf_df |
| |
| declare float @sf_sf_sf(float, float) #1 |
| ; stel: .section .mips16.call.fp.sf_sf_sf,"ax",@progbits |
| ; stel: .ent __call_stub_fp_sf_sf_sf |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $5, $f14 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal sf_sf_sf |
| ; stel: mfc1 $2, $f0 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_sf_sf_sf |
| |
| declare float @sf_sf_df(float, double) #1 |
| ; stel: .section .mips16.call.fp.sf_sf_df,"ax",@progbits |
| ; stel: .ent __call_stub_fp_sf_sf_df |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $6, $f14 |
| ; stel: mtc1 $7, $f15 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal sf_sf_df |
| ; stel: mfc1 $2, $f0 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_sf_sf_df |
| |
| declare float @sf_df_sf(double, float) #1 |
| ; stel: .section .mips16.call.fp.sf_df_sf,"ax",@progbits |
| ; stel: .ent __call_stub_fp_sf_df_sf |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $5, $f13 |
| ; stel: mtc1 $6, $f14 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal sf_df_sf |
| ; stel: mfc1 $2, $f0 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_sf_df_sf |
| |
| declare float @sf_df_df(double, double) #1 |
| ; stel: .section .mips16.call.fp.sf_df_df,"ax",@progbits |
| ; stel: .ent __call_stub_fp_sf_df_df |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $5, $f13 |
| ; stel: mtc1 $6, $f14 |
| ; stel: mtc1 $7, $f15 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal sf_df_df |
| ; stel: mfc1 $2, $f0 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_sf_df_df |
| |
| declare double @df_v() #1 |
| ; stel: .section .mips16.call.fp.df_v,"ax",@progbits |
| ; stel: .ent __call_stub_fp_df_v |
| ; stel: move $18, $ra |
| ; stel: jal df_v |
| ; stel: mfc1 $2, $f0 |
| ; stel: mfc1 $3, $f1 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_df_v |
| |
| declare double @df_sf(float) #1 |
| ; stel: .section .mips16.call.fp.df_sf,"ax",@progbits |
| ; stel: .ent __call_stub_fp_df_sf |
| ; stel: mtc1 $4, $f12 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal df_sf |
| ; stel: mfc1 $2, $f0 |
| ; stel: mfc1 $3, $f1 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_df_sf |
| |
| declare double @df_df(double) #1 |
| ; stel: .section .mips16.call.fp.df_df,"ax",@progbits |
| ; stel: .ent __call_stub_fp_df_df |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $5, $f13 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal df_df |
| ; stel: mfc1 $2, $f0 |
| ; stel: mfc1 $3, $f1 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_df_df |
| |
| declare double @df_sf_sf(float, float) #1 |
| ; stel: .section .mips16.call.fp.df_sf_sf,"ax",@progbits |
| ; stel: .ent __call_stub_fp_df_sf_sf |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $5, $f14 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal df_sf_sf |
| ; stel: mfc1 $2, $f0 |
| ; stel: mfc1 $3, $f1 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_df_sf_sf |
| |
| declare double @df_sf_df(float, double) #1 |
| ; stel: .section .mips16.call.fp.df_sf_df,"ax",@progbits |
| ; stel: .ent __call_stub_fp_df_sf_df |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $6, $f14 |
| ; stel: mtc1 $7, $f15 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal df_sf_df |
| ; stel: mfc1 $2, $f0 |
| ; stel: mfc1 $3, $f1 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_df_sf_df |
| |
| declare double @df_df_sf(double, float) #1 |
| ; stel: .section .mips16.call.fp.df_df_sf,"ax",@progbits |
| ; stel: .ent __call_stub_fp_df_df_sf |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $5, $f13 |
| ; stel: mtc1 $6, $f14 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal df_df_sf |
| ; stel: mfc1 $2, $f0 |
| ; stel: mfc1 $3, $f1 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_df_df_sf |
| |
| declare double @df_df_df(double, double) #1 |
| ; stel: .section .mips16.call.fp.df_df_df,"ax",@progbits |
| ; stel: .ent __call_stub_fp_df_df_df |
| ; stel: mtc1 $4, $f12 |
| ; stel: mtc1 $5, $f13 |
| ; stel: mtc1 $6, $f14 |
| ; stel: mtc1 $7, $f15 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal df_df_df |
| ; stel: mfc1 $2, $f0 |
| ; stel: mfc1 $3, $f1 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_df_df_df |
| |
| declare { float, float } @sc_v() #1 |
| ; stel: .section .mips16.call.fp.sc_v,"ax",@progbits |
| ; stel: .ent __call_stub_fp_sc_v |
| ; stel: move $18, $ra |
| ; stel: jal sc_v |
| ; stel: mfc1 $2, $f0 |
| ; stel: mfc1 $3, $f2 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_sc_v |
| |
| declare { float, float } @sc_sf(float) #1 |
| ; stel: .section .mips16.call.fp.sc_sf,"ax",@progbits |
| ; stel: .ent __call_stub_fp_sc_sf |
| ; stel: mtc1 $4, $f12 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal sc_sf |
| ; stel: mfc1 $2, $f0 |
| ; stel: mfc1 $3, $f2 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_sc_sf |
| |
| declare { double, double } @dc_v() #1 |
| ; stel: .section .mips16.call.fp.dc_v,"ax",@progbits |
| ; stel: .ent __call_stub_fp_dc_v |
| ; stel: move $18, $ra |
| ; stel: jal dc_v |
| ; stel: mfc1 $4, $f2 |
| ; stel: mfc1 $5, $f3 |
| ; stel: mfc1 $2, $f0 |
| ; stel: mfc1 $3, $f1 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_dc_v |
| |
| declare { double, double } @dc_sf(float) #1 |
| ; stel: .section .mips16.call.fp.dc_sf,"ax",@progbits |
| ; stel: .ent __call_stub_fp_dc_sf |
| ; stel: mtc1 $4, $f12 |
| ; stel: move $18, ${{31|ra}} |
| ; stel: jal dc_sf |
| ; stel: mfc1 $4, $f2 |
| ; stel: mfc1 $5, $f3 |
| ; stel: mfc1 $2, $f0 |
| ; stel: mfc1 $3, $f1 |
| ; stel: jr $18 |
| ; stel: .end __call_stub_fp_dc_sf |
| |
| attributes #0 = { nounwind "less-precise-fpmad"="false" "frame-pointer"="all" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "unsafe-fp-math"="false" "use-soft-float"="false" } |
| attributes #1 = { "less-precise-fpmad"="false" "frame-pointer"="all" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "unsafe-fp-math"="false" "use-soft-float"="false" } |