Mercurial > libavcodec.hg
changeset 10496:74b0c1a0851e libavcodec
Add ff_init_ff_cos_tabs function and use it in rdft.c to ensure that the
necessary ff_cos_tabs tables are initialized.
Fixes issue 1507 (QDM2 broken since r20237 without hardcoded tables).
author | reimar |
---|---|
date | Thu, 05 Nov 2009 18:29:06 +0000 |
parents | 8e91a3efdbd2 |
children | 8b4b365d08f5 |
files | dsputil.h fft.c rdft.c |
diffstat | 3 files changed, 22 insertions(+), 9 deletions(-) [+] |
line wrap: on
line diff
--- a/dsputil.h Thu Nov 05 01:10:27 2009 +0000 +++ b/dsputil.h Thu Nov 05 18:29:06 2009 +0000 @@ -769,6 +769,12 @@ extern COSTABLE(65536); extern COSTABLE_CONST FFTSample* const ff_cos_tabs[17]; +/** + * Initializes the cosine table in ff_cos_tabs[index] + * \param index index in ff_cos_tabs array of the table to initialize + */ +void ff_init_ff_cos_tabs(int index); + extern SINTABLE(16); extern SINTABLE(32); extern SINTABLE(64);
--- a/fft.c Thu Nov 05 01:10:27 2009 +0000 +++ b/fft.c Thu Nov 05 18:29:06 2009 +0000 @@ -61,6 +61,20 @@ else return split_radix_permutation(i, m, inverse)*4 - 1; } +av_cold void ff_init_ff_cos_tabs(int index) +{ +#if !CONFIG_HARDCODED_TABLES + int i; + int m = 1<<index; + double freq = 2*M_PI/m; + FFTSample *tab = ff_cos_tabs[index]; + for(i=0; i<=m/4; i++) + tab[i] = cos(i*freq); + for(i=1; i<m/4; i++) + tab[m/2-i] = tab[i]; +#endif +} + av_cold int ff_fft_init(FFTContext *s, int nbits, int inverse) { int i, j, m, n; @@ -96,17 +110,9 @@ if (HAVE_MMX) ff_fft_init_mmx(s); if (s->split_radix) { -#if !CONFIG_HARDCODED_TABLES for(j=4; j<=nbits; j++) { - int m = 1<<j; - double freq = 2*M_PI/m; - FFTSample *tab = ff_cos_tabs[j]; - for(i=0; i<=m/4; i++) - tab[i] = cos(i*freq); - for(i=1; i<m/4; i++) - tab[m/2-i] = tab[i]; + ff_init_ff_cos_tabs(j); } -#endif for(i=0; i<n; i++) s->revtab[-split_radix_permutation(i, n, s->inverse) & (n-1)] = i; s->tmp_buf = av_malloc(n * sizeof(FFTComplex));
--- a/rdft.c Thu Nov 05 01:10:27 2009 +0000 +++ b/rdft.c Thu Nov 05 18:29:06 2009 +0000 @@ -64,6 +64,7 @@ if (ff_fft_init(&s->fft, nbits-1, trans == IRDFT || trans == RIDFT) < 0) return -1; + ff_init_ff_cos_tabs(nbits); s->tcos = ff_cos_tabs[nbits]; s->tsin = ff_sin_tabs[nbits]+(trans == RDFT || trans == IRIDFT)*(n>>2); #if !CONFIG_HARDCODED_TABLES