Commit 4027e136 authored by Michael Niedermayer's avatar Michael Niedermayer

Merge commit '42d73f7f'

* commit '42d73f7f':
  4xm: do not overread while parsing header

Conflicts:
	libavformat/4xm.c
Merged-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parents 60657ee3 42d73f7f
...@@ -90,11 +90,12 @@ static int fourxm_probe(AVProbeData *p) ...@@ -90,11 +90,12 @@ static int fourxm_probe(AVProbeData *p)
} }
static int parse_vtrk(AVFormatContext *s, static int parse_vtrk(AVFormatContext *s,
FourxmDemuxContext *fourxm, uint8_t *buf, int size) FourxmDemuxContext *fourxm, uint8_t *buf, int size,
int left)
{ {
AVStream *st; AVStream *st;
/* check that there is enough data */ /* check that there is enough data */
if (size != vtrk_SIZE) { if (size != vtrk_SIZE || left < size + 8) {
return AVERROR_INVALIDDATA; return AVERROR_INVALIDDATA;
} }
...@@ -120,12 +121,13 @@ static int parse_vtrk(AVFormatContext *s, ...@@ -120,12 +121,13 @@ static int parse_vtrk(AVFormatContext *s,
static int parse_strk(AVFormatContext *s, static int parse_strk(AVFormatContext *s,
FourxmDemuxContext *fourxm, uint8_t *buf, int size) FourxmDemuxContext *fourxm, uint8_t *buf, int size,
int left)
{ {
AVStream *st; AVStream *st;
int track; int track;
/* check that there is enough data */ /* check that there is enough data */
if (size != strk_SIZE) if (size != strk_SIZE || left < size + 8)
return AVERROR_INVALIDDATA; return AVERROR_INVALIDDATA;
track = AV_RL32(buf + 8); track = AV_RL32(buf + 8);
...@@ -230,18 +232,21 @@ static int fourxm_read_header(AVFormatContext *s) ...@@ -230,18 +232,21 @@ static int fourxm_read_header(AVFormatContext *s)
} }
if (fourcc_tag == std__TAG) { if (fourcc_tag == std__TAG) {
if (header_size < i + 16) { if (header_size - i < 16) {
av_log(s, AV_LOG_ERROR, "std TAG truncated\n"); av_log(s, AV_LOG_ERROR, "std TAG truncated\n");
return AVERROR_INVALIDDATA; ret = AVERROR_INVALIDDATA;
goto fail;
} }
fourxm->fps = av_int2float(AV_RL32(&header[i + 12])); fourxm->fps = av_int2float(AV_RL32(&header[i + 12]));
} else if (fourcc_tag == vtrk_TAG) { } else if (fourcc_tag == vtrk_TAG) {
if ((ret = parse_vtrk(s, fourxm, header + i, size)) < 0) if ((ret = parse_vtrk(s, fourxm, header + i, size,
header_size - i)) < 0)
goto fail; goto fail;
i += 8 + size; i += 8 + size;
} else if (fourcc_tag == strk_TAG) { } else if (fourcc_tag == strk_TAG) {
if ((ret = parse_strk(s, fourxm, header + i, size)) < 0) if ((ret = parse_strk(s, fourxm, header + i, size,
header_size - i)) < 0)
goto fail; goto fail;
i += 8 + size; i += 8 + size;
......
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