diff options
author | Martin Storsjö <martin@martin.st> | 2013-03-01 16:45:24 +0200 |
---|---|---|
committer | Martin Storsjö <martin@martin.st> | 2013-03-02 00:39:37 +0200 |
commit | c5a738ca4e9789b4678b10240777d931e7dc24c9 (patch) | |
tree | 499800628a9d55987cc56340fd993e45fbec9a4e /libavformat | |
parent | c91c63b5380bf79655c09320774a022f84d76fd5 (diff) | |
download | ffmpeg-c5a738ca4e9789b4678b10240777d931e7dc24c9.tar.gz |
flvdec: Check the return value of a malloc
The callers of this function can't report errors sanely. If this
one malloc fails, don't write the extradata byte, make sure we
try to malloc it the next time we're called instead, and make sure
we still consume the input data byte.
CC: libav-stable@libav.org
Signed-off-by: Martin Storsjö <martin@martin.st>
Diffstat (limited to 'libavformat')
-rw-r--r-- | libavformat/flvdec.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/libavformat/flvdec.c b/libavformat/flvdec.c index e45a9a2bfa..403a9b5089 100644 --- a/libavformat/flvdec.c +++ b/libavformat/flvdec.c @@ -213,10 +213,14 @@ static int flv_set_video_codec(AVFormatContext *s, AVStream *vstream, int flv_co vcodec->codec_id = AV_CODEC_ID_VP6A; if (read) { if (vcodec->extradata_size != 1) { - vcodec->extradata_size = 1; vcodec->extradata = av_malloc(1); + if (vcodec->extradata) + vcodec->extradata_size = 1; } - vcodec->extradata[0] = avio_r8(s->pb); + if (vcodec->extradata) + vcodec->extradata[0] = avio_r8(s->pb); + else + avio_skip(s->pb, 1); } return 1; // 1 byte body size adjustment for flv_read_packet() case FLV_CODECID_H264: |