diff options
author | James Almer <jamrial@gmail.com> | 2019-07-30 15:08:36 -0300 |
---|---|---|
committer | James Almer <jamrial@gmail.com> | 2019-08-03 12:33:14 -0300 |
commit | ce6a98e8306105b07bd7653f4f10c23fd75914ee (patch) | |
tree | 3ef2ff458eddd20349a8dc02db84a84fc2f9c913 /libavformat/dashenc.c | |
parent | 9a44ec94100a647df6920c65cccdd605a2e6865b (diff) | |
download | ffmpeg-streaming-ce6a98e8306105b07bd7653f4f10c23fd75914ee.zip ffmpeg-streaming-ce6a98e8306105b07bd7653f4f10c23fd75914ee.tar.gz |
avformat/dashenc: update stream extradata from packet side data
codecpar->extradata is not going to change between packets. New extradata
is instead propagated using packet side data.
Use ff_alloc_extradata() as well.
Signed-off-by: James Almer <jamrial@gmail.com>
Diffstat (limited to 'libavformat/dashenc.c')
-rw-r--r-- | libavformat/dashenc.c | 23 |
1 files changed, 12 insertions, 11 deletions
diff --git a/libavformat/dashenc.c b/libavformat/dashenc.c index ab16750..5c51f61 100644 --- a/libavformat/dashenc.c +++ b/libavformat/dashenc.c @@ -1454,23 +1454,24 @@ static void find_index_range(AVFormatContext *s, const char *full_path, } static int update_stream_extradata(AVFormatContext *s, OutputStream *os, - AVCodecParameters *par, - AVRational *frame_rate) + AVPacket *pkt, AVRational *frame_rate) { + AVCodecParameters *par = os->ctx->streams[0]->codecpar; uint8_t *extradata; + int ret, extradata_size; - if (os->ctx->streams[0]->codecpar->extradata_size || !par->extradata_size) + if (par->extradata_size) return 0; - extradata = av_malloc(par->extradata_size); - - if (!extradata) - return AVERROR(ENOMEM); + extradata = av_packet_get_side_data(pkt, AV_PKT_DATA_NEW_EXTRADATA, &extradata_size); + if (!extradata_size) + return 0; - memcpy(extradata, par->extradata, par->extradata_size); + ret = ff_alloc_extradata(par, extradata_size); + if (ret < 0) + return ret; - os->ctx->streams[0]->codecpar->extradata = extradata; - os->ctx->streams[0]->codecpar->extradata_size = par->extradata_size; + memcpy(par->extradata, extradata, extradata_size); set_codec_str(s, par, frame_rate, os->codec_str, sizeof(os->codec_str)); @@ -1687,7 +1688,7 @@ static int dash_write_packet(AVFormatContext *s, AVPacket *pkt) int64_t seg_end_duration, elapsed_duration; int ret; - ret = update_stream_extradata(s, os, st->codecpar, &st->avg_frame_rate); + ret = update_stream_extradata(s, os, pkt, &st->avg_frame_rate); if (ret < 0) return ret; |