[FFmpeg-cvslog] avcodec/flacenc: Fix Invalid Rice order
    George Boyle 
    git at videolan.org
       
    Fri Jun 19 10:15:55 CEST 2015
    
    
  
ffmpeg | branch: release/2.7 | George Boyle <george at thebuds.net> | Tue Jun 16 08:25:01 2015 +0100| [a9b600cf3995bc075090f4f1dbfbf772e21a4d5b] | committer: Carl Eugen Hoyos
avcodec/flacenc: Fix Invalid Rice order
Fixes ticket #4628.
The problem arose, in the sample file at least, in the last block where the
minimum and maximum Rice partition orders were both 0. In that case, and any
other where pmax == pmin, the original UINT32_MAX placeholder value for
bits[opt_porder] was getting overwritten before the comparison to check if the
current partition order is a new optimal, so the correct partition order and
RiceContext params were not being set.
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
(cherry picked from commit 2469ed32c81ebf2347e6883091c566724b286167)
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=a9b600cf3995bc075090f4f1dbfbf772e21a4d5b
---
 libavcodec/flacenc.c |    2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/libavcodec/flacenc.c b/libavcodec/flacenc.c
index cdfeaf8..29bd999 100644
--- a/libavcodec/flacenc.c
+++ b/libavcodec/flacenc.c
@@ -705,7 +705,7 @@ static uint64_t calc_rice_params(RiceContext *rc,
     bits[pmin] = UINT32_MAX;
     for (i = pmax; ; ) {
         bits[i] = calc_optimal_rice_params(&tmp_rc, i, sums, n, pred_order, kmax, exact);
-        if (bits[i] < bits[opt_porder]) {
+        if (bits[i] < bits[opt_porder] || pmax == pmin) {
             opt_porder = i;
             *rc = tmp_rc;
         }
    
    
More information about the ffmpeg-cvslog
mailing list