diff options
author | Clément Bœsch <u@pkh.me> | 2016-07-09 15:03:27 +0200 |
---|---|---|
committer | Clément Bœsch <u@pkh.me> | 2016-07-09 15:03:27 +0200 |
commit | c67aa7f287e791b2c02c0c6471336c8adc88020e (patch) | |
tree | 90c07bb51950e2136f09572668102fc8e6cac013 /libavcodec/h264.c | |
parent | 46bd0e8e0dfb4b295e8fbe6854904eccb0cb5c82 (diff) | |
parent | 187d719760bd130f848194ec4a6bd476341914bb (diff) | |
download | ffmpeg-c67aa7f287e791b2c02c0c6471336c8adc88020e.tar.gz |
Merge commit '187d719760bd130f848194ec4a6bd476341914bb'
* commit '187d719760bd130f848194ec4a6bd476341914bb':
h264: Support AV_PKT_DATA_NEW_EXTRADATA
Merged-by: Clément Bœsch <u@pkh.me>
Diffstat (limited to 'libavcodec/h264.c')
-rw-r--r-- | libavcodec/h264.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/libavcodec/h264.c b/libavcodec/h264.c index 8eb3b13e12..b4eae374ce 100644 --- a/libavcodec/h264.c +++ b/libavcodec/h264.c @@ -1235,6 +1235,8 @@ static int h264_decode_frame(AVCodecContext *avctx, void *data, H264Picture *out; int i, out_idx; int ret; + const uint8_t *new_extradata; + int new_extradata_size; h->flags = avctx->flags; h->setup_finished = 0; @@ -1302,6 +1304,17 @@ static int h264_decode_frame(AVCodecContext *avctx, void *data, avctx->err_recognition, avctx); } + new_extradata_size = 0; + new_extradata = av_packet_get_side_data(avpkt, AV_PKT_DATA_NEW_EXTRADATA, + &new_extradata_size); + if (new_extradata_size > 0 && new_extradata) { + ret = ff_h264_decode_extradata(new_extradata, new_extradata_size, + &h->ps, &h->is_avc, &h->nal_length_size, + avctx->err_recognition, avctx); + if (ret < 0) + return ret; + } + buf_index = decode_nal_units(h, buf, buf_size); if (buf_index < 0) return AVERROR_INVALIDDATA; |