alsdec: Check k used for rice decoder.
Values that fail this check will cause failure of decode_rice() Signed-off-by: Michael Niedermayer <michaelni@gmx.at> Signed-off-by: Justin Ruggles <justin.ruggles@gmail.com>
This commit is contained in:
		
							parent
							
								
									e3496e5dbe
								
							
						
					
					
						commit
						23aae62c2c
					
				@ -651,6 +651,11 @@ static int read_var_block_data(ALSDecContext *ctx, ALSBlockData *bd)
 | 
			
		||||
        for (k = 1; k < sub_blocks; k++)
 | 
			
		||||
            s[k] = s[k - 1] + decode_rice(gb, 0);
 | 
			
		||||
    }
 | 
			
		||||
    for (k = 1; k < sub_blocks; k++)
 | 
			
		||||
        if (s[k] > 32) {
 | 
			
		||||
            av_log(avctx, AV_LOG_ERROR, "k invalid for rice code.\n");
 | 
			
		||||
            return AVERROR_INVALIDDATA;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    if (get_bits1(gb))
 | 
			
		||||
        *bd->shift_lsbs = get_bits(gb, 4) + 1;
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user