From: Xuan-Son Nguyen Date: Thu, 21 Aug 2025 05:32:26 +0000 (+0200) Subject: ggml : fix condition of im2col on Metal backend (#15460) X-Git-Tag: upstream/0.0.6527~303 X-Git-Url: https://git.djapps.eu/?a=commitdiff_plain;h=945e1f12a6b586ebf82fa4fd7f347225e58174c5;p=pkg%2Fggml%2Fsources%2Fllama.cpp ggml : fix condition of im2col on Metal backend (#15460) --- diff --git a/ggml/src/ggml-metal/ggml-metal.m b/ggml/src/ggml-metal/ggml-metal.m index cb8eff4a..7c70d352 100644 --- a/ggml/src/ggml-metal/ggml-metal.m +++ b/ggml/src/ggml-metal/ggml-metal.m @@ -1846,7 +1846,7 @@ static bool ggml_metal_supports_op(const struct ggml_backend_metal_device_contex case GGML_OP_ROPE: return true; case GGML_OP_IM2COL: - return op->src[0]->type == GGML_TYPE_F16; + return op->src[1]->type == GGML_TYPE_F32 && (op->type == GGML_TYPE_F16 || op->type == GGML_TYPE_F32); case GGML_OP_POOL_1D: return false; case GGML_OP_UPSCALE: @@ -4703,7 +4703,6 @@ static int ggml_metal_encode_node( { GGML_ASSERT(ggml_is_contiguous(src0)); GGML_ASSERT(ggml_is_contiguous(src1)); - GGML_ASSERT(src0->type == GGML_TYPE_F16); GGML_ASSERT(src1->type == GGML_TYPE_F32); GGML_ASSERT( dst->type == GGML_TYPE_F16 || dst->type == GGML_TYPE_F32);