summaryrefslogtreecommitdiff
path: root/libavcodec/h264_parser.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michael@niedermayer.cc>2016-07-02 03:06:27 +0200
committerMichael Niedermayer <michael@niedermayer.cc>2016-07-02 03:07:23 +0200
commitfebc862b53c090e530b943ebd873747addf5f913 (patch)
tree3b4409492f1d2401bd39b942c020761b8b22b376 /libavcodec/h264_parser.c
parent77eb05a2f11f03c98837fa5350d17a8a1c5a2a3d (diff)
avcodec/h264_parser: Set sps/pps_ref
Fixes use of freed memory Should fix valgrind failures of fate-h264-skip-nointra Found-by: logan Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
Diffstat (limited to 'libavcodec/h264_parser.c')
-rw-r--r--libavcodec/h264_parser.c17
1 files changed, 15 insertions, 2 deletions
diff --git a/libavcodec/h264_parser.c b/libavcodec/h264_parser.c
index 7af2a8dddc..ce46c58dda 100644
--- a/libavcodec/h264_parser.c
+++ b/libavcodec/h264_parser.c
@@ -367,13 +367,26 @@ static inline int parse_nal_units(AVCodecParserContext *s,
"non-existing PPS %u referenced\n", pps_id);
goto fail;
}
- p->ps.pps = (const PPS*)p->ps.pps_list[pps_id]->data;
+
+ av_buffer_unref(&p->ps.pps_ref);
+ av_buffer_unref(&p->ps.sps_ref);
+ p->ps.pps = NULL;
+ p->ps.sps = NULL;
+ p->ps.pps_ref = av_buffer_ref(p->ps.pps_list[pps_id]);
+ if (!p->ps.pps_ref)
+ goto fail;
+ p->ps.pps = (const PPS*)p->ps.pps_ref->data;
+
if (!p->ps.sps_list[p->ps.pps->sps_id]) {
av_log(avctx, AV_LOG_ERROR,
"non-existing SPS %u referenced\n", p->ps.pps->sps_id);
goto fail;
}
- p->ps.sps = (const SPS*)p->ps.sps_list[p->ps.pps->sps_id]->data;
+
+ p->ps.sps_ref = av_buffer_ref(p->ps.sps_list[p->ps.pps->sps_id]);
+ if (!p->ps.sps_ref)
+ goto fail;
+ p->ps.sps = (const SPS*)p->ps.sps_ref->data;
sps = p->ps.sps;