Commit 2d3601b5 authored by Michael Niedermayer's avatar Michael Niedermayer

qprd + mpeg2 segfault fix

Originally committed as revision 3461 to svn://svn.ffmpeg.org/ffmpeg/trunk
parent 0bae10cc
...@@ -4408,7 +4408,7 @@ static int encode_thread(AVCodecContext *c, void *arg){ ...@@ -4408,7 +4408,7 @@ static int encode_thread(AVCodecContext *c, void *arg){
if(qp < s->avctx->qmin || qp > s->avctx->qmax) if(qp < s->avctx->qmin || qp > s->avctx->qmax)
break; break;
backup_s.dquant= dquant; backup_s.dquant= dquant;
if(s->mb_intra){ if(s->mb_intra && s->dc_val[0]){
for(i=0; i<6; i++){ for(i=0; i<6; i++){
dc[i]= s->dc_val[0][ s->block_index[i] ]; dc[i]= s->dc_val[0][ s->block_index[i] ];
memcpy(ac[i], s->ac_val[0][s->block_index[i]], sizeof(DCTELEM)*16); memcpy(ac[i], s->ac_val[0][s->block_index[i]], sizeof(DCTELEM)*16);
...@@ -4418,7 +4418,7 @@ static int encode_thread(AVCodecContext *c, void *arg){ ...@@ -4418,7 +4418,7 @@ static int encode_thread(AVCodecContext *c, void *arg){
encode_mb_hq(s, &backup_s, &best_s, CANDIDATE_MB_TYPE_INTER /* wrong but unused */, pb, pb2, tex_pb, encode_mb_hq(s, &backup_s, &best_s, CANDIDATE_MB_TYPE_INTER /* wrong but unused */, pb, pb2, tex_pb,
&dmin, &next_block, s->mv[mvdir][0][0], s->mv[mvdir][0][1]); &dmin, &next_block, s->mv[mvdir][0][0], s->mv[mvdir][0][1]);
if(best_s.qscale != qp){ if(best_s.qscale != qp){
if(s->mb_intra){ if(s->mb_intra && s->dc_val[0]){
for(i=0; i<6; i++){ for(i=0; i<6; i++){
s->dc_val[0][ s->block_index[i] ]= dc[i]; s->dc_val[0][ s->block_index[i] ]= dc[i];
memcpy(s->ac_val[0][s->block_index[i]], ac[i], sizeof(DCTELEM)*16); memcpy(s->ac_val[0][s->block_index[i]], ac[i], sizeof(DCTELEM)*16);
......
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