aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec/cook.c
diff options
context:
space:
mode:
authorMarc Hoffman <mmhoffm@gmail.com>2007-07-16 13:24:43 +0000
committerMarc Hoffman <mmhoffm@gmail.com>2007-07-16 13:24:43 +0000
commitdae92b62a3178e786ad0c2b593cfb1be37ee812b (patch)
treed3ccb9144d5ff898ca9567c0baa702289b0db0fc /libavcodec/cook.c
parent28d997f9327a80ff38e857c971716fa165fafe3f (diff)
downloadffmpeg-dae92b62a3178e786ad0c2b593cfb1be37ee812b.tar.gz
fixpoint: move cplscales to context structure and provide hook for data format conversion
Originally committed as revision 9702 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/cook.c')
-rw-r--r--libavcodec/cook.c17
1 files changed, 16 insertions, 1 deletions
diff --git a/libavcodec/cook.c b/libavcodec/cook.c
index 1a58ad8e21..a6a7360f35 100644
--- a/libavcodec/cook.c
+++ b/libavcodec/cook.c
@@ -144,6 +144,8 @@ typedef struct cook {
float decode_buffer_1[1024];
float decode_buffer_2[1024];
float decode_buffer_0[1060]; /* static allocation for joint decode */
+
+ float *cplscales[5];
} COOKContext;
/* debug functions */
@@ -262,6 +264,18 @@ static int init_cook_mlt(COOKContext *q) {
return 0;
}
+static float *maybe_reformat_buffer32 (COOKContext *q, float *ptr, int n)
+{
+ if (1)
+ return ptr;
+}
+
+static int init_cplscales_table (COOKContext *q) {
+ int i;
+ for (i=0;i<5;i++)
+ q->cplscales[i] = maybe_reformat_buffer32 (q, cplscales[i], (1<<(i+2))-1);
+}
+
/*************** init functions end ***********/
/**
@@ -843,7 +857,7 @@ static void joint_decode(COOKContext *q, float* mlt_buffer1,
for (i=q->js_subband_start ; i<q->subbands ; i++) {
cpl_tmp = cplband[i];
idx -=decouple_tab[cpl_tmp];
- cplscale = (float*)cplscales[q->js_vlc_bits-2]; //choose decoupler table
+ cplscale = q->cplscales[q->js_vlc_bits-2]; //choose decoupler table
f1 = cplscale[decouple_tab[cpl_tmp]];
f2 = cplscale[idx-1];
q->decouple (q, i, f1, f2, decode_buffer, mlt_buffer1, mlt_buffer2);
@@ -1113,6 +1127,7 @@ static int cook_decode_init(AVCodecContext *avctx)
init_rootpow2table(q);
init_pow2table(q);
init_gain_table(q);
+ init_cplscales_table(q);
if (init_cook_vlc_tables(q) != 0)
return -1;