From ab2eb92710730ebafcb4a018fc7a9e741eec8b13 Mon Sep 17 00:00:00 2001 From: Steffen Larsen Date: Wed, 22 Nov 2023 08:21:41 +0100 Subject: [PATCH 1/4] Uplift DPC++ to 2a3e1ab824f072670c186ec715f29b88c9df9d45 Signed-off-by: Larsen --- .github/workflows/cts_ci.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/cts_ci.yml b/.github/workflows/cts_ci.yml index bd8103d0e..f50f44f66 100644 --- a/.github/workflows/cts_ci.yml +++ b/.github/workflows/cts_ci.yml @@ -56,7 +56,7 @@ jobs: matrix: include: - sycl-impl: dpcpp - version: 9dfaf274e2cbe42e992be0519fa7d2b0eb0face5 + version: 2a3e1ab824f072670c186ec715f29b88c9df9d45 - sycl-impl: hipsycl version: 3d8b1cd steps: @@ -114,7 +114,7 @@ jobs: matrix: include: - sycl-impl: dpcpp - version: 9dfaf274e2cbe42e992be0519fa7d2b0eb0face5 + version: 2a3e1ab824f072670c186ec715f29b88c9df9d45 - sycl-impl: hipsycl version: 3d8b1cd env: From 4c0163e7f1df0b62190f3fbb4a2c140fcac401e3 Mon Sep 17 00:00:00 2001 From: Steffen Larsen Date: Wed, 22 Nov 2023 16:06:22 +0100 Subject: [PATCH 2/4] Use 6bce7f64f51a4370052bffa3fa257ca16d8aad9e instead --- .github/workflows/cts_ci.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/cts_ci.yml b/.github/workflows/cts_ci.yml index f50f44f66..96a2f9f65 100644 --- a/.github/workflows/cts_ci.yml +++ b/.github/workflows/cts_ci.yml @@ -56,7 +56,7 @@ jobs: matrix: include: - sycl-impl: dpcpp - version: 2a3e1ab824f072670c186ec715f29b88c9df9d45 + version: 6bce7f64f51a4370052bffa3fa257ca16d8aad9e - sycl-impl: hipsycl version: 3d8b1cd steps: @@ -114,7 +114,7 @@ jobs: matrix: include: - sycl-impl: dpcpp - version: 2a3e1ab824f072670c186ec715f29b88c9df9d45 + version: 6bce7f64f51a4370052bffa3fa257ca16d8aad9e - sycl-impl: hipsycl version: 3d8b1cd env: From f157d0bc686c030d6e0b3163e85b2d185741b471 Mon Sep 17 00:00:00 2001 From: "Larsen, Steffen" Date: Thu, 16 Nov 2023 02:56:22 -0800 Subject: [PATCH 3/4] Change abs_diff return type Following https://github.com/KhronosGroup/SYCL-Docs/pull/458 the return type of abs_diff was changed to be the same as the input types. This commit makes the corresponding changes to the CTS tests for it. Signed-off-by: Larsen, Steffen --- .../modules/sycl_functions.py | 2 +- util/math_reference.h | 20 +++++++++---------- 2 files changed, 10 insertions(+), 12 deletions(-) diff --git a/tests/math_builtin_api/modules/sycl_functions.py b/tests/math_builtin_api/modules/sycl_functions.py index 897751a19..fcc40e563 100644 --- a/tests/math_builtin_api/modules/sycl_functions.py +++ b/tests/math_builtin_api/modules/sycl_functions.py @@ -39,7 +39,7 @@ def create_integer_signatures(): f_abs = funsig("sycl", "geninteger", "abs", ["geninteger"]) sig_list.append(f_abs) - f_abs_diff = funsig("sycl", "ugeninteger", "abs_diff", ["geninteger", "geninteger"], "0", "", [], [["geninteger", "ugeninteger", "base_type_but_same_sizeof"]]) + f_abs_diff = funsig("sycl", "geninteger", "abs_diff", ["geninteger", "geninteger"]) sig_list.append(f_abs_diff) f_add_sat = funsig("sycl", "geninteger", "add_sat", ["geninteger", "geninteger"]) diff --git a/util/math_reference.h b/util/math_reference.h index d48f6e2b5..593d93df6 100644 --- a/util/math_reference.h +++ b/util/math_reference.h @@ -305,23 +305,21 @@ sycl_cts::resultRef> abs(sycl::marray a) { /* absolute difference */ template -auto abs_diff(T a, T b) { - using R = typename std::make_unsigned::type; - R h = (a > b) ? a : b; - R l = (a <= b) ? a : b; +T abs_diff(T a, T b) { + T h = (a > b) ? a : b; + T l = (a <= b) ? a : b; return h - l; } -template ::type> -sycl::vec abs_diff(sycl::vec a, sycl::vec b) { - return sycl_cts::math::run_func_on_vector( +template +sycl::vec abs_diff(sycl::vec a, sycl::vec b) { + return sycl_cts::math::run_func_on_vector( [](T x, T y) { return abs_diff(x, y); }, a, b); } // FIXME: hipSYCL does not support marray #ifndef SYCL_CTS_COMPILING_WITH_HIPSYCL -template ::type> -sycl::marray abs_diff(sycl::marray a, sycl::marray b) { - return sycl_cts::math::run_func_on_marray( +template +sycl::marray abs_diff(sycl::marray a, sycl::marray b) { + return sycl_cts::math::run_func_on_marray( [](T x, T y) { return abs_diff(x, y); }, a, b); } #endif From 436c42026515d8ee7104d52b28eb77115bfc9039 Mon Sep 17 00:00:00 2001 From: Steffen Larsen Date: Fri, 24 Nov 2023 14:33:13 +0100 Subject: [PATCH 4/4] Restore ULP precision --- tests/math_builtin_api/modules/sycl_functions.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/math_builtin_api/modules/sycl_functions.py b/tests/math_builtin_api/modules/sycl_functions.py index fcc40e563..726ee8651 100644 --- a/tests/math_builtin_api/modules/sycl_functions.py +++ b/tests/math_builtin_api/modules/sycl_functions.py @@ -39,7 +39,7 @@ def create_integer_signatures(): f_abs = funsig("sycl", "geninteger", "abs", ["geninteger"]) sig_list.append(f_abs) - f_abs_diff = funsig("sycl", "geninteger", "abs_diff", ["geninteger", "geninteger"]) + f_abs_diff = funsig("sycl", "geninteger", "abs_diff", ["geninteger", "geninteger"], "0") sig_list.append(f_abs_diff) f_add_sat = funsig("sycl", "geninteger", "add_sat", ["geninteger", "geninteger"])