summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ggml.c17
1 files changed, 16 insertions, 1 deletions
diff --git a/ggml.c b/ggml.c
index a15d41ad..9a83059d 100644
--- a/ggml.c
+++ b/ggml.c
@@ -12368,7 +12368,22 @@ static void ggml_compute_forward_mul_mat(
// compute by src0 rows
#if GGML_USE_IQK_MULMAT
- if (ggml_is_contiguous(src1) && dst->type == GGML_TYPE_F32) {
+ if (dst->type == GGML_TYPE_F32 && params->type == GGML_TASK_TYPE_COMPUTE && (ne12*ne13)%nth == 0) {
+ int counter = 0;
+ for (int64_t i13 = 0; i13 < ne13; i13++) {
+ for (int64_t i12 = 0; i12 < ne12; i12++) {
+ if (counter++ % nth == ith) {
+ if (!iqk_mul_mat(params->type, ne01, ne11, ne00,
+ src0->type, (const char *)src0->data + i12/r2*nb02 + i13/r3*nb03, nb01/ggml_type_size(src0->type),
+ src1->type, (const char *)src1->data + i12*nb12 + i13*nb13, nb11/ggml_type_size(src1->type),
+ (float *)((char *)dst->data + i12*nb2 + i13*nb3), nb1/ggml_type_size(dst->type),
+ 0, 1)) goto IQK_MulMat_Not_Available1;
+ }
+ }
+ }
+ return;
+ }
+ if (dst->type == GGML_TYPE_F32) {
for (int64_t i13 = 0; i13 < ne13; i13++)
for (int64_t i12 = 0; i12 < ne12; i12++)
if (!iqk_mul_mat(params->type, ne01, ne11, ne00,