1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2025-01-13 21:28:01 +02:00

Call rdft by function pointer

Call the RDFT by a function pointer like other FFT related transforms.
This makes instruction set optimized versions possible.

Based on patch by Alex Converse.

Originally committed as revision 22609 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
Måns Rullgård 2010-03-20 21:27:03 +00:00
parent b297129bdb
commit 2881c83127
2 changed files with 9 additions and 6 deletions

View File

@ -196,6 +196,7 @@ struct RDFTContext {
const FFTSample *tcos; const FFTSample *tcos;
SINTABLE_CONST FFTSample *tsin; SINTABLE_CONST FFTSample *tsin;
FFTContext fft; FFTContext fft;
void (*rdft_calc)(struct RDFTContext *s, FFTSample *z);
}; };
/** /**
@ -204,9 +205,13 @@ struct RDFTContext {
* @param trans the type of transform * @param trans the type of transform
*/ */
int ff_rdft_init(RDFTContext *s, int nbits, enum RDFTransformType trans); int ff_rdft_init(RDFTContext *s, int nbits, enum RDFTransformType trans);
void ff_rdft_calc(RDFTContext *s, FFTSample *data);
void ff_rdft_end(RDFTContext *s); void ff_rdft_end(RDFTContext *s);
static av_always_inline void ff_rdft_calc(RDFTContext *s, FFTSample *data)
{
s->rdft_calc(s, data);
}
/* Discrete Cosine Transform */ /* Discrete Cosine Transform */
struct DCTContext { struct DCTContext {

View File

@ -50,6 +50,8 @@ SINTABLE_CONST FFTSample * const ff_sin_tabs[] = {
ff_sin_2048, ff_sin_4096, ff_sin_8192, ff_sin_16384, ff_sin_32768, ff_sin_65536, ff_sin_2048, ff_sin_4096, ff_sin_8192, ff_sin_16384, ff_sin_32768, ff_sin_65536,
}; };
static void ff_rdft_calc_c(RDFTContext* s, FFTSample* data);
av_cold int ff_rdft_init(RDFTContext *s, int nbits, enum RDFTransformType trans) av_cold int ff_rdft_init(RDFTContext *s, int nbits, enum RDFTransformType trans)
{ {
int n = 1 << nbits; int n = 1 << nbits;
@ -74,6 +76,7 @@ av_cold int ff_rdft_init(RDFTContext *s, int nbits, enum RDFTransformType trans)
s->tsin[i] = sin(i*theta); s->tsin[i] = sin(i*theta);
} }
#endif #endif
s->rdft_calc = ff_rdft_calc_c;
return 0; return 0;
} }
@ -123,11 +126,6 @@ static void ff_rdft_calc_c(RDFTContext* s, FFTSample* data)
} }
} }
void ff_rdft_calc(RDFTContext *s, FFTSample *data)
{
ff_rdft_calc_c(s, data);
}
av_cold void ff_rdft_end(RDFTContext *s) av_cold void ff_rdft_end(RDFTContext *s)
{ {
ff_fft_end(&s->fft); ff_fft_end(&s->fft);