2013-02-13 18:20:51 +01:00
|
|
|
/* (C) 2001-2008 Timothy B. Terriberry
|
|
|
|
(C) 2008 Jean-Marc Valin */
|
|
|
|
/*
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions
|
|
|
|
are met:
|
|
|
|
|
|
|
|
- Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
|
|
|
|
- Redistributions in binary form must reproduce the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer in the
|
|
|
|
documentation and/or other materials provided with the distribution.
|
|
|
|
|
|
|
|
- Neither the name of the Xiph.org Foundation nor the names of its
|
|
|
|
contributors may be used to endorse or promote products derived from
|
|
|
|
this software without specific prior written permission.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR
|
|
|
|
CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
|
|
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
|
|
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
|
|
|
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
|
|
|
LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
|
|
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
|
|
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
2013-02-15 21:04:02 +01:00
|
|
|
#if !defined(cc6__mfrngcode_H)
|
|
|
|
# define cc6__mfrngcode_H (1)
|
2013-02-13 18:20:51 +01:00
|
|
|
# include "cc6_entcode.h"
|
|
|
|
|
|
|
|
/*Constants used by the entropy encoder/decoder.*/
|
|
|
|
|
|
|
|
/*The number of bits to output at a time.*/
|
2013-02-15 21:04:02 +01:00
|
|
|
# define cc6_EC_SYM_BITS (8)
|
2013-02-13 18:20:51 +01:00
|
|
|
/*The total number of bits in each of the state registers.*/
|
2013-02-15 21:04:02 +01:00
|
|
|
# define cc6_EC_CODE_BITS (32)
|
2013-02-13 18:20:51 +01:00
|
|
|
/*The maximum symbol value.*/
|
2013-02-15 21:04:02 +01:00
|
|
|
# define cc6_EC_SYM_MAX ((1U<<cc6_EC_SYM_BITS)-1)
|
2013-02-13 18:20:51 +01:00
|
|
|
/*Bits to shift by to move a symbol into the high-order position.*/
|
2013-02-15 21:04:02 +01:00
|
|
|
# define cc6_EC_CODE_SHIFT (cc6_EC_CODE_BITS-cc6_EC_SYM_BITS-1)
|
2013-02-13 18:20:51 +01:00
|
|
|
/*Carry bit of the high-order range symbol.*/
|
2013-02-15 21:04:02 +01:00
|
|
|
# define cc6_EC_CODE_TOP (((cc6_ec_uint32)1U)<<cc6_EC_CODE_BITS-1)
|
2013-02-13 18:20:51 +01:00
|
|
|
/*Low-order bit of the high-order range symbol.*/
|
2013-02-15 21:04:02 +01:00
|
|
|
# define cc6_EC_CODE_BOT (cc6_EC_CODE_TOP>>cc6_EC_SYM_BITS)
|
2013-02-13 18:20:51 +01:00
|
|
|
/*Code for which propagating carries are possible.*/
|
2013-02-15 21:04:02 +01:00
|
|
|
# define cc6_EC_CODE_CARRY (((cc6_ec_uint32)cc6_EC_SYM_MAX)<<cc6_EC_CODE_SHIFT)
|
2013-02-13 18:20:51 +01:00
|
|
|
/*The number of bits available for the last, partial symbol in the code field.*/
|
2013-02-15 21:04:02 +01:00
|
|
|
# define cc6_EC_CODE_EXTRA ((cc6_EC_CODE_BITS-2)%cc6_EC_SYM_BITS+1)
|
2013-02-13 18:20:51 +01:00
|
|
|
/*A mask for the bits available in the coding buffer.
|
|
|
|
This allows different platforms to use a variable with more bits, if it is
|
|
|
|
convenient.
|
2013-02-15 21:04:02 +01:00
|
|
|
We will only use cc6_EC_CODE_BITS of it.*/
|
|
|
|
# define cc6_EC_CODE_MASK ((((cc6_ec_uint32)1U)<<cc6_EC_CODE_BITS-1)-1<<1|1)
|
2013-02-13 18:20:51 +01:00
|
|
|
|
|
|
|
#endif
|