fixes... mostly sound fuckery

git-svn-id: https://svn.eduke32.com/eduke32@1481 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
terminx 2009-07-31 11:45:29 +00:00
parent a188f1600e
commit 3964ca6766
20 changed files with 112 additions and 804 deletions

View file

@ -1610,7 +1610,7 @@ static int32_t kpegrend(const char *kfilebuf, int32_t kfilength,
//Get DC //Get DC
if (!Ss) if (!Ss)
{ {
while (curbits < 24) //Getbits while (curbits < 16) //Getbits
{ {
ch = *kfileptr++; if (ch == 255) kfileptr++; ch = *kfileptr++; if (ch == 255) kfileptr++;
num = (num<<8)+((int32_t)ch); curbits += 8; num = (num<<8)+((int32_t)ch); curbits += 8;
@ -1625,7 +1625,7 @@ static int32_t kpegrend(const char *kfilebuf, int32_t kfilength,
if (daval) if (daval)
{ {
while (curbits < 24) //Getbits while (curbits < daval) //Getbits
{ {
ch = *kfileptr++; if (ch == 255) kfileptr++; ch = *kfileptr++; if (ch == 255) kfileptr++;
num = (num<<8)+((int32_t)ch); curbits += 8; num = (num<<8)+((int32_t)ch); curbits += 8;
@ -1647,7 +1647,7 @@ static int32_t kpegrend(const char *kfilebuf, int32_t kfilength,
{ {
for (; z<=Se; z++) for (; z<=Se; z++)
{ {
while (curbits < 24) //Getbits while (curbits < 16) //Getbits
{ {
ch = *kfileptr++; if (ch == 255) kfileptr++; ch = *kfileptr++; if (ch == 255) kfileptr++;
num = (num<<8)+((int32_t)ch); curbits += 8; num = (num<<8)+((int32_t)ch); curbits += 8;
@ -1662,7 +1662,11 @@ static int32_t kpegrend(const char *kfilebuf, int32_t kfilength,
{ {
if (Ah) if (Ah)
{ {
//NOTE: Getbits not needed here - buffer should have enough bits if (curbits < 8) //Getbits
{
ch = *kfileptr++; if (ch == 255) kfileptr++;
num = (num<<8)+((long)ch); curbits += 8;
}
if (num&(pow2long[--curbits])) daval = Alut[0]; else daval = Alut[1]; if (num&(pow2long[--curbits])) daval = Alut[0]; else daval = Alut[1];
} }
} }
@ -1671,7 +1675,7 @@ static int32_t kpegrend(const char *kfilebuf, int32_t kfilength,
eobrun = pow2long[zz]; eobrun = pow2long[zz];
if (zz) if (zz)
{ {
while (curbits < 24) //Getbits while (curbits < zz) //Getbits
{ {
ch = *kfileptr++; if (ch == 255) kfileptr++; ch = *kfileptr++; if (ch == 255) kfileptr++;
num = (num<<8)+((int32_t)ch); curbits += 8; num = (num<<8)+((int32_t)ch); curbits += 8;
@ -1687,7 +1691,7 @@ static int32_t kpegrend(const char *kfilebuf, int32_t kfilength,
{ {
if (dcs[z]) if (dcs[z])
{ {
while (curbits < 24) //Getbits if (curbits < 8) //Getbits
{ {
ch = *kfileptr++; if (ch == 255) kfileptr++; ch = *kfileptr++; if (ch == 255) kfileptr++;
num = (num<<8)+((int32_t)ch); curbits += 8; num = (num<<8)+((int32_t)ch); curbits += 8;
@ -1704,7 +1708,7 @@ static int32_t kpegrend(const char *kfilebuf, int32_t kfilength,
{ {
z += zz; if (z > Se) break; z += zz; if (z > Se) break;
while (curbits < 24) //Getbits while (curbits < daval) //Getbits
{ {
ch = *kfileptr++; if (ch == 255) kfileptr++; ch = *kfileptr++; if (ch == 255) kfileptr++;
num = (num<<8)+((int32_t)ch); curbits += 8; num = (num<<8)+((int32_t)ch); curbits += 8;
@ -1723,7 +1727,7 @@ static int32_t kpegrend(const char *kfilebuf, int32_t kfilength,
for (; z<=Se; z++) for (; z<=Se; z++)
{ {
if (!dcs[z]) continue; if (!dcs[z]) continue;
while (curbits < 24) //Getbits if (curbits < 8) //Getbits
{ {
ch = *kfileptr++; if (ch == 255) kfileptr++; ch = *kfileptr++; if (ch == 255) kfileptr++;
num = (num<<8)+((int32_t)ch); curbits += 8; num = (num<<8)+((int32_t)ch); curbits += 8;
@ -1996,7 +2000,7 @@ static int32_t ktgarend(const char *header, int32_t fleng,
const uint8_t *fptr, *cptr, *nptr; const uint8_t *fptr, *cptr, *nptr;
//Ugly and unreliable identification for .TGA! //Ugly and unreliable identification for .TGA!
if ((fleng < 20) || (header[1]&0xfe)) return(-1); if ((fleng < 19) || (header[1]&0xfe)) return(-1);
if ((header[2] >= 12) || (!((1<<header[2])&0xe0e))) return(-1); if ((header[2] >= 12) || (!((1<<header[2])&0xe0e))) return(-1);
if ((header[16]&7) || (header[16] == 0) || (header[16] > 32)) return(-1); if ((header[16]&7) || (header[16] == 0) || (header[16] > 32)) return(-1);
if (header[17]&0xc0) return(-1); if (header[17]&0xc0) return(-1);
@ -2476,7 +2480,7 @@ void kpgetdim(const char *buf, int32_t leng, int32_t *xsiz, int32_t *ysiz)
} }
else else
{ //Unreliable .TGA identification - this MUST be final case! { //Unreliable .TGA identification - this MUST be final case!
if ((leng >= 20) && (!(ubuf[1]&0xfe))) if ((leng >= 19) && (!(ubuf[1]&0xfe)))
if ((ubuf[2] < 12) && ((1<<ubuf[2])&0xe0e)) if ((ubuf[2] < 12) && ((1<<ubuf[2])&0xe0e))
if ((!(ubuf[16]&7)) && (ubuf[16] != 0) && (ubuf[16] <= 32)) if ((!(ubuf[16]&7)) && (ubuf[16] != 0) && (ubuf[16] <= 32))
if (!(buf[17]&0xc0)) if (!(buf[17]&0xc0))
@ -2516,7 +2520,7 @@ int32_t kprender(const char *buf, int32_t leng, intptr_t frameptr, int32_t bpl,
return(kddsrend(buf,leng,frameptr,bpl,xdim,ydim,xoff,yoff)); return(kddsrend(buf,leng,frameptr,bpl,xdim,ydim,xoff,yoff));
//Unreliable .TGA identification - this MUST be final case! //Unreliable .TGA identification - this MUST be final case!
if ((leng >= 20) && (!(ubuf[1]&0xfe))) if ((leng >= 19) && (!(ubuf[1]&0xfe)))
if ((ubuf[2] < 12) && ((1<<ubuf[2])&0xe0e)) if ((ubuf[2] < 12) && ((1<<ubuf[2])&0xe0e))
if ((!(ubuf[16]&7)) && (ubuf[16] != 0) && (ubuf[16] <= 32)) if ((!(ubuf[16]&7)) && (ubuf[16] != 0) && (ubuf[16] <= 32))
if (!(ubuf[17]&0xc0)) if (!(ubuf[17]&0xc0))

View file

@ -592,10 +592,6 @@
RelativePath=".\source\jaudiolib\src\_multivc.h" RelativePath=".\source\jaudiolib\src\_multivc.h"
> >
</File> </File>
<File
RelativePath=".\source\jaudiolib\src\driver_coreaudio.h"
>
</File>
<File <File
RelativePath=".\source\jaudiolib\src\driver_directsound.h" RelativePath=".\source\jaudiolib\src\driver_directsound.h"
> >
@ -644,10 +640,6 @@
<Filter <Filter
Name="Source Files" Name="Source Files"
> >
<File
RelativePath=".\source\jaudiolib\src\driver_coreaudio.c"
>
</File>
<File <File
RelativePath=".\source\jaudiolib\src\driver_directsound.c" RelativePath=".\source\jaudiolib\src\driver_directsound.c"
> >

View file

@ -37,7 +37,6 @@ typedef enum
{ {
ASS_NoSound, ASS_NoSound,
ASS_SDL, ASS_SDL,
ASS_CoreAudio,
ASS_DirectSound, ASS_DirectSound,
ASS_NumSoundCards, ASS_NumSoundCards,
ASS_AutoDetect = -2 ASS_AutoDetect = -2

View file

@ -1,307 +0,0 @@
// !$*UTF8*$!
{
archiveVersion = 1;
classes = {
};
objectVersion = 42;
objects = {
/* Begin PBXBuildFile section */
AB2E9E5F1011E65900DD2F1F /* _multivc.h in Headers */ = {isa = PBXBuildFile; fileRef = AB2E9E4D1011E65900DD2F1F /* _multivc.h */; };
AB2E9E601011E65900DD2F1F /* driver_coreaudio.c in Sources */ = {isa = PBXBuildFile; fileRef = AB2E9E4E1011E65900DD2F1F /* driver_coreaudio.c */; };
AB2E9E611011E65900DD2F1F /* driver_coreaudio.h in Headers */ = {isa = PBXBuildFile; fileRef = AB2E9E4F1011E65900DD2F1F /* driver_coreaudio.h */; };
AB2E9E641011E65900DD2F1F /* driver_nosound.c in Sources */ = {isa = PBXBuildFile; fileRef = AB2E9E521011E65900DD2F1F /* driver_nosound.c */; };
AB2E9E651011E65900DD2F1F /* driver_nosound.h in Headers */ = {isa = PBXBuildFile; fileRef = AB2E9E531011E65900DD2F1F /* driver_nosound.h */; };
AB2E9E681011E65900DD2F1F /* drivers.c in Sources */ = {isa = PBXBuildFile; fileRef = AB2E9E561011E65900DD2F1F /* drivers.c */; };
AB2E9E691011E65900DD2F1F /* drivers.h in Headers */ = {isa = PBXBuildFile; fileRef = AB2E9E571011E65900DD2F1F /* drivers.h */; };
AB2E9E6A1011E65900DD2F1F /* fx_man.c in Sources */ = {isa = PBXBuildFile; fileRef = AB2E9E581011E65900DD2F1F /* fx_man.c */; };
AB2E9E6B1011E65900DD2F1F /* linklist.h in Headers */ = {isa = PBXBuildFile; fileRef = AB2E9E591011E65900DD2F1F /* linklist.h */; };
AB2E9E6C1011E65900DD2F1F /* ll_man.h in Headers */ = {isa = PBXBuildFile; fileRef = AB2E9E5A1011E65900DD2F1F /* ll_man.h */; };
AB2E9E6D1011E65900DD2F1F /* multivoc.c in Sources */ = {isa = PBXBuildFile; fileRef = AB2E9E5B1011E65900DD2F1F /* multivoc.c */; };
AB2E9E6E1011E65900DD2F1F /* multivoc.h in Headers */ = {isa = PBXBuildFile; fileRef = AB2E9E5C1011E65900DD2F1F /* multivoc.h */; };
AB2E9E6F1011E65900DD2F1F /* pitch.c in Sources */ = {isa = PBXBuildFile; fileRef = AB2E9E5D1011E65900DD2F1F /* pitch.c */; };
AB2E9E701011E65900DD2F1F /* pitch.h in Headers */ = {isa = PBXBuildFile; fileRef = AB2E9E5E1011E65900DD2F1F /* pitch.h */; };
AB2E9E741011E66100DD2F1F /* fx_man.h in Headers */ = {isa = PBXBuildFile; fileRef = AB2E9E711011E66100DD2F1F /* fx_man.h */; };
AB2E9E751011E66100DD2F1F /* music.h in Headers */ = {isa = PBXBuildFile; fileRef = AB2E9E721011E66100DD2F1F /* music.h */; };
AB2E9E761011E66100DD2F1F /* sndcards.h in Headers */ = {isa = PBXBuildFile; fileRef = AB2E9E731011E66100DD2F1F /* sndcards.h */; };
AB2EA0831012029200DD2F1F /* AudioUnit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = AB2EA0821012029200DD2F1F /* AudioUnit.framework */; };
AB2EA17710121AA900DD2F1F /* mix.c in Sources */ = {isa = PBXBuildFile; fileRef = AB2EA17610121AA900DD2F1F /* mix.c */; };
AB8C5612101A077700B42306 /* mixst.c in Sources */ = {isa = PBXBuildFile; fileRef = AB8C5611101A077700B42306 /* mixst.c */; };
AB8C5828101B6B7100B42306 /* ogg.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = AB8C5826101B6B7100B42306 /* ogg.framework */; };
AB8C5829101B6B7100B42306 /* vorbis.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = AB8C5827101B6B7100B42306 /* vorbis.framework */; };
AB8C5868101B6D7500B42306 /* vorbis.c in Sources */ = {isa = PBXBuildFile; fileRef = AB8C5867101B6D7500B42306 /* vorbis.c */; };
/* End PBXBuildFile section */
/* Begin PBXFileReference section */
AB2E9E421011E61700DD2F1F /* libjfaudiolib.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = libjfaudiolib.a; sourceTree = BUILT_PRODUCTS_DIR; };
AB2E9E4D1011E65900DD2F1F /* _multivc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = _multivc.h; sourceTree = "<group>"; };
AB2E9E4E1011E65900DD2F1F /* driver_coreaudio.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = driver_coreaudio.c; sourceTree = "<group>"; };
AB2E9E4F1011E65900DD2F1F /* driver_coreaudio.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = driver_coreaudio.h; sourceTree = "<group>"; };
AB2E9E521011E65900DD2F1F /* driver_nosound.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = driver_nosound.c; sourceTree = "<group>"; };
AB2E9E531011E65900DD2F1F /* driver_nosound.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = driver_nosound.h; sourceTree = "<group>"; };
AB2E9E561011E65900DD2F1F /* drivers.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = drivers.c; sourceTree = "<group>"; };
AB2E9E571011E65900DD2F1F /* drivers.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = drivers.h; sourceTree = "<group>"; };
AB2E9E581011E65900DD2F1F /* fx_man.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = fx_man.c; sourceTree = "<group>"; };
AB2E9E591011E65900DD2F1F /* linklist.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = linklist.h; sourceTree = "<group>"; };
AB2E9E5A1011E65900DD2F1F /* ll_man.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ll_man.h; sourceTree = "<group>"; };
AB2E9E5B1011E65900DD2F1F /* multivoc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = multivoc.c; sourceTree = "<group>"; };
AB2E9E5C1011E65900DD2F1F /* multivoc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = multivoc.h; sourceTree = "<group>"; };
AB2E9E5D1011E65900DD2F1F /* pitch.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = pitch.c; sourceTree = "<group>"; };
AB2E9E5E1011E65900DD2F1F /* pitch.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch.h; sourceTree = "<group>"; };
AB2E9E711011E66100DD2F1F /* fx_man.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fx_man.h; sourceTree = "<group>"; };
AB2E9E721011E66100DD2F1F /* music.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = music.h; sourceTree = "<group>"; };
AB2E9E731011E66100DD2F1F /* sndcards.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = sndcards.h; sourceTree = "<group>"; };
AB2EA0821012029200DD2F1F /* AudioUnit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = AudioUnit.framework; path = /System/Library/Frameworks/AudioUnit.framework; sourceTree = "<absolute>"; };
AB2EA17610121AA900DD2F1F /* mix.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = mix.c; sourceTree = "<group>"; };
AB8C5611101A077700B42306 /* mixst.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = mixst.c; sourceTree = "<group>"; };
AB8C5826101B6B7100B42306 /* ogg.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = ogg.framework; path = "third-party/ogg.framework"; sourceTree = "<group>"; };
AB8C5827101B6B7100B42306 /* vorbis.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = vorbis.framework; path = "third-party/vorbis.framework"; sourceTree = "<group>"; };
AB8C5867101B6D7500B42306 /* vorbis.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = vorbis.c; sourceTree = "<group>"; };
/* End PBXFileReference section */
/* Begin PBXFrameworksBuildPhase section */
AB2E9E401011E61600DD2F1F /* Frameworks */ = {
isa = PBXFrameworksBuildPhase;
buildActionMask = 2147483647;
files = (
AB2EA0831012029200DD2F1F /* AudioUnit.framework in Frameworks */,
AB8C5828101B6B7100B42306 /* ogg.framework in Frameworks */,
AB8C5829101B6B7100B42306 /* vorbis.framework in Frameworks */,
);
runOnlyForDeploymentPostprocessing = 0;
};
/* End PBXFrameworksBuildPhase section */
/* Begin PBXGroup section */
AB2E9E301011E60300DD2F1F = {
isa = PBXGroup;
children = (
AB8C582E101B6B7900B42306 /* Linked frameworks */,
AB2E9E481011E63F00DD2F1F /* include */,
AB2E9E471011E63900DD2F1F /* src */,
AB2E9E431011E61700DD2F1F /* Products */,
);
sourceTree = "<group>";
};
AB2E9E431011E61700DD2F1F /* Products */ = {
isa = PBXGroup;
children = (
AB2E9E421011E61700DD2F1F /* libjfaudiolib.a */,
);
name = Products;
sourceTree = "<group>";
};
AB2E9E471011E63900DD2F1F /* src */ = {
isa = PBXGroup;
children = (
AB2E9E4D1011E65900DD2F1F /* _multivc.h */,
AB2E9E4E1011E65900DD2F1F /* driver_coreaudio.c */,
AB2E9E4F1011E65900DD2F1F /* driver_coreaudio.h */,
AB2E9E521011E65900DD2F1F /* driver_nosound.c */,
AB2E9E531011E65900DD2F1F /* driver_nosound.h */,
AB2E9E561011E65900DD2F1F /* drivers.c */,
AB2E9E571011E65900DD2F1F /* drivers.h */,
AB2E9E581011E65900DD2F1F /* fx_man.c */,
AB2E9E591011E65900DD2F1F /* linklist.h */,
AB2E9E5A1011E65900DD2F1F /* ll_man.h */,
AB2E9E5B1011E65900DD2F1F /* multivoc.c */,
AB2E9E5C1011E65900DD2F1F /* multivoc.h */,
AB2E9E5D1011E65900DD2F1F /* pitch.c */,
AB2E9E5E1011E65900DD2F1F /* pitch.h */,
AB2EA17610121AA900DD2F1F /* mix.c */,
AB8C5611101A077700B42306 /* mixst.c */,
AB8C5867101B6D7500B42306 /* vorbis.c */,
);
path = src;
sourceTree = "<group>";
};
AB2E9E481011E63F00DD2F1F /* include */ = {
isa = PBXGroup;
children = (
AB2E9E711011E66100DD2F1F /* fx_man.h */,
AB2E9E721011E66100DD2F1F /* music.h */,
AB2E9E731011E66100DD2F1F /* sndcards.h */,
);
path = include;
sourceTree = "<group>";
};
AB8C582E101B6B7900B42306 /* Linked frameworks */ = {
isa = PBXGroup;
children = (
AB2EA0821012029200DD2F1F /* AudioUnit.framework */,
AB8C5827101B6B7100B42306 /* vorbis.framework */,
AB8C5826101B6B7100B42306 /* ogg.framework */,
);
name = "Linked frameworks";
sourceTree = "<group>";
};
/* End PBXGroup section */
/* Begin PBXHeadersBuildPhase section */
AB2E9E3E1011E61600DD2F1F /* Headers */ = {
isa = PBXHeadersBuildPhase;
buildActionMask = 2147483647;
files = (
AB2E9E5F1011E65900DD2F1F /* _multivc.h in Headers */,
AB2E9E611011E65900DD2F1F /* driver_coreaudio.h in Headers */,
AB2E9E651011E65900DD2F1F /* driver_nosound.h in Headers */,
AB2E9E691011E65900DD2F1F /* drivers.h in Headers */,
AB2E9E6B1011E65900DD2F1F /* linklist.h in Headers */,
AB2E9E6C1011E65900DD2F1F /* ll_man.h in Headers */,
AB2E9E6E1011E65900DD2F1F /* multivoc.h in Headers */,
AB2E9E701011E65900DD2F1F /* pitch.h in Headers */,
AB2E9E741011E66100DD2F1F /* fx_man.h in Headers */,
AB2E9E751011E66100DD2F1F /* music.h in Headers */,
AB2E9E761011E66100DD2F1F /* sndcards.h in Headers */,
);
runOnlyForDeploymentPostprocessing = 0;
};
/* End PBXHeadersBuildPhase section */
/* Begin PBXNativeTarget section */
AB2E9E411011E61600DD2F1F /* jfaudiolib */ = {
isa = PBXNativeTarget;
buildConfigurationList = AB2E9E441011E61900DD2F1F /* Build configuration list for PBXNativeTarget "jfaudiolib" */;
buildPhases = (
AB2E9E3E1011E61600DD2F1F /* Headers */,
AB2E9E3F1011E61600DD2F1F /* Sources */,
AB2E9E401011E61600DD2F1F /* Frameworks */,
);
buildRules = (
);
dependencies = (
);
name = jfaudiolib;
productName = jfaudiolib;
productReference = AB2E9E421011E61700DD2F1F /* libjfaudiolib.a */;
productType = "com.apple.product-type.library.static";
};
/* End PBXNativeTarget section */
/* Begin PBXProject section */
AB2E9E321011E60300DD2F1F /* Project object */ = {
isa = PBXProject;
buildConfigurationList = AB2E9E331011E60300DD2F1F /* Build configuration list for PBXProject "jfaudiolib" */;
compatibilityVersion = "Xcode 2.4";
hasScannedForEncodings = 0;
mainGroup = AB2E9E301011E60300DD2F1F;
productRefGroup = AB2E9E431011E61700DD2F1F /* Products */;
projectDirPath = "";
projectRoot = "";
targets = (
AB2E9E411011E61600DD2F1F /* jfaudiolib */,
);
};
/* End PBXProject section */
/* Begin PBXSourcesBuildPhase section */
AB2E9E3F1011E61600DD2F1F /* Sources */ = {
isa = PBXSourcesBuildPhase;
buildActionMask = 2147483647;
files = (
AB2E9E601011E65900DD2F1F /* driver_coreaudio.c in Sources */,
AB2E9E641011E65900DD2F1F /* driver_nosound.c in Sources */,
AB2E9E681011E65900DD2F1F /* drivers.c in Sources */,
AB2E9E6A1011E65900DD2F1F /* fx_man.c in Sources */,
AB2E9E6D1011E65900DD2F1F /* multivoc.c in Sources */,
AB2E9E6F1011E65900DD2F1F /* pitch.c in Sources */,
AB2EA17710121AA900DD2F1F /* mix.c in Sources */,
AB8C5612101A077700B42306 /* mixst.c in Sources */,
AB8C5868101B6D7500B42306 /* vorbis.c in Sources */,
);
runOnlyForDeploymentPostprocessing = 0;
};
/* End PBXSourcesBuildPhase section */
/* Begin XCBuildConfiguration section */
AB2E9E341011E60300DD2F1F /* Debug */ = {
isa = XCBuildConfiguration;
buildSettings = {
ARCHS = (
ppc,
i386,
);
COPY_PHASE_STRIP = NO;
FRAMEWORK_SEARCH_PATHS = "third-party";
GCC_PREPROCESSOR_DEFINITIONS = __MACOSX__;
GCC_VERSION_i386 = 4.0;
GCC_VERSION_ppc = 4.0;
MACOSX_DEPLOYMENT_TARGET_i386 = 10.4;
MACOSX_DEPLOYMENT_TARGET_ppc = 10.3;
SDKROOT_i386 = /Developer/SDKs/MacOSX10.4u.sdk;
SDKROOT_ppc = /Developer/SDKs/MacOSX10.3.9.sdk;
};
name = Debug;
};
AB2E9E351011E60300DD2F1F /* Release */ = {
isa = XCBuildConfiguration;
buildSettings = {
ARCHS = (
ppc,
i386,
);
COPY_PHASE_STRIP = YES;
FRAMEWORK_SEARCH_PATHS = "third-party";
GCC_PREPROCESSOR_DEFINITIONS = __MACOSX__;
GCC_VERSION_i386 = 4.0;
GCC_VERSION_ppc = 4.0;
MACOSX_DEPLOYMENT_TARGET_i386 = 10.4;
MACOSX_DEPLOYMENT_TARGET_ppc = 10.3;
SDKROOT_i386 = /Developer/SDKs/MacOSX10.4u.sdk;
SDKROOT_ppc = /Developer/SDKs/MacOSX10.3.9.sdk;
};
name = Release;
};
AB2E9E451011E61900DD2F1F /* Debug */ = {
isa = XCBuildConfiguration;
buildSettings = {
COPY_PHASE_STRIP = NO;
FRAMEWORK_SEARCH_PATHS = "$(inherited)";
GCC_DYNAMIC_NO_PIC = NO;
GCC_ENABLE_FIX_AND_CONTINUE = YES;
GCC_GENERATE_DEBUGGING_SYMBOLS = YES;
GCC_OPTIMIZATION_LEVEL = 0;
PREBINDING = NO;
PRODUCT_NAME = jfaudiolib;
ZERO_LINK = YES;
};
name = Debug;
};
AB2E9E461011E61900DD2F1F /* Release */ = {
isa = XCBuildConfiguration;
buildSettings = {
COPY_PHASE_STRIP = YES;
FRAMEWORK_SEARCH_PATHS = "$(inherited)";
GCC_ENABLE_FIX_AND_CONTINUE = NO;
GCC_GENERATE_DEBUGGING_SYMBOLS = NO;
PREBINDING = NO;
PRODUCT_NAME = jfaudiolib;
ZERO_LINK = NO;
};
name = Release;
};
/* End XCBuildConfiguration section */
/* Begin XCConfigurationList section */
AB2E9E331011E60300DD2F1F /* Build configuration list for PBXProject "jfaudiolib" */ = {
isa = XCConfigurationList;
buildConfigurations = (
AB2E9E341011E60300DD2F1F /* Debug */,
AB2E9E351011E60300DD2F1F /* Release */,
);
defaultConfigurationIsVisible = 0;
defaultConfigurationName = Release;
};
AB2E9E441011E61900DD2F1F /* Build configuration list for PBXNativeTarget "jfaudiolib" */ = {
isa = XCConfigurationList;
buildConfigurations = (
AB2E9E451011E61900DD2F1F /* Debug */,
AB2E9E461011E61900DD2F1F /* Release */,
);
defaultConfigurationIsVisible = 0;
defaultConfigurationName = Release;
};
/* End XCConfigurationList section */
};
rootObject = AB2E9E321011E60300DD2F1F /* Project object */;
}

View file

@ -1,339 +0,0 @@
/*
Copyright (C) 2009 Jonathon Fowler <jf@jonof.id.au>
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
/**
* CoreAudio output driver for MultiVoc
*
* Inspired by the example set by the Audiere sound library available at
* https://audiere.svn.sourceforge.net/svnroot/audiere/trunk/audiere/
*
*/
#include <AudioUnit/AudioUnit.h>
#include <pthread.h>
#include "driver_coreaudio.h"
enum {
CAErr_Warning = -2,
CAErr_Error = -1,
CAErr_Ok = 0,
CAErr_Uninitialised,
CAErr_FindNextComponent,
CAErr_OpenAComponent,
CAErr_AudioUnitInitialize,
CAErr_AudioUnitSetProperty,
CAErr_Mutex
};
static int32_t ErrorCode = CAErr_Ok;
static int32_t Initialised = 0;
static int32_t Playing = 0;
static ComponentInstance output_audio_unit;
static pthread_mutex_t mutex;
static char *MixBuffer = 0;
static int32_t MixBufferSize = 0;
static int32_t MixBufferCount = 0;
static int32_t MixBufferCurrent = 0;
static int32_t MixBufferUsed = 0;
static void ( *MixCallBack )( void ) = 0;
static OSStatus fillInput(
void *inRefCon,
AudioUnitRenderActionFlags inActionFlags,
const AudioTimeStamp *inTimeStamp,
UInt32 inBusNumber,
AudioBuffer *ioData)
{
UInt32 remaining, len;
char *ptr, *sptr;
remaining = ioData->mDataByteSize;
ptr = ioData->mData;
while (remaining > 0) {
if (MixBufferUsed == MixBufferSize) {
CoreAudioDrv_Lock();
MixCallBack();
CoreAudioDrv_Unlock();
MixBufferUsed = 0;
MixBufferCurrent++;
if (MixBufferCurrent >= MixBufferCount) {
MixBufferCurrent -= MixBufferCount;
}
}
while (remaining > 0 && MixBufferUsed < MixBufferSize) {
sptr = MixBuffer + (MixBufferCurrent * MixBufferSize) + MixBufferUsed;
len = MixBufferSize - MixBufferUsed;
if (remaining < len) {
len = remaining;
}
memcpy(ptr, sptr, len);
ptr += len;
MixBufferUsed += len;
remaining -= len;
}
}
return noErr;
}
int32_t CoreAudioDrv_GetError(void)
{
return ErrorCode;
}
const char *CoreAudioDrv_ErrorString( int32_t ErrorNumber )
{
const char *ErrorString;
switch( ErrorNumber )
{
case CAErr_Warning :
case CAErr_Error :
ErrorString = CoreAudioDrv_ErrorString( ErrorCode );
break;
case CAErr_Ok :
ErrorString = "CoreAudio ok.";
break;
case CAErr_Uninitialised:
ErrorString = "CoreAudio uninitialised.";
break;
case CAErr_FindNextComponent:
ErrorString = "CoreAudio error: FindNextComponent returned NULL.";
break;
case CAErr_OpenAComponent:
ErrorString = "CoreAudio error: OpenAComponent failed.";
break;
case CAErr_AudioUnitInitialize:
ErrorString = "CoreAudio error: AudioUnitInitialize failed.";
break;
case CAErr_AudioUnitSetProperty:
ErrorString = "CoreAudio error: AudioUnitSetProperty failed.";
break;
case CAErr_Mutex:
ErrorString = "CoreAudio error: could not initialise mutex.";
break;
default:
ErrorString = "Unknown CoreAudio error code.";
break;
}
return ErrorString;
}
/*
int32_t CoreAudioDrv_InitMIDI()
{
AudioStreamBasicDescription requestedDesc;
requestedDesc.mFormatID = kAudioFormatMIDIStream;
}
*/
int32_t CoreAudioDrv_Init(int32_t mixrate, int32_t numchannels, int32_t samplebits, void * initdata)
{
OSStatus result = noErr;
Component comp;
ComponentDescription desc;
AudioStreamBasicDescription requestedDesc;
struct AudioUnitInputCallback callback;
if (Initialised) {
CoreAudioDrv_Shutdown();
}
if (pthread_mutex_init(&mutex, 0) < 0) {
ErrorCode = CAErr_Mutex;
return CAErr_Error;
}
// Setup a AudioStreamBasicDescription with the requested format
requestedDesc.mFormatID = kAudioFormatLinearPCM;
requestedDesc.mFormatFlags = kLinearPCMFormatFlagIsPacked;
requestedDesc.mChannelsPerFrame = numchannels;
requestedDesc.mSampleRate = mixrate;
requestedDesc.mBitsPerChannel = samplebits;
if (samplebits == 16) {
requestedDesc.mFormatFlags |= kLinearPCMFormatFlagIsSignedInteger;
#ifdef __POWERPC__
requestedDesc.mFormatFlags |= kLinearPCMFormatFlagIsBigEndian;
#endif
}
requestedDesc.mFramesPerPacket = 1;
requestedDesc.mBytesPerFrame = requestedDesc.mBitsPerChannel * \
requestedDesc.mChannelsPerFrame / 8;
requestedDesc.mBytesPerPacket = requestedDesc.mBytesPerFrame * \
requestedDesc.mFramesPerPacket;
// Locate the default output audio unit
desc.componentType = kAudioUnitComponentType;
desc.componentSubType = kAudioUnitSubType_Output;
desc.componentManufacturer = kAudioUnitID_DefaultOutput;
desc.componentFlags = 0;
desc.componentFlagsMask = 0;
comp = FindNextComponent(NULL, &desc);
if (comp == NULL) {
ErrorCode = CAErr_FindNextComponent;
pthread_mutex_destroy(&mutex);
return CAErr_Error;
}
// Open & initialize the default output audio unit
result = OpenAComponent(comp, &output_audio_unit);
if (result != noErr) {
ErrorCode = CAErr_OpenAComponent;
CloseComponent(output_audio_unit);
pthread_mutex_destroy(&mutex);
return CAErr_Error;
}
result = AudioUnitInitialize(output_audio_unit);
if (result != noErr) {
ErrorCode = CAErr_AudioUnitInitialize;
CloseComponent(output_audio_unit);
pthread_mutex_destroy(&mutex);
return CAErr_Error;
}
// Set the input format of the audio unit.
result = AudioUnitSetProperty(output_audio_unit,
kAudioUnitProperty_StreamFormat,
kAudioUnitScope_Input,
0,
&requestedDesc,
sizeof(requestedDesc));
if (result != noErr) {
ErrorCode = CAErr_AudioUnitSetProperty;
CloseComponent(output_audio_unit);
pthread_mutex_destroy(&mutex);
return CAErr_Error;
}
// Set the audio callback
callback.inputProc = fillInput;
callback.inputProcRefCon = 0;
AudioUnitSetProperty(output_audio_unit,
kAudioUnitProperty_SetInputCallback,
kAudioUnitScope_Input,
0,
&callback,
sizeof(callback));
Initialised = 1;
return CAErr_Ok;
}
void CoreAudioDrv_Shutdown(void)
{
OSStatus result;
struct AudioUnitInputCallback callback;
if (!Initialised) {
return;
}
// stop processing the audio unit
CoreAudioDrv_StopPlayback();
// Remove the input callback
callback.inputProc = 0;
callback.inputProcRefCon = 0;
result = AudioUnitSetProperty(output_audio_unit,
kAudioUnitProperty_SetInputCallback,
kAudioUnitScope_Input,
0,
&callback,
sizeof(callback));
result = CloseComponent(output_audio_unit);
pthread_mutex_destroy(&mutex);
Initialised = 0;
}
int32_t CoreAudioDrv_BeginPlayback(char *BufferStart, int32_t BufferSize,
int32_t NumDivisions, void ( *CallBackFunc )( void ) )
{
if (!Initialised) {
ErrorCode = CAErr_Uninitialised;
return CAErr_Error;
}
if (Playing) {
CoreAudioDrv_StopPlayback();
}
MixBuffer = BufferStart;
MixBufferSize = BufferSize;
MixBufferCount = NumDivisions;
MixBufferCurrent = 0;
MixBufferUsed = 0;
MixCallBack = CallBackFunc;
// prime the buffer
MixCallBack();
AudioOutputUnitStart(output_audio_unit);
Playing = 1;
return CAErr_Ok;
}
void CoreAudioDrv_StopPlayback(void)
{
if (!Initialised || !Playing) {
return;
}
CoreAudioDrv_Lock();
AudioOutputUnitStop(output_audio_unit);
CoreAudioDrv_Unlock();
Playing = 0;
}
void CoreAudioDrv_Lock(void)
{
pthread_mutex_lock(&mutex);
}
void CoreAudioDrv_Unlock(void)
{
pthread_mutex_unlock(&mutex);
}

View file

@ -1,29 +0,0 @@
/*
Copyright (C) 2009 Jonathon Fowler <jf@jonof.id.au>
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
int32_t CoreAudioDrv_GetError(void);
const char *CoreAudioDrv_ErrorString( int32_t ErrorNumber );
int32_t CoreAudioDrv_Init(int32_t mixrate, int32_t numchannels, int32_t samplebits, void * initdata);
void CoreAudioDrv_Shutdown(void);
int32_t CoreAudioDrv_BeginPlayback(char *BufferStart, int32_t BufferSize,
int32_t NumDivisions, void ( *CallBackFunc )( void ) );
void CoreAudioDrv_StopPlayback(void);
void CoreAudioDrv_Lock(void);
void CoreAudioDrv_Unlock(void);

View file

@ -293,14 +293,14 @@ static void TeardownDSound(HRESULT err)
lpds = 0; lpds = 0;
} }
int32_t DirectSoundDrv_Init(int32_t mixrate, int32_t numchannels, int32_t samplebits, void * initdata) int32_t DirectSoundDrv_PCM_Init(int32_t *mixrate, int32_t *numchannels, int32_t *samplebits, void * initdata)
{ {
HRESULT err; HRESULT err;
DSBUFFERDESC bufdesc; DSBUFFERDESC bufdesc;
WAVEFORMATEX wfex; WAVEFORMATEX wfex;
if (Initialised) { if (Initialised) {
DirectSoundDrv_Shutdown(); DirectSoundDrv_PCM_Shutdown();
} }
err = DirectSoundCreate(0, &lpds, 0); err = DirectSoundCreate(0, &lpds, 0);
@ -329,9 +329,9 @@ int32_t DirectSoundDrv_Init(int32_t mixrate, int32_t numchannels, int32_t sample
memset(&wfex, 0, sizeof(WAVEFORMATEX)); memset(&wfex, 0, sizeof(WAVEFORMATEX));
wfex.wFormatTag = WAVE_FORMAT_PCM; wfex.wFormatTag = WAVE_FORMAT_PCM;
wfex.nChannels = numchannels; wfex.nChannels = *numchannels;
wfex.nSamplesPerSec = mixrate; wfex.nSamplesPerSec = *mixrate;
wfex.wBitsPerSample = samplebits; wfex.wBitsPerSample = *samplebits;
wfex.nBlockAlign = wfex.nChannels * wfex.wBitsPerSample / 8; wfex.nBlockAlign = wfex.nChannels * wfex.wBitsPerSample / 8;
wfex.nAvgBytesPerSec = wfex.nSamplesPerSec * wfex.nBlockAlign; wfex.nAvgBytesPerSec = wfex.nSamplesPerSec * wfex.nBlockAlign;
@ -405,20 +405,20 @@ int32_t DirectSoundDrv_Init(int32_t mixrate, int32_t numchannels, int32_t sample
return DSErr_Ok; return DSErr_Ok;
} }
void DirectSoundDrv_Shutdown(void) void DirectSoundDrv_PCM_Shutdown(void)
{ {
if (!Initialised) { if (!Initialised) {
return; return;
} }
DirectSoundDrv_StopPlayback(); DirectSoundDrv_PCM_StopPlayback();
TeardownDSound(DS_OK); TeardownDSound(DS_OK);
Initialised = 0; Initialised = 0;
} }
int32_t DirectSoundDrv_BeginPlayback(char *BufferStart, int32_t BufferSize, int32_t DirectSoundDrv_PCM_BeginPlayback(char *BufferStart, int32_t BufferSize,
int32_t NumDivisions, void ( *CallBackFunc )( void ) ) int32_t NumDivisions, void ( *CallBackFunc )( void ) )
{ {
HRESULT err; HRESULT err;
@ -428,7 +428,7 @@ int32_t DirectSoundDrv_BeginPlayback(char *BufferStart, int32_t BufferSize,
return DSErr_Error; return DSErr_Error;
} }
DirectSoundDrv_StopPlayback(); DirectSoundDrv_PCM_StopPlayback();
MixBuffer = BufferStart; MixBuffer = BufferStart;
MixBufferSize = BufferSize; MixBufferSize = BufferSize;
@ -459,7 +459,7 @@ int32_t DirectSoundDrv_BeginPlayback(char *BufferStart, int32_t BufferSize,
return DSErr_Ok; return DSErr_Ok;
} }
void DirectSoundDrv_StopPlayback(void) void DirectSoundDrv_PCM_StopPlayback(void)
{ {
if (!Playing) { if (!Playing) {
return; return;
@ -471,7 +471,7 @@ void DirectSoundDrv_StopPlayback(void)
Playing = 0; Playing = 0;
} }
void DirectSoundDrv_Lock(void) void DirectSoundDrv_PCM_Lock(void)
{ {
DWORD err; DWORD err;
@ -481,7 +481,7 @@ void DirectSoundDrv_Lock(void)
} }
} }
void DirectSoundDrv_Unlock(void) void DirectSoundDrv_PCM_Unlock(void)
{ {
ReleaseMutex(mutex); ReleaseMutex(mutex);
} }

View file

@ -22,10 +22,10 @@
int32_t DirectSoundDrv_GetError(void); int32_t DirectSoundDrv_GetError(void);
const char *DirectSoundDrv_ErrorString( int32_t ErrorNumber ); const char *DirectSoundDrv_ErrorString( int32_t ErrorNumber );
int32_t DirectSoundDrv_Init(int32_t mixrate, int32_t numchannels, int32_t samplebits, void * initdata); int32_t DirectSoundDrv_PCM_Init(int32_t *mixrate, int32_t *numchannels, int32_t *samplebits, void * initdata);
void DirectSoundDrv_Shutdown(void); void DirectSoundDrv_PCM_Shutdown(void);
int32_t DirectSoundDrv_BeginPlayback(char *BufferStart, int32_t BufferSize, int32_t DirectSoundDrv_PCM_BeginPlayback(char *BufferStart, int32_t BufferSize,
int32_t NumDivisions, void ( *CallBackFunc )( void ) ); int32_t NumDivisions, void ( *CallBackFunc )( void ) );
void DirectSoundDrv_StopPlayback(void); void DirectSoundDrv_PCM_StopPlayback(void);
void DirectSoundDrv_Lock(void); void DirectSoundDrv_PCM_Lock(void);
void DirectSoundDrv_Unlock(void); void DirectSoundDrv_PCM_Unlock(void);

View file

@ -34,29 +34,29 @@ const char *NoSoundDrv_ErrorString( int32_t ErrorNumber )
return "No sound, Ok."; return "No sound, Ok.";
} }
int32_t NoSoundDrv_Init(int32_t mixrate, int32_t numchannels, int32_t samplebits, void * initdata) int32_t NoSoundDrv_PCM_Init(int32_t *mixrate, int32_t *numchannels, int32_t *samplebits, void * initdata)
{ {
return 0; return 0;
} }
void NoSoundDrv_Shutdown(void) void NoSoundDrv_PCM_Shutdown(void)
{ {
} }
int32_t NoSoundDrv_BeginPlayback(char *BufferStart, int32_t BufferSize, int32_t NoSoundDrv_PCM_BeginPlayback(char *BufferStart, int32_t BufferSize,
int32_t NumDivisions, void ( *CallBackFunc )( void ) ) int32_t NumDivisions, void ( *CallBackFunc )( void ) )
{ {
return 0; return 0;
} }
void NoSoundDrv_StopPlayback(void) void NoSoundDrv_PCM_StopPlayback(void)
{ {
} }
void NoSoundDrv_Lock(void) void NoSoundDrv_PCM_Lock(void)
{ {
} }
void NoSoundDrv_Unlock(void) void NoSoundDrv_PCM_Unlock(void)
{ {
} }

View file

@ -21,10 +21,10 @@
int NoSoundDrv_GetError(void); int NoSoundDrv_GetError(void);
const char *NoSoundDrv_ErrorString( int ErrorNumber ); const char *NoSoundDrv_ErrorString( int ErrorNumber );
int NoSoundDrv_Init(int mixrate, int numchannels, int samplebits, void * initdata); int NoSoundDrv_PCM_Init(int *mixrate, int *numchannels, int *samplebits, void * initdata);
void NoSoundDrv_Shutdown(void); void NoSoundDrv_PCM_Shutdown(void);
int NoSoundDrv_BeginPlayback(char *BufferStart, int BufferSize, int NoSoundDrv_PCM_BeginPlayback(char *BufferStart, int BufferSize,
int NumDivisions, void ( *CallBackFunc )( void ) ); int NumDivisions, void ( *CallBackFunc )( void ) );
void NoSoundDrv_StopPlayback(void); void NoSoundDrv_PCM_StopPlayback(void);
void NoSoundDrv_Lock(void); void NoSoundDrv_PCM_Lock(void);
void NoSoundDrv_Unlock(void); void NoSoundDrv_PCM_Unlock(void);

View file

@ -43,7 +43,7 @@ enum {
static int32_t ErrorCode = SDLErr_Ok; static int32_t ErrorCode = SDLErr_Ok;
static int32_t Initialised = 0; static int32_t Initialised = 0;
static int32_t Playing = 0; static int32_t Playing = 0;
static int32_t StartedSDL = -1; // static int32_t StartedSDL = -1;
static char *MixBuffer = 0; static char *MixBuffer = 0;
static int32_t MixBufferSize = 0; static int32_t MixBufferSize = 0;
@ -132,19 +132,21 @@ const char *SDLDrv_ErrorString( int32_t ErrorNumber )
return ErrorString; return ErrorString;
} }
int32_t SDLDrv_Init(int32_t mixrate, int32_t numchannels, int32_t samplebits, void * initdata) int32_t SDLDrv_PCM_Init(int32_t *mixrate, int32_t *numchannels, int32_t *samplebits, void * initdata)
{ {
uint32_t inited; // uint32_t inited;
int32_t err = 0; int32_t err = 0;
int32_t chunksize; int32_t chunksize;
uint16_t fmt;
UNREFERENCED_PARAMETER(numchannels); UNREFERENCED_PARAMETER(numchannels);
UNREFERENCED_PARAMETER(initdata); UNREFERENCED_PARAMETER(initdata);
if (Initialised) { if (Initialised) {
SDLDrv_Shutdown(); SDLDrv_PCM_Shutdown();
} }
/*
inited = SDL_WasInit(SDL_INIT_EVERYTHING); inited = SDL_WasInit(SDL_INIT_EVERYTHING);
if (inited == 0) { if (inited == 0) {
@ -160,20 +162,26 @@ int32_t SDLDrv_Init(int32_t mixrate, int32_t numchannels, int32_t samplebits, vo
ErrorCode = SDLErr_InitSubSystem; ErrorCode = SDLErr_InitSubSystem;
return SDLErr_Error; return SDLErr_Error;
} }
*/
chunksize = 512; chunksize = 512;
if (mixrate >= 16000) chunksize *= 2; if (*mixrate >= 16000) chunksize *= 2;
if (mixrate >= 32000) chunksize *= 2; if (*mixrate >= 32000) chunksize *= 2;
// allocate 4 channels: 2 for the game's SFX, 1 for music, and 1 for fillData() // allocate 4 channels: 2 for the game's SFX, 1 for music, and 1 for fillData()
err = Mix_OpenAudio(mixrate, (samplebits == 8) ? AUDIO_U8 : AUDIO_S16SYS, 4, chunksize); err = Mix_OpenAudio(*mixrate, (*samplebits == 8) ? AUDIO_U8 : AUDIO_S16SYS, 4, chunksize);
if (err < 0) { if (err < 0) {
ErrorCode = SDLErr_OpenAudio; ErrorCode = SDLErr_OpenAudio;
return SDLErr_Error; return SDLErr_Error;
} }
Mix_QuerySpec(mixrate, &fmt, numchannels);
if (fmt == AUDIO_U8) *samplebits = 8;
else *samplebits = 16;
//Mix_SetPostMix(fillData, NULL); //Mix_SetPostMix(fillData, NULL);
// channel 0 and 1 are actual sounds // channel 0 and 1 are actual sounds
@ -192,39 +200,38 @@ int32_t SDLDrv_Init(int32_t mixrate, int32_t numchannels, int32_t samplebits, vo
return SDLErr_Ok; return SDLErr_Ok;
} }
void SDLDrv_Shutdown(void) void SDLDrv_PCM_Shutdown(void)
{ {
if (!Initialised) { if (!Initialised) {
return; return;
} }
if (StartedSDL > 0) { // if (StartedSDL > 0) {
if (Initialised) if (Initialised)
{ {
Mix_HaltChannel(0); Mix_HaltChannel(-1);
} }
if (DummyChunk != NULL) if (DummyChunk != NULL)
{ {
Mix_FreeChunk(DummyChunk); Mix_FreeChunk(DummyChunk);
}
DummyChunk = NULL; DummyChunk = NULL;
}
if (DummyBuffer != NULL) if (DummyBuffer != NULL)
{ {
free(DummyBuffer); free(DummyBuffer);
DummyBuffer = NULL;
} }
DummyBuffer = NULL;
if (Initialised) if (Initialised)
{ {
Mix_CloseAudio(); Mix_CloseAudio();
Initialised = 0;
} }
Initialised = 0; /*
SDL_QuitSubSystem(SDL_INIT_AUDIO); SDL_QuitSubSystem(SDL_INIT_AUDIO);
} }
else if (StartedSDL == 0) { else if (StartedSDL == 0) {
@ -233,9 +240,10 @@ void SDLDrv_Shutdown(void)
StartedSDL = -1; StartedSDL = -1;
*/
} }
int32_t SDLDrv_BeginPlayback(char *BufferStart, int32_t BufferSize, int32_t SDLDrv_PCM_BeginPlayback(char *BufferStart, int32_t BufferSize,
int32_t NumDivisions, void ( *CallBackFunc )( void ) ) int32_t NumDivisions, void ( *CallBackFunc )( void ) )
{ {
if (!Initialised) { if (!Initialised) {
@ -244,7 +252,7 @@ int32_t SDLDrv_BeginPlayback(char *BufferStart, int32_t BufferSize,
} }
if (Playing) { if (Playing) {
SDLDrv_StopPlayback(); SDLDrv_PCM_StopPlayback();
} }
MixBuffer = BufferStart; MixBuffer = BufferStart;
@ -264,7 +272,7 @@ int32_t SDLDrv_BeginPlayback(char *BufferStart, int32_t BufferSize,
return SDLErr_Ok; return SDLErr_Ok;
} }
void SDLDrv_StopPlayback(void) void SDLDrv_PCM_StopPlayback(void)
{ {
if (!Initialised || !Playing) { if (!Initialised || !Playing) {
return; return;
@ -275,7 +283,7 @@ void SDLDrv_StopPlayback(void)
Playing = 0; Playing = 0;
} }
void SDLDrv_Lock(void) void SDLDrv_PCM_Lock(void)
{ {
/* /*
if (InterruptsDisabled++) if (InterruptsDisabled++)
@ -285,7 +293,7 @@ void SDLDrv_Lock(void)
} }
void SDLDrv_Unlock(void) void SDLDrv_PCM_Unlock(void)
{ {
/* /*
if (--InterruptsDisabled) if (--InterruptsDisabled)

View file

@ -21,10 +21,10 @@
int32_t SDLDrv_GetError(void); int32_t SDLDrv_GetError(void);
const char *SDLDrv_ErrorString( int32_t ErrorNumber ); const char *SDLDrv_ErrorString( int32_t ErrorNumber );
int32_t SDLDrv_Init(int32_t mixrate, int32_t numchannels, int32_t samplebits, void * initdata); int32_t SDLDrv_PCM_Init(int32_t *mixrate, int32_t *numchannels, int32_t *samplebits, void * initdata);
void SDLDrv_Shutdown(void); void SDLDrv_PCM_Shutdown(void);
int32_t SDLDrv_BeginPlayback(char *BufferStart, int32_t BufferSize, int32_t SDLDrv_PCM_BeginPlayback(char *BufferStart, int32_t BufferSize,
int32_t NumDivisions, void ( *CallBackFunc )( void ) ); int32_t NumDivisions, void ( *CallBackFunc )( void ) );
void SDLDrv_StopPlayback(void); void SDLDrv_PCM_StopPlayback(void);
void SDLDrv_Lock(void); void SDLDrv_PCM_Lock(void);
void SDLDrv_Unlock(void); void SDLDrv_PCM_Unlock(void);

View file

@ -31,10 +31,6 @@
# include "driver_sdl.h" # include "driver_sdl.h"
#endif #endif
#ifdef __APPLE__
# include "driver_coreaudio.h"
#endif
#ifdef WIN32 #ifdef WIN32
# include "driver_directsound.h" # include "driver_directsound.h"
#endif #endif
@ -46,7 +42,7 @@ int32_t ASS_SoundDriver = -1;
static struct { static struct {
int32_t (* GetError)(void); int32_t (* GetError)(void);
const char * (* ErrorString)(int32_t); const char * (* ErrorString)(int32_t);
int32_t (* Init)(int32_t, int32_t, int32_t, void *); int32_t (* Init)(int32_t *, int32_t *, int32_t *, void *);
void (* Shutdown)(void); void (* Shutdown)(void);
int32_t (* BeginPlayback)(char *, int32_t, int32_t, void ( * )(void) ); int32_t (* BeginPlayback)(char *, int32_t, int32_t, void ( * )(void) );
void (* StopPlayback)(void); void (* StopPlayback)(void);
@ -58,12 +54,12 @@ static struct {
{ {
NoSoundDrv_GetError, NoSoundDrv_GetError,
NoSoundDrv_ErrorString, NoSoundDrv_ErrorString,
NoSoundDrv_Init, NoSoundDrv_PCM_Init,
NoSoundDrv_Shutdown, NoSoundDrv_PCM_Shutdown,
NoSoundDrv_BeginPlayback, NoSoundDrv_PCM_BeginPlayback,
NoSoundDrv_StopPlayback, NoSoundDrv_PCM_StopPlayback,
NoSoundDrv_Lock, NoSoundDrv_PCM_Lock,
NoSoundDrv_Unlock, NoSoundDrv_PCM_Unlock,
}, },
// Simple DirectMedia Layer // Simple DirectMedia Layer
@ -71,28 +67,12 @@ static struct {
{ {
SDLDrv_GetError, SDLDrv_GetError,
SDLDrv_ErrorString, SDLDrv_ErrorString,
SDLDrv_Init, SDLDrv_PCM_Init,
SDLDrv_Shutdown, SDLDrv_PCM_Shutdown,
SDLDrv_BeginPlayback, SDLDrv_PCM_BeginPlayback,
SDLDrv_StopPlayback, SDLDrv_PCM_StopPlayback,
SDLDrv_Lock, SDLDrv_PCM_Lock,
SDLDrv_Unlock, SDLDrv_PCM_Unlock,
},
#else
UNSUPPORTED
#endif
// OS X CoreAudio
#ifdef __APPLE__
{
CoreAudioDrv_GetError,
CoreAudioDrv_ErrorString,
CoreAudioDrv_Init,
CoreAudioDrv_Shutdown,
CoreAudioDrv_BeginPlayback,
CoreAudioDrv_StopPlayback,
CoreAudioDrv_Lock,
CoreAudioDrv_Unlock,
}, },
#else #else
UNSUPPORTED UNSUPPORTED
@ -103,12 +83,12 @@ static struct {
{ {
DirectSoundDrv_GetError, DirectSoundDrv_GetError,
DirectSoundDrv_ErrorString, DirectSoundDrv_ErrorString,
DirectSoundDrv_Init, DirectSoundDrv_PCM_Init,
DirectSoundDrv_Shutdown, DirectSoundDrv_PCM_Shutdown,
DirectSoundDrv_BeginPlayback, DirectSoundDrv_PCM_BeginPlayback,
DirectSoundDrv_StopPlayback, DirectSoundDrv_PCM_StopPlayback,
DirectSoundDrv_Lock, DirectSoundDrv_PCM_Lock,
DirectSoundDrv_Unlock, DirectSoundDrv_PCM_Unlock,
}, },
#else #else
UNSUPPORTED UNSUPPORTED
@ -141,7 +121,7 @@ const char * SoundDriver_ErrorString( int32_t ErrorNumber )
return SoundDrivers[ASS_SoundDriver].ErrorString(ErrorNumber); return SoundDrivers[ASS_SoundDriver].ErrorString(ErrorNumber);
} }
int32_t SoundDriver_Init(int32_t mixrate, int32_t numchannels, int32_t samplebits, void * initdata) int32_t SoundDriver_Init(int32_t *mixrate, int32_t *numchannels, int32_t *samplebits, void * initdata)
{ {
return SoundDrivers[ASS_SoundDriver].Init(mixrate, numchannels, samplebits, initdata); return SoundDrivers[ASS_SoundDriver].Init(mixrate, numchannels, samplebits, initdata);
} }

View file

@ -30,7 +30,7 @@ int32_t SoundDriver_IsSupported(int32_t driver);
int32_t SoundDriver_GetError(void); int32_t SoundDriver_GetError(void);
const char * SoundDriver_ErrorString( int32_t ErrorNumber ); const char * SoundDriver_ErrorString( int32_t ErrorNumber );
int32_t SoundDriver_Init(int32_t mixrate, int32_t numchannels, int32_t samplebits, void * initdata); int32_t SoundDriver_Init(int32_t *mixrate, int32_t *numchannels, int32_t *samplebits, void * initdata);
void SoundDriver_Shutdown(void); void SoundDriver_Shutdown(void);
int32_t SoundDriver_BeginPlayback( char *BufferStart, int32_t SoundDriver_BeginPlayback( char *BufferStart,
int32_t BufferSize, int32_t NumDivisions, int32_t BufferSize, int32_t NumDivisions,

View file

@ -126,9 +126,7 @@ int32_t FX_Init
if (SoundCard == ASS_AutoDetect) if (SoundCard == ASS_AutoDetect)
{ {
#if defined __APPLE__ #if defined WIN32
SoundCard = ASS_CoreAudio;
#elif defined WIN32
SoundCard = ASS_DirectSound; SoundCard = ASS_DirectSound;
#elif defined HAVE_SDL #elif defined HAVE_SDL
SoundCard = ASS_SDL; SoundCard = ASS_SDL;

View file

@ -2829,7 +2829,7 @@ int32_t MV_Init
ASS_SoundDriver = soundcard; ASS_SoundDriver = soundcard;
// Initialize the sound card // Initialize the sound card
status = SoundDriver_Init(MixRate, numchannels, samplebits, initdata); status = SoundDriver_Init(&MixRate, &numchannels, &samplebits, initdata);
if (status != MV_Ok) if (status != MV_Ok)
{ {
MV_SetErrorCode(MV_DriverError); MV_SetErrorCode(MV_DriverError);

View file

@ -4610,10 +4610,10 @@ cheat_for_port_credits:
if (x==io) if (x==io)
{ {
ud.config.NumVoices++; ud.config.NumVoices++;
if (ud.config.NumVoices > 32) if (ud.config.NumVoices > 96)
ud.config.NumVoices = 4; ud.config.NumVoices = 4;
} }
modval(4,32,(int32_t *)&ud.config.NumVoices,1,probey==io); modval(4,96,(int32_t *)&ud.config.NumVoices,1,probey==io);
if (ud.config.NumVoices != i) if (ud.config.NumVoices != i)
changesmade |= 8; changesmade |= 8;
Bsprintf(tempbuf,"%d",ud.config.NumVoices); Bsprintf(tempbuf,"%d",ud.config.NumVoices);

View file

@ -255,9 +255,8 @@ int32_t MUSIC_PlaySong(char *song, int32_t loopflag)
music_musicchunk = Mix_LoadMUS_RW(SDL_RWFromMem((char *) song, g_musicSize)); music_musicchunk = Mix_LoadMUS_RW(SDL_RWFromMem((char *) song, g_musicSize));
if (music_musicchunk != NULL) if (music_musicchunk != NULL)
{
Mix_PlayMusic(music_musicchunk, (loopflag == MUSIC_LoopSong)?-1:0); Mix_PlayMusic(music_musicchunk, (loopflag == MUSIC_LoopSong)?-1:0);
}
return MUSIC_Ok; return MUSIC_Ok;
} }

View file

@ -3275,7 +3275,7 @@ void P_CheckSectors(int32_t snum)
if (PN == CAMERA1 && SP == 0 && sprite[neartagsprite].hitag == SLT) if (PN == CAMERA1 && SP == 0 && sprite[neartagsprite].hitag == SLT)
{ {
SP = 1; //Using this camera SP = 1; //Using this camera
A_PlaySound(MONITOR_ACTIVE,neartagsprite); A_PlaySound(MONITOR_ACTIVE,p->i);
sprite[neartagsprite].owner = i; sprite[neartagsprite].owner = i;
sprite[neartagsprite].yvel = 1; sprite[neartagsprite].yvel = 1;

View file

@ -204,10 +204,13 @@ void S_PauseMusic(int32_t onf)
if (MusicIsWaveform) if (MusicIsWaveform)
FX_PauseVoice(MusicVoice, onf); FX_PauseVoice(MusicVoice, onf);
else if (onf) else
{
if (onf)
MUSIC_Pause(); MUSIC_Pause();
else else
MUSIC_Continue(); MUSIC_Continue();
}
MusicPaused = onf; MusicPaused = onf;
} }