diff options
author | Måns Rullgård <mans@mansr.com> | 2008-11-24 19:08:02 +0000 |
---|---|---|
committer | Måns Rullgård <mans@mansr.com> | 2008-11-24 19:08:02 +0000 |
commit | 819e4dd9e65739dba357f79d0442bdecb7ac692d (patch) | |
tree | e96e3f54dba9e421d66ac415a9bb3b7dcdebd672 /libavcodec/svq1enc.c | |
parent | 6b8810d0ca35edaba119b6225c9695afbdd38263 (diff) | |
download | ffmpeg-819e4dd9e65739dba357f79d0442bdecb7ac692d.tar.gz |
svq1enc: move scratch buffer from stack to context to ensure alignment
Originally committed as revision 15931 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/svq1enc.c')
-rw-r--r-- | libavcodec/svq1enc.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/libavcodec/svq1enc.c b/libavcodec/svq1enc.c index 8d0bca567d..49ad3d31bb 100644 --- a/libavcodec/svq1enc.c +++ b/libavcodec/svq1enc.c @@ -67,6 +67,8 @@ typedef struct SVQ1Context { int16_t (*motion_val16[3])[2]; int64_t rd_total; + + uint8_t *scratchbuf; } SVQ1Context; static void svq1_write_header(SVQ1Context *s, int frame_type) @@ -378,7 +380,7 @@ static int svq1_encode_plane(SVQ1Context *s, int plane, unsigned char *src_plane uint8_t *decoded= decoded_plane + offset; uint8_t *ref= ref_plane + offset; int score[4]={0,0,0,0}, best; - uint8_t temp[16*stride]; + uint8_t *temp = s->scratchbuf; if(s->pb.buf_end - s->pb.buf - (put_bits_count(&s->pb)>>3) < 3000){ //FIXME check size av_log(s->avctx, AV_LOG_ERROR, "encoded frame too large\n"); @@ -524,6 +526,7 @@ static int svq1_encode_frame(AVCodecContext *avctx, unsigned char *buf, if(!s->current_picture.data[0]){ avctx->get_buffer(avctx, &s->current_picture); avctx->get_buffer(avctx, &s->last_picture); + s->scratchbuf = av_malloc(s->current_picture.linesize[0] * 16); } temp= s->current_picture; @@ -566,6 +569,7 @@ static av_cold int svq1_encode_end(AVCodecContext *avctx) av_freep(&s->m.me.score_map); av_freep(&s->mb_type); av_freep(&s->dummy); + av_freep(&s->scratchbuf); for(i=0; i<3; i++){ av_freep(&s->motion_val8[i]); |