From: Matt Arsenault Date: Sat, 27 Feb 2016 09:06:18 +0000 (+0000) Subject: Add __builtin_canonicalize X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=25cdeb0940dfadaf0a3075f91605a662f4705d21;p=clang Add __builtin_canonicalize git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@262122 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/docs/LanguageExtensions.rst b/docs/LanguageExtensions.rst index 2dbf223d68..baca28e8dc 100644 --- a/docs/LanguageExtensions.rst +++ b/docs/LanguageExtensions.rst @@ -1728,6 +1728,24 @@ convert their operands before performing the operation. Query for this feature with ``__has_builtin(__builtin_add_overflow)``, etc. +Floating point builtins +--------------------------------------- + +``__builtin_canonicalize`` +-------------------------- + +.. code-block:: c + + double __builtin_canonicalize(double); + float __builtin_canonicalizef(float); + long double__builtin_canonicalizel(long double); + +Returns the platform specific canonical encoding of a floating point +number. This canonicalization is useful for implementing certain +numeric primitives such as frexp. See `LLVM canonicalize intrinsic +`_ for +more information on the semantics. + .. _langext-__c11_atomic: __c11_atomic builtins diff --git a/include/clang/Basic/Builtins.def b/include/clang/Basic/Builtins.def index 515785abee..21a90ade05 100644 --- a/include/clang/Basic/Builtins.def +++ b/include/clang/Basic/Builtins.def @@ -377,6 +377,11 @@ BUILTIN(__builtin_signbit, "i.", "Fnc") BUILTIN(__builtin_signbitf, "if", "Fnc") BUILTIN(__builtin_signbitl, "iLd", "Fnc") +// Special FP builtins. +BUILTIN(__builtin_canonicalize, "dd", "nc") +BUILTIN(__builtin_canonicalizef, "ff", "nc") +BUILTIN(__builtin_canonicalizel, "LdLd", "nc") + // Builtins for arithmetic. BUILTIN(__builtin_clzs , "iUs" , "nc") BUILTIN(__builtin_clz , "iUi" , "nc") diff --git a/lib/CodeGen/CGBuiltin.cpp b/lib/CodeGen/CGBuiltin.cpp index e384851112..fbba561f7c 100644 --- a/lib/CodeGen/CGBuiltin.cpp +++ b/lib/CodeGen/CGBuiltin.cpp @@ -2138,6 +2138,11 @@ RValue CodeGenFunction::EmitBuiltinExpr(const FunctionDecl *FD, case Builtin::BIprintf: if (getLangOpts().CUDA && getLangOpts().CUDAIsDevice) return EmitCUDADevicePrintfCallExpr(E, ReturnValue); + break; + case Builtin::BI__builtin_canonicalize: + case Builtin::BI__builtin_canonicalizef: + case Builtin::BI__builtin_canonicalizel: + return RValue::get(emitUnaryBuiltin(*this, E, Intrinsic::canonicalize)); } // If this is an alias for a lib function (e.g. __builtin_sin), emit diff --git a/test/CodeGen/builtins.c b/test/CodeGen/builtins.c index 44a2bc585a..62741ee803 100644 --- a/test/CodeGen/builtins.c +++ b/test/CodeGen/builtins.c @@ -250,6 +250,13 @@ void test_float_builtin_ops(float F, double D, long double LD) { // CHECK: call float @llvm.fabs.f32(float // CHECK: call double @llvm.fabs.f64(double // CHECK: call x86_fp80 @llvm.fabs.f80(x86_fp80 + + resf = __builtin_canonicalizef(F); + resd = __builtin_canonicalize(D); + resld = __builtin_canonicalizel(LD); + // CHECK: call float @llvm.canonicalize.f32(float + // CHECK: call double @llvm.canonicalize.f64(double + // CHECK: call x86_fp80 @llvm.canonicalize.f80(x86_fp80 } // __builtin_longjmp isn't supported on all platforms, so only test it on X86.