summaryrefslogtreecommitdiff
path: root/libavcodec/mdct.c
diff options
context:
space:
mode:
authorMåns Rullgård <mans@mansr.com>2009-09-21 02:56:06 +0000
committerMåns Rullgård <mans@mansr.com>2009-09-21 02:56:06 +0000
commit94274b82f63c2befc48181745594ea75c97c50a2 (patch)
treeb41d55592939cb149c571d5af09d093e26f59d99 /libavcodec/mdct.c
parent670bd2005af2a80ccc67bbceee6c1e437ea95732 (diff)
Allow arch-specific mdct code to request interleaving of cos/sin tables
Originally committed as revision 19939 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/mdct.c')
-rw-r--r--libavcodec/mdct.c32
1 files changed, 22 insertions, 10 deletions
diff --git a/libavcodec/mdct.c b/libavcodec/mdct.c
index 4e5609c0c0..a2b9e8b423 100644
--- a/libavcodec/mdct.c
+++ b/libavcodec/mdct.c
@@ -76,32 +76,45 @@ av_cold int ff_mdct_init(FFTContext *s, int nbits, int inverse, double scale)
{
int n, n4, i;
double alpha, theta;
+ int tstep;
memset(s, 0, sizeof(*s));
n = 1 << nbits;
s->mdct_bits = nbits;
s->mdct_size = n;
n4 = n >> 2;
- s->tcos = av_malloc(n4 * sizeof(FFTSample));
+ s->permutation = FF_MDCT_PERM_NONE;
+
+ if (ff_fft_init(s, s->mdct_bits - 2, inverse) < 0)
+ goto fail;
+
+ s->tcos = av_malloc(n/2 * sizeof(FFTSample));
if (!s->tcos)
goto fail;
- s->tsin = av_malloc(n4 * sizeof(FFTSample));
- if (!s->tsin)
+
+ switch (s->permutation) {
+ case FF_MDCT_PERM_NONE:
+ s->tsin = s->tcos + n4;
+ tstep = 1;
+ break;
+ case FF_MDCT_PERM_INTERLEAVE:
+ s->tsin = s->tcos + 1;
+ tstep = 2;
+ break;
+ default:
goto fail;
+ }
theta = 1.0 / 8.0 + (scale < 0 ? n4 : 0);
scale = sqrt(fabs(scale));
for(i=0;i<n4;i++) {
alpha = 2 * M_PI * (i + theta) / n;
- s->tcos[i] = -cos(alpha) * scale;
- s->tsin[i] = -sin(alpha) * scale;
+ s->tcos[i*tstep] = -cos(alpha) * scale;
+ s->tsin[i*tstep] = -sin(alpha) * scale;
}
- if (ff_fft_init(s, s->mdct_bits - 2, inverse) < 0)
- goto fail;
return 0;
fail:
- av_freep(&s->tcos);
- av_freep(&s->tsin);
+ ff_mdct_end(s);
return -1;
}
@@ -229,6 +242,5 @@ void ff_mdct_calc_c(FFTContext *s, FFTSample *out, const FFTSample *input)
av_cold void ff_mdct_end(FFTContext *s)
{
av_freep(&s->tcos);
- av_freep(&s->tsin);
ff_fft_end(s);
}