From mboxrd@z Thu Jan  1 00:00:00 1970
Return-Path: <ffmpeg-devel-bounces@ffmpeg.org>
Received: from ffbox0-bg.ffmpeg.org (ffbox0-bg.ffmpeg.org [79.124.17.100])
	by master.gitmailbox.com (Postfix) with ESMTPS id A17104DCD3
	for <ffmpegdev@gitmailbox.com>; Wed,  4 Jun 2025 15:54:33 +0000 (UTC)
Received: from [127.0.1.1] (localhost [127.0.0.1])
	by ffbox0-bg.ffmpeg.org (Postfix) with ESMTP id B924268D442;
	Wed,  4 Jun 2025 18:54:09 +0300 (EEST)
Received: from vidala.pars.ee (vidala.pars.ee [116.203.72.101])
 by ffbox0-bg.ffmpeg.org (Postfix) with ESMTPS id D7BC168C50D
 for <ffmpeg-devel@ffmpeg.org>; Wed,  4 Jun 2025 18:54:02 +0300 (EEST)
DKIM-Signature: v=1; a=rsa-sha256; s=202405r; d=lynne.ee; c=relaxed/relaxed;
 h=Message-ID:Date:Subject:To:From; t=1749052442; bh=8aDz2WZIZzRBkyYbh+YTiTm
 r2xLiIsslWIPl9iZ9w4s=; b=mQeeRUVx/LnfdE1M2qtwrmIWNfoyVPgGs0sudccsq6s9tTmr3/
 NpJh9+izbImKFbspZcKVLFs1Vi0PFPZ+DNC5IkA0lq8wSD6Zn9hkUS2frHb/OnmsuQHoPQbWN0M
 r0wVaxqe9uucXX1Dv1cdqUZJgBknu8R03UPVQi2m2A2u4NfJq6JUl0v+NUJv/E9qP+lEJ6aP6oD
 PSraloXfYRS+3/Oxg9++6e4zkX0WB8qqa3w5yk6lQtqV1Eam0I75VhxHFRVilPqxkalYXl1JUM6
 F4pq9/K0qGeWEhLAusevjWGv4ctAKCV8F7AkFRpEx5ygKu1lMAW0Ych8WvWIudP63pw==;
DKIM-Signature: v=1; a=ed25519-sha256; s=202405e; d=lynne.ee; c=relaxed/relaxed;
 h=Message-ID:Date:Subject:To:From; t=1749052442; bh=8aDz2WZIZzRBkyYbh+YTiTm
 r2xLiIsslWIPl9iZ9w4s=; b=Q5toWfCr+JO5/d2QLzDOAqZVWC/jp/xvqsZz97lgtCKTRuZPkX
 3U4Q8Iag5UpmvFLFlw7bSdMDPa/8JRr7WDCA==;
From: Lynne <dev@lynne.ee>
To: ffmpeg-devel@ffmpeg.org
Date: Thu,  5 Jun 2025 00:53:49 +0900
Message-ID: <20250604155355.1681074-3-dev@lynne.ee>
X-Mailer: git-send-email 2.49.0.395.g12beb8f557c
In-Reply-To: <20250604155355.1681074-1-dev@lynne.ee>
References: <20250604155355.1681074-1-dev@lynne.ee>
MIME-Version: 1.0
Subject: [FFmpeg-devel] [PATCH v2 3/3] hwcontext_vulkan: add a setting to
 limit queues
X-BeenThere: ffmpeg-devel@ffmpeg.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: FFmpeg development discussions and patches <ffmpeg-devel.ffmpeg.org>
List-Unsubscribe: <https://ffmpeg.org/mailman/options/ffmpeg-devel>,
 <mailto:ffmpeg-devel-request@ffmpeg.org?subject=unsubscribe>
List-Archive: <https://ffmpeg.org/pipermail/ffmpeg-devel>
List-Post: <mailto:ffmpeg-devel@ffmpeg.org>
List-Help: <mailto:ffmpeg-devel-request@ffmpeg.org?subject=help>
List-Subscribe: <https://ffmpeg.org/mailman/listinfo/ffmpeg-devel>,
 <mailto:ffmpeg-devel-request@ffmpeg.org?subject=subscribe>
Reply-To: FFmpeg development discussions and patches <ffmpeg-devel@ffmpeg.org>
Cc: Lynne <dev@lynne.ee>
Content-Type: text/plain; charset="us-ascii"
Content-Transfer-Encoding: 7bit
Errors-To: ffmpeg-devel-bounces@ffmpeg.org
Sender: "ffmpeg-devel" <ffmpeg-devel-bounces@ffmpeg.org>
Archived-At: <https://master.gitmailbox.com/ffmpegdev/20250604155355.1681074-3-dev@lynne.ee/>
List-Archive: <https://master.gitmailbox.com/ffmpegdev/>
List-Post: <mailto:ffmpegdev@gitmailbox.com>

If its a problem, you'll likely want to set it to 1 than more fine-grained
control, which you can already do via the API.
---
 libavutil/hwcontext_vulkan.c | 21 +++++++++++++++++----
 1 file changed, 17 insertions(+), 4 deletions(-)

diff --git a/libavutil/hwcontext_vulkan.c b/libavutil/hwcontext_vulkan.c
index 243d68dc44..2d3a95d263 100644
--- a/libavutil/hwcontext_vulkan.c
+++ b/libavutil/hwcontext_vulkan.c
@@ -143,6 +143,9 @@ typedef struct VulkanDevicePriv {
     /* Disable multiplane images */
     int disable_multiplane;
 
+    /* Maximum queues */
+    int limit_queues;
+
     /* Nvidia */
     int dev_is_nvidia;
 } VulkanDevicePriv;
@@ -1509,13 +1512,18 @@ static int setup_queue_families(AVHWDeviceContext *ctx, VkDeviceCreateInfo *cd)
         if (i == hwctx->nb_qf) {                                         \
             hwctx->qf[i].idx = idx;                                      \
             hwctx->qf[i].num = qf[idx].queueFamilyProperties.queueCount; \
-            if (dprops.driverID == VK_DRIVER_ID_NVIDIA_PROPRIETARY) {    \
+            if (p->limit_queues ||                                       \
+                dprops.driverID == VK_DRIVER_ID_NVIDIA_PROPRIETARY) {    \
+                int max = p->limit_queues;                               \
                 if (type == VK_QUEUE_GRAPHICS_BIT)                       \
-                    hwctx->qf[i].num = FFMIN(hwctx->qf[i].num, 1);       \
+                    hwctx->qf[i].num = FFMIN(hwctx->qf[i].num,           \
+                                             max ? max : 1);             \
                 if (type == VK_QUEUE_COMPUTE_BIT)                        \
-                    hwctx->qf[i].num = FFMIN(hwctx->qf[i].num, 4);       \
+                    hwctx->qf[i].num = FFMIN(hwctx->qf[i].num,           \
+                                             max ? max : 4);             \
                 if (type == VK_QUEUE_TRANSFER_BIT)                       \
-                    hwctx->qf[i].num = FFMIN(hwctx->qf[i].num, 2);       \
+                    hwctx->qf[i].num = FFMIN(hwctx->qf[i].num,           \
+                                             max ? max : 2);             \
             }                                                            \
             hwctx->qf[i].flags = type;                                   \
             hwctx->qf[i].video_caps = vid_op;                            \
@@ -1722,6 +1730,11 @@ static int vulkan_device_create_internal(AVHWDeviceContext *ctx,
     if (opt_d)
         p->use_linear_images = strtol(opt_d->value, NULL, 10);
 
+    /* Limit queues to a given number if needed */
+    opt_d = av_dict_get(opts, "limit_queues", NULL, 0);
+    if (opt_d)
+        p->limit_queues = strtol(opt_d->value, NULL, 10);
+
     /* The disable_multiplane argument takes precedent over the option */
     p->disable_multiplane = disable_multiplane;
     if (!p->disable_multiplane) {
-- 
2.49.0.395.g12beb8f557c
_______________________________________________
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel

To unsubscribe, visit link above, or email
ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".