X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=libavfilter%2Ff_reverse.c;h=1e27264dd6204ad762437ca8844a767e77991c2d;hb=f61e9f8aef3a13fe976c241f828fca4222d8e922;hp=5f27927075562c2467ad5e58e5fc65f7443a799c;hpb=d0c43e32427ec1efac364be0987a6aafa695527f;p=ffmpeg diff --git a/libavfilter/f_reverse.c b/libavfilter/f_reverse.c index 5f279270755..1e27264dd62 100644 --- a/libavfilter/f_reverse.c +++ b/libavfilter/f_reverse.c @@ -58,6 +58,11 @@ static av_cold void uninit(AVFilterContext *ctx) { ReverseContext *s = ctx->priv; + while (s->nb_frames > 0) { + av_frame_free(&s->frames[s->nb_frames - 1]); + s->nb_frames--; + } + av_freep(&s->pts); av_freep(&s->frames); } @@ -103,6 +108,7 @@ static int request_frame(AVFilterLink *outlink) AVFrame *out = s->frames[s->nb_frames - 1]; out->pts = s->pts[s->flush_idx++]; ret = ff_filter_frame(outlink, out); + s->frames[s->nb_frames - 1] = NULL; s->nb_frames--; } @@ -262,6 +268,7 @@ static int areverse_request_frame(AVFilterLink *outlink) else reverse_samples_packed(out); ret = ff_filter_frame(outlink, out); + s->frames[s->nb_frames - 1] = NULL; s->nb_frames--; }