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

vulkan: disable large mmv subgroups on older Nvidia GPUs (#15717)

Ruben Ortlam 4 месяцев назад
Родитель
Сommit
fec7911f8f
1 измененных файлов с 1 добавлено и 1 удалено
  1. 1 1
      ggml/src/ggml-vulkan/ggml-vulkan.cpp

+ 1 - 1
ggml/src/ggml-vulkan/ggml-vulkan.cpp

@@ -4662,7 +4662,7 @@ static vk_pipeline ggml_vk_get_dequantize_mul_mat_vec(ggml_backend_vk_context *
 
     // heuristic to choose workgroup size
     uint32_t dmmv_wg = DMMV_WG_SIZE_SUBGROUP;
-    if (ctx->device->vendor_id == VK_VENDOR_ID_NVIDIA || ctx->device->vendor_id == VK_VENDOR_ID_INTEL) {
+    if ((ctx->device->vendor_id == VK_VENDOR_ID_NVIDIA && ctx->device->architecture != vk_device_architecture::NVIDIA_PRE_TURING) || ctx->device->vendor_id == VK_VENDOR_ID_INTEL) {
         // Prefer larger workgroups when M is small, to spread the work out more
         // and keep more SMs busy.
         // q6_k seems to prefer small workgroup size even for "medium" values of M.