[FFmpeg-devel] [PATCH 2/6] avcodec/extract_extradata: move the reference in the bsf internal buffer
James Almer
jamrial at gmail.com
Sun Mar 11 19:58:50 EET 2018
There's no need to allocate a new packet for it.
Signed-off-by: James Almer <jamrial at gmail.com>
---
libavcodec/extract_extradata_bsf.c | 11 +++++------
1 file changed, 5 insertions(+), 6 deletions(-)
diff --git a/libavcodec/extract_extradata_bsf.c b/libavcodec/extract_extradata_bsf.c
index 64017b6fb7..711814576c 100644
--- a/libavcodec/extract_extradata_bsf.c
+++ b/libavcodec/extract_extradata_bsf.c
@@ -280,21 +280,20 @@ static int extract_extradata_init(AVBSFContext *ctx)
static int extract_extradata_filter(AVBSFContext *ctx, AVPacket *out)
{
ExtractExtradataContext *s = ctx->priv_data;
- AVPacket *in;
uint8_t *extradata = NULL;
int extradata_size;
int ret = 0;
- ret = ff_bsf_get_packet(ctx, &in);
+ ret = ff_bsf_get_packet_ref(ctx, out);
if (ret < 0)
return ret;
- ret = s->extract(ctx, in, &extradata, &extradata_size);
+ ret = s->extract(ctx, out, &extradata, &extradata_size);
if (ret < 0)
goto fail;
if (extradata) {
- ret = av_packet_add_side_data(in, AV_PKT_DATA_NEW_EXTRADATA,
+ ret = av_packet_add_side_data(out, AV_PKT_DATA_NEW_EXTRADATA,
extradata, extradata_size);
if (ret < 0) {
av_freep(&extradata);
@@ -302,10 +301,10 @@ static int extract_extradata_filter(AVBSFContext *ctx, AVPacket *out)
}
}
- av_packet_move_ref(out, in);
+ return 0;
fail:
- av_packet_free(&in);
+ av_packet_unref(out);
return ret;
}
--
2.16.2
More information about the ffmpeg-devel
mailing list