Skip to content

Commit

Permalink
lavf: use a malloced AVFrame in try_decode_frame().
Browse files Browse the repository at this point in the history
This allows using avcodec_free_frame() to free it properly.
  • Loading branch information
elenril committed Sep 24, 2012
1 parent a42aada commit 9eb2965
Showing 1 changed file with 17 additions and 8 deletions.
25 changes: 17 additions & 8 deletions libavformat/utils.c
Original file line number Diff line number Diff line change
Expand Up @@ -2084,9 +2084,12 @@ static int try_decode_frame(AVStream *st, AVPacket *avpkt, AVDictionary **option
{
const AVCodec *codec;
int got_picture = 1, ret = 0;
AVFrame picture;
AVFrame *frame = avcodec_alloc_frame();
AVPacket pkt = *avpkt;

if (!frame)
return AVERROR(ENOMEM);

if (!avcodec_is_open(st->codec) && !st->info->found_decoder) {
AVDictionary *thread_opt = NULL;

Expand All @@ -2095,7 +2098,8 @@ static int try_decode_frame(AVStream *st, AVPacket *avpkt, AVDictionary **option

if (!codec) {
st->info->found_decoder = -1;
return -1;
ret = -1;
goto fail;
}

/* force thread count to 1 since the h264 decoder will not extract SPS
Expand All @@ -2106,29 +2110,31 @@ static int try_decode_frame(AVStream *st, AVPacket *avpkt, AVDictionary **option
av_dict_free(&thread_opt);
if (ret < 0) {
st->info->found_decoder = -1;
return ret;
goto fail;
}
st->info->found_decoder = 1;
} else if (!st->info->found_decoder)
st->info->found_decoder = 1;

if (st->info->found_decoder < 0)
return -1;
if (st->info->found_decoder < 0) {
ret = -1;
goto fail;
}

while ((pkt.size > 0 || (!pkt.data && got_picture)) &&
ret >= 0 &&
(!has_codec_parameters(st) ||
!has_decode_delay_been_guessed(st) ||
(!st->codec_info_nb_frames && st->codec->codec->capabilities & CODEC_CAP_CHANNEL_CONF))) {
got_picture = 0;
avcodec_get_frame_defaults(&picture);
avcodec_get_frame_defaults(frame);
switch(st->codec->codec_type) {
case AVMEDIA_TYPE_VIDEO:
ret = avcodec_decode_video2(st->codec, &picture,
ret = avcodec_decode_video2(st->codec, frame,
&got_picture, &pkt);
break;
case AVMEDIA_TYPE_AUDIO:
ret = avcodec_decode_audio4(st->codec, &picture, &got_picture, &pkt);
ret = avcodec_decode_audio4(st->codec, frame, &got_picture, &pkt);
break;
default:
break;
Expand All @@ -2141,6 +2147,9 @@ static int try_decode_frame(AVStream *st, AVPacket *avpkt, AVDictionary **option
ret = got_picture;
}
}

fail:
avcodec_free_frame(&frame);
return ret;
}

Expand Down

0 comments on commit 9eb2965

Please sign in to comment.