From 7b2b1bf3bdad8ecdee381824ea7105bf7a7dc1d5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Miko=C5=82aj=20Zuzek?= Date: Wed, 5 Jan 2022 15:36:55 +0100 Subject: [PATCH] Fixed inlining: don't comile exception throwing MKL wrappers for GPU --- .../impl/KokkosSparse_spgemm_mkl_impl.hpp | 22 +++++++++---------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/src/sparse/impl/KokkosSparse_spgemm_mkl_impl.hpp b/src/sparse/impl/KokkosSparse_spgemm_mkl_impl.hpp index 1b22906ea3..1008819a24 100644 --- a/src/sparse/impl/KokkosSparse_spgemm_mkl_impl.hpp +++ b/src/sparse/impl/KokkosSparse_spgemm_mkl_impl.hpp @@ -54,7 +54,7 @@ namespace Impl { #ifdef KOKKOSKERNELS_ENABLE_TPL_MKL -KOKKOS_INLINE_FUNCTION +inline void mkl_call(sparse_status_t result, const char *err_msg) { if (SPARSE_STATUS_SUCCESS != result) { throw std::runtime_error(err_msg); @@ -66,11 +66,11 @@ class MKLSparseMatrix { sparse_matrix_t mtx; public: - KOKKOS_INLINE_FUNCTION + inline MKLSparseMatrix(const MKL_INT m, const MKL_INT n, MKL_INT *xadj, MKL_INT *adj, value_type *values); - KOKKOS_INLINE_FUNCTION + inline static MKLSparseMatrix spmm( sparse_operation_t operation, const MKLSparseMatrix &A, const MKLSparseMatrix &B) { @@ -80,22 +80,22 @@ class MKLSparseMatrix { return MKLSparseMatrix(c); } - KOKKOS_INLINE_FUNCTION + inline void get(MKL_INT &rows, MKL_INT &cols, MKL_INT *&rows_start, MKL_INT *&columns, value_type *&values); - KOKKOS_INLINE_FUNCTION + inline void destroy() { mkl_call(mkl_sparse_destroy(mtx), "mkl_sparse_destroy() failed!"); } private: - KOKKOS_INLINE_FUNCTION + inline MKLSparseMatrix(sparse_matrix_t mtx_) : mtx(mtx_) {} }; template <> -KOKKOS_INLINE_FUNCTION MKLSparseMatrix::MKLSparseMatrix( +inline MKLSparseMatrix::MKLSparseMatrix( const MKL_INT rows, const MKL_INT cols, MKL_INT *xadj, MKL_INT *adj, float *values) { mkl_call(mkl_sparse_s_create_csr(&mtx, SPARSE_INDEX_BASE_ZERO, rows, cols, @@ -104,7 +104,7 @@ KOKKOS_INLINE_FUNCTION MKLSparseMatrix::MKLSparseMatrix( } template <> -KOKKOS_INLINE_FUNCTION MKLSparseMatrix::MKLSparseMatrix( +inline MKLSparseMatrix::MKLSparseMatrix( const MKL_INT rows, const MKL_INT cols, MKL_INT *xadj, MKL_INT *adj, double *values) { mkl_call(mkl_sparse_d_create_csr(&mtx, SPARSE_INDEX_BASE_ZERO, rows, cols, @@ -113,7 +113,7 @@ KOKKOS_INLINE_FUNCTION MKLSparseMatrix::MKLSparseMatrix( } template <> -KOKKOS_INLINE_FUNCTION void MKLSparseMatrix::get(MKL_INT &rows, +inline void MKLSparseMatrix::get(MKL_INT &rows, MKL_INT &cols, MKL_INT *&rows_start, MKL_INT *&columns, @@ -131,7 +131,7 @@ KOKKOS_INLINE_FUNCTION void MKLSparseMatrix::get(MKL_INT &rows, } template <> -KOKKOS_INLINE_FUNCTION void MKLSparseMatrix::get(MKL_INT &rows, +inline void MKLSparseMatrix::get(MKL_INT &rows, MKL_INT &cols, MKL_INT *&rows_start, MKL_INT *&columns, @@ -326,7 +326,7 @@ class MKLApply { } template - KOKKOS_INLINE_FUNCTION static void copy(size_t num_elems, from_type from, + inline static void copy(size_t num_elems, from_type from, to_type to) { KokkosKernels::Impl::copy_vector(num_elems, from, to);