aboutsummaryrefslogtreecommitdiffstats
path: root/Alc/mixer_inc.c
diff options
context:
space:
mode:
Diffstat (limited to 'Alc/mixer_inc.c')
-rw-r--r--Alc/mixer_inc.c33
1 files changed, 33 insertions, 0 deletions
diff --git a/Alc/mixer_inc.c b/Alc/mixer_inc.c
index e9d81c2a..25dc2b58 100644
--- a/Alc/mixer_inc.c
+++ b/Alc/mixer_inc.c
@@ -114,3 +114,36 @@ skip_stepping:
OutPos += todo;
}
}
+
+void MixDirectHrtf(ALfloat (*restrict OutBuffer)[BUFFERSIZE], ALuint lidx, ALuint ridx,
+ const ALfloat *data, ALuint Offset, const ALuint IrSize,
+ ALfloat (*restrict Coeffs)[2], ALfloat (*restrict Values)[2],
+ ALuint BufferSize)
+{
+ ALfloat out[MAX_UPDATE_SAMPLES][2];
+ ALfloat insample;
+ ALuint pos, i;
+
+ for(pos = 0;pos < BufferSize;)
+ {
+ ALuint todo = minu(BufferSize-pos, MAX_UPDATE_SAMPLES);
+
+ for(i = 0;i < todo;i++)
+ {
+ Values[(Offset+IrSize)&HRIR_MASK][0] = 0.0f;
+ Values[(Offset+IrSize)&HRIR_MASK][1] = 0.0f;
+ Offset++;
+
+ insample = *(data++);
+ ApplyCoeffs(Offset, Values, IrSize, Coeffs, insample, insample);
+ out[i][0] = Values[Offset&HRIR_MASK][0];
+ out[i][1] = Values[Offset&HRIR_MASK][1];
+ }
+
+ for(i = 0;i < todo;i++)
+ OutBuffer[lidx][pos+i] += out[i][0];
+ for(i = 0;i < todo;i++)
+ OutBuffer[ridx][pos+i] += out[i][1];
+ pos += todo;
+ }
+}