From: Mashiat Sarker Shakkhar Date: Thu, 8 Dec 2011 19:43:34 +0000 (+0600) Subject: Do not update buffers in case no speed change is necessary X-Git-Tag: android-x86-4.4-r1~13333^2~20 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=4fa3f1c50718622ca04298d2d01b5a4c7d319cbf;p=android-x86%2Fexternal-ffmpeg.git Do not update buffers in case no speed change is necessary --- diff --git a/libavcodec/wmalosslessdec.c b/libavcodec/wmalosslessdec.c index 4c6df066b1..c61e39645a 100644 --- a/libavcodec/wmalosslessdec.c +++ b/libavcodec/wmalosslessdec.c @@ -948,9 +948,10 @@ static void lms_update(WmallDecodeCtx *s, int ich, int ilms, int input, int resi static void use_high_update_speed(WmallDecodeCtx *s, int ich) { int ilms, recent, icoef; - s->update_speed[ich] = 16; for (ilms = s->cdlms_ttl[ich] - 1; ilms >= 0; ilms--) { recent = s->cdlms[ich][ilms].recent; + if (s->update_speed[ich] == 16) + continue; if (s->bV3RTM) { for (icoef = 0; icoef < s->cdlms[ich][ilms].order; icoef++) s->cdlms[ich][ilms].lms_updates[icoef + recent] *= 2; @@ -959,14 +960,16 @@ static void use_high_update_speed(WmallDecodeCtx *s, int ich) s->cdlms[ich][ilms].lms_updates[icoef] *= 2; } } + s->update_speed[ich] = 16; } static void use_normal_update_speed(WmallDecodeCtx *s, int ich) { int ilms, recent, icoef; - s->update_speed[ich] = 8; for (ilms = s->cdlms_ttl[ich] - 1; ilms >= 0; ilms--) { recent = s->cdlms[ich][ilms].recent; + if (s->update_speed[ich] == 8) + continue; if (s->bV3RTM) { for (icoef = 0; icoef < s->cdlms[ich][ilms].order; icoef++) s->cdlms[ich][ilms].lms_updates[icoef + recent] /= 2; @@ -975,6 +978,7 @@ static void use_normal_update_speed(WmallDecodeCtx *s, int ich) s->cdlms[ich][ilms].lms_updates[icoef] /= 2; } } + s->update_speed[ich] = 8; } static void revert_cdlms(WmallDecodeCtx *s, int ch, int coef_begin, int coef_end)