diff --git a/libavcodec/avcodec.c b/libavcodec/avcodec.c index 888dd76228..214dca4566 100644 --- a/libavcodec/avcodec.c +++ b/libavcodec/avcodec.c @@ -462,6 +462,8 @@ av_cold void ff_codec_close(AVCodecContext *avctx) av_freep(&avctx->coded_side_data[i].data); av_freep(&avctx->coded_side_data); avctx->nb_coded_side_data = 0; + av_frame_side_data_free(&avctx->decoded_side_data, + &avctx->nb_decoded_side_data); av_buffer_unref(&avctx->hw_frames_ctx); av_buffer_unref(&avctx->hw_device_ctx); diff --git a/libavcodec/options.c b/libavcodec/options.c index 0c3b40a186..f60c41bdc3 100644 --- a/libavcodec/options.c +++ b/libavcodec/options.c @@ -177,8 +177,6 @@ void avcodec_free_context(AVCodecContext **pavctx) av_freep(&avctx->inter_matrix); av_freep(&avctx->rc_override); av_channel_layout_uninit(&avctx->ch_layout); - av_frame_side_data_free( - &avctx->decoded_side_data, &avctx->nb_decoded_side_data); av_freep(pavctx); }