[clang] [llvm] [HLSL] Move length support out of the DirectX Backend (PR #121611)

Justin Bogner via llvm-commits llvm-commits at lists.llvm.org
Fri Jan 3 15:48:53 PST 2025


================
@@ -33,6 +41,23 @@ constexpr enable_if_t<sizeof(U) == sizeof(T), U> bit_cast(T F) {
   return __builtin_bit_cast(U, F);
 }
 
+template <typename T>
+constexpr enable_if_t<is_same<float, T>::value || is_same<half, T>::value, T>
+length_impl(T X) {
+  return __builtin_elementwise_abs(X);
+}
+
+template <typename T, int N>
+enable_if_t<is_same<float, T>::value || is_same<half, T>::value, T>
+length_vec_impl(vector<T, N> X) {
+  vector<T, N> XSquared = X * X;
+  T XSquaredSum = XSquared[0];
+  [unroll]
+  for (int i = 1; i < N; ++i)
----------------
bogner wrote:

This is because HLSL is only C++11 and not C++14, right? We could always implement this with template recursion if we really want it to be constexpr, but in all likelihood waiting until we bring HLSL up to C++14 eventually before we make this constexpr is fine.

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


More information about the llvm-commits mailing list