avoid graphics queues on small GPUs

This commit is contained in:
Ruben Ortlam 2026-03-15 18:08:45 +01:00
parent 6c48fa46f6
commit c68b2428b3
1 changed files with 2 additions and 1 deletions

View File

@ -4982,7 +4982,8 @@ static vk_device ggml_vk_get_device(size_t idx) {
// Try to find a non-graphics compute queue and transfer-focused queues
// On AMD GPUs with RADV driver, the graphics queue seems to be faster, so don't avoid it
const vk::QueueFlagBits graphics_flag = (device->vendor_id == VK_VENDOR_ID_AMD && device->driver_id == vk::DriverId::eMesaRadv) ? (vk::QueueFlagBits)0 : vk::QueueFlagBits::eGraphics;
// Avoid on small GPUs to prevent interfering with graphics tasks
const vk::QueueFlagBits graphics_flag = (device->vendor_id == VK_VENDOR_ID_AMD && device->driver_id == vk::DriverId::eMesaRadv && device->shader_core_count > 16) ? (vk::QueueFlagBits)0 : vk::QueueFlagBits::eGraphics;
const uint32_t compute_queue_family_index = ggml_vk_find_queue_family_index(queue_family_props, vk::QueueFlagBits::eCompute, graphics_flag, -1, 1);
const uint32_t transfer_queue_family_index = ggml_vk_find_queue_family_index(queue_family_props, vk::QueueFlagBits::eTransfer, vk::QueueFlagBits::eCompute | graphics_flag, compute_queue_family_index, 1);