[libclc] libclc: Use frexp builtins to implement frexp for amdgpu (PR #185637)

via cfe-commits cfe-commits at lists.llvm.org
Tue Mar 10 05:38:52 PDT 2026


llvmbot wrote:


<!--LLVM PR SUMMARY COMMENT-->

@llvm/pr-subscribers-backend-amdgpu

Author: Matt Arsenault (arsenm)

<details>
<summary>Changes</summary>

This should really be the default implementation.

---
Full diff: https://github.com/llvm/llvm-project/pull/185637.diff


3 Files Affected:

- (modified) libclc/clc/lib/amdgpu/CMakeLists.txt (+1) 
- (added) libclc/clc/lib/amdgpu/math/clc_frexp.cl (+43) 
- (added) libclc/clc/lib/generic/math/clc_frexp_builtin.inc (+47) 


``````````diff
diff --git a/libclc/clc/lib/amdgpu/CMakeLists.txt b/libclc/clc/lib/amdgpu/CMakeLists.txt
index f593bc6fdd8cf..4fbb9bb25777e 100644
--- a/libclc/clc/lib/amdgpu/CMakeLists.txt
+++ b/libclc/clc/lib/amdgpu/CMakeLists.txt
@@ -4,6 +4,7 @@ libclc_configure_source_list(CLC_AMDGPU_SOURCES
   math/clc_exp.cl
   math/clc_exp2.cl
   math/clc_exp10.cl
+  math/clc_frexp.cl
   math/clc_half_exp.cl
   math/clc_half_exp2.cl
   math/clc_half_exp10.cl
diff --git a/libclc/clc/lib/amdgpu/math/clc_frexp.cl b/libclc/clc/lib/amdgpu/math/clc_frexp.cl
new file mode 100644
index 0000000000000..9234f84b274df
--- /dev/null
+++ b/libclc/clc/lib/amdgpu/math/clc_frexp.cl
@@ -0,0 +1,43 @@
+//===----------------------------------------------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+#include <clc/internal/clc.h>
+#include <clc/math/clc_frexp.h>
+
+#define __CLC_BODY <clc_frexp_builtin.inc>
+#define __CLC_ADDRESS_SPACE private
+#define __CLC_PRIVATE
+#include <clc/math/gentype.inc>
+#undef __CLC_ADDRESS_SPACE
+#undef __CLC_PRIVATE
+
+#define __CLC_BODY <clc_frexp_builtin.inc>
+#define __CLC_ADDRESS_SPACE global
+#include <clc/math/gentype.inc>
+#undef __CLC_ADDRESS_SPACE
+
+#define __CLC_BODY <clc_frexp_builtin.inc>
+#define __CLC_ADDRESS_SPACE local
+#include <clc/math/gentype.inc>
+#undef __CLC_ADDRESS_SPACE
+
+#if _CLC_DISTINCT_GENERIC_AS_SUPPORTED
+#define __CLC_BODY <clc_frexp_builtin.inc>
+#define __CLC_ADDRESS_SPACE generic
+#include <clc/math/gentype.inc>
+#undef __CLC_ADDRESS_SPACE
+#endif
+
+#define __CLC_FUNCTION __clc_frexp
+#define __CLC_ARG2_TYPE int
+#define __CLC_ADDRSPACE private
+#define __CLC_BODY <clc/shared/unary_def_with_ptr_scalarize.inc>
+#include <clc/math/gentype.inc>
+#undef __CLC_ADDRSPACE
+#undef __CLC_ARG2_TYPE
+#undef __CLC_FUNCTION
diff --git a/libclc/clc/lib/generic/math/clc_frexp_builtin.inc b/libclc/clc/lib/generic/math/clc_frexp_builtin.inc
new file mode 100644
index 0000000000000..72113ce36a591
--- /dev/null
+++ b/libclc/clc/lib/generic/math/clc_frexp_builtin.inc
@@ -0,0 +1,47 @@
+//===----------------------------------------------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+#if defined(__CLC_PRIVATE) && defined(__CLC_SCALAR)
+
+#if __CLC_FPSIZE == 16
+
+_CLC_OVERLOAD _CLC_DEF __CLC_GENTYPE __clc_frexp(__CLC_GENTYPE x,
+                                                 private __CLC_INTN *ep) {
+  return __builtin_frexpf16(x, ep);
+}
+
+#elif __CLC_FPSIZE == 32
+
+_CLC_OVERLOAD _CLC_DEF __CLC_GENTYPE __clc_frexp(__CLC_GENTYPE x,
+                                                 private __CLC_INTN *ep) {
+  return __builtin_frexpf(x, ep);
+}
+
+#elif __CLC_FPSIZE == 64
+
+_CLC_OVERLOAD _CLC_DEF __CLC_GENTYPE __clc_frexp(__CLC_GENTYPE x,
+                                                 private __CLC_INTN *ep) {
+  return __builtin_frexp(x, ep);
+}
+
+#else
+#error "unhandled fpsize"
+#endif
+
+#elif !defined(__CLC_PRIVATE)
+
+_CLC_OVERLOAD _CLC_DEF __CLC_GENTYPE
+__clc_frexp(__CLC_GENTYPE x, __CLC_ADDRESS_SPACE __CLC_INTN *ep) {
+private
+  __CLC_INTN e;
+  __CLC_GENTYPE result = __clc_frexp(x, &e);
+  *ep = e;
+  return result;
+}
+
+#endif

``````````

</details>


https://github.com/llvm/llvm-project/pull/185637


More information about the cfe-commits mailing list