1
0
mirror of https://github.com/mpv-player/mpv synced 2025-01-16 20:14:57 +00:00
mpv/video/out/vulkan/utils.c
Niklas Haas 96cdf5315e vo_gpu: vulkan: print libplacebo API ver
This normally gets printed by libplacebo itself when initializing the
context, but due to the way our code is structured (for convenience) we
don't have the log hook enabled by the time this function call is
relevant. So instead just print it manually as an easier work-around
than restructuring the code.
2020-07-16 09:41:09 +02:00

48 lines
1.1 KiB
C

#include "video/out/placebo/utils.h"
#include "utils.h"
bool mpvk_init(struct mpvk_ctx *vk, struct ra_ctx *ctx, const char *surface_ext)
{
vk->ctx = pl_context_create(PL_API_VER, NULL);
if (!vk->ctx)
goto error;
vk->pl_log = mp_log_new(ctx, ctx->log, "libplacebo");
mppl_ctx_set_log(vk->ctx, vk->pl_log, true);
mp_verbose(vk->pl_log, "Initialized libplacebo v%d\n", PL_API_VER);
const char *exts[] = {
VK_KHR_SURFACE_EXTENSION_NAME,
surface_ext,
};
vk->vkinst = pl_vk_inst_create(vk->ctx, &(struct pl_vk_inst_params) {
.debug = ctx->opts.debug,
.extensions = exts,
.num_extensions = MP_ARRAY_SIZE(exts),
});
if (!vk->vkinst)
goto error;
mppl_ctx_set_log(vk->ctx, vk->pl_log, false); // disable probing
return true;
error:
mpvk_uninit(vk);
return false;
}
void mpvk_uninit(struct mpvk_ctx *vk)
{
if (vk->surface) {
assert(vk->vkinst);
vkDestroySurfaceKHR(vk->vkinst->instance, vk->surface, NULL);
vk->surface = NULL;
}
pl_vk_inst_destroy(&vk->vkinst);
pl_context_destroy(&vk->ctx);
TA_FREEP(&vk->pl_log);
}