* [FFmpeg-devel] [PATCH v3] lavfi/vf_libplacebo: allow operation without avhwdevice
@ 2023-05-13 15:42 Niklas Haas
2023-05-13 18:00 ` Lynne
0 siblings, 1 reply; 2+ messages in thread
From: Niklas Haas @ 2023-05-13 15:42 UTC (permalink / raw)
To: ffmpeg-devel; +Cc: Niklas Haas
From: Niklas Haas <git@haasn.dev>
Recent versions of libplacebo have required Vulkan versions incompatible
with lavu Vulkan hwcontexts. While this is expected to change
eventually, breaking vf_libplacebo every time there is such a transition
period is obviously undesired behavior, as the following sea of bug
reports shows.
This commit adds a fallback path for init_vulkan failures which simply
creates an internal device if there was no user-supplied Vulkan hwaccel.
Useful when no interop with lavu vulkan hwframes is needed or desired,
and makes using this filter easier inside certain applications.
Fixes: https://github.com/haasn/libplacebo/issues/170
Fixes: https://github.com/mpv-player/mpv/issues/9589#issuecomment-1535432185
Fixes: https://github.com/mpv-player/mpv/issues/11363
Fixes: https://github.com/mpv-player/mpv/issues/11685#issuecomment-1546627082
Closes: https://code.videolan.org/videolan/libplacebo/-/issues/270
---
libavfilter/vf_libplacebo.c | 87 +++++++++++++++++++------------------
1 file changed, 45 insertions(+), 42 deletions(-)
diff --git a/libavfilter/vf_libplacebo.c b/libavfilter/vf_libplacebo.c
index 6fe3e0ea882..8387f4dd47f 100644
--- a/libavfilter/vf_libplacebo.c
+++ b/libavfilter/vf_libplacebo.c
@@ -351,56 +351,47 @@ fail:
return err;
}
-static int init_vulkan(AVFilterContext *avctx)
+static int init_vulkan(AVFilterContext *avctx, const AVVulkanDeviceContext *hwctx)
{
int err = 0;
LibplaceboContext *s = avctx->priv;
- const AVHWDeviceContext *avhwctx;
- const AVVulkanDeviceContext *hwctx;
uint8_t *buf = NULL;
size_t buf_len;
- if (!avctx->hw_device_ctx) {
- av_log(s, AV_LOG_ERROR, "Missing vulkan hwdevice for vf_libplacebo.\n");
- return AVERROR(EINVAL);
- }
-
- avhwctx = (AVHWDeviceContext *) avctx->hw_device_ctx->data;
- if (avhwctx->type != AV_HWDEVICE_TYPE_VULKAN) {
- av_log(s, AV_LOG_ERROR, "Expected vulkan hwdevice for vf_libplacebo, got %s.\n",
- av_hwdevice_get_type_name(avhwctx->type));
- return AVERROR(EINVAL);
+ if (hwctx) {
+ /* Import libavfilter vulkan context into libplacebo */
+ s->vulkan = pl_vulkan_import(s->log, pl_vulkan_import_params(
+ .instance = hwctx->inst,
+ .get_proc_addr = hwctx->get_proc_addr,
+ .phys_device = hwctx->phys_dev,
+ .device = hwctx->act_dev,
+ .extensions = hwctx->enabled_dev_extensions,
+ .num_extensions = hwctx->nb_enabled_dev_extensions,
+ .features = &hwctx->device_features,
+ .queue_graphics = {
+ .index = hwctx->queue_family_index,
+ .count = hwctx->nb_graphics_queues,
+ },
+ .queue_compute = {
+ .index = hwctx->queue_family_comp_index,
+ .count = hwctx->nb_comp_queues,
+ },
+ .queue_transfer = {
+ .index = hwctx->queue_family_tx_index,
+ .count = hwctx->nb_tx_queues,
+ },
+ /* This is the highest version created by hwcontext_vulkan.c */
+ .max_api_version = VK_API_VERSION_1_2,
+ ));
+ } else {
+ s->vulkan = pl_vulkan_create(s->log, pl_vulkan_params(
+ .queue_count = 0, /* enable all queues for parallelization */
+ ));
}
- hwctx = avhwctx->hwctx;
-
- /* Import libavfilter vulkan context into libplacebo */
- s->vulkan = pl_vulkan_import(s->log, pl_vulkan_import_params(
- .instance = hwctx->inst,
- .get_proc_addr = hwctx->get_proc_addr,
- .phys_device = hwctx->phys_dev,
- .device = hwctx->act_dev,
- .extensions = hwctx->enabled_dev_extensions,
- .num_extensions = hwctx->nb_enabled_dev_extensions,
- .features = &hwctx->device_features,
- .queue_graphics = {
- .index = hwctx->queue_family_index,
- .count = hwctx->nb_graphics_queues,
- },
- .queue_compute = {
- .index = hwctx->queue_family_comp_index,
- .count = hwctx->nb_comp_queues,
- },
- .queue_transfer = {
- .index = hwctx->queue_family_tx_index,
- .count = hwctx->nb_tx_queues,
- },
- /* This is the highest version created by hwcontext_vulkan.c */
- .max_api_version = VK_API_VERSION_1_2,
- ));
-
if (!s->vulkan) {
- av_log(s, AV_LOG_ERROR, "Failed importing vulkan device to libplacebo!\n");
+ av_log(s, AV_LOG_ERROR, "Failed %s Vulkan device!\n",
+ hwctx ? "importing" : "creating");
err = AVERROR_EXTERNAL;
goto fail;
}
@@ -695,10 +686,17 @@ static int libplacebo_query_format(AVFilterContext *ctx)
{
int err;
LibplaceboContext *s = ctx->priv;
+ const AVVulkanDeviceContext *vkhwctx = NULL;
const AVPixFmtDescriptor *desc = NULL;
AVFilterFormats *infmts = NULL, *outfmts = NULL;
- RET(init_vulkan(ctx));
+ if (ctx->hw_device_ctx) {
+ const AVHWDeviceContext *avhwctx = (void *) ctx->hw_device_ctx->data;
+ if (avhwctx->type == AV_HWDEVICE_TYPE_VULKAN)
+ vkhwctx = avhwctx->hwctx;
+ }
+
+ RET(init_vulkan(ctx, vkhwctx));
while ((desc = av_pix_fmt_desc_next(desc))) {
enum AVPixelFormat pixfmt = av_pix_fmt_desc_get_id(desc);
@@ -710,6 +708,11 @@ static int libplacebo_query_format(AVFilterContext *ctx)
continue;
#endif
+ if (pixfmt == AV_PIX_FMT_VULKAN) {
+ if (!vkhwctx || vkhwctx->act_dev != s->vulkan->device)
+ continue;
+ }
+
if (!pl_test_pixfmt(s->gpu, pixfmt))
continue;
--
2.40.1
_______________________________________________
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".
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: [FFmpeg-devel] [PATCH v3] lavfi/vf_libplacebo: allow operation without avhwdevice
2023-05-13 15:42 [FFmpeg-devel] [PATCH v3] lavfi/vf_libplacebo: allow operation without avhwdevice Niklas Haas
@ 2023-05-13 18:00 ` Lynne
0 siblings, 0 replies; 2+ messages in thread
From: Lynne @ 2023-05-13 18:00 UTC (permalink / raw)
To: FFmpeg development discussions and patches
May 13, 2023, 17:42 by ffmpeg@haasn.xyz:
> From: Niklas Haas <git@haasn.dev>
>
> Recent versions of libplacebo have required Vulkan versions incompatible
> with lavu Vulkan hwcontexts. While this is expected to change
> eventually, breaking vf_libplacebo every time there is such a transition
> period is obviously undesired behavior, as the following sea of bug
> reports shows.
>
> This commit adds a fallback path for init_vulkan failures which simply
> creates an internal device if there was no user-supplied Vulkan hwaccel.
> Useful when no interop with lavu vulkan hwframes is needed or desired,
> and makes using this filter easier inside certain applications.
>
> Fixes: https://github.com/haasn/libplacebo/issues/170
> Fixes: https://github.com/mpv-player/mpv/issues/9589#issuecomment-1535432185
> Fixes: https://github.com/mpv-player/mpv/issues/11363
> Fixes: https://github.com/mpv-player/mpv/issues/11685#issuecomment-1546627082
> Closes: https://code.videolan.org/videolan/libplacebo/-/issues/270
>
Looks good to me now
Thanks
_______________________________________________
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".
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2023-05-13 18:00 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-05-13 15:42 [FFmpeg-devel] [PATCH v3] lavfi/vf_libplacebo: allow operation without avhwdevice Niklas Haas
2023-05-13 18:00 ` Lynne
Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
This inbox may be cloned and mirrored by anyone:
git clone --mirror https://master.gitmailbox.com/ffmpegdev/0 ffmpegdev/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 ffmpegdev ffmpegdev/ https://master.gitmailbox.com/ffmpegdev \
ffmpegdev@gitmailbox.com
public-inbox-index ffmpegdev
Example config snippet for mirrors.
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git