Print a=b as an assignment.
[oota-llvm.git] / test / CodeGen / Mips / hfptrcall.ll
index b7cd2e9560db9e32d4c5cc346b386569fb272a5d..9df8d900693c0408548e1bb0bb26f27fcf69d5bc 100644 (file)
@@ -1,4 +1,4 @@
-; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mcpu=mips16 -soft-float -mips16-hard-float -relocation-model=pic < %s | FileCheck %s -check-prefix=picel
+; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mcpu=mips16 -relocation-model=pic < %s | FileCheck %s -check-prefix=picel
 
 @ptrsv = global float ()* @sv, align 4
 @ptrdv = global double ()* @dv, align 4
@@ -62,6 +62,64 @@ entry:
 ; picel:       lw      ${{[0-9]+}}, %call16(__mips16_ret_dc)(${{[0-9]+}})
 ; picel:       .end    dcv
 
+; Function Attrs: nounwind
+define i32 @main() #0 {
+entry:
+  %0 = load float ()** @ptrsv, align 4
+  %call = call float %0()
+  store float %call, float* @x, align 4
+  %1 = load float* @x, align 4
+  %conv = fpext float %1 to double
+  %call1 = call i32 (i8*, ...)* @printf(i8* getelementptr inbounds ([4 x i8]* @.str, i32 0, i32 0), double %conv)
+  %2 = load double ()** @ptrdv, align 4
+  %call2 = call double %2()
+  store double %call2, double* @xd, align 8
+  %3 = load double* @xd, align 8
+  %call3 = call i32 (i8*, ...)* @printf(i8* getelementptr inbounds ([4 x i8]* @.str, i32 0, i32 0), double %3)
+  %4 = load { float, float } ()** @ptrscv, align 4
+  %call4 = call { float, float } %4()
+  %5 = extractvalue { float, float } %call4, 0
+  %6 = extractvalue { float, float } %call4, 1
+  store float %5, float* getelementptr inbounds ({ float, float }* @xy, i32 0, i32 0)
+  store float %6, float* getelementptr inbounds ({ float, float }* @xy, i32 0, i32 1)
+  %xy.real = load float* getelementptr inbounds ({ float, float }* @xy, i32 0, i32 0)
+  %xy.imag = load float* getelementptr inbounds ({ float, float }* @xy, i32 0, i32 1)
+  %conv5 = fpext float %xy.real to double
+  %conv6 = fpext float %xy.imag to double
+  %xy.real7 = load float* getelementptr inbounds ({ float, float }* @xy, i32 0, i32 0)
+  %xy.imag8 = load float* getelementptr inbounds ({ float, float }* @xy, i32 0, i32 1)
+  %conv9 = fpext float %xy.real7 to double
+  %conv10 = fpext float %xy.imag8 to double
+  %call11 = call i32 (i8*, ...)* @printf(i8* getelementptr inbounds ([10 x i8]* @.str1, i32 0, i32 0), double %conv5, double %conv10)
+  %7 = load { double, double } ()** @ptrdcv, align 4
+  %call12 = call { double, double } %7()
+  %8 = extractvalue { double, double } %call12, 0
+  %9 = extractvalue { double, double } %call12, 1
+  store double %8, double* getelementptr inbounds ({ double, double }* @xyd, i32 0, i32 0)
+  store double %9, double* getelementptr inbounds ({ double, double }* @xyd, i32 0, i32 1)
+  %xyd.real = load double* getelementptr inbounds ({ double, double }* @xyd, i32 0, i32 0)
+  %xyd.imag = load double* getelementptr inbounds ({ double, double }* @xyd, i32 0, i32 1)
+  %xyd.real13 = load double* getelementptr inbounds ({ double, double }* @xyd, i32 0, i32 0)
+  %xyd.imag14 = load double* getelementptr inbounds ({ double, double }* @xyd, i32 0, i32 1)
+  %call15 = call i32 (i8*, ...)* @printf(i8* getelementptr inbounds ([10 x i8]* @.str1, i32 0, i32 0), double %xyd.real, double %xyd.imag14)
+  ret i32 0
+}
+
+; picel:       .ent    main
+
+; picel:       lw      ${{[0-9]+}}, %got(__mips16_call_stub_sf_0)(${{[0-9]+}})
+
+; picel:       lw      ${{[0-9]+}}, %got(__mips16_call_stub_df_0)(${{[0-9]+}})
+
+; picel:       lw      ${{[0-9]+}}, %got(__mips16_call_stub_sc_0)(${{[0-9]+}})
+
+; picel:       lw      ${{[0-9]+}}, %got(__mips16_call_stub_dc_0)(${{[0-9]+}})
+
+
+declare i32 @printf(i8*, ...) #1
+
+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"="true" }
+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"="true" }
+
 
-attributes #0 = { nounwind "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf"="true" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "unsafe-fp-math"="false" "use-soft-float"="true" }