diff options
author | Kawrakow <iwankawrakow@gmail.com> | 2025-06-07 08:19:18 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2025-06-07 08:19:18 +0300 |
commit | 8c1d5a2033b5206fe5774115e860f3519a5d4f89 (patch) | |
tree | 7b710213767ee6b60c609a75875525dfc759ecc0 | |
parent | ffd87f282e76ff9d34f47efd6d3f6af2071d416a (diff) |
Fix #499 (#501)
Co-authored-by: Iwan Kawrakow <iwan.kawrakow@gmail.com>
-rw-r--r-- | ggml/src/ggml-cuda.cu | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/ggml/src/ggml-cuda.cu b/ggml/src/ggml-cuda.cu index 6bdeb465..0961e2bd 100644 --- a/ggml/src/ggml-cuda.cu +++ b/ggml/src/ggml-cuda.cu @@ -1273,7 +1273,8 @@ static void ggml_cuda_op_mul_mat_cublas( #ifdef GGML_CUDA_IQK_FORCE_BF16 if (ggml_is_quantized(src0->type) && ggml_is_contiguous(src0) && row_diff == src0->ne[1]) { to_bf16_cuda_t to_bf16_cuda = ggml_get_to_bf16_cuda(src0->type); - if (to_bf16_cuda) { + to_bf16_cuda_t to_bf16_cuda_1 = src1->type != GGML_TYPE_BF16 ? ggml_get_to_bf16_cuda(src1->type) : nullptr; + if (to_bf16_cuda && (src1->type == GGML_TYPE_BF16 || to_bf16_cuda_1)) { size_t ne = row_diff*ne00; ggml_cuda_pool_alloc<nv_bfloat16> src0_as_bf16(ctx.pool(id), ne); to_bf16_cuda(src0_dd_i, src0_as_bf16.get(), row_diff, ne00, stream); @@ -1282,9 +1283,7 @@ static void ggml_cuda_op_mul_mat_cublas( if (src1->type != GGML_TYPE_BF16) { size_t ne = src1_ncols*ne10; src1_as_bf16.alloc(ne); - to_bf16_cuda = ggml_get_to_bf16_cuda(src1->type); - GGML_ASSERT(to_bf16_cuda != nullptr); - to_bf16_cuda(src1_ddf_i, src1_as_bf16.get(), src1_ncols, ne10, stream); + to_bf16_cuda_1(src1_ddf_i, src1_as_bf16.get(), src1_ncols, ne10, stream); } const nv_bfloat16 * src1_ptr = src1->type == GGML_TYPE_BF16 ? (const nv_bfloat16 *) src1_ddf_i : src1_as_bf16.get(); const nv_bfloat16 * src0_ptr = src0_as_bf16.get(); |