cleanup debugging code and implement _dropBufferedAudio()

git-svn-id: https://svn.musicpd.org/mpd/trunk@3090 09075e82-0dd4-0310-85a5-a0d7c8717e4f
This commit is contained in:
Warren Dukes 2005-03-16 23:24:07 +00:00
parent b9bcfeaf49
commit 6b36bf7964

View File

@ -26,7 +26,7 @@
#include "../log.h"
#define BUFFER_SIZE 8192
#define BUFFER_SIZE 4096
typedef struct _OsxData {
AudioUnit au;
@ -98,32 +98,37 @@ static void osx_finishDriver(AudioOutput * audioOutput) {
}
static void osx_dropBufferedAudio(AudioOutput * audioOutput) {
/* not implemented yet */
OsxData * od = (OsxData *)audioOutput->data;
pthread_mutex_lock(&od->mutex);
od->go = 0;
od->len = 0;
pthread_mutex_unlock(&od->mutex);
/*if(od->started) {
AudioOutputUnitStop(od->au);
od->started = 0;
}*/
}
static void osx_closeDevice(AudioOutput * audioOutput) {
OsxData * od = (OsxData *) audioOutput->data;
DEBUG("entering osx_closeDevice\n");
pthread_mutex_lock(&od->mutex);
od->go = 0;
while(od->len) {
DEBUG("osx_closeDevice: cond_wait\n");
pthread_cond_wait(&od->condition, &od->mutex);
}
pthread_mutex_unlock(&od->mutex);
DEBUG("stopping au\n");
if(od->started) {
AudioOutputUnitStop(od->au);
od->started = 0;
}
DEBUG("closing au\n");
CloseComponent(od->au);
AudioUnitUninitialize(od->au);
DEBUG("Leaving osx_closeDevice\n");
audioOutput->open = 0;
}
@ -161,7 +166,6 @@ static OSStatus osx_render(void * vdata,
bytesToCopy -= bytes;
}
assert(bytesToCopy);
memcpy(buffer->mData+curpos, od->buffer+od->pos, bytesToCopy);
od->pos += bytesToCopy;
curpos += bytesToCopy;
@ -193,21 +197,17 @@ static int osx_openDevice(AudioOutput * audioOutput) {
desc.componentFlags = 0;
desc.componentFlagsMask = 0;
DEBUG("finding component\n");
comp = FindNextComponent(NULL, &desc);
if(comp == 0) {
ERROR("Error finding OS X component\n");
return -1;
}
DEBUG("opening component\n");
if(OpenAComponent(comp, &od->au) != noErr) {
ERROR("Unable to open OS X component\n");
return -1;
}
DEBUG("initializing au\n");
if(AudioUnitInitialize(od->au) != 0) {
CloseComponent(od->au);
ERROR("Unable to initialuze OS X audio unit\n");
@ -217,7 +217,6 @@ static int osx_openDevice(AudioOutput * audioOutput) {
callback.inputProc = osx_render;
callback.inputProcRefCon = od;
DEBUG("set callback\n");
if(AudioUnitSetProperty(od->au, kAudioUnitProperty_SetRenderCallback,
kAudioUnitScope_Input, 0,
&callback, sizeof(callback)) != 0)
@ -238,7 +237,6 @@ static int osx_openDevice(AudioOutput * audioOutput) {
streamDesc.mChannelsPerFrame = audioFormat->channels;
streamDesc.mBitsPerChannel = audioFormat->bits;
DEBUG("set format\n");
if(AudioUnitSetProperty(od->au, kAudioUnitProperty_StreamFormat,
kAudioUnitScope_Input, 0,
&streamDesc, sizeof(streamDesc)) != 0)
@ -249,20 +247,11 @@ static int osx_openDevice(AudioOutput * audioOutput) {
return -1;
}
DEBUG("start\n");
int err = AudioOutputUnitStart(od->au);
if(err) {
ERROR("unable to start audio output: %i\n", err);
return -1;
}
od->go = 1;
od->pos = 0;
od->len = 0;
audioOutput->open = 1;
DEBUG("opened OS X device\n");
return 0;
}
@ -271,6 +260,16 @@ static int osx_play(AudioOutput * audioOutput, char * playChunk, int size) {
int bytesToCopy;
int curpos;
if(!od->started) {
od->go = 1;
od->started = 1;
int err = AudioOutputUnitStart(od->au);
if(err) {
ERROR("unable to start audio output: %i\n", err);
return -1;
}
}
pthread_mutex_lock(&od->mutex);
curpos = od->pos+od->len;
@ -278,10 +277,6 @@ static int osx_play(AudioOutput * audioOutput, char * playChunk, int size) {
while(size) {
while(od->len >= BUFFER_SIZE) {
if(curpos!=od->pos) {
DEBUG("%i != %i\n", curpos, od->pos);
abort();
}
pthread_cond_signal(&od->condition);
pthread_cond_wait(&od->condition, &od->mutex);
}
@ -299,7 +294,6 @@ static int osx_play(AudioOutput * audioOutput, char * playChunk, int size) {
bytesToCopy -= bytes;
}
assert(bytesToCopy);
memcpy(od->buffer+curpos, playChunk, bytesToCopy);
curpos += bytesToCopy;
playChunk += bytesToCopy;