C++: сбивает с толку шаблон переменной, приводящий к ошибке "функция-кандидат недоступна"

Я пытался перенести проект CUDA на платформу ROCm, которая широко использует шаблоны C++. Во время этого процесса я получаю следующую ошибку компиляции

/root/warp-ctc/include/detail/gpu_ctc.h:381:5: error: no matching function for call to 'hipLaunchKernelGGL'
    hipLaunchKernelGGL((prepare_stable_SM_kernel<ProbT, VT>), dim3(grid_size), dim3(NT), 0, stream_, ctc_helper::identity<ProbT>(), probs_,
    ^~~~~~~~~~~~~~~~~~
.....
.....
/opt/rocm/hip/include/hip/hcc_detail/functional_grid_launch.hpp:138:13: note: candidate function [with Args = <ctc_helper::identity<float, float>, float *,
      float *, int, int>, F = void (*)(ctc_helper::identity<float, float>, float *, float *, int, int)] not viable: no overload of 'prepare_stable_SM_kernel'
      matching 'void (*)(ctc_helper::identity<float, float>, float *, float *, int, int)' for 1st argument
inline void hipLaunchKernelGGL(F kernel, const dim3& numBlocks, const dim3& dimBlocks,

для следующего фрагмента кода C++

hipLaunchKernelGGL((prepare_stable_SM_kernel<ProbT, VT>),
                   dim3(grid_size),
                   dim3(NT),
                   0,
                   stream_,
                   ctc_helper::identity<ProbT>(),
                   probs_,
                   denoms_,
                   out_dim_,
                   num_elements);

где hipLaunchKernelGGL определяется как

template <typename... Args, typename F = void (*)(Args...)>
inline void hipLaunchKernelGGL(F kernel,
                               const dim3& numBlocks,
                               const dim3& dimBlocks,
                               std::uint32_t sharedMemBytes,
                               hipStream_t stream,
                               Args... args) {

// ...
// ...
}

а также prepare_stable_SM_kernel определяется как

template <typename ProbT, int VT = 1, typename Op>
__global__ void prepare_stable_SM_kernel(Op f, ProbT* probs,
                                         const ProbT* const col_max,
                                         int alphabet_size,
                                         int count) {
// ...
}

Кто-нибудь, пожалуйста, помогите мне, предоставив несколько советов, чтобы решить эту проблему.

1 ответ

Решение

Эта ошибка была исправлена ​​добавлением третьего параметра ctc_helper::identity<ProbT> в prepare_stable_SM_kernel функция

Ссылка https://github.com/harish2704/warp-ctc/commit/c7ec45febc9c0077ffa35932b3d11a05daf8bf7c

Другие вопросы по тегам