summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorReed Kotler <rkotler@mips.com>2013-10-08 19:55:01 +0000
committerReed Kotler <rkotler@mips.com>2013-10-08 19:55:01 +0000
commit339c7410467af48b6620be15e988e73585b54f84 (patch)
treefdcc203ad9e070c8c8a0e6a1508216239eaec3fb /llvm
parent0ec313e9ec573bc3c8e6d2bfd5e63762da500ad9 (diff)
downloadbcm5719-llvm-339c7410467af48b6620be15e988e73585b54f84.tar.gz
bcm5719-llvm-339c7410467af48b6620be15e988e73585b54f84.zip
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. llvm-svn: 192223
Diffstat (limited to 'llvm')
-rw-r--r--llvm/lib/Target/Mips/Mips16HardFloat.cpp1
-rw-r--r--llvm/test/CodeGen/Mips/f16abs.ll12
2 files changed, 13 insertions, 0 deletions
diff --git a/llvm/lib/Target/Mips/Mips16HardFloat.cpp b/llvm/lib/Target/Mips/Mips16HardFloat.cpp
index 4d728bdfc69..81bf18cd09d 100644
--- a/llvm/lib/Target/Mips/Mips16HardFloat.cpp
+++ b/llvm/lib/Target/Mips/Mips16HardFloat.cpp
@@ -326,6 +326,7 @@ static void assureFPCallStub(Function &F, Module *M,
//
static const char *IntrinsicInline[] =
{"fabs",
+ "fabsf",
"llvm.ceil.f32", "llvm.ceil.f64",
"llvm.copysign.f32", "llvm.copysign.f64",
"llvm.cos.f32", "llvm.cos.f64",
diff --git a/llvm/test/CodeGen/Mips/f16abs.ll b/llvm/test/CodeGen/Mips/f16abs.ll
index 29743a2d70c..928914f067d 100644
--- a/llvm/test/CodeGen/Mips/f16abs.ll
+++ b/llvm/test/CodeGen/Mips/f16abs.ll
@@ -3,6 +3,11 @@
@y = global double -1.450000e+00, align 8
@x = common global double 0.000000e+00, align 8
+@y1 = common global float 0.000000e+00, align 4
+@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 }
OpenPOWER on IntegriCloud