diff options
author | Abderrazek Zaafrani <a.zaafrani@samsung.com> | 2017-06-20 18:54:57 +0000 |
---|---|---|
committer | Abderrazek Zaafrani <a.zaafrani@samsung.com> | 2017-06-20 18:54:57 +0000 |
commit | f10ca93f34d3c88dfed98bfef28f45c8088d4ace (patch) | |
tree | b877b3482bb5c0995d7d9bfc27da001f4987ca47 /clang/lib/Basic/Targets.cpp | |
parent | 297b6eb20df59d7c5d593b6f04fd4ea9d0e77e29 (diff) | |
download | bcm5719-llvm-f10ca93f34d3c88dfed98bfef28f45c8088d4ace.tar.gz bcm5719-llvm-f10ca93f34d3c88dfed98bfef28f45c8088d4ace.zip |
[AArch64] ADD ARMv.2-A FP16 vector intrinsics
Differential Revision: https://reviews.llvm.org/D34161
llvm-svn: 305820
Diffstat (limited to 'clang/lib/Basic/Targets.cpp')
-rw-r--r-- | clang/lib/Basic/Targets.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/clang/lib/Basic/Targets.cpp b/clang/lib/Basic/Targets.cpp index a3b8330707b..e23a93e8ced 100644 --- a/clang/lib/Basic/Targets.cpp +++ b/clang/lib/Basic/Targets.cpp @@ -6172,6 +6172,8 @@ class AArch64TargetInfo : public TargetInfo { unsigned Crypto; unsigned Unaligned; unsigned V8_1A; + unsigned V8_2A; + unsigned HasFullFP16; static const Builtin::Info BuiltinInfo[]; @@ -6303,6 +6305,8 @@ public: if (V8_1A) Builder.defineMacro("__ARM_FEATURE_QRDMX", "1"); + if (V8_2A && FPU == NeonMode && HasFullFP16) + Builder.defineMacro("__ARM_FEATURE_FP16_VECTOR_ARITHMETIC", "1"); // All of the __sync_(bool|val)_compare_and_swap_(1|2|4|8) builtins work. Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_1"); @@ -6330,6 +6334,8 @@ public: Crypto = 0; Unaligned = 1; V8_1A = 0; + V8_2A = 0; + HasFullFP16 = 0; for (const auto &Feature : Features) { if (Feature == "+neon") @@ -6342,6 +6348,10 @@ public: Unaligned = 0; if (Feature == "+v8.1a") V8_1A = 1; + if (Feature == "+v8.2a") + V8_2A = 1; + if (Feature == "+fullfp16") + HasFullFP16 = 1; } setDataLayout(); |