aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Robinson <[email protected]>2010-12-02 16:36:37 -0800
committerChris Robinson <[email protected]>2010-12-02 16:36:37 -0800
commit59990acc2a380987886e6fa26a8a644d6016b4a9 (patch)
treedb9b7955330e0fa937d39c4f0dd1ed5d278d937e
parent0bf771633287b70659f1a000f94c0d2d9cd0a8d6 (diff)
Add functions to write (signed) byte and ushort samples to devices
-rw-r--r--Alc/ALu.c35
1 files changed, 34 insertions, 1 deletions
diff --git a/Alc/ALu.c b/Alc/ALu.c
index 2b263d01..cc8107df 100644
--- a/Alc/ALu.c
+++ b/Alc/ALu.c
@@ -765,6 +765,16 @@ static __inline ALfloat aluF2F(ALfloat Value)
{
return Value;
}
+static __inline ALshort aluF2US(ALfloat Value)
+{
+ ALint i;
+
+ if(Value <= -1.0f) i = 0;
+ else if(Value >= 1.0f) i = 65535;
+ else i = (ALint)(Value*32767.0f) + 32768;
+
+ return ((ALushort)i);
+}
static __inline ALshort aluF2S(ALfloat Value)
{
ALint i;
@@ -777,8 +787,13 @@ static __inline ALshort aluF2S(ALfloat Value)
}
static __inline ALubyte aluF2UB(ALfloat Value)
{
+ ALshort i = aluF2US(Value);
+ return i>>8;
+}
+static __inline ALubyte aluF2B(ALfloat Value)
+{
ALshort i = aluF2S(Value);
- return (i>>8)+128;
+ return i>>8;
}
static const Channel MonoChans[] = { FRONT_CENTER };
@@ -823,6 +838,12 @@ DECL_TEMPLATE(ALfloat, X51Chans,6, aluF2F)
DECL_TEMPLATE(ALfloat, X61Chans,7, aluF2F)
DECL_TEMPLATE(ALfloat, X71Chans,8, aluF2F)
+DECL_TEMPLATE(ALushort, MonoChans,1, aluF2US)
+DECL_TEMPLATE(ALushort, QuadChans,4, aluF2US)
+DECL_TEMPLATE(ALushort, X51Chans,6, aluF2US)
+DECL_TEMPLATE(ALushort, X61Chans,7, aluF2US)
+DECL_TEMPLATE(ALushort, X71Chans,8, aluF2US)
+
DECL_TEMPLATE(ALshort, MonoChans,1, aluF2S)
DECL_TEMPLATE(ALshort, QuadChans,4, aluF2S)
DECL_TEMPLATE(ALshort, X51Chans,6, aluF2S)
@@ -835,6 +856,12 @@ DECL_TEMPLATE(ALubyte, X51Chans,6, aluF2UB)
DECL_TEMPLATE(ALubyte, X61Chans,7, aluF2UB)
DECL_TEMPLATE(ALubyte, X71Chans,8, aluF2UB)
+DECL_TEMPLATE(ALbyte, MonoChans,1, aluF2B)
+DECL_TEMPLATE(ALbyte, QuadChans,4, aluF2B)
+DECL_TEMPLATE(ALbyte, X51Chans,6, aluF2B)
+DECL_TEMPLATE(ALbyte, X61Chans,7, aluF2B)
+DECL_TEMPLATE(ALbyte, X71Chans,8, aluF2B)
+
#undef DECL_TEMPLATE
#define DECL_TEMPLATE(T, chans,N, func) \
@@ -878,8 +905,10 @@ static void Write_##T##_##chans(ALCdevice *device, T *buffer, ALuint SamplesToDo
}
DECL_TEMPLATE(ALfloat, StereoChans,2, aluF2F)
+DECL_TEMPLATE(ALushort, StereoChans,2, aluF2US)
DECL_TEMPLATE(ALshort, StereoChans,2, aluF2S)
DECL_TEMPLATE(ALubyte, StereoChans,2, aluF2UB)
+DECL_TEMPLATE(ALbyte, StereoChans,2, aluF2B)
#undef DECL_TEMPLATE
@@ -910,8 +939,10 @@ static void Write_##T(ALCdevice *device, T *buffer, ALuint SamplesToDo) \
}
DECL_TEMPLATE(ALfloat, aluF2F)
+DECL_TEMPLATE(ALushort, aluF2US)
DECL_TEMPLATE(ALshort, aluF2S)
DECL_TEMPLATE(ALubyte, aluF2UB)
+DECL_TEMPLATE(ALbyte, aluF2B)
#undef DECL_TEMPLATE
@@ -1016,12 +1047,14 @@ ALvoid aluMixData(ALCdevice *device, ALvoid *buffer, ALsizei size)
switch(aluBytesFromFormat(device->Format))
{
+ (void)Write_ALbyte;
case 1:
Write_ALubyte(device, buffer, SamplesToDo);
break;
case 2:
Write_ALshort(device, buffer, SamplesToDo);
break;
+ (void)Write_ALushort;
case 4:
Write_ALfloat(device, buffer, SamplesToDo);
break;