Better organize the reverb code into separate labeled sections
[openal-soft.git] / Alc / mixer_defs.h
blob3c32278bb1fef16ab18b4019f040b87a6a107059
1 #ifndef MIXER_DEFS_H
2 #define MIXER_DEFS_H
4 #include "AL/alc.h"
5 #include "AL/al.h"
6 #include "alMain.h"
7 #include "alu.h"
9 struct MixGains;
11 struct HrtfParams;
12 struct HrtfState;
14 /* C resamplers */
15 const ALfloat *Resample_copy32_C(const BsincState *state, const ALfloat *src, ALuint frac, ALuint increment, ALfloat *restrict dst, ALuint dstlen);
16 const ALfloat *Resample_point32_C(const BsincState *state, const ALfloat *src, ALuint frac, ALuint increment, ALfloat *restrict dst, ALuint dstlen);
17 const ALfloat *Resample_lerp32_C(const BsincState *state, const ALfloat *src, ALuint frac, ALuint increment, ALfloat *restrict dst, ALuint dstlen);
18 const ALfloat *Resample_fir4_32_C(const BsincState *state, const ALfloat *src, ALuint frac, ALuint increment, ALfloat *restrict dst, ALuint dstlen);
19 const ALfloat *Resample_fir8_32_C(const BsincState *state, const ALfloat *src, ALuint frac, ALuint increment, ALfloat *restrict dst, ALuint dstlen);
20 const ALfloat *Resample_bsinc32_C(const BsincState *state, const ALfloat *src, ALuint frac, ALuint increment, ALfloat *restrict dst, ALuint dstlen);
23 /* C mixers */
24 void MixHrtf_C(ALfloat (*restrict OutBuffer)[BUFFERSIZE], const ALfloat *data,
25 ALuint Counter, ALuint Offset, ALuint OutPos, const ALuint IrSize,
26 const struct HrtfParams *hrtfparams, struct HrtfState *hrtfstate,
27 ALuint BufferSize);
28 void Mix_C(const ALfloat *data, ALuint OutChans, ALfloat (*restrict OutBuffer)[BUFFERSIZE],
29 struct MixGains *Gains, ALuint Counter, ALuint OutPos, ALuint BufferSize);
31 /* SSE mixers */
32 void MixHrtf_SSE(ALfloat (*restrict OutBuffer)[BUFFERSIZE], const ALfloat *data,
33 ALuint Counter, ALuint Offset, ALuint OutPos, const ALuint IrSize,
34 const struct HrtfParams *hrtfparams, struct HrtfState *hrtfstate,
35 ALuint BufferSize);
36 void Mix_SSE(const ALfloat *data, ALuint OutChans, ALfloat (*restrict OutBuffer)[BUFFERSIZE],
37 struct MixGains *Gains, ALuint Counter, ALuint OutPos, ALuint BufferSize);
39 /* SSE resamplers */
40 inline void InitiatePositionArrays(ALuint frac, ALuint increment, ALuint *frac_arr, ALuint *pos_arr, ALuint size)
42 ALuint i;
44 pos_arr[0] = 0;
45 frac_arr[0] = frac;
46 for(i = 1;i < size;i++)
48 ALuint frac_tmp = frac_arr[i-1] + increment;
49 pos_arr[i] = pos_arr[i-1] + (frac_tmp>>FRACTIONBITS);
50 frac_arr[i] = frac_tmp&FRACTIONMASK;
54 const ALfloat *Resample_bsinc32_SSE(const BsincState *state, const ALfloat *src, ALuint frac,
55 ALuint increment, ALfloat *restrict dst, ALuint dstlen);
57 const ALfloat *Resample_lerp32_SSE2(const BsincState *state, const ALfloat *src, ALuint frac, ALuint increment,
58 ALfloat *restrict dst, ALuint numsamples);
59 const ALfloat *Resample_lerp32_SSE41(const BsincState *state, const ALfloat *src, ALuint frac, ALuint increment,
60 ALfloat *restrict dst, ALuint numsamples);
62 const ALfloat *Resample_fir4_32_SSE3(const BsincState *state, const ALfloat *src, ALuint frac, ALuint increment,
63 ALfloat *restrict dst, ALuint numsamples);
64 const ALfloat *Resample_fir4_32_SSE41(const BsincState *state, const ALfloat *src, ALuint frac, ALuint increment,
65 ALfloat *restrict dst, ALuint numsamples);
67 const ALfloat *Resample_fir8_32_SSE3(const BsincState *state, const ALfloat *src, ALuint frac, ALuint increment,
68 ALfloat *restrict dst, ALuint numsamples);
69 const ALfloat *Resample_fir8_32_SSE41(const BsincState *state, const ALfloat *src, ALuint frac, ALuint increment,
70 ALfloat *restrict dst, ALuint numsamples);
72 /* Neon mixers */
73 void MixHrtf_Neon(ALfloat (*restrict OutBuffer)[BUFFERSIZE], const ALfloat *data,
74 ALuint Counter, ALuint Offset, ALuint OutPos, const ALuint IrSize,
75 const struct HrtfParams *hrtfparams, struct HrtfState *hrtfstate,
76 ALuint BufferSize);
77 void Mix_Neon(const ALfloat *data, ALuint OutChans, ALfloat (*restrict OutBuffer)[BUFFERSIZE],
78 struct MixGains *Gains, ALuint Counter, ALuint OutPos, ALuint BufferSize);
80 #endif /* MIXER_DEFS_H */