Mercurial > sdl-ios-xcode
diff src/audio/mint/SDL_mintaudio_stfa.c @ 3820:1f156fd874fa SDL-ryan-multiple-audio-device
Moved more audio drivers to 1.3 API (all 5 MiNT backends, BSD, IRIX...), and
some other tweaks in already-converted drivers.
author | Ryan C. Gordon <icculus@icculus.org> |
---|---|
date | Sat, 07 Oct 2006 05:36:36 +0000 |
parents | c8b3d3d13ed1 |
children | 66fb40445587 |
line wrap: on
line diff
--- a/src/audio/mint/SDL_mintaudio_stfa.c Fri Oct 06 20:36:23 2006 +0000 +++ b/src/audio/mint/SDL_mintaudio_stfa.c Sat Oct 07 05:36:36 2006 +0000 @@ -59,8 +59,9 @@ /*--- Static variables ---*/ -static unsigned long cookie_snd, cookie_mch; -static cookie_stfa_t *cookie_stfa; +static unsigned long cookie_snd = 0; +static unsigned long cookie_mch = 0; +static cookie_stfa_t *cookie_stfa = NULL; static const int freqs[16] = { 4995, 6269, 7493, 8192, @@ -69,30 +70,9 @@ 30720, 32336, 43885, 49152 }; -/*--- Audio driver functions ---*/ - -static void Mint_CloseAudio(_THIS); -static int Mint_OpenAudio(_THIS, SDL_AudioSpec * spec); -static void Mint_LockAudio(_THIS); -static void Mint_UnlockAudio(_THIS); - -/* To check/init hardware audio */ -static int Mint_CheckAudio(_THIS, SDL_AudioSpec * spec); -static void Mint_InitAudio(_THIS, SDL_AudioSpec * spec); - -/*--- Audio driver bootstrap functions ---*/ - static int -Audio_Available(void) +MINTSTFA_Available(void) { - const char *envr = SDL_getenv("SDL_AUDIODRIVER"); - - /* Check if user asked a different audio driver */ - if ((envr) && (SDL_strcmp(envr, MINT_AUDIO_DRIVER_NAME) != 0)) { - DEBUG_PRINT((DEBUG_NAME "user asked a different audio driver\n")); - return (0); - } - /* Cookie _MCH present ? if not, assume ST machine */ if (Getcookie(C__MCH, &cookie_mch) == C_NOTFOUND) { cookie_mch = MCH_ST; @@ -116,115 +96,65 @@ } static void -Audio_DeleteDevice(SDL_AudioDevice * device) -{ - SDL_free(device->hidden); - SDL_free(device); -} - -static SDL_AudioDevice * -Audio_CreateDevice(int devindex) +MINTSTFA_LockDevice(_THIS) { - SDL_AudioDevice *this; - - /* Initialize all variables that we clean on shutdown */ - this = (SDL_AudioDevice *) SDL_malloc(sizeof(SDL_AudioDevice)); - if (this) { - SDL_memset(this, 0, (sizeof *this)); - this->hidden = (struct SDL_PrivateAudioData *) - SDL_malloc((sizeof *this->hidden)); - } - if ((this == NULL) || (this->hidden == NULL)) { - SDL_OutOfMemory(); - if (this) { - SDL_free(this); - } - return (0); - } - SDL_memset(this->hidden, 0, (sizeof *this->hidden)); - - /* Set the function pointers */ - this->OpenAudio = Mint_OpenAudio; - this->CloseAudio = Mint_CloseAudio; - this->LockAudio = Mint_LockAudio; - this->UnlockAudio = Mint_UnlockAudio; - this->free = Audio_DeleteDevice; - - /* Uses interrupt driven audio, without thread */ - #if SDL_THREADS_DISABLED - this->SkipMixerLock = 1; - #endif - - return this; -} - -AudioBootStrap MINTAUDIO_STFA_bootstrap = { - MINT_AUDIO_DRIVER_NAME, "MiNT STFA audio driver", - Audio_Available, Audio_CreateDevice, 0 -}; - -static void -Mint_LockAudio(_THIS) -{ - void *oldpile; - /* Stop replay */ - oldpile = (void *) Super(0); + void *oldpile = (void *) Super(0); cookie_stfa->sound_enable = STFA_PLAY_DISABLE; Super(oldpile); } static void -Mint_UnlockAudio(_THIS) +MINTSTFA_UnlockDevice(_THIS) { - void *oldpile; - /* Restart replay */ - oldpile = (void *) Super(0); + void *oldpile = (void *) Super(0); cookie_stfa->sound_enable = STFA_PLAY_ENABLE | STFA_PLAY_REPEAT; Super(oldpile); } static void -Mint_CloseAudio(_THIS) +MINTSTFA_CloseDevice(_THIS) { - void *oldpile; - - /* Stop replay */ - oldpile = (void *) Super(0); - cookie_stfa->sound_enable = STFA_PLAY_DISABLE; - Super(oldpile); + if (this->hidden != NULL) { + /* Stop replay */ + void *oldpile = (void *) Super(0); + cookie_stfa->sound_enable = STFA_PLAY_DISABLE; + Super(oldpile); - /* Wait if currently playing sound */ - while (SDL_MintAudio_mutex != 0) { - } + /* Wait if currently playing sound */ + while (SDL_MintAudio_mutex != 0) {} - /* Clear buffers */ - if (SDL_MintAudio_audiobuf[0]) { - Mfree(SDL_MintAudio_audiobuf[0]); - SDL_MintAudio_audiobuf[0] = SDL_MintAudio_audiobuf[1] = NULL; + /* Clear buffers */ + if (SDL_MintAudio_audiobuf[0]) { + Mfree(SDL_MintAudio_audiobuf[0]); + SDL_MintAudio_audiobuf[0] = SDL_MintAudio_audiobuf[1] = NULL; + } + + SDL_free(this->hidden); + this->hidden = NULL; } } static int -Mint_CheckAudio(_THIS, SDL_AudioSpec * spec) +MINTSTFA_CheckAudio(_THIS) { int i; DEBUG_PRINT((DEBUG_NAME "asked: %d bits, ", - SDL_AUDIO_BITSIZE(spec->format))); - DEBUG_PRINT(("float=%d, ", SDL_AUDIO_ISFLOAT(spec->format))); - DEBUG_PRINT(("signed=%d, ", SDL_AUDIO_ISSIGNED(spec->format))); - DEBUG_PRINT(("big endian=%d, ", SDL_AUDIO_ISBIGENDIAN(spec->format))); - DEBUG_PRINT(("channels=%d, ", spec->channels)); - DEBUG_PRINT(("freq=%d\n", spec->freq)); + SDL_AUDIO_BITSIZE(this->spec.format))); + DEBUG_PRINT(("float=%d, ", SDL_AUDIO_ISFLOAT(this->spec.format))); + DEBUG_PRINT(("signed=%d, ", SDL_AUDIO_ISSIGNED(this->spec.format))); + DEBUG_PRINT(("big endian=%d, ", SDL_AUDIO_ISBIGENDIAN(this->spec.format))); + DEBUG_PRINT(("channels=%d, ", this->spec.channels)); + DEBUG_PRINT(("freq=%d\n", this->spec.freq)); - if (SDL_AUDIO_BITSIZE(spec->format) > 16) { - spec->format = AUDIO_S16SYS; /* clamp out int32/float32 ... */ + if (SDL_AUDIO_BITSIZE(this->spec.format) > 16) { + this->spec.format = AUDIO_S16SYS; /* clamp out int32/float32 ... */ } - if (spec->channels > 2) { - spec->channels = 2; /* no more than stereo! */ + if (this->spec.channels > 2) { + this->spec.channels = 2; /* no more than stereo! */ } /* Check formats available */ @@ -242,29 +172,25 @@ } #endif - MINTAUDIO_numfreq = SDL_MintAudio_SearchFrequency(this, spec->freq); - spec->freq = MINTAUDIO_frequencies[MINTAUDIO_numfreq].frequency; + MINTAUDIO_numfreq = SDL_MintAudio_SearchFrequency(this, this->spec.freq); + this->spec.freq = MINTAUDIO_frequencies[MINTAUDIO_numfreq].frequency; DEBUG_PRINT((DEBUG_NAME "obtained: %d bits, ", - SDL_AUDIO_BITSIZE(spec->format))); - DEBUG_PRINT(("float=%d, ", SDL_AUDIO_ISFLOAT(spec->format))); - DEBUG_PRINT(("signed=%d, ", SDL_AUDIO_ISSIGNED(spec->format))); - DEBUG_PRINT(("big endian=%d, ", SDL_AUDIO_ISBIGENDIAN(spec->format))); - DEBUG_PRINT(("channels=%d, ", spec->channels)); - DEBUG_PRINT(("freq=%d\n", spec->freq)); + SDL_AUDIO_BITSIZE(this->spec.format))); + DEBUG_PRINT(("float=%d, ", SDL_AUDIO_ISFLOAT(this->spec.format))); + DEBUG_PRINT(("signed=%d, ", SDL_AUDIO_ISSIGNED(this->spec.format))); + DEBUG_PRINT(("big endian=%d, ", SDL_AUDIO_ISBIGENDIAN(this->spec.format))); + DEBUG_PRINT(("channels=%d, ", this->spec.channels)); + DEBUG_PRINT(("freq=%d\n", this->spec.freq)); return 0; } static void -Mint_InitAudio(_THIS, SDL_AudioSpec * spec) +MINTSTFA_InitAudio(_THIS) { - void *buffer; - void *oldpile; - - buffer = SDL_MintAudio_audiobuf[SDL_MintAudio_numbuf]; - - oldpile = (void *) Super(0); + void *buffer = SDL_MintAudio_audiobuf[SDL_MintAudio_numbuf]; + void *oldpile = (void *) Super(0); /* Stop replay */ cookie_stfa->sound_enable = STFA_PLAY_DISABLE; @@ -272,22 +198,22 @@ /* Select replay format */ cookie_stfa->sound_control = MINTAUDIO_frequencies[MINTAUDIO_numfreq].predivisor; - if (SDL_AUDIO_BITSIZE(spec->format) == 8) { + if (SDL_AUDIO_BITSIZE(this->spec.format) == 8) { cookie_stfa->sound_control |= STFA_FORMAT_8BIT; } else { cookie_stfa->sound_control |= STFA_FORMAT_16BIT; } - if (spec->channels == 2) { + if (this->spec.channels == 2) { cookie_stfa->sound_control |= STFA_FORMAT_STEREO; } else { cookie_stfa->sound_control |= STFA_FORMAT_MONO; } - if (SDL_AUDIO_ISSIGNED(spec->format) != 0) { + if (SDL_AUDIO_ISSIGNED(this->spec.format) != 0) { cookie_stfa->sound_control |= STFA_FORMAT_SIGNED; } else { cookie_stfa->sound_control |= STFA_FORMAT_UNSIGNED; } - if (SDL_AUDIO_ISBIGENDIAN(spec->format) != 0) { + if (SDL_AUDIO_ISBIGENDIAN(this->spec.format) != 0) { cookie_stfa->sound_control |= STFA_FORMAT_BIGENDIAN; } else { cookie_stfa->sound_control |= STFA_FORMAT_LITENDIAN; @@ -295,7 +221,7 @@ /* Set buffer */ cookie_stfa->sound_start = (unsigned long) buffer; - cookie_stfa->sound_end = (unsigned long) (buffer + spec->size); + cookie_stfa->sound_end = (unsigned long) (buffer + this->spec.size); /* Set interrupt */ cookie_stfa->stfa_it = SDL_MintAudio_StfaInterrupt; @@ -309,29 +235,40 @@ } static int -Mint_OpenAudio(_THIS, SDL_AudioSpec * spec) +MINTSTFA_OpenDevice(_THIS, const char *devname, int iscapture) { SDL_MintAudio_device = this; /* Check audio capabilities */ - if (Mint_CheckAudio(this, spec) == -1) { - return -1; + if (MINTSTFA_CheckAudio(this) == -1) { + return 0; } - SDL_CalculateAudioSpec(spec); + /* Initialize all variables that we clean on shutdown */ + this->hidden = (struct SDL_PrivateAudioData *) + SDL_malloc((sizeof *this->hidden)); + if (this->hidden == NULL) { + SDL_OutOfMemory(); + return 0; + } + SDL_memset(this->hidden, 0, (sizeof *this->hidden)); + + SDL_CalculateAudioSpec(&this->spec); /* Allocate memory for audio buffers in DMA-able RAM */ - DEBUG_PRINT((DEBUG_NAME "buffer size=%d\n", spec->size)); + DEBUG_PRINT((DEBUG_NAME "buffer size=%d\n", this->spec.size)); - SDL_MintAudio_audiobuf[0] = Atari_SysMalloc(spec->size * 2, MX_STRAM); + SDL_MintAudio_audiobuf[0] = Atari_SysMalloc(this->spec.size * 2, MX_STRAM); if (SDL_MintAudio_audiobuf[0] == NULL) { - SDL_SetError("MINT_OpenAudio: Not enough memory for audio buffer"); - return (-1); + SDL_OutOfMemory() + SDL_free(this->hidden); + this->hidden = NULL; + return 0; } - SDL_MintAudio_audiobuf[1] = SDL_MintAudio_audiobuf[0] + spec->size; + SDL_MintAudio_audiobuf[1] = SDL_MintAudio_audiobuf[0] + this->spec.size; SDL_MintAudio_numbuf = 0; - SDL_memset(SDL_MintAudio_audiobuf[0], spec->silence, spec->size * 2); - SDL_MintAudio_audiosize = spec->size; + SDL_memset(SDL_MintAudio_audiobuf[0],this->spec.silence,this->spec.size*2); + SDL_MintAudio_audiosize = this->spec.size; SDL_MintAudio_mutex = 0; DEBUG_PRINT((DEBUG_NAME "buffer 0 at 0x%08x\n", @@ -342,9 +279,30 @@ SDL_MintAudio_CheckFpu(); /* Setup audio hardware */ - Mint_InitAudio(this, spec); + MINTSTFA_InitAudio(this); - return (1); /* We don't use threaded audio */ + return 1; /* good to go. */ } + +static int +MINTSTFA_Init(SDL_AudioDriverImpl *impl) +{ + /* Set the function pointers */ + impl->OpenDevice = MINTSTFA_OpenDevice; + impl->CloseDevice = MINTSTFA_CloseDevice; + impl->LockAudio = MINTSTFA_LockAudio; + impl->UnlockAudio = MINTSTFA_UnlockAudio; + impl->OnlyHasDefaultOutputDevice = 1; + impl->ProvidesOwnCallbackThread = 1; + impl->SkipMixerLock = 1; + + return 1; +} + +AudioBootStrap MINTAUDIO_STFA_bootstrap = { + MINT_AUDIO_DRIVER_NAME, "MiNT STFA audio driver", + MINTSTFA_Available, MINTSTFA_Init, 0 +}; + /* vi: set ts=4 sw=4 expandtab: */