2012-08-15 08:01:55 +00:00
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include "AL/al.h"
|
|
|
|
#include "AL/alc.h"
|
|
|
|
#include "alMain.h"
|
|
|
|
#include "alu.h"
|
|
|
|
|
|
|
|
|
2012-08-15 15:19:04 +00:00
|
|
|
static __inline void ApplyCoeffsStep(ALuint Offset, ALfloat (*RESTRICT Values)[2],
|
|
|
|
ALfloat (*RESTRICT Coeffs)[2],
|
|
|
|
ALfloat (*RESTRICT CoeffStep)[2],
|
|
|
|
ALfloat left, ALfloat right)
|
|
|
|
{
|
|
|
|
ALuint c;
|
|
|
|
for(c = 0;c < HRIR_LENGTH;c++)
|
|
|
|
{
|
|
|
|
const ALuint off = (Offset+c)&HRIR_MASK;
|
|
|
|
Values[off][0] += Coeffs[c][0] * left;
|
|
|
|
Values[off][1] += Coeffs[c][1] * right;
|
|
|
|
Coeffs[c][0] += CoeffStep[c][0];
|
|
|
|
Coeffs[c][1] += CoeffStep[c][1];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-08-15 08:01:55 +00:00
|
|
|
static __inline void ApplyCoeffs(ALuint Offset, ALfloat (*RESTRICT Values)[2],
|
|
|
|
ALfloat (*RESTRICT Coeffs)[2],
|
|
|
|
ALfloat left, ALfloat right)
|
|
|
|
{
|
|
|
|
ALuint c;
|
|
|
|
for(c = 0;c < HRIR_LENGTH;c++)
|
|
|
|
{
|
|
|
|
const ALuint off = (Offset+c)&HRIR_MASK;
|
|
|
|
Values[off][0] += Coeffs[c][0] * left;
|
|
|
|
Values[off][1] += Coeffs[c][1] * right;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#define SUFFIX C
|
|
|
|
#define SAMPLER point32
|
|
|
|
#include "mixer_inc.c"
|
|
|
|
#undef SAMPLER
|
|
|
|
#define SAMPLER lerp32
|
|
|
|
#include "mixer_inc.c"
|
|
|
|
#undef SAMPLER
|
|
|
|
#define SAMPLER cubic32
|
|
|
|
#include "mixer_inc.c"
|
|
|
|
#undef SAMPLER
|
|
|
|
#undef SUFFIX
|