From: John Stebbins Date: Tue, 24 Jan 2017 18:01:48 +0000 (-0700) Subject: decavcodec: fix avcodec_open failure upon bad extradata X-Git-Tag: 1.1.0~760 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=ca1dcccd09b5dfac93829d46fd6c7c9711898b77;p=handbrake decavcodec: fix avcodec_open failure upon bad extradata If extradata is improperly parsed, avcodec_open may fail. Keep trying avcodec_open as long as there is more data to parse. Fixes https://github.com/HandBrake/HandBrake/issues/542 --- diff --git a/libhb/decavcodec.c b/libhb/decavcodec.c index c8b12d770..953fa2582 100644 --- a/libhb/decavcodec.c +++ b/libhb/decavcodec.c @@ -1665,8 +1665,12 @@ static int decavcodecvWork( hb_work_object_t * w, hb_buffer_t ** buf_in, { av_dict_free( &av_opts ); hb_log( "decavcodecvWork: avcodec_open failed" ); - *buf_out = hb_buffer_eof_init(); - return HB_WORK_DONE; + // avcodec_open can fail due to incorrectly parsed extradata + // so try again when this fails + av_freep( &pv->context->extradata ); + pv->context->extradata_size = 0; + hb_buffer_close( &in ); + return HB_WORK_OK; } av_dict_free( &av_opts ); pv->video_codec_opened = 1;