# HG changeset patch # User iive # Date 1088078513 0 # Node ID 6cbccc0c7d7bb8820bf60db7a52aaa875ca086a9 # Parent 47dbe356085cfaf68b760e72e3e148f2b8a6d066 Fix memory corruption, noticable at reallocate image diff -r 47dbe356085c -r 6cbccc0c7d7b libmpcodecs/vf_spp.c --- a/libmpcodecs/vf_spp.c Thu Jun 24 10:25:05 2004 +0000 +++ b/libmpcodecs/vf_spp.c Thu Jun 24 12:01:53 2004 +0000 @@ -472,13 +472,15 @@ if(!(mpi->flags&MP_IMGFLAG_DIRECT)){ // no DR, so get a new image! hope we'll get DR buffer: - vf->dmpi=vf_get_image(vf->next,vf->priv->outfmt, - MP_IMGTYPE_TEMP, MP_IMGFLAG_ACCEPT_STRIDE|MP_IMGFLAG_PREFER_ALIGNED_STRIDE, - mpi->w,mpi->h); - } + dmpi=vf_get_image(vf->next,vf->priv->outfmt, + MP_IMGTYPE_TEMP, + MP_IMGFLAG_ACCEPT_STRIDE|MP_IMGFLAG_PREFER_ALIGNED_STRIDE, + mpi->w,mpi->h); + vf_clone_mpi_attributes(dmpi, mpi); + }else{ + dmpi=mpi; + } - dmpi= vf->dmpi; - vf->priv->mpeg2= mpi->qscale_type; if(vf->priv->log2_count || !(mpi->flags&MP_IMGFLAG_DIRECT)){ if(mpi->qscale || vf->priv->qp){ @@ -491,7 +493,6 @@ memcpy_pic(dmpi->planes[2], mpi->planes[2], mpi->w>>mpi->chroma_x_shift, mpi->h>>mpi->chroma_y_shift, dmpi->stride[2], mpi->stride[2]); } } - vf_clone_mpi_attributes(dmpi, mpi); #ifdef HAVE_MMX if(gCpuCaps.hasMMX) asm volatile ("emms\n\t"); @@ -566,7 +567,7 @@ static int open(vf_instance_t *vf, char* args){ - int log2c; + int log2c=0; vf->config=config; vf->put_image=put_image;