diff options
author | Matthieu Bouron <matthieu.bouron@stupeflix.com> | 2016-06-20 16:02:10 +0200 |
---|---|---|
committer | Matthieu Bouron <matthieu.bouron@stupeflix.com> | 2016-06-20 16:09:09 +0200 |
commit | 0ea58059d635484957b332fe9432351381fae6cd (patch) | |
tree | b279eff229ef626f63a3167397079fe329e5bced /libavcodec | |
parent | acfab2dce6d30ab30b953d10e2e0097d8f8cb29f (diff) | |
download | ffmpeg-0ea58059d635484957b332fe9432351381fae6cd.tar.gz |
lavc/h264_ps: add ff_h264_ps_uninit and use it
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/h264.c | 10 | ||||
-rw-r--r-- | libavcodec/h264.h | 6 | ||||
-rw-r--r-- | libavcodec/h264_parser.c | 8 | ||||
-rw-r--r-- | libavcodec/h264_ps.c | 17 |
4 files changed, 25 insertions, 16 deletions
diff --git a/libavcodec/h264.c b/libavcodec/h264.c index f2dc47338c..9d2cabaa04 100644 --- a/libavcodec/h264.c +++ b/libavcodec/h264.c @@ -377,15 +377,7 @@ static av_cold int h264_decode_end(AVCodecContext *avctx) h->nb_slice_ctx = 0; ff_h264_sei_uninit(&h->sei); - - for (i = 0; i < MAX_SPS_COUNT; i++) - av_buffer_unref(&h->ps.sps_list[i]); - - for (i = 0; i < MAX_PPS_COUNT; i++) - av_buffer_unref(&h->ps.pps_list[i]); - - av_buffer_unref(&h->ps.sps_ref); - av_buffer_unref(&h->ps.pps_ref); + ff_h264_ps_uninit(&h->ps); ff_h2645_packet_uninit(&h->pkt); diff --git a/libavcodec/h264.h b/libavcodec/h264.h index 61d94cd6d4..8e92f62372 100644 --- a/libavcodec/h264.h +++ b/libavcodec/h264.h @@ -695,6 +695,12 @@ typedef struct H264Context { extern const uint16_t ff_h264_mb_sizes[4]; /** + * Uninit H264 param sets structure. + */ + +void ff_h264_ps_uninit(H264ParamSets *ps); + +/** * Decode SPS */ int ff_h264_decode_seq_parameter_set(GetBitContext *gb, AVCodecContext *avctx, diff --git a/libavcodec/h264_parser.c b/libavcodec/h264_parser.c index 3ce049ee56..42ad932a68 100644 --- a/libavcodec/h264_parser.c +++ b/libavcodec/h264_parser.c @@ -649,17 +649,11 @@ static void h264_close(AVCodecParserContext *s) { H264ParseContext *p = s->priv_data; ParseContext *pc = &p->pc; - int i; av_freep(&pc->buffer); ff_h264_sei_uninit(&p->sei); - - for (i = 0; i < FF_ARRAY_ELEMS(p->ps.sps_list); i++) - av_buffer_unref(&p->ps.sps_list[i]); - - for (i = 0; i < FF_ARRAY_ELEMS(p->ps.pps_list); i++) - av_buffer_unref(&p->ps.pps_list[i]); + ff_h264_ps_uninit(&p->ps); } static av_cold int init(AVCodecParserContext *s) diff --git a/libavcodec/h264_ps.c b/libavcodec/h264_ps.c index 521f560bc1..fb05b05fac 100644 --- a/libavcodec/h264_ps.c +++ b/libavcodec/h264_ps.c @@ -298,6 +298,23 @@ static void decode_scaling_matrices(GetBitContext *gb, SPS *sps, } } +void ff_h264_ps_uninit(H264ParamSets *ps) +{ + int i; + + for (i = 0; i < MAX_SPS_COUNT; i++) + av_buffer_unref(&ps->sps_list[i]); + + for (i = 0; i < MAX_PPS_COUNT; i++) + av_buffer_unref(&ps->pps_list[i]); + + av_buffer_unref(&ps->sps_ref); + av_buffer_unref(&ps->pps_ref); + + ps->pps = NULL; + ps->sps = NULL; +} + int ff_h264_decode_seq_parameter_set(GetBitContext *gb, AVCodecContext *avctx, H264ParamSets *ps, int ignore_truncation) { |