goto done;
}
- res = av_packet_ref(s->cache[s->n_cache++], in);
- if (res < 0)
- goto done;
+ av_packet_move_ref(s->cache[s->n_cache++], in);
if (invisible) {
res = AVERROR(EAGAIN);
return 0;
}
+static void vp9_superframe_flush(AVBSFContext *ctx)
+{
+ VP9BSFContext *s = ctx->priv_data;
+ int n;
+
+ // unref cached data
+ for (n = 0; n < s->n_cache; n++)
+ av_packet_unref(s->cache[n]);
+ s->n_cache = 0;
+}
+
static void vp9_superframe_close(AVBSFContext *ctx)
{
VP9BSFContext *s = ctx->priv_data;
.priv_data_size = sizeof(VP9BSFContext),
.filter = vp9_superframe_filter,
.init = vp9_superframe_init,
+ .flush = vp9_superframe_flush,
.close = vp9_superframe_close,
.codec_ids = codec_ids,
};