diff options
author | Michael Zolotukhin <mzolotukhin@apple.com> | 2015-05-07 17:11:51 +0000 |
---|---|---|
committer | Michael Zolotukhin <mzolotukhin@apple.com> | 2015-05-07 17:11:51 +0000 |
commit | de63aace8a5954dabab06682a0fbf3eddc9de541 (patch) | |
tree | 38eb3467fc2d259a338fbac6e0534ce333201114 /llvm/lib/Analysis/TargetLibraryInfo.cpp | |
parent | 062e198d934b2e9df44a46c2dfc3cd7ed87fb140 (diff) | |
download | bcm5719-llvm-de63aace8a5954dabab06682a0fbf3eddc9de541.tar.gz bcm5719-llvm-de63aace8a5954dabab06682a0fbf3eddc9de541.zip |
Populate list of vectorizable functions for Accelerate library.
Summary:
This patch adds majority of supported by Accelerate library functions to the
list of vectorizable functions.
The full list of available vector functions could be found here:
https://developer.apple.com/library/mac/documentation/Performance/Conceptual/vecLib/index.html
Test Plan: Unit tests are added.
Reviewers: hfinkel, aschwaighofer, nadav
Subscribers: llvm-commits
Differential Revision: http://reviews.llvm.org/D9543
llvm-svn: 236747
Diffstat (limited to 'llvm/lib/Analysis/TargetLibraryInfo.cpp')
-rw-r--r-- | llvm/lib/Analysis/TargetLibraryInfo.cpp | 36 |
1 files changed, 32 insertions, 4 deletions
diff --git a/llvm/lib/Analysis/TargetLibraryInfo.cpp b/llvm/lib/Analysis/TargetLibraryInfo.cpp index 8b378a340fd..635c50ca6e5 100644 --- a/llvm/lib/Analysis/TargetLibraryInfo.cpp +++ b/llvm/lib/Analysis/TargetLibraryInfo.cpp @@ -467,14 +467,42 @@ void TargetLibraryInfoImpl::addVectorizableFunctionsFromVecLib( switch (VecLib) { case Accelerate: { const VecDesc VecFuncs[] = { + // Floating-Point Arithmetic and Auxiliary Functions + {"ceilf", "vceilf", 4}, + {"fabsf", "vfabsf", 4}, + {"llvm.fabs.f32", "vfabsf", 4}, + {"floorf", "vfloorf", 4}, + {"sqrtf", "vsqrtf", 4}, + {"llvm.sqrt.f32", "vsqrtf", 4}, + + // Exponential and Logarithmic Functions {"expf", "vexpf", 4}, {"llvm.exp.f32", "vexpf", 4}, + {"expm1f", "vexpm1f", 4}, {"logf", "vlogf", 4}, {"llvm.log.f32", "vlogf", 4}, - {"sqrtf", "vsqrtf", 4}, - {"llvm.sqrt.f32", "vsqrtf", 4}, - {"fabsf", "vfabsf", 4}, - {"llvm.fabs.f32", "vfabsf", 4}, + {"log1pf", "vlog1pf", 4}, + {"log10f", "vlog10f", 4}, + {"llvm.log10.f32", "vlog10f", 4}, + {"logbf", "vlogbf", 4}, + + // Trigonometric Functions + {"sinf", "vsinf", 4}, + {"llvm.sin.f32", "vsinf", 4}, + {"cosf", "vcosf", 4}, + {"llvm.cos.f32", "vcosf", 4}, + {"tanf", "vtanf", 4}, + {"asinf", "vasinf", 4}, + {"acosf", "vacosf", 4}, + {"atanf", "vatanf", 4}, + + // Hyperbolic Functions + {"sinhf", "vsinhf", 4}, + {"coshf", "vcoshf", 4}, + {"tanhf", "vtanhf", 4}, + {"asinhf", "vasinhf", 4}, + {"acoshf", "vacoshf", 4}, + {"atanhf", "vatanhf", 4}, }; addVectorizableFunctions(VecFuncs); break; |