diff --git a/libavformat/asf.c b/libavformat/asf.c index 9f94137dc0e70cc59941db655ba5be6055cf21dc..64444b1277c98dcc4888e83a9dfa576e53ab7505 100644 --- a/libavformat/asf.c +++ b/libavformat/asf.c @@ -274,7 +274,7 @@ static int asf_read_header(AVFormatContext *s, AVFormatParameters *ap) url_fskip(pb, 20); if (size > 40) { st->codec.extradata_size = size - 40; - st->codec.extradata = av_mallocz(st->codec.extradata_size); + st->codec.extradata = av_mallocz(st->codec.extradata_size + FF_INPUT_BUFFER_PADDING_SIZE); get_buffer(pb, st->codec.extradata, st->codec.extradata_size); } diff --git a/libavformat/avidec.c b/libavformat/avidec.c index 4af4a0d3edbcf7b81839f8644ae3fb394f7fe308..72989fcc80a8b51ccda7018dd0ebd897621a7636 100644 --- a/libavformat/avidec.c +++ b/libavformat/avidec.c @@ -301,7 +301,7 @@ static int avi_read_header(AVFormatContext *s, AVFormatParameters *ap) get_le32(pb); /* ClrImportant */ st->codec.extradata_size= size - 10*4; - st->codec.extradata= av_malloc(st->codec.extradata_size); + st->codec.extradata= av_malloc(st->codec.extradata_size + FF_INPUT_BUFFER_PADDING_SIZE); get_buffer(pb, st->codec.extradata, st->codec.extradata_size); if(st->codec.extradata_size & 1) //FIXME check if the encoder really did this correctly diff --git a/libavformat/mov.c b/libavformat/mov.c index b0f4b8bf6b341e8575463d8ca066091e82593f4e..2b05b9486fe525d974abe78a93e3650ad6dd362d 100644 --- a/libavformat/mov.c +++ b/libavformat/mov.c @@ -569,7 +569,7 @@ static int mov_read_esds(MOVContext *c, ByteIOContext *pb, MOV_atom_t atom) #ifdef DEBUG av_log(NULL, AV_LOG_DEBUG, "Specific MPEG4 header len=%d\n", len); #endif - st->codec.extradata = (uint8_t*) av_mallocz(len); + st->codec.extradata = (uint8_t*) av_mallocz(len + FF_INPUT_BUFFER_PADDING_SIZE); if (st->codec.extradata) { get_buffer(pb, st->codec.extradata, len); st->codec.extradata_size = len; @@ -680,7 +680,7 @@ static int mov_read_smi(MOVContext *c, ByteIOContext *pb, MOV_atom_t atom) // this should be fixed and just SMI header should be passed av_free(st->codec.extradata); st->codec.extradata_size = 0x5a + atom.size; - st->codec.extradata = (uint8_t*) av_mallocz(st->codec.extradata_size); + st->codec.extradata = (uint8_t*) av_mallocz(st->codec.extradata_size + FF_INPUT_BUFFER_PADDING_SIZE); if (st->codec.extradata) { strcpy(st->codec.extradata, "SVQ3"); // fake diff --git a/libavformat/nut.c b/libavformat/nut.c index 544036670b3a8ad7db057301c52355ef774521b2..67b317ed692055d9b22fdf9731ae0092d8321eae 100644 --- a/libavformat/nut.c +++ b/libavformat/nut.c @@ -982,7 +982,7 @@ static int decode_stream_header(NUTContext *nut){ /* codec specific data headers */ while(get_v(bc) != 0){ st->codec.extradata_size= get_v(bc); - st->codec.extradata= av_mallocz(st->codec.extradata_size); + st->codec.extradata= av_mallocz(st->codec.extradata_size + FF_INPUT_BUFFER_PADDING_SIZE); get_buffer(bc, st->codec.extradata, st->codec.extradata_size); // url_fskip(bc, get_v(bc)); } diff --git a/libavformat/ogg.c b/libavformat/ogg.c index 00c9f3ffd04e6936efb067daa9219162318308c9..e0a72306c960f6f8e1b06d585b51429f15a0577a 100644 --- a/libavformat/ogg.c +++ b/libavformat/ogg.c @@ -196,7 +196,7 @@ static int ogg_read_header(AVFormatContext *avfcontext, AVFormatParameters *ap) return -1; } codec->extradata_size+= 2 + op.bytes; - codec->extradata= av_realloc(codec->extradata, codec->extradata_size); + codec->extradata= av_realloc(codec->extradata, codec->extradata_size + FF_INPUT_BUFFER_PADDING_SIZE); p= codec->extradata + codec->extradata_size - 2 - op.bytes; *(p++)= op.bytes>>8; *(p++)= op.bytes&0xFF; diff --git a/libavformat/rtsp.c b/libavformat/rtsp.c index af898ba21769d672cdda0cf186bb5ba65d85be3d..2b6fa8844a68ef0b3378641fa44c8df41430c7b2 100644 --- a/libavformat/rtsp.c +++ b/libavformat/rtsp.c @@ -211,7 +211,7 @@ static void sdp_parse_fmtp(AVCodecContext *codec, const char *p) if (!strcmp(attr, "config")) { /* decode the hexa encoded parameter */ len = hex_to_data(NULL, value); - codec->extradata = av_mallocz(len); + codec->extradata = av_mallocz(len + FF_INPUT_BUFFER_PADDING_SIZE); if (!codec->extradata) goto fail; codec->extradata_size = len; diff --git a/libavformat/wav.c b/libavformat/wav.c index 3497126e67ef0fcc9d646fd645939a0c0c01a321..f2bb503b212782e1bc164447b45317a10d4c1526 100644 --- a/libavformat/wav.c +++ b/libavformat/wav.c @@ -154,7 +154,7 @@ void get_wav_header(ByteIOContext *pb, AVCodecContext *codec, int size) if (codec->extradata_size > 0) { if (codec->extradata_size > size - 18) codec->extradata_size = size - 18; - codec->extradata = av_mallocz(codec->extradata_size); + codec->extradata = av_mallocz(codec->extradata_size + FF_INPUT_BUFFER_PADDING_SIZE); get_buffer(pb, codec->extradata, codec->extradata_size); } else codec->extradata_size = 0;