[libclc] 72/79: amdgcn/fmin: fcanonicalize operands

Andreas Boll aboll-guest at moszumanska.debian.org
Mon Mar 19 16:51:02 UTC 2018


This is an automated email from the git hooks/post-receive script.

aboll-guest pushed a commit to branch master
in repository libclc.

commit 443a7c38139df81d858e00a3e4864f9a43e03aff
Author: Jan Vesely <jan.vesely at rutgers.edu>
Date:   Thu Mar 8 23:00:58 2018 +0000

    amdgcn/fmin: fcanonicalize operands
    
    v_min instruction needs canonicalized operands.
    Passes CTS on carrizo
    
    Reviewer: Aaron Watry <awatry at gmail.com>
    Signed-off-by: Jan Vesely <jan.vesely at rutgers.edu>
    
    git-svn-id: https://llvm.org/svn/llvm-project/libclc/trunk@327075 91177308-0d34-0410-b5e6-96231b3b80d8
---
 amdgcn/lib/SOURCES      |  1 +
 amdgcn/lib/math/fmin.cl | 31 +++++++++++++++++++++++++++++++
 2 files changed, 32 insertions(+)

diff --git a/amdgcn/lib/SOURCES b/amdgcn/lib/SOURCES
index 6a5ce00..9cdc7b8 100644
--- a/amdgcn/lib/SOURCES
+++ b/amdgcn/lib/SOURCES
@@ -1,5 +1,6 @@
 cl_khr_int64_extended_atomics/minmax_helpers.ll
 integer/popcount.cl
+math/fmin.cl
 math/ldexp.cl
 mem_fence/fence.cl
 synchronization/barrier.cl
diff --git a/amdgcn/lib/math/fmin.cl b/amdgcn/lib/math/fmin.cl
new file mode 100644
index 0000000..6a11785
--- /dev/null
+++ b/amdgcn/lib/math/fmin.cl
@@ -0,0 +1,31 @@
+#include <clc/clc.h>
+
+#include "../../../generic/lib/clcmacro.h"
+
+_CLC_DEF _CLC_OVERLOAD float fmin(float x, float y)
+{
+   /* fcanonicalize removes sNaNs and flushes denormals if not enabled.
+    * Otherwise fmin instruction flushes the values for comparison,
+    * but outputs original denormal */
+   x = __builtin_canonicalizef(x);
+   y = __builtin_canonicalizef(y);
+   return __builtin_fminf(x, y);
+}
+_CLC_BINARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, float, fmin, float, float)
+
+#ifdef cl_khr_fp64
+
+#pragma OPENCL EXTENSION cl_khr_fp64 : enable
+
+_CLC_DEF _CLC_OVERLOAD double fmin(double x, double y)
+{
+   x = __builtin_canonicalizef(x);
+   y = __builtin_canonicalizef(y);
+   return __builtin_fminf(x, y);
+}
+_CLC_BINARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, double, fmin, double, double)
+
+#endif
+
+#define __CLC_BODY <../../../generic/lib/math/fmin.inc>
+#include <clc/math/gentype.inc>

-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-opencl/libclc.git



More information about the Pkg-opencl-commits mailing list