mirror of
https://github.com/mauiaaron/apple2.git
synced 2025-01-11 14:30:08 +00:00
Fix desktop Linux build break
This commit is contained in:
parent
7ca4a2646d
commit
2ae8468b10
@ -264,7 +264,10 @@ static long ALUnlockBuffer(AudioBuffer_s *_this, unsigned long audio_bytes) {
|
||||
|
||||
voice->index += audio_bytes;
|
||||
|
||||
assert((voice->index < voice->buffersize) && "OOPS, overflow in queued sound data");
|
||||
|
||||
if (voice->index >= voice->buffersize) {
|
||||
assert((voice->index == voice->buffersize) && "OOPS, detected an actual overflow in queued sound data");
|
||||
}
|
||||
|
||||
if (bytes_queued >= (voice->buffersize>>2)/*quarter buffersize*/) {
|
||||
// keep accumulating data into working buffer
|
||||
@ -284,6 +287,7 @@ static long ALUnlockBuffer(AudioBuffer_s *_this, unsigned long audio_bytes) {
|
||||
return err;
|
||||
}
|
||||
|
||||
#if 0
|
||||
// HACK Part I : done once for mockingboard that has semiauto repeating phonemes ...
|
||||
static long ALUnlockStaticBuffer(AudioBuffer_s *_this, unsigned long audio_bytes) {
|
||||
ALVoice *voice = (ALVoice*)_this->_internal;
|
||||
@ -298,6 +302,7 @@ static long ALReplay(AudioBuffer_s *_this) {
|
||||
long err = _ALSubmitBufferToOpenAL(voice);
|
||||
return err;
|
||||
}
|
||||
#endif
|
||||
|
||||
static long ALGetStatus(AudioBuffer_s *_this, OUTPARM unsigned long *status) {
|
||||
*status = -1;
|
||||
@ -466,7 +471,7 @@ static long openal_destroySoundBuffer(const struct AudioContext_s *sound_system,
|
||||
return 0;
|
||||
}
|
||||
|
||||
static long openal_createSoundBuffer(const AudioContext_s *audio_context, unsigned long numChannels, INOUT AudioBuffer_s **soundbuf_struct) {
|
||||
static long openal_createSoundBuffer(const AudioContext_s *audio_context, INOUT AudioBuffer_s **soundbuf_struct) {
|
||||
LOG("openal_createSoundBuffer ...");
|
||||
assert(*soundbuf_struct == NULL);
|
||||
|
||||
@ -477,7 +482,7 @@ static long openal_createSoundBuffer(const AudioContext_s *audio_context, unsign
|
||||
ALCcontext *ctx = (ALCcontext*)(audio_context->_internal);
|
||||
assert(ctx != NULL);
|
||||
|
||||
if ((voice = _openal_createVoice(numChannels)) == NULL) {
|
||||
if ((voice = _openal_createVoice(NUM_CHANNELS)) == NULL) {
|
||||
ERRLOG("OOPS, Cannot create new voice");
|
||||
break;
|
||||
}
|
||||
@ -503,8 +508,8 @@ static long openal_createSoundBuffer(const AudioContext_s *audio_context, unsign
|
||||
(*soundbuf_struct)->Unlock = &ALUnlockBuffer;
|
||||
(*soundbuf_struct)->GetStatus = &ALGetStatus;
|
||||
// mockingboard-specific hacks
|
||||
(*soundbuf_struct)->UnlockStaticBuffer = &ALUnlockStaticBuffer;
|
||||
(*soundbuf_struct)->Replay = &ALReplay;
|
||||
//(*soundbuf_struct)->UnlockStaticBuffer = &ALUnlockStaticBuffer;
|
||||
//(*soundbuf_struct)->Replay = &ALReplay;
|
||||
|
||||
return 0;
|
||||
} while(0);
|
||||
@ -586,7 +591,7 @@ static long openal_systemSetup(INOUT AudioContext_s **audio_context) {
|
||||
return result;
|
||||
}
|
||||
|
||||
static long openal_systemPause(void) {
|
||||
static long openal_systemPause(AudioContext_s *audio_context) {
|
||||
ALVoices *vnode = NULL;
|
||||
ALVoices *tmp = NULL;
|
||||
long err = 0;
|
||||
@ -602,7 +607,7 @@ static long openal_systemPause(void) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
static long openal_systemResume(void) {
|
||||
static long openal_systemResume(AudioContext_s *audio_context) {
|
||||
ALVoices *vnode = NULL;
|
||||
ALVoices *tmp = NULL;
|
||||
long err = 0;
|
||||
|
@ -24,6 +24,14 @@
|
||||
#define SOUNDCORE_ERROR_INC 20
|
||||
#define SOUNDCORE_ERROR_MAX 200
|
||||
|
||||
// Note to future self:
|
||||
//
|
||||
// Although output for the speaker could be MONO (and was at one point in time) ... we optimize the OpenSLES backend on
|
||||
// Android to have just one buffer queue callback, where we need to mix both mockingboard and speaker samples.
|
||||
//
|
||||
// For now, just make everything use stereo for simplicity (including OpenAL backend).
|
||||
#define NUM_CHANNELS 2
|
||||
|
||||
typedef struct AudioBuffer_s {
|
||||
bool bActive; // Mockingboard ... refactor?
|
||||
bool bMute; // Mockingboard ... refactor?
|
||||
|
@ -31,20 +31,6 @@
|
||||
|
||||
#define SPKR_SILENT_STEP 1
|
||||
|
||||
#if defined(ANDROID)
|
||||
// Note to future self:
|
||||
//
|
||||
// This is a leaky backend implementation detail : we are optimizing to use only one OpenSLES buffer queue callback that
|
||||
// mixes samples from both mockingboard and speaker (thus the speaker needs to be stereo to match mockingboard).
|
||||
//
|
||||
// This is different than the OpenAL backend implementation for desktop (Linux/Mac/...) which is a push-based local
|
||||
// queue.
|
||||
# define NUM_CHANNELS 2
|
||||
#else
|
||||
// this can still be mono for other systems ...
|
||||
# define NUM_CHANNELS 1
|
||||
#endif
|
||||
|
||||
static unsigned long bufferTotalSize = 0;
|
||||
static unsigned long bufferSizeIdealMin = 0;
|
||||
static unsigned long bufferSizeIdealMax = 0;
|
||||
|
Loading…
x
Reference in New Issue
Block a user