[vlc-commits] ci_filters: rework CVPX to CVPX conversions
Thomas Guillem
git at videolan.org
Fri Feb 9 19:46:01 CET 2018
vlc/vlc-3.0 | branch: master | Thomas Guillem <thomas at gllm.fr> | Fri Feb 9 17:12:54 2018 +0100| [78eb0e166e8c82ca17da62c6cbc94f2a1a030c04] | committer: Thomas Guillem
ci_filters: rework CVPX to CVPX conversions
CD 155f0680-aa44-49a8-a2ec-e1a341fc55fe
These 2 extra conversions (CVPX_X to CVPX_RGBA and CVPX_RGBA to CVPX_X) will be
done only if ci_filters doesn't accept the input chroma. This won't happen
often since videotoolbox will most likely output chromas that can be accepted
by ci_filters.
This was not never touched since the initial commit and was not up to date.
(cherry picked from commit 4e803da88615704ab7b2ddcd581c8d33267db663)
Signed-off-by: Thomas Guillem <thomas at gllm.fr>
> http://git.videolan.org/gitweb.cgi/vlc/vlc-3.0.git/?a=commit;h=78eb0e166e8c82ca17da62c6cbc94f2a1a030c04
---
modules/video_chroma/cvpx.c | 73 ++++++++++++-----------
modules/video_filter/ci_filters.m | 118 ++++++++++++++++++--------------------
2 files changed, 95 insertions(+), 96 deletions(-)
diff --git a/modules/video_chroma/cvpx.c b/modules/video_chroma/cvpx.c
index 88238f4020..62eb8885f4 100644
--- a/modules/video_chroma/cvpx.c
+++ b/modules/video_chroma/cvpx.c
@@ -45,40 +45,29 @@ static int Open_CVPX_to_CVPX(vlc_object_t *);
static void Close_CVPX_to_CVPX(vlc_object_t *);
#endif
-vlc_module_begin ()
- set_description("Conversions from/to CoreVideo buffers")
- set_capability("video converter", 10)
- set_callbacks(Open, Close)
-
-#if TARGET_OS_IPHONE
-vlc_module_end ()
-
struct filter_sys_t
{
- filter_t *p_sw_filter;
CVPixelBufferPoolRef pool;
+ union
+ {
+ filter_t *p_sw_filter;
+#if !TARGET_OS_IPHONE
+ VTPixelTransferSessionRef vttransfer;
+#endif
+ };
};
-#else
+vlc_module_begin ()
+ set_description("Conversions from/to CoreVideo buffers")
+ set_capability("video converter", 10)
+ set_callbacks(Open, Close)
+#if !TARGET_OS_IPHONE
add_submodule()
set_description("Conversions between CoreVideo buffers")
set_callbacks(Open_CVPX_to_CVPX, Close_CVPX_to_CVPX)
+#endif
vlc_module_end ()
-struct filter_sys_t
-{
- union
- {
- struct
- {
- filter_t *p_sw_filter;
- CVPixelBufferPoolRef pool;
- };
-
- VTPixelTransferSessionRef vttransfer;
- };
-};
-#endif
/********************************
* CVPX to/from I420 conversion *
@@ -334,6 +323,8 @@ error:
static picture_t *
Filter(filter_t *filter, picture_t *src)
{
+ filter_sys_t *p_sys = filter->p_sys;
+
CVPixelBufferRef src_cvpx = cvpxpic_get_ref(src);
assert(src_cvpx);
@@ -344,8 +335,13 @@ Filter(filter_t *filter, picture_t *src)
return NULL;
}
- CVPixelBufferRef dst_cvpx = cvpxpic_get_ref(dst);
- assert(dst_cvpx);
+ CVPixelBufferRef dst_cvpx = cvpxpool_new_cvpx(p_sys->pool);
+ if (dst_cvpx == NULL)
+ {
+ picture_Release(src);
+ picture_Release(dst);
+ return NULL;
+ }
if (VTPixelTransferSessionTransferImage(filter->p_sys->vttransfer,
src_cvpx, dst_cvpx) != noErr)
@@ -355,6 +351,8 @@ Filter(filter_t *filter, picture_t *src)
return NULL;
}
+ cvpxpic_attach(dst, dst_cvpx);
+
picture_CopyProperties(dst, src);
picture_Release(src);
return dst;
@@ -383,19 +381,26 @@ Open_CVPX_to_CVPX(vlc_object_t *obj)
CHECK_CHROMA(filter->fmt_out.video.i_chroma)
#undef CHECK_CHROMA
- filter->p_sys = calloc(1, sizeof(filter_sys_t));
- if (!filter->p_sys)
+ filter_sys_t *p_sys = filter->p_sys = calloc(1, sizeof(filter_sys_t));
+ if (!p_sys)
return VLC_ENOMEM;
- if (VTPixelTransferSessionCreate(NULL, &filter->p_sys->vttransfer)
+ if (VTPixelTransferSessionCreate(NULL, &p_sys->vttransfer)
!= noErr)
{
- free(filter->p_sys);
+ free(p_sys);
return VLC_EGENERIC;
}
- filter->pf_video_filter = Filter;
+ if ((p_sys->pool = cvpxpool_create(&filter->fmt_out.video, 3)) == NULL)
+ {
+ VTPixelTransferSessionInvalidate(p_sys->vttransfer);
+ CFRelease(p_sys->vttransfer);
+ free(p_sys);
+ return VLC_EGENERIC;
+ }
+ filter->pf_video_filter = Filter;
return VLC_SUCCESS;
}
@@ -403,9 +408,11 @@ static void
Close_CVPX_to_CVPX(vlc_object_t *obj)
{
filter_t *filter = (filter_t *)obj;
+ filter_sys_t *p_sys = filter->p_sys;
- VTPixelTransferSessionInvalidate(filter->p_sys->vttransfer);
- CFRelease(filter->p_sys->vttransfer);
+ VTPixelTransferSessionInvalidate(p_sys->vttransfer);
+ CFRelease(p_sys->vttransfer);
+ CVPixelBufferPoolRelease(p_sys->pool);
free(filter->p_sys);
}
diff --git a/modules/video_filter/ci_filters.m b/modules/video_filter/ci_filters.m
index 579ac81630..8a8f7a3527 100644
--- a/modules/video_filter/ci_filters.m
+++ b/modules/video_filter/ci_filters.m
@@ -87,6 +87,7 @@ struct ci_filters_ctx
CVPixelBufferPoolRef outconv_cvpx_pool;
CIContext * ci_ctx;
struct filter_chain * fchain;
+ filter_t * src_converter;
filter_t * dst_converter;
};
@@ -377,6 +378,13 @@ Filter(filter_t *filter, picture_t *src)
}
CFRelease(cvpx);
+ if (ctx->src_converter)
+ {
+ src = ctx->dst_converter->pf_video_filter(ctx->src_converter, src);
+ if (!src)
+ return NULL;
+ }
+
@autoreleasepool {
CIImage *ci_img = [CIImage imageWithCVImageBuffer: cvpxpic_get_ref(src)];
if (!ci_img)
@@ -515,80 +523,59 @@ Open_CreateFilters(filter_t *filter, struct filter_chain **p_last_filter,
return VLC_SUCCESS;
}
-static picture_t *
-CVPX_buffer_new(filter_t *converter)
-{
- CVPixelBufferPoolRef pool = converter->owner.sys;
- CVPixelBufferRef cvpx = cvpxpool_new_cvpx(pool);
- if (!cvpx)
- return NULL;
-
- picture_t *pic = picture_NewFromFormat(&converter->fmt_out.video);
- if (!pic || cvpxpic_attach(pic, cvpx))
- {
- CFRelease(cvpx);
- return NULL;
- }
- CFRelease(cvpx);
-
- return pic;
-}
-
static void
Close_RemoveConverters(filter_t *filter, struct ci_filters_ctx *ctx)
{
VLC_UNUSED(filter);
+ if (ctx->src_converter)
+ {
+ module_unneed(ctx->src_converter, ctx->src_converter->p_module);
+ vlc_object_release(ctx->src_converter);
+ }
if (ctx->dst_converter)
{
module_unneed(ctx->dst_converter, ctx->dst_converter->p_module);
vlc_object_release(ctx->dst_converter);
- CVPixelBufferPoolRelease(ctx->outconv_cvpx_pool);
}
}
-static int
-Open_AddConverter(filter_t *filter, struct ci_filters_ctx *ctx)
+static picture_t *CVPX_to_CVPX_converter_BufferNew(filter_t *p_filter)
{
- ctx->cvpx_pool_fmt = filter->fmt_in.video;
- ctx->cvpx_pool_fmt.i_chroma = VLC_CODEC_CVPX_BGRA;
- ctx->cvpx_pool = cvpxpool_create(&ctx->cvpx_pool_fmt, 3);
- if (!ctx->cvpx_pool)
- goto error;
-
- ctx->dst_converter = vlc_object_create(filter, sizeof(filter_t));
- if (!ctx->dst_converter)
- goto error;
+ return picture_NewFromFormat(&p_filter->fmt_out.video);
+}
- ctx->dst_converter->fmt_in = filter->fmt_out;
- ctx->dst_converter->fmt_out = filter->fmt_out;
- ctx->dst_converter->fmt_in.video.i_chroma =
- ctx->dst_converter->fmt_in.i_codec = VLC_CODEC_CVPX_BGRA;
+static filter_t *
+CVPX_to_CVPX_converter_Create(filter_t *filter, bool to_rgba)
+{
+ filter_t *converter = vlc_object_create(filter, sizeof(filter_t));
+ if (!converter)
+ return NULL;
- ctx->outconv_cvpx_pool =
- cvpxpool_create(&filter->fmt_out.video, 2);
- if (!ctx->outconv_cvpx_pool)
- goto error;
+ converter->fmt_in = filter->fmt_out;
+ converter->fmt_out = filter->fmt_out;
- ctx->dst_converter->owner.sys = ctx->outconv_cvpx_pool;
- ctx->dst_converter->owner.video.buffer_new = CVPX_buffer_new;
+ if (to_rgba)
+ {
+ converter->fmt_out.video.i_chroma =
+ converter->fmt_out.i_codec = VLC_CODEC_CVPX_BGRA;
+ }
+ else
+ {
+ converter->fmt_in.video.i_chroma =
+ converter->fmt_in.i_codec = VLC_CODEC_CVPX_BGRA;
+ }
- ctx->dst_converter->p_module =
- module_need(ctx->dst_converter, "video converter", NULL, false);
- if (!ctx->dst_converter->p_module)
- goto error;
+ converter->owner.video.buffer_new = CVPX_to_CVPX_converter_BufferNew;
- return VLC_SUCCESS;
-error:
- if (ctx->dst_converter)
+ converter->p_module = module_need(converter, "video converter", NULL, false);
+ if (!converter->p_module)
{
- if (ctx->dst_converter->p_module)
- module_unneed(ctx->dst_converter, ctx->dst_converter->p_module);
- vlc_object_release(ctx->dst_converter);
- if (ctx->outconv_cvpx_pool)
- CVPixelBufferPoolRelease(ctx->outconv_cvpx_pool);
+ vlc_object_release(converter);
+ return NULL;
}
- return VLC_EGENERIC;
+
+ return converter;
}
static int
@@ -626,10 +613,19 @@ Open(vlc_object_t *obj, char const *psz_filter)
if (!ctx)
goto error;
+ ctx->cvpx_pool_fmt = filter->fmt_out.video;
+
if (filter->fmt_in.video.i_chroma != VLC_CODEC_CVPX_NV12
- && filter->fmt_in.video.i_chroma != VLC_CODEC_CVPX_BGRA
- && Open_AddConverter(filter, ctx))
- goto error;
+ && filter->fmt_in.video.i_chroma != VLC_CODEC_CVPX_BGRA)
+ {
+ ctx->src_converter =
+ CVPX_to_CVPX_converter_Create(filter, true);
+ ctx->dst_converter = ctx->src_converter ?
+ CVPX_to_CVPX_converter_Create(filter, false) : NULL;
+ if (!ctx->src_converter || !ctx->dst_converter)
+ goto error;
+ ctx->cvpx_pool_fmt.i_chroma = VLC_CODEC_CVPX_BGRA;
+ }
#if !TARGET_OS_IPHONE
CGLContextObj glctx = var_InheritAddress(filter, "macosx-glcontext");
@@ -654,13 +650,9 @@ Open(vlc_object_t *obj, char const *psz_filter)
if (!ctx->ci_ctx)
goto error;
+ ctx->cvpx_pool = cvpxpool_create(&ctx->cvpx_pool_fmt, 2);
if (!ctx->cvpx_pool)
- {
- ctx->cvpx_pool_fmt = filter->fmt_out.video;
- ctx->cvpx_pool = cvpxpool_create(&ctx->cvpx_pool_fmt, 2);
- if (!ctx->cvpx_pool)
- goto error;
- }
+ goto error;
if (Open_CreateFilters(filter, &ctx->fchain, filter_types))
goto error;
More information about the vlc-commits
mailing list