forked from len0rd/rockbox
Remove the floating point code from wmaprodec.c and change variable names accordingly.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@27416 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
parent
4b457d688b
commit
16284ae8ae
5 changed files with 75 additions and 322 deletions
|
@ -1,9 +1,6 @@
|
||||||
wmaprodec.c
|
wmaprodec.c
|
||||||
wma.c
|
wma.c
|
||||||
dsputil.c
|
|
||||||
mdct.c
|
|
||||||
mdct_tables.c
|
mdct_tables.c
|
||||||
fft.c
|
|
||||||
bitstream.c
|
bitstream.c
|
||||||
wmapro_mdct.c
|
wmapro_mdct.c
|
||||||
libavutil/log.c
|
libavutil/log.c
|
||||||
|
|
|
@ -468,62 +468,6 @@ unsigned int ff_wma_get_large_val(GetBitContext* gb)
|
||||||
* @return 0 on success, -1 otherwise
|
* @return 0 on success, -1 otherwise
|
||||||
*/
|
*/
|
||||||
int ff_wma_run_level_decode(AVCodecContext* avctx, GetBitContext* gb,
|
int ff_wma_run_level_decode(AVCodecContext* avctx, GetBitContext* gb,
|
||||||
VLC *vlc,
|
|
||||||
const float *level_table, const uint16_t *run_table,
|
|
||||||
int version, WMACoef *ptr, int offset,
|
|
||||||
int num_coefs, int block_len, int frame_len_bits,
|
|
||||||
int coef_nb_bits)
|
|
||||||
{
|
|
||||||
int code, level, sign;
|
|
||||||
const uint32_t *ilvl = (const uint32_t*)level_table;
|
|
||||||
uint32_t *iptr = (uint32_t*)ptr;
|
|
||||||
const unsigned int coef_mask = block_len - 1;
|
|
||||||
for (; offset < num_coefs; offset++) {
|
|
||||||
code = get_vlc2(gb, vlc->table, VLCBITS, VLCMAX);
|
|
||||||
if (code > 1) {
|
|
||||||
/** normal code */
|
|
||||||
offset += run_table[code];
|
|
||||||
sign = get_bits1(gb) - 1;
|
|
||||||
iptr[offset & coef_mask] = ilvl[code] ^ sign<<31;
|
|
||||||
} else if (code == 1) {
|
|
||||||
/** EOB */
|
|
||||||
break;
|
|
||||||
} else {
|
|
||||||
/** escape */
|
|
||||||
if (!version) {
|
|
||||||
level = get_bits(gb, coef_nb_bits);
|
|
||||||
/** NOTE: this is rather suboptimal. reading
|
|
||||||
block_len_bits would be better */
|
|
||||||
offset += get_bits(gb, frame_len_bits);
|
|
||||||
} else {
|
|
||||||
level = ff_wma_get_large_val(gb);
|
|
||||||
/** escape decode */
|
|
||||||
if (get_bits1(gb)) {
|
|
||||||
if (get_bits1(gb)) {
|
|
||||||
if (get_bits1(gb)) {
|
|
||||||
av_log(avctx,AV_LOG_ERROR,
|
|
||||||
"broken escape sequence\n");
|
|
||||||
return -1;
|
|
||||||
} else
|
|
||||||
offset += get_bits(gb, frame_len_bits) + 4;
|
|
||||||
} else
|
|
||||||
offset += get_bits(gb, 2) + 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
sign = get_bits1(gb) - 1;
|
|
||||||
ptr[offset & coef_mask] = (level^sign) - sign;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/** NOTE: EOB can be omitted */
|
|
||||||
if (offset > num_coefs) {
|
|
||||||
av_log(avctx, AV_LOG_ERROR, "overflow in spectral RLE, ignoring\n");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int ff_wma_fix_run_level_decode(AVCodecContext* avctx, GetBitContext* gb,
|
|
||||||
VLC *vlc,
|
VLC *vlc,
|
||||||
const int32_t *level_table, const uint16_t *run_table,
|
const int32_t *level_table, const uint16_t *run_table,
|
||||||
int version, int32_t *ptr, int offset,
|
int version, int32_t *ptr, int offset,
|
||||||
|
|
|
@ -154,12 +154,6 @@ int ff_wma_total_gain_to_bits(int total_gain);
|
||||||
int ff_wma_end(AVCodecContext *avctx);
|
int ff_wma_end(AVCodecContext *avctx);
|
||||||
unsigned int ff_wma_get_large_val(GetBitContext* gb);
|
unsigned int ff_wma_get_large_val(GetBitContext* gb);
|
||||||
int ff_wma_run_level_decode(AVCodecContext* avctx, GetBitContext* gb,
|
int ff_wma_run_level_decode(AVCodecContext* avctx, GetBitContext* gb,
|
||||||
VLC *vlc,
|
|
||||||
const float *level_table, const uint16_t *run_table,
|
|
||||||
int version, WMACoef *ptr, int offset,
|
|
||||||
int num_coefs, int block_len, int frame_len_bits,
|
|
||||||
int coef_nb_bits);
|
|
||||||
int ff_wma_fix_run_level_decode(AVCodecContext* avctx, GetBitContext* gb,
|
|
||||||
VLC *vlc,
|
VLC *vlc,
|
||||||
const int32_t *level_table, const uint16_t *run_table,
|
const int32_t *level_table, const uint16_t *run_table,
|
||||||
int version, int32_t *ptr, int offset,
|
int version, int32_t *ptr, int offset,
|
||||||
|
|
|
@ -361,30 +361,7 @@ static const uint16_t coef0_run[HUFF_COEF0_SIZE] = {
|
||||||
1, 0, 1, 0, 1, 0,
|
1, 0, 1, 0, 1, 0,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const float coef0_level[HUFF_COEF0_SIZE] = {
|
static const int32_t coef0_level[HUFF_COEF0_SIZE] = {
|
||||||
0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2,
|
|
||||||
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
||||||
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
||||||
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3,
|
|
||||||
3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
|
|
||||||
3, 3, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 5, 5,
|
|
||||||
5, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11,
|
|
||||||
11, 12, 12, 13, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18,
|
|
||||||
18, 19, 19, 20, 20, 21, 21, 22, 22, 23, 23, 24, 24, 25,
|
|
||||||
25, 26, 26, 27, 27, 28,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const int32_t fixcoef0_level[HUFF_COEF0_SIZE] = {
|
|
||||||
0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
||||||
|
@ -425,24 +402,7 @@ static const uint16_t coef1_run[HUFF_COEF1_SIZE] = {
|
||||||
1, 0, 1, 0, 1, 0, 1, 0, 0, 0,
|
1, 0, 1, 0, 1, 0, 1, 0, 0, 0,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const float coef1_level[HUFF_COEF1_SIZE] = {
|
static const int32_t coef1_level[HUFF_COEF1_SIZE] = {
|
||||||
0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2,
|
|
||||||
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
||||||
2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 4, 4,
|
|
||||||
4, 4, 4, 4, 5, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 9, 9, 10,
|
|
||||||
10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15, 16, 16, 17, 17, 18, 18, 19,
|
|
||||||
19, 20, 20, 21, 21, 22, 22, 23, 23, 24, 24, 25, 25, 26, 26, 27, 27, 28,
|
|
||||||
28, 29, 29, 30, 30, 31, 31, 32, 32, 33, 33, 34, 34, 35, 35, 36, 36, 37,
|
|
||||||
37, 38, 38, 39, 39, 40, 40, 41, 41, 42, 42, 43, 43, 44, 44, 45, 45, 46,
|
|
||||||
46, 47, 47, 48, 48, 49, 49, 50, 51, 52,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const int32_t fixcoef1_level[HUFF_COEF1_SIZE] = {
|
|
||||||
0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
||||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
||||||
|
|
|
@ -91,7 +91,6 @@
|
||||||
#include "get_bits.h"
|
#include "get_bits.h"
|
||||||
#include "put_bits.h"
|
#include "put_bits.h"
|
||||||
#include "wmaprodata.h"
|
#include "wmaprodata.h"
|
||||||
#include "dsputil.h"
|
|
||||||
#include "wma.h"
|
#include "wma.h"
|
||||||
#include "wmaprodec.h"
|
#include "wmaprodec.h"
|
||||||
#include "wmapro_mdct.h"
|
#include "wmapro_mdct.h"
|
||||||
|
@ -101,6 +100,9 @@
|
||||||
#include "wmapro_math.h"
|
#include "wmapro_math.h"
|
||||||
#include "codecs.h"
|
#include "codecs.h"
|
||||||
|
|
||||||
|
/* Uncomment the following line to enable some debug output */
|
||||||
|
//#define WMAPRO_DUMP_CTX_EN
|
||||||
|
|
||||||
/* Some defines to make it compile */
|
/* Some defines to make it compile */
|
||||||
#define AVERROR_INVALIDDATA -1
|
#define AVERROR_INVALIDDATA -1
|
||||||
#define AVERROR_PATCHWELCOME -2
|
#define AVERROR_PATCHWELCOME -2
|
||||||
|
@ -131,7 +133,7 @@ static VLC vec4_vlc; ///< 4 coefficients per symbol
|
||||||
static VLC vec2_vlc; ///< 2 coefficients per symbol
|
static VLC vec2_vlc; ///< 2 coefficients per symbol
|
||||||
static VLC vec1_vlc; ///< 1 coefficient per symbol
|
static VLC vec1_vlc; ///< 1 coefficient per symbol
|
||||||
static VLC coef_vlc[2]; ///< coefficient run length vlc codes
|
static VLC coef_vlc[2]; ///< coefficient run length vlc codes
|
||||||
static float sin64[33]; ///< sinus table for decorrelation
|
//static float sin64[33]; ///< sinus table for decorrelation
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief frame specific decoder context for a single channel
|
* @brief frame specific decoder context for a single channel
|
||||||
|
@ -153,10 +155,8 @@ typedef struct {
|
||||||
int8_t scale_factor_idx; ///< index for the transmitted scale factor values (used for resampling)
|
int8_t scale_factor_idx; ///< index for the transmitted scale factor values (used for resampling)
|
||||||
int* scale_factors; ///< pointer to the scale factor values used for decoding
|
int* scale_factors; ///< pointer to the scale factor values used for decoding
|
||||||
uint8_t table_idx; ///< index in sf_offsets for the scale factor reference block
|
uint8_t table_idx; ///< index in sf_offsets for the scale factor reference block
|
||||||
float* coeffs; ///< pointer to the subframe decode buffer
|
FIXED* coeffs; ///< pointer to the subframe decode buffer
|
||||||
FIXED* fixcoeffs;
|
DECLARE_ALIGNED(16, FIXED, out)[WMAPRO_BLOCK_MAX_SIZE + WMAPRO_BLOCK_MAX_SIZE / 2]; ///< output buffer
|
||||||
DECLARE_ALIGNED(16, float, out)[WMAPRO_BLOCK_MAX_SIZE + WMAPRO_BLOCK_MAX_SIZE / 2]; ///< output buffer
|
|
||||||
DECLARE_ALIGNED(16, FIXED, fixout)[WMAPRO_BLOCK_MAX_SIZE + WMAPRO_BLOCK_MAX_SIZE / 2]; ///< output buffer
|
|
||||||
} WMAProChannelCtx;
|
} WMAProChannelCtx;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -166,10 +166,9 @@ typedef struct {
|
||||||
uint8_t num_channels; ///< number of channels in the group
|
uint8_t num_channels; ///< number of channels in the group
|
||||||
int8_t transform; ///< transform on / off
|
int8_t transform; ///< transform on / off
|
||||||
int8_t transform_band[MAX_BANDS]; ///< controls if the transform is enabled for a certain band
|
int8_t transform_band[MAX_BANDS]; ///< controls if the transform is enabled for a certain band
|
||||||
float decorrelation_matrix[WMAPRO_MAX_CHANNELS*WMAPRO_MAX_CHANNELS];
|
//float decorrelation_matrix[WMAPRO_MAX_CHANNELS*WMAPRO_MAX_CHANNELS];
|
||||||
float* channel_data[WMAPRO_MAX_CHANNELS]; ///< transformation coefficients
|
FIXED* channel_data[WMAPRO_MAX_CHANNELS]; ///< transformation coefficients
|
||||||
FIXED fixdecorrelation_matrix[WMAPRO_MAX_CHANNELS*WMAPRO_MAX_CHANNELS];
|
FIXED fixdecorrelation_matrix[WMAPRO_MAX_CHANNELS*WMAPRO_MAX_CHANNELS];
|
||||||
FIXED* fixchannel_data[WMAPRO_MAX_CHANNELS]; ///< transformation coefficients
|
|
||||||
} WMAProChannelGrp;
|
} WMAProChannelGrp;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -182,10 +181,7 @@ typedef struct WMAProDecodeCtx {
|
||||||
uint8_t frame_data[MAX_FRAMESIZE +
|
uint8_t frame_data[MAX_FRAMESIZE +
|
||||||
FF_INPUT_BUFFER_PADDING_SIZE];///< compressed frame data
|
FF_INPUT_BUFFER_PADDING_SIZE];///< compressed frame data
|
||||||
PutBitContext pb; ///< context for filling the frame_data buffer
|
PutBitContext pb; ///< context for filling the frame_data buffer
|
||||||
FFTContext mdct_ctx[WMAPRO_BLOCK_SIZES]; ///< MDCT context per block size
|
DECLARE_ALIGNED(16, FIXED, tmp)[WMAPRO_BLOCK_MAX_SIZE]; ///< IMDCT input buffer
|
||||||
DECLARE_ALIGNED(16, float, tmp)[WMAPRO_BLOCK_MAX_SIZE]; ///< IMDCT output buffer
|
|
||||||
DECLARE_ALIGNED(16, FIXED, fixtmp)[WMAPRO_BLOCK_MAX_SIZE]; ///< IMDCT output buffer
|
|
||||||
float* windows[WMAPRO_BLOCK_SIZES]; ///< windows for the different block sizes
|
|
||||||
|
|
||||||
/* frame size dependent frame information (set during initialization) */
|
/* frame size dependent frame information (set during initialization) */
|
||||||
uint32_t decode_flags; ///< used compression features
|
uint32_t decode_flags; ///< used compression features
|
||||||
|
@ -219,7 +215,6 @@ typedef struct WMAProDecodeCtx {
|
||||||
uint32_t frame_num; ///< current frame number (not used for decoding)
|
uint32_t frame_num; ///< current frame number (not used for decoding)
|
||||||
GetBitContext gb; ///< bitstream reader context
|
GetBitContext gb; ///< bitstream reader context
|
||||||
int buf_bit_size; ///< buffer size in bits
|
int buf_bit_size; ///< buffer size in bits
|
||||||
float* samplesf; ///< current samplebuffer pointer
|
|
||||||
FIXED* samples;
|
FIXED* samples;
|
||||||
FIXED* samples_end; ///< maximum samplebuffer pointer
|
FIXED* samples_end; ///< maximum samplebuffer pointer
|
||||||
uint8_t drc_gain; ///< gain for the DRC tool
|
uint8_t drc_gain; ///< gain for the DRC tool
|
||||||
|
@ -246,6 +241,7 @@ typedef struct WMAProDecodeCtx {
|
||||||
*@brief helper function to print the most important members of the context
|
*@brief helper function to print the most important members of the context
|
||||||
*@param s context
|
*@param s context
|
||||||
*/
|
*/
|
||||||
|
#ifdef WMAPRO_DUMP_CTX_EN
|
||||||
static void av_cold dump_context(WMAProDecodeCtx *s)
|
static void av_cold dump_context(WMAProDecodeCtx *s)
|
||||||
{
|
{
|
||||||
#define PRINT(a, b) printf(" %s = %d\n", a, b);
|
#define PRINT(a, b) printf(" %s = %d\n", a, b);
|
||||||
|
@ -259,22 +255,7 @@ static void av_cold dump_context(WMAProDecodeCtx *s)
|
||||||
PRINT("len prefix", s->len_prefix);
|
PRINT("len prefix", s->len_prefix);
|
||||||
PRINT("num channels", s->num_channels);
|
PRINT("num channels", s->num_channels);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
/**
|
|
||||||
*@brief Uninitialize the decoder and free all resources.
|
|
||||||
*@param avctx codec context
|
|
||||||
*@return 0 on success, < 0 otherwise
|
|
||||||
*/
|
|
||||||
av_cold int decode_end(AVCodecContext *avctx)
|
|
||||||
{
|
|
||||||
WMAProDecodeCtx *s = avctx->priv_data;
|
|
||||||
int i;
|
|
||||||
|
|
||||||
for (i = 0; i < WMAPRO_BLOCK_SIZES; i++)
|
|
||||||
ff_mdct_end(&s->mdct_ctx[i]);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*@brief Initialize the decoder.
|
*@brief Initialize the decoder.
|
||||||
|
@ -293,7 +274,6 @@ av_cold int decode_init(AVCodecContext *avctx)
|
||||||
int num_possible_block_sizes;
|
int num_possible_block_sizes;
|
||||||
|
|
||||||
s->avctx = avctx;
|
s->avctx = avctx;
|
||||||
dsputil_init(&s->dsp, avctx);
|
|
||||||
init_put_bits(&s->pb, s->frame_data, MAX_FRAMESIZE);
|
init_put_bits(&s->pb, s->frame_data, MAX_FRAMESIZE);
|
||||||
|
|
||||||
avctx->sample_fmt = SAMPLE_FMT_FLT;
|
avctx->sample_fmt = SAMPLE_FMT_FLT;
|
||||||
|
@ -440,19 +420,6 @@ av_cold int decode_init(AVCodecContext *avctx)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** init MDCT, FIXME: only init needed sizes */
|
|
||||||
for (i = 0; i < WMAPRO_BLOCK_SIZES; i++)
|
|
||||||
ff_mdct_init(&s->mdct_ctx[i], BLOCK_MIN_BITS+1+i, 1,
|
|
||||||
1.0 / (1 << (BLOCK_MIN_BITS + i - 1))
|
|
||||||
/ (1 << (s->bits_per_sample - 1)));
|
|
||||||
|
|
||||||
/** init MDCT windows: simple sinus window */
|
|
||||||
for (i = 0; i < WMAPRO_BLOCK_SIZES; i++) {
|
|
||||||
const int win_idx = WMAPRO_BLOCK_MAX_BITS - i;
|
|
||||||
ff_init_ff_sine_windows(win_idx);
|
|
||||||
s->windows[WMAPRO_BLOCK_SIZES - i - 1] = ff_sine_windows[win_idx];
|
|
||||||
}
|
|
||||||
|
|
||||||
/** calculate subwoofer cutoff values */
|
/** calculate subwoofer cutoff values */
|
||||||
for (i = 0; i < num_possible_block_sizes; i++) {
|
for (i = 0; i < num_possible_block_sizes; i++) {
|
||||||
int block_size = s->samples_per_frame >> i;
|
int block_size = s->samples_per_frame >> i;
|
||||||
|
@ -461,11 +428,14 @@ av_cold int decode_init(AVCodecContext *avctx)
|
||||||
s->subwoofer_cutoffs[i] = av_clip(cutoff, 4, block_size);
|
s->subwoofer_cutoffs[i] = av_clip(cutoff, 4, block_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
/** calculate sine values for the decorrelation matrix */
|
/** calculate sine values for the decorrelation matrix */
|
||||||
for (i = 0; i < 33; i++)
|
for (i = 0; i < 33; i++)
|
||||||
sin64[i] = sin(i*M_PI / 64.0);
|
sin64[i] = sin(i*M_PI / 64.0);
|
||||||
#if 0
|
#endif
|
||||||
if (avctx->debug & FF_DEBUG_BITSTREAM)
|
|
||||||
|
#ifdef WMAPRO_DUMP_CTX_EN
|
||||||
|
dump_context(s);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
avctx->channel_layout = channel_mask;
|
avctx->channel_layout = channel_mask;
|
||||||
|
@ -614,6 +584,7 @@ static int decode_tilehdr(WMAProDecodeCtx *s)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
/**
|
/**
|
||||||
*@brief Calculate a decorrelation matrix from the bitstream parameters.
|
*@brief Calculate a decorrelation matrix from the bitstream parameters.
|
||||||
*@param s codec context
|
*@param s codec context
|
||||||
|
@ -682,6 +653,7 @@ static void decode_decorrelation_matrix(WMAProDecodeCtx *s,
|
||||||
offset += i;
|
offset += i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*@brief Decode channel transformation parameters
|
*@brief Decode channel transformation parameters
|
||||||
|
@ -710,8 +682,7 @@ static int decode_channel_transform(WMAProDecodeCtx* s)
|
||||||
for (s->num_chgroups = 0; remaining_channels &&
|
for (s->num_chgroups = 0; remaining_channels &&
|
||||||
s->num_chgroups < s->channels_for_cur_subframe; s->num_chgroups++) {
|
s->num_chgroups < s->channels_for_cur_subframe; s->num_chgroups++) {
|
||||||
WMAProChannelGrp* chgroup = &s->chgroup[s->num_chgroups];
|
WMAProChannelGrp* chgroup = &s->chgroup[s->num_chgroups];
|
||||||
float** channel_data = chgroup->channel_data;
|
FIXED** channel_data = chgroup->channel_data;
|
||||||
FIXED** fixchdata = chgroup->fixchannel_data;
|
|
||||||
chgroup->num_channels = 0;
|
chgroup->num_channels = 0;
|
||||||
chgroup->transform = 0;
|
chgroup->transform = 0;
|
||||||
|
|
||||||
|
@ -723,18 +694,15 @@ static int decode_channel_transform(WMAProDecodeCtx* s)
|
||||||
&& get_bits1(&s->gb)) {
|
&& get_bits1(&s->gb)) {
|
||||||
++chgroup->num_channels;
|
++chgroup->num_channels;
|
||||||
s->channel[channel_idx].grouped = 1;
|
s->channel[channel_idx].grouped = 1;
|
||||||
*channel_data++ = s->channel[channel_idx].coeffs;
|
*channel_data++ = s->channel[channel_idx].coeffs;
|
||||||
*fixchdata++ = s->channel[channel_idx].fixcoeffs;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
chgroup->num_channels = remaining_channels;
|
chgroup->num_channels = remaining_channels;
|
||||||
for (i = 0; i < s->channels_for_cur_subframe; i++) {
|
for (i = 0; i < s->channels_for_cur_subframe; i++) {
|
||||||
int channel_idx = s->channel_indexes_for_cur_subframe[i];
|
int channel_idx = s->channel_indexes_for_cur_subframe[i];
|
||||||
if (!s->channel[channel_idx].grouped) {
|
if (!s->channel[channel_idx].grouped)
|
||||||
*channel_data++ = s->channel[channel_idx].coeffs;
|
*channel_data++ = s->channel[channel_idx].coeffs;
|
||||||
*fixchdata++ = s->channel[channel_idx].fixcoeffs;
|
|
||||||
}
|
|
||||||
s->channel[channel_idx].grouped = 1;
|
s->channel[channel_idx].grouped = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -749,22 +717,12 @@ static int decode_channel_transform(WMAProDecodeCtx* s)
|
||||||
} else {
|
} else {
|
||||||
chgroup->transform = 1;
|
chgroup->transform = 1;
|
||||||
if (s->num_channels == 2) {
|
if (s->num_channels == 2) {
|
||||||
chgroup->decorrelation_matrix[0] = 1.0;
|
|
||||||
chgroup->decorrelation_matrix[1] = -1.0;
|
|
||||||
chgroup->decorrelation_matrix[2] = 1.0;
|
|
||||||
chgroup->decorrelation_matrix[3] = 1.0;
|
|
||||||
|
|
||||||
chgroup->fixdecorrelation_matrix[0] = 0x10000;
|
chgroup->fixdecorrelation_matrix[0] = 0x10000;
|
||||||
chgroup->fixdecorrelation_matrix[1] = -0x10000;
|
chgroup->fixdecorrelation_matrix[1] = -0x10000;
|
||||||
chgroup->fixdecorrelation_matrix[2] = 0x10000;
|
chgroup->fixdecorrelation_matrix[2] = 0x10000;
|
||||||
chgroup->fixdecorrelation_matrix[3] = 0x10000;
|
chgroup->fixdecorrelation_matrix[3] = 0x10000;
|
||||||
} else {
|
} else {
|
||||||
/** cos(pi/4) */
|
/** cos(pi/4) */
|
||||||
chgroup->decorrelation_matrix[0] = 0.70703125;
|
|
||||||
chgroup->decorrelation_matrix[1] = -0.70703125;
|
|
||||||
chgroup->decorrelation_matrix[2] = 0.70703125;
|
|
||||||
chgroup->decorrelation_matrix[3] = 0.70703125;
|
|
||||||
|
|
||||||
chgroup->fixdecorrelation_matrix[0] = 0xB500;
|
chgroup->fixdecorrelation_matrix[0] = 0xB500;
|
||||||
chgroup->fixdecorrelation_matrix[1] = -0xB500;
|
chgroup->fixdecorrelation_matrix[1] = -0xB500;
|
||||||
chgroup->fixdecorrelation_matrix[2] = 0xB500;
|
chgroup->fixdecorrelation_matrix[2] = 0xB500;
|
||||||
|
@ -772,6 +730,9 @@ static int decode_channel_transform(WMAProDecodeCtx* s)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (chgroup->num_channels > 2) {
|
} else if (chgroup->num_channels > 2) {
|
||||||
|
LOGF("in wmaprodec.c: Multichannel streams still not supported\n");
|
||||||
|
return -1;
|
||||||
|
#if 0
|
||||||
if (get_bits1(&s->gb)) {
|
if (get_bits1(&s->gb)) {
|
||||||
chgroup->transform = 1;
|
chgroup->transform = 1;
|
||||||
if (get_bits1(&s->gb)) {
|
if (get_bits1(&s->gb)) {
|
||||||
|
@ -789,6 +750,7 @@ static int decode_channel_transform(WMAProDecodeCtx* s)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/** decode transform on / off */
|
/** decode transform on / off */
|
||||||
|
@ -817,15 +779,6 @@ static int decode_channel_transform(WMAProDecodeCtx* s)
|
||||||
*/
|
*/
|
||||||
static int decode_coeffs(WMAProDecodeCtx *s, int c)
|
static int decode_coeffs(WMAProDecodeCtx *s, int c)
|
||||||
{
|
{
|
||||||
/* Integers 0..15 as single-precision floats. The table saves a
|
|
||||||
costly int to float conversion, and storing the values as
|
|
||||||
integers allows fast sign-flipping. */
|
|
||||||
static const int fval_tab[16] = {
|
|
||||||
0x00000000, 0x3f800000, 0x40000000, 0x40400000,
|
|
||||||
0x40800000, 0x40a00000, 0x40c00000, 0x40e00000,
|
|
||||||
0x41000000, 0x41100000, 0x41200000, 0x41300000,
|
|
||||||
0x41400000, 0x41500000, 0x41600000, 0x41700000,
|
|
||||||
};
|
|
||||||
int vlctable;
|
int vlctable;
|
||||||
VLC* vlc;
|
VLC* vlc;
|
||||||
WMAProChannelCtx* ci = &s->channel[c];
|
WMAProChannelCtx* ci = &s->channel[c];
|
||||||
|
@ -833,8 +786,7 @@ static int decode_coeffs(WMAProDecodeCtx *s, int c)
|
||||||
int cur_coeff = 0;
|
int cur_coeff = 0;
|
||||||
int num_zeros = 0;
|
int num_zeros = 0;
|
||||||
const uint16_t* run;
|
const uint16_t* run;
|
||||||
const float* level;
|
const FIXED* level;
|
||||||
const FIXED* fixlevel;
|
|
||||||
|
|
||||||
dprintf(s->avctx, "decode coefficients for channel %i\n", c);
|
dprintf(s->avctx, "decode coefficients for channel %i\n", c);
|
||||||
|
|
||||||
|
@ -844,18 +796,15 @@ static int decode_coeffs(WMAProDecodeCtx *s, int c)
|
||||||
if (vlctable) {
|
if (vlctable) {
|
||||||
run = coef1_run;
|
run = coef1_run;
|
||||||
level = coef1_level;
|
level = coef1_level;
|
||||||
fixlevel = fixcoef1_level;
|
|
||||||
} else {
|
} else {
|
||||||
run = coef0_run;
|
run = coef0_run;
|
||||||
level = coef0_level;
|
level = coef0_level;
|
||||||
fixlevel = fixcoef0_level;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** decode vector coefficients (consumes up to 167 bits per iteration for
|
/** decode vector coefficients (consumes up to 167 bits per iteration for
|
||||||
4 vector coded large values) */
|
4 vector coded large values) */
|
||||||
while (!rl_mode && cur_coeff + 3 < s->subframe_len) {
|
while (!rl_mode && cur_coeff + 3 < s->subframe_len) {
|
||||||
int vals[4];
|
int32_t vals[4];
|
||||||
int32_t fixvals[4];
|
|
||||||
int i;
|
int i;
|
||||||
unsigned int idx;
|
unsigned int idx;
|
||||||
|
|
||||||
|
@ -872,42 +821,29 @@ static int decode_coeffs(WMAProDecodeCtx *s, int c)
|
||||||
v1 = get_vlc2(&s->gb, vec1_vlc.table, VLCBITS, VEC1MAXDEPTH);
|
v1 = get_vlc2(&s->gb, vec1_vlc.table, VLCBITS, VEC1MAXDEPTH);
|
||||||
if (v1 == HUFF_VEC1_SIZE - 1)
|
if (v1 == HUFF_VEC1_SIZE - 1)
|
||||||
v1 += ff_wma_get_large_val(&s->gb);
|
v1 += ff_wma_get_large_val(&s->gb);
|
||||||
((float*)vals)[i ] = v0;
|
|
||||||
((float*)vals)[i+1] = v1;
|
vals[i] = v0;
|
||||||
fixvals[i] = v0;
|
vals[i+1] = v1;
|
||||||
fixvals[i+1] = v1;
|
|
||||||
} else {
|
} else {
|
||||||
vals[i] = fval_tab[symbol_to_vec2[idx] >> 4 ];
|
vals[i] = symbol_to_vec2[idx] >> 4;
|
||||||
vals[i+1] = fval_tab[symbol_to_vec2[idx] & 0xF];
|
vals[i+1] = symbol_to_vec2[idx] & 0xF;
|
||||||
fixvals[i] = symbol_to_vec2[idx] >> 4;
|
|
||||||
fixvals[i+1] = symbol_to_vec2[idx] & 0xF;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
vals[0] = fval_tab[ symbol_to_vec4[idx] >> 12 ];
|
vals[0] = symbol_to_vec4[idx] >> 12;
|
||||||
vals[1] = fval_tab[(symbol_to_vec4[idx] >> 8) & 0xF];
|
vals[1] = (symbol_to_vec4[idx] >> 8) & 0xF;
|
||||||
vals[2] = fval_tab[(symbol_to_vec4[idx] >> 4) & 0xF];
|
vals[2] = (symbol_to_vec4[idx] >> 4) & 0xF;
|
||||||
vals[3] = fval_tab[ symbol_to_vec4[idx] & 0xF];
|
vals[3] = symbol_to_vec4[idx] & 0xF;
|
||||||
|
|
||||||
fixvals[0] = symbol_to_vec4[idx] >> 12;
|
|
||||||
fixvals[1] = (symbol_to_vec4[idx] >> 8) & 0xF;
|
|
||||||
fixvals[2] = (symbol_to_vec4[idx] >> 4) & 0xF;
|
|
||||||
fixvals[3] = symbol_to_vec4[idx] & 0xF;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** decode sign */
|
/** decode sign */
|
||||||
for (i = 0; i < 4; i++) {
|
for (i = 0; i < 4; i++) {
|
||||||
if (vals[i]) {
|
if (vals[i]) {
|
||||||
int sign = get_bits1(&s->gb) - 1;
|
int sign = get_bits1(&s->gb) - 1;
|
||||||
*(uint32_t*)&ci->coeffs[cur_coeff] = vals[i] ^ sign<<31;
|
ci->coeffs[cur_coeff] = (sign == -1)? -vals[i]<<16 : vals[i]<<16;
|
||||||
ci->fixcoeffs[cur_coeff] = (sign == -1)? -fixvals[i]<<16 : fixvals[i]<<16;
|
|
||||||
if(ftofix16(ci->coeffs[cur_coeff]) != ci->fixcoeffs[cur_coeff]) {
|
|
||||||
printf("coeff = %f, fixcoeff = %f\n", ci->coeffs[cur_coeff], fixtof16(ci->fixcoeffs[cur_coeff]));getchar();
|
|
||||||
}
|
|
||||||
num_zeros = 0;
|
num_zeros = 0;
|
||||||
} else {
|
} else {
|
||||||
ci->coeffs[cur_coeff] = 0;
|
ci->coeffs[cur_coeff] = 0;
|
||||||
ci->fixcoeffs[cur_coeff] = 0;
|
|
||||||
/** switch to run level mode when subframe_len / 128 zeros
|
/** switch to run level mode when subframe_len / 128 zeros
|
||||||
were found in a row */
|
were found in a row */
|
||||||
rl_mode |= (++num_zeros > s->subframe_len >> 8);
|
rl_mode |= (++num_zeros > s->subframe_len >> 8);
|
||||||
|
@ -920,20 +856,11 @@ static int decode_coeffs(WMAProDecodeCtx *s, int c)
|
||||||
if (rl_mode) {
|
if (rl_mode) {
|
||||||
memset(&ci->coeffs[cur_coeff], 0,
|
memset(&ci->coeffs[cur_coeff], 0,
|
||||||
sizeof(*ci->coeffs) * (s->subframe_len - cur_coeff));
|
sizeof(*ci->coeffs) * (s->subframe_len - cur_coeff));
|
||||||
memset(&ci->fixcoeffs[cur_coeff], 0,
|
|
||||||
sizeof(*ci->fixcoeffs) * (s->subframe_len - cur_coeff));
|
|
||||||
|
|
||||||
int indx = s->gb.index;
|
if (ff_wma_run_level_decode(s->avctx, &s->gb, vlc,
|
||||||
if (ff_wma_run_level_decode(s->avctx, &s->gb, vlc,
|
|
||||||
level, run, 1, ci->coeffs,
|
level, run, 1, ci->coeffs,
|
||||||
cur_coeff, s->subframe_len,
|
cur_coeff, s->subframe_len,
|
||||||
s->subframe_len, s->esc_len, 0))
|
s->subframe_len, s->esc_len, 0))
|
||||||
return AVERROR_INVALIDDATA;
|
|
||||||
s->gb.index = indx;
|
|
||||||
if (ff_wma_fix_run_level_decode(s->avctx, &s->gb, vlc,
|
|
||||||
fixlevel, run, 1, ci->fixcoeffs,
|
|
||||||
cur_coeff, s->subframe_len,
|
|
||||||
s->subframe_len, s->esc_len, 0))
|
|
||||||
return AVERROR_INVALIDDATA;
|
return AVERROR_INVALIDDATA;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1045,13 +972,10 @@ static void inverse_channel_transform(WMAProDecodeCtx *s)
|
||||||
|
|
||||||
for (i = 0; i < s->num_chgroups; i++) {
|
for (i = 0; i < s->num_chgroups; i++) {
|
||||||
if (s->chgroup[i].transform) {
|
if (s->chgroup[i].transform) {
|
||||||
float data[WMAPRO_MAX_CHANNELS];
|
|
||||||
const int num_channels = s->chgroup[i].num_channels;
|
const int num_channels = s->chgroup[i].num_channels;
|
||||||
float** ch_data = s->chgroup[i].channel_data;
|
FIXED data[WMAPRO_MAX_CHANNELS];
|
||||||
float** ch_end = ch_data + num_channels;
|
FIXED** ch_data = s->chgroup[i].channel_data;
|
||||||
FIXED fixdata[WMAPRO_MAX_CHANNELS];
|
FIXED** ch_end = ch_data + num_channels;
|
||||||
FIXED** fixchdata = s->chgroup[i].fixchannel_data;
|
|
||||||
FIXED** fixchend = fixchdata + num_channels;
|
|
||||||
const int8_t* tb = s->chgroup[i].transform_band;
|
const int8_t* tb = s->chgroup[i].transform_band;
|
||||||
int16_t* sfb;
|
int16_t* sfb;
|
||||||
|
|
||||||
|
@ -1062,51 +986,33 @@ static void inverse_channel_transform(WMAProDecodeCtx *s)
|
||||||
if (*tb++ == 1) {
|
if (*tb++ == 1) {
|
||||||
/** multiply values with the decorrelation_matrix */
|
/** multiply values with the decorrelation_matrix */
|
||||||
for (y = sfb[0]; y < FFMIN(sfb[1], s->subframe_len); y++) {
|
for (y = sfb[0]; y < FFMIN(sfb[1], s->subframe_len); y++) {
|
||||||
const float* mat = s->chgroup[i].decorrelation_matrix;
|
const FIXED* mat = s->chgroup[i].fixdecorrelation_matrix;
|
||||||
const float* data_end = data + num_channels;
|
const FIXED* data_end = data + num_channels;
|
||||||
float* data_ptr = data;
|
FIXED* data_ptr = data;
|
||||||
float** ch;
|
FIXED** ch;
|
||||||
const FIXED* fixmat = s->chgroup[i].fixdecorrelation_matrix;
|
|
||||||
const FIXED* fixdata_end = fixdata + num_channels;
|
|
||||||
FIXED* fixdata_ptr = fixdata;
|
|
||||||
FIXED** fixch;
|
|
||||||
|
|
||||||
for (ch = ch_data, fixch = fixchdata; ch < ch_end && fixch < fixchend; ch++, fixch++) {
|
for (ch = ch_data; ch < ch_end; ch++)
|
||||||
*data_ptr++ = (*ch)[y];
|
*data_ptr++ = (*ch)[y];
|
||||||
*fixdata_ptr++ = (*fixch)[y];
|
|
||||||
}
|
|
||||||
|
|
||||||
for (ch = ch_data, fixch = fixchdata; ch < ch_end && fixch < fixchend; ch++, fixch++) {
|
for (ch = ch_data; ch < ch_end; ch++) {
|
||||||
float sum = 0;
|
FIXED sum = 0;
|
||||||
FIXED fixsum = 0;
|
|
||||||
data_ptr = data;
|
data_ptr = data;
|
||||||
fixdata_ptr = fixdata;
|
|
||||||
|
|
||||||
while (data_ptr < data_end)
|
while (data_ptr < data_end)
|
||||||
sum += *data_ptr++ * *mat++;
|
sum += fixmulshift(*data_ptr++, *mat++, 16);
|
||||||
|
|
||||||
while (fixdata_ptr < fixdata_end)
|
|
||||||
fixsum += fixmulshift(*fixdata_ptr++, *fixmat++, 16);
|
|
||||||
|
|
||||||
(*ch)[y] = sum;
|
(*ch)[y] = sum;
|
||||||
(*fixch)[y] = fixsum;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (s->num_channels == 2) {
|
} else if (s->num_channels == 2) {
|
||||||
|
|
||||||
int len = FFMIN(sfb[1], s->subframe_len) - sfb[0];
|
int len = FFMIN(sfb[1], s->subframe_len) - sfb[0];
|
||||||
s->dsp.vector_fmul_scalar(ch_data[0] + sfb[0],
|
vector_fixmul_scalar(ch_data[0] + sfb[0],
|
||||||
ch_data[0] + sfb[0],
|
ch_data[0] + sfb[0],
|
||||||
181.0 / 128, len);
|
0x00016A00, len,16);
|
||||||
s->dsp.vector_fmul_scalar(ch_data[1] + sfb[0],
|
vector_fixmul_scalar(ch_data[1] + sfb[0],
|
||||||
ch_data[1] + sfb[0],
|
ch_data[1] + sfb[0],
|
||||||
181.0 / 128, len);
|
0x00016A00, len,16);
|
||||||
vector_fixmul_scalar(fixchdata[0] + sfb[0],
|
|
||||||
fixchdata[0] + sfb[0],
|
|
||||||
0x00016A00, len, 16);
|
|
||||||
vector_fixmul_scalar(fixchdata[1] + sfb[0],
|
|
||||||
fixchdata[1] + sfb[0],
|
|
||||||
0x00016A00, len,16);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1124,26 +1030,19 @@ static void wmapro_window(WMAProDecodeCtx *s)
|
||||||
|
|
||||||
for (i = 0; i < s->channels_for_cur_subframe; i++) {
|
for (i = 0; i < s->channels_for_cur_subframe; i++) {
|
||||||
int c = s->channel_indexes_for_cur_subframe[i];
|
int c = s->channel_indexes_for_cur_subframe[i];
|
||||||
FIXED* window;
|
const FIXED* window;
|
||||||
float* win2;
|
|
||||||
int winlen = s->channel[c].prev_block_len;
|
int winlen = s->channel[c].prev_block_len;
|
||||||
float* start = s->channel[c].coeffs - (winlen >> 1);
|
FIXED *xstart= s->channel[c].coeffs - (winlen >> 1);
|
||||||
FIXED *xstart= s->channel[c].fixcoeffs - (winlen >> 1);
|
|
||||||
int j;
|
|
||||||
|
|
||||||
if (s->subframe_len < winlen) {
|
if (s->subframe_len < winlen) {
|
||||||
start += (winlen - s->subframe_len) >> 1;
|
|
||||||
xstart += (winlen - s->subframe_len) >> 1;
|
xstart += (winlen - s->subframe_len) >> 1;
|
||||||
winlen = s->subframe_len;
|
winlen = s->subframe_len;
|
||||||
}
|
}
|
||||||
|
|
||||||
window = sine_windows[av_log2(winlen) - BLOCK_MIN_BITS];
|
window = sine_windows[av_log2(winlen) - BLOCK_MIN_BITS];
|
||||||
win2 = s->windows[av_log2(winlen) - BLOCK_MIN_BITS];
|
|
||||||
|
|
||||||
winlen >>= 1;
|
winlen >>= 1;
|
||||||
|
|
||||||
s->dsp.vector_fmul_window(start, start, start + winlen,
|
|
||||||
win2, 0, winlen);
|
|
||||||
vector_fixmul_window(xstart, xstart, xstart + winlen,
|
vector_fixmul_window(xstart, xstart, xstart + winlen,
|
||||||
window, 0, winlen);
|
window, 0, winlen);
|
||||||
|
|
||||||
|
@ -1223,8 +1122,6 @@ static int decode_subframe(WMAProDecodeCtx *s)
|
||||||
|
|
||||||
s->channel[c].coeffs = &s->channel[c].out[(s->samples_per_frame >> 1)
|
s->channel[c].coeffs = &s->channel[c].out[(s->samples_per_frame >> 1)
|
||||||
+ offset];
|
+ offset];
|
||||||
s->channel[c].fixcoeffs = &s->channel[c].fixout[(s->samples_per_frame >> 1)
|
|
||||||
+ offset];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
s->subframe_len = subframe_len;
|
s->subframe_len = subframe_len;
|
||||||
|
@ -1322,8 +1219,6 @@ static int decode_subframe(WMAProDecodeCtx *s)
|
||||||
} else {
|
} else {
|
||||||
memset(s->channel[c].coeffs, 0,
|
memset(s->channel[c].coeffs, 0,
|
||||||
sizeof(*s->channel[c].coeffs) * subframe_len);
|
sizeof(*s->channel[c].coeffs) * subframe_len);
|
||||||
memset(s->channel[c].fixcoeffs, 0,
|
|
||||||
sizeof(*s->channel[c].fixcoeffs) * subframe_len);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1338,42 +1233,34 @@ static int decode_subframe(WMAProDecodeCtx *s)
|
||||||
const int* sf = s->channel[c].scale_factors;
|
const int* sf = s->channel[c].scale_factors;
|
||||||
int b;
|
int b;
|
||||||
|
|
||||||
if (c == s->lfe_channel){
|
if (c == s->lfe_channel)
|
||||||
memset(&s->tmp[cur_subwoofer_cutoff], 0, sizeof(*s->tmp) *
|
memset(&s->tmp[cur_subwoofer_cutoff], 0, sizeof(*s->tmp) *
|
||||||
(subframe_len - cur_subwoofer_cutoff));
|
(subframe_len - cur_subwoofer_cutoff));
|
||||||
memset(&s->fixtmp[cur_subwoofer_cutoff], 0, sizeof(*s->fixtmp) *
|
|
||||||
(subframe_len - cur_subwoofer_cutoff));
|
|
||||||
}
|
|
||||||
/** inverse quantization and rescaling */
|
/** inverse quantization and rescaling */
|
||||||
for (b = 0; b < s->num_bands; b++) {
|
for (b = 0; b < s->num_bands; b++) {
|
||||||
const int end = FFMIN(s->cur_sfb_offsets[b+1], s->subframe_len);
|
const int end = FFMIN(s->cur_sfb_offsets[b+1], s->subframe_len);
|
||||||
const int exp = s->channel[c].quant_step -
|
const int exp = s->channel[c].quant_step -
|
||||||
(s->channel[c].max_scale_factor - *sf++) *
|
(s->channel[c].max_scale_factor - *sf++) *
|
||||||
s->channel[c].scale_factor_step;
|
s->channel[c].scale_factor_step;
|
||||||
const float quant = pow(10.0, exp / 20.0);
|
|
||||||
|
|
||||||
if(exp < EXP_MIN || exp > EXP_MAX) {
|
if(exp < EXP_MIN || exp > EXP_MAX) {
|
||||||
LOGF("in wmaprodec.c : unhandled value for exp, please report sample.\n");
|
LOGF("in wmaprodec.c : unhandled value for exp, please report sample.\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
const FIXED fixquant = QUANT(exp);
|
const FIXED quant = QUANT(exp);
|
||||||
int start = s->cur_sfb_offsets[b];
|
int start = s->cur_sfb_offsets[b];
|
||||||
|
|
||||||
s->dsp.vector_fmul_scalar(s->tmp + start,
|
vector_fixmul_scalar(s->tmp+start,
|
||||||
s->channel[c].coeffs + start,
|
s->channel[c].coeffs + start,
|
||||||
quant, end - start);
|
quant, end-start, 24);
|
||||||
vector_fixmul_scalar(s->fixtmp+start,
|
|
||||||
s->channel[c].fixcoeffs + start,
|
|
||||||
fixquant, end-start, 24);
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** apply imdct (ff_imdct_half == DCTIV with reverse) */
|
/** apply imdct (ff_imdct_half == DCTIV with reverse) */
|
||||||
fff_imdct_half(&s->mdct_ctx[av_log2(subframe_len) - BLOCK_MIN_BITS],
|
imdct_half(av_log2(subframe_len)+1,
|
||||||
s->channel[c].coeffs, s->tmp);
|
s->channel[c].coeffs, s->tmp);
|
||||||
imdct_half((s->mdct_ctx[av_log2(subframe_len) - BLOCK_MIN_BITS]).mdct_bits,
|
|
||||||
s->channel[c].fixcoeffs, s->fixtmp);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1482,13 +1369,9 @@ static int decode_frame(WMAProDecodeCtx *s)
|
||||||
/** interleave samples and write them to the output buffer */
|
/** interleave samples and write them to the output buffer */
|
||||||
for (i = 0; i < s->num_channels; i++) {
|
for (i = 0; i < s->num_channels; i++) {
|
||||||
FIXED* ptr = s->samples + i;
|
FIXED* ptr = s->samples + i;
|
||||||
float* fptr = s->samplesf + i;
|
|
||||||
int incr = s->num_channels;
|
int incr = s->num_channels;
|
||||||
FIXED* iptr = s->channel[i].fixout;
|
FIXED* iptr = s->channel[i].out;
|
||||||
float* fiptr = s->channel[i].out;
|
|
||||||
FIXED* iend = iptr + s->samples_per_frame;
|
FIXED* iend = iptr + s->samples_per_frame;
|
||||||
float* fiend = fiptr + s->samples_per_frame;
|
|
||||||
int j;
|
|
||||||
|
|
||||||
while (iptr < iend) {
|
while (iptr < iend) {
|
||||||
*ptr = *iptr++ << 1;
|
*ptr = *iptr++ << 1;
|
||||||
|
@ -1499,18 +1382,12 @@ static int decode_frame(WMAProDecodeCtx *s)
|
||||||
memcpy(&s->channel[i].out[0],
|
memcpy(&s->channel[i].out[0],
|
||||||
&s->channel[i].out[s->samples_per_frame],
|
&s->channel[i].out[s->samples_per_frame],
|
||||||
s->samples_per_frame * sizeof(*s->channel[i].out) >> 1);
|
s->samples_per_frame * sizeof(*s->channel[i].out) >> 1);
|
||||||
|
|
||||||
memcpy(&s->channel[i].fixout[0],
|
|
||||||
&s->channel[i].fixout[s->samples_per_frame],
|
|
||||||
s->samples_per_frame * sizeof(*s->channel[i].fixout) >> 1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (s->skip_frame) {
|
if (s->skip_frame) {
|
||||||
s->skip_frame = 0;
|
s->skip_frame = 0;
|
||||||
} else {
|
} else
|
||||||
s->samples += s->num_channels * s->samples_per_frame;
|
s->samples += s->num_channels * s->samples_per_frame;
|
||||||
s->samplesf += s->num_channels * s->samples_per_frame;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (len != (get_bits_count(gb) - s->frame_offset) + 2) {
|
if (len != (get_bits_count(gb) - s->frame_offset) + 2) {
|
||||||
/** FIXME: not sure if this is always an error */
|
/** FIXME: not sure if this is always an error */
|
||||||
|
@ -1688,25 +1565,6 @@ int decode_packet(AVCodecContext *avctx,
|
||||||
return (s->packet_loss) ? AVERROR_INVALIDDATA : get_bits_count(gb) >> 3;
|
return (s->packet_loss) ? AVERROR_INVALIDDATA : get_bits_count(gb) >> 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
*@brief Clear decoder buffers (for seeking).
|
|
||||||
*@param avctx codec context
|
|
||||||
*/
|
|
||||||
static void flush(AVCodecContext *avctx)
|
|
||||||
{
|
|
||||||
WMAProDecodeCtx *s = avctx->priv_data;
|
|
||||||
int i;
|
|
||||||
/** reset output buffer as a part of it is used during the windowing of a
|
|
||||||
new frame */
|
|
||||||
for (i = 0; i < s->num_channels; i++) {
|
|
||||||
memset(s->channel[i].out, 0, s->samples_per_frame *
|
|
||||||
sizeof(*s->channel[i].out));
|
|
||||||
memset(s->channel[i].out, 0, s->samples_per_frame *
|
|
||||||
sizeof(*s->channel[i].fixout));
|
|
||||||
}
|
|
||||||
s->packet_loss = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
/**
|
/**
|
||||||
*@brief wmapro decoder
|
*@brief wmapro decoder
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue