[llvm] r192223 - Add fabsf to the list of inlined functions; otherwise
Reed Kotler
rkotler at mips.com
Tue Oct 8 12:55:01 PDT 2013
Author: rkotler
Date: Tue Oct 8 14:55:01 2013
New Revision: 192223
URL: http://llvm.org/viewvc/llvm-project?rev=192223&view=rev
Log:
Add fabsf to the list of inlined functions; otherwise
Mips16 will try and create a stub for it and this will
result in a link error because that function does not exist in libc.
Modified:
llvm/trunk/lib/Target/Mips/Mips16HardFloat.cpp
llvm/trunk/test/CodeGen/Mips/f16abs.ll
Modified: llvm/trunk/lib/Target/Mips/Mips16HardFloat.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/Mips/Mips16HardFloat.cpp?rev=192223&r1=192222&r2=192223&view=diff
==============================================================================
--- llvm/trunk/lib/Target/Mips/Mips16HardFloat.cpp (original)
+++ llvm/trunk/lib/Target/Mips/Mips16HardFloat.cpp Tue Oct 8 14:55:01 2013
@@ -326,6 +326,7 @@ static void assureFPCallStub(Function &F
//
static const char *IntrinsicInline[] =
{"fabs",
+ "fabsf",
"llvm.ceil.f32", "llvm.ceil.f64",
"llvm.copysign.f32", "llvm.copysign.f64",
"llvm.cos.f32", "llvm.cos.f64",
Modified: llvm/trunk/test/CodeGen/Mips/f16abs.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/Mips/f16abs.ll?rev=192223&r1=192222&r2=192223&view=diff
==============================================================================
--- llvm/trunk/test/CodeGen/Mips/f16abs.ll (original)
+++ llvm/trunk/test/CodeGen/Mips/f16abs.ll Tue Oct 8 14:55:01 2013
@@ -3,6 +3,11 @@
@y = global double -1.450000e+00, align 8
@x = common global double 0.000000e+00, align 8
+ at y1 = common global float 0.000000e+00, align 4
+ at x1 = common global float 0.000000e+00, align 4
+
+
+
; Function Attrs: nounwind optsize
define i32 @main() #0 {
entry:
@@ -11,12 +16,19 @@ entry:
store double %call, double* @x, align 8
; static-NOT: .ent __call_stub_fp_fabs
; static-NOT: jal fabs
+ %1 = load float* @y1, align 4
+ %call2 = tail call float @fabsf(float %1) #2
+ store float %call2, float* @x1, align 4
+; static-NOT: .ent __call_stub_fp_fabsf
+; static-NOT: jal fabsf
ret i32 0
}
; Function Attrs: nounwind optsize readnone
declare double @fabs(double) #1
+declare float @fabsf(float) #1
+
attributes #0 = { nounwind optsize "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" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="true" }
attributes #1 = { nounwind optsize readnone "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" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="true" }
attributes #2 = { nounwind optsize readnone }
More information about the llvm-commits
mailing list