Переглянути джерело

[SYCL] fix scratch size of softmax (#8642)

luoyu-intel 1 рік тому
батько
коміт
063d99ad11
1 змінених файлів з 2 додано та 1 видалено
  1. 2 1
      ggml/src/ggml-sycl/softmax.cpp

+ 2 - 1
ggml/src/ggml-sycl/softmax.cpp

@@ -152,7 +152,8 @@ static void soft_max_f32_sycl(const float * x, const float * mask,
 
     const sycl::range<3> block_dims(1, 1, nth);
     const sycl::range<3> block_nums(1, 1, nrows_x);
-    const size_t n_local_scratch = (GGML_PAD(ncols_x, WARP_SIZE) + WARP_SIZE);
+    const size_t n_val_tmp = nth / WARP_SIZE;
+    const size_t n_local_scratch = (GGML_PAD(ncols_x, WARP_SIZE) + n_val_tmp);
 
     const uint32_t n_head_kv   = nrows_x/nrows_y;
     const uint32_t n_head_log2 = 1u << (uint32_t) floorf(log2f((float) n_head_kv));