summaryrefslogtreecommitdiff
path: root/libavutil
diff options
context:
space:
mode:
authorLynne <dev@lynne.ee>2020-05-14 23:59:22 +0100
committerLynne <dev@lynne.ee>2020-05-23 19:07:37 +0100
commit3dd3d1b7fb5ebcac3d2a7598d84e6f5c5723e867 (patch)
treea9c48504883fe28b7c819de50faf95239b943d32 /libavutil
parentc0b0807871985c1d136a7ffd1470aa3e5155b422 (diff)
downloadffmpeg-3dd3d1b7fb5ebcac3d2a7598d84e6f5c5723e867.tar.gz
hwcontext_vulkan: support user-provided pools
If an external pool was provided we skipped all of frames init, including the exec context.
Diffstat (limited to 'libavutil')
-rw-r--r--libavutil/hwcontext_vulkan.c19
1 files changed, 10 insertions, 9 deletions
diff --git a/libavutil/hwcontext_vulkan.c b/libavutil/hwcontext_vulkan.c
index 800db74f74..b2c1e66ff3 100644
--- a/libavutil/hwcontext_vulkan.c
+++ b/libavutil/hwcontext_vulkan.c
@@ -1697,9 +1697,6 @@ static int vulkan_frames_init(AVHWFramesContext *hwfc)
AVVulkanDeviceContext *dev_hwctx = hwfc->device_ctx->hwctx;
VulkanDevicePriv *p = hwfc->device_ctx->internal->priv;
- if (hwfc->pool)
- return 0;
-
/* Default pool flags */
hwctx->tiling = hwctx->tiling ? hwctx->tiling : p->use_linear_images ?
VK_IMAGE_TILING_LINEAR : VK_IMAGE_TILING_OPTIMAL;
@@ -1722,12 +1719,16 @@ static int vulkan_frames_init(AVHWFramesContext *hwfc)
vulkan_frame_free(hwfc, (uint8_t *)f);
- hwfc->internal->pool_internal = av_buffer_pool_init2(sizeof(AVVkFrame),
- hwfc, vulkan_pool_alloc,
- NULL);
- if (!hwfc->internal->pool_internal) {
- free_exec_ctx(hwfc->device_ctx, &p->cmd);
- return AVERROR(ENOMEM);
+ /* If user did not specify a pool, hwfc->pool will be set to the internal one
+ * in hwcontext.c just after this gets called */
+ if (!hwfc->pool) {
+ hwfc->internal->pool_internal = av_buffer_pool_init2(sizeof(AVVkFrame),
+ hwfc, vulkan_pool_alloc,
+ NULL);
+ if (!hwfc->internal->pool_internal) {
+ free_exec_ctx(hwfc->device_ctx, &p->cmd);
+ return AVERROR(ENOMEM);
+ }
}
return 0;