Просмотр исходного кода

metal : adjust support conditions for norm operators (#11671)

cont #11659

ggml-ci
Georgi Gerganov 11 месяцев назад
Родитель
Сommit
d774ab3acc
1 измененных файлов с 2 добавлено и 2 удалено
  1. 2 2
      ggml/src/ggml-metal/ggml-metal.m

+ 2 - 2
ggml/src/ggml-metal/ggml-metal.m

@@ -1204,13 +1204,13 @@ static bool ggml_metal_supports_op(const struct ggml_backend_metal_device_contex
         case GGML_OP_SUM_ROWS:
         case GGML_OP_SOFT_MAX:
         case GGML_OP_GROUP_NORM:
-            return has_simdgroup_reduction;
+            return has_simdgroup_reduction && ggml_is_contiguous(op->src[0]);
         case GGML_OP_RMS_NORM:
             return has_simdgroup_reduction && (op->ne[0] % 4 == 0 && ggml_is_contiguous_1(op->src[0]));
         case GGML_OP_ARGMAX:
             return true;
         case GGML_OP_NORM:
-            return has_simdgroup_reduction && ggml_is_contiguous(op->src[0]);
+            return has_simdgroup_reduction && (op->ne[0] % 4 == 0 && ggml_is_contiguous_1(op->src[0]));
         case GGML_OP_ROPE:
             {
                 const int mode = ((const int32_t *) op->op_params)[2];