--- trunk/xvidcore/src/encoder.c 2006/02/24 14:18:59 1684 +++ trunk/xvidcore/src/encoder.c 2006/12/14 13:09:00 1766 @@ -21,7 +21,7 @@ * along with this program ; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * - * $Id: encoder.c,v 1.127 2006-02-24 14:18:59 syskin Exp $ + * $Id: encoder.c,v 1.129 2006-12-14 13:09:00 Isibaar Exp $ * ****************************************************************************/ @@ -662,6 +662,9 @@ xvid_free(pEnc->temp_dquants); } + if ((pEnc->mbParam.plugin_flags & XVID_REQLAMBDA)) { + xvid_free(pEnc->temp_lambda); + } if (pEnc->num_plugins>0) { xvid_plg_destroy_t pdestroy; @@ -767,6 +770,7 @@ if(pEnc->mbParam.plugin_flags & XVID_REQLAMBDA) { int block = 0; + emms(); data.lambda = pEnc->temp_lambda; for(i = 0;i < pEnc->mbParam.mb_height; i++) for(j = 0;j < pEnc->mbParam.mb_width; j++) @@ -2034,7 +2038,7 @@ pthread_create(&pEnc->motionData[k].handle, NULL, (void*)SMPMotionEstimationBVOP, (void*)&pEnc->motionData[k]); } - + SMPMotionEstimationBVOP(&pEnc->motionData[0]); for (k = 1; k < pEnc->num_threads; k++) {