|
|
|
@@ -233,10 +233,14 @@ static int asfrtp_parse_packet(AVFormatContext *s, PayloadContext *asf, |
|
|
|
|
|
|
|
int cur_len = start_off + len_off - off; |
|
|
|
int prev_len = out_len; |
|
|
|
void *newbuf; |
|
|
|
out_len += cur_len; |
|
|
|
asf->buf = av_realloc(asf->buf, out_len); |
|
|
|
if(!asf->buf || FFMIN(cur_len, len - off)<0) |
|
|
|
if(FFMIN(cur_len, len - off)<0) |
|
|
|
return -1; |
|
|
|
newbuf = av_realloc(asf->buf, out_len); |
|
|
|
if(!newbuf) |
|
|
|
return -1; |
|
|
|
asf->buf= newbuf; |
|
|
|
memcpy(asf->buf + prev_len, buf + off, |
|
|
|
FFMIN(cur_len, len - off)); |
|
|
|
avio_skip(pb, cur_len); |
|
|
|
|