[FFmpeg-cvslog] avfilter/vf_paletteuse: don't constantly free and realloc internal frames
James Almer
git at videolan.org
Thu Jan 17 18:27:02 EET 2019
ffmpeg | branch: master | James Almer <jamrial at gmail.com> | Tue Jan 15 01:14:34 2019 -0300| [af05070ddf8e748132047b265cebd7f893fb37f9] | committer: James Almer
avfilter/vf_paletteuse: don't constantly free and realloc internal frames
Reviewed-by: Clément Bœsch <u at pkh.me>
Signed-off-by: James Almer <jamrial at gmail.com>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=af05070ddf8e748132047b265cebd7f893fb37f9
---
libavfilter/vf_paletteuse.c | 19 +++++++++++++------
1 file changed, 13 insertions(+), 6 deletions(-)
diff --git a/libavfilter/vf_paletteuse.c b/libavfilter/vf_paletteuse.c
index 5966f10685..ed128813d6 100644
--- a/libavfilter/vf_paletteuse.c
+++ b/libavfilter/vf_paletteuse.c
@@ -814,7 +814,7 @@ static void set_processing_window(enum diff_mode diff_mode,
int width = cur_src->width;
int height = cur_src->height;
- if (prv_src && diff_mode == DIFF_MODE_RECTANGLE) {
+ if (prv_src->data[0] && diff_mode == DIFF_MODE_RECTANGLE) {
int y;
int x_end = cur_src->width - 1,
y_end = cur_src->height - 1;
@@ -911,11 +911,10 @@ static int apply_palette(AVFilterLink *inlink, AVFrame *in, AVFrame **outf)
set_processing_window(s->diff_mode, s->last_in, in,
s->last_out, out, &x, &y, &w, &h);
- av_frame_free(&s->last_in);
- av_frame_free(&s->last_out);
- s->last_in = av_frame_clone(in);
- s->last_out = av_frame_clone(out);
- if (!s->last_in || !s->last_out ||
+ av_frame_unref(s->last_in);
+ av_frame_unref(s->last_out);
+ if (av_frame_ref(s->last_in, in) < 0 ||
+ av_frame_ref(s->last_out, out) < 0 ||
av_frame_make_writable(s->last_in) < 0) {
av_frame_free(&in);
av_frame_free(&out);
@@ -1086,6 +1085,14 @@ static av_cold int init(AVFilterContext *ctx)
{
PaletteUseContext *s = ctx->priv;
+ s->last_in = av_frame_alloc();
+ s->last_out = av_frame_alloc();
+ if (!s->last_in || !s->last_out) {
+ av_frame_free(&s->last_in);
+ av_frame_free(&s->last_out);
+ return AVERROR(ENOMEM);
+ }
+
s->set_frame = set_frame_lut[s->color_search_method][s->dither];
if (s->dither == DITHERING_BAYER) {
More information about the ffmpeg-cvslog
mailing list