Commit ee4e8050 authored by Michael Niedermayer's avatar Michael Niedermayer

avformat: add ff_get_extradata()

Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent ac480cb5
...@@ -371,6 +371,15 @@ int ff_generate_avci_extradata(AVStream *st); ...@@ -371,6 +371,15 @@ int ff_generate_avci_extradata(AVStream *st);
*/ */
int ff_alloc_extradata(AVCodecContext *avctx, int size); int ff_alloc_extradata(AVCodecContext *avctx, int size);
/**
* Allocate extradata with additional FF_INPUT_BUFFER_PADDING_SIZE at end
* which is always set to 0 and fill it from pb.
*
* @param size size of extradata
* @return >= 0 if OK, AVERROR_xxx on error
*/
int ff_get_extradata(AVCodecContext *avctx, AVIOContext *pb, int size);
/** /**
* add frame for rfps calculation. * add frame for rfps calculation.
* *
......
...@@ -2701,6 +2701,22 @@ int ff_alloc_extradata(AVCodecContext *avctx, int size) ...@@ -2701,6 +2701,22 @@ int ff_alloc_extradata(AVCodecContext *avctx, int size)
return ret; return ret;
} }
int ff_get_extradata(AVCodecContext *avctx, AVIOContext *pb, int size)
{
int ret = ff_alloc_extradata(avctx, size);
if (ret < 0)
return ret;
ret = avio_read(pb, avctx->extradata, size);
if (ret != size) {
av_freep(&avctx->extradata);
avctx->extradata_size = 0;
av_log(avctx, AV_LOG_ERROR, "Failed to read extradata of size %d\n", size);
return ret < 0 ? ret : AVERROR_INVALIDDATA;
}
return ret;
}
int ff_rfps_add_frame(AVFormatContext *ic, AVStream *st, int64_t ts) int ff_rfps_add_frame(AVFormatContext *ic, AVStream *st, int64_t ts)
{ {
int i, j; int i, j;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment