diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2012-08-10 04:33:42 +0200 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2012-08-10 04:36:43 +0200 |
commit | 969267482de97b08503d27d2fe090ec820273e40 (patch) | |
tree | bd53994a26490bc3d93e2f1d69e6bf6121211450 | |
parent | a0d15027e3b0c7825cc10052363b72e9398578b9 (diff) | |
download | ffmpeg-969267482de97b08503d27d2fe090ec820273e40.tar.gz |
ffmpeg: Allocate new buffer for bitstream filter when buffer shifted
fix crash with aac_adtstoasc bitstream filter
Fixes Ticket1441
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r-- | ffmpeg.c | 10 |
1 files changed, 10 insertions, 0 deletions
@@ -534,6 +534,16 @@ static void write_frame(AVFormatContext *s, AVPacket *pkt, OutputStream *ost) &new_pkt.data, &new_pkt.size, pkt->data, pkt->size, pkt->flags & AV_PKT_FLAG_KEY); + if(a == 0 && new_pkt.data != pkt->data && new_pkt.destruct) { + uint8_t *t = av_malloc(new_pkt.size + FF_INPUT_BUFFER_PADDING_SIZE); //the new should be a subset of the old so cannot overflow + if(t) { + memcpy(t, new_pkt.data, new_pkt.size); + memset(t + new_pkt.size, 0, FF_INPUT_BUFFER_PADDING_SIZE); + new_pkt.data = t; + a = 1; + } else + a = AVERROR(ENOMEM); + } if (a > 0) { av_free_packet(pkt); new_pkt.destruct = av_destruct_packet; |