From c22a53d373f840569c56a1b3f6a774fc94b1e1e1 Mon Sep 17 00:00:00 2001 From: Eric Wong Date: Tue, 1 Aug 2006 10:07:07 +0000 Subject: audio: remove AUDIO_MAX_DEVICES limit Some people have more than 8 devices (the old limit). It's pretty easy to support as many as our hardware and OS allows so we might as well. git-svn-id: https://svn.musicpd.org/mpd/trunk@4513 09075e82-0dd4-0310-85a5-a0d7c8717e4f --- src/audio.c | 45 ++++++++++++++++++++++++--------------------- 1 file changed, 24 insertions(+), 21 deletions(-) (limited to 'src/audio.c') diff --git a/src/audio.c b/src/audio.c index b4f0dadc..04c38716 100644 --- a/src/audio.c +++ b/src/audio.c @@ -49,7 +49,7 @@ static mpd_uint8 audioOutputArraySize = 0; /* the audioEnabledArray should be stuck into shared memory, and then disable and enable in playAudio() routine */ static mpd_sint8 *pdAudioDevicesEnabled = NULL; -static mpd_sint8 myAudioDevicesEnabled[AUDIO_MAX_DEVICES]; +static mpd_sint8 *myAudioDevicesEnabled = NULL; static mpd_uint8 audioOpened = 0; @@ -57,6 +57,18 @@ static mpd_sint32 audioBufferSize = 0; static char *audioBuffer = NULL; static mpd_sint32 audioBufferPos = 0; +size_t audio_device_count(void) +{ + size_t nr = 0; + ConfigParam *param = NULL; + + while ((param = getNextConfigParam(CONF_AUDIO_OUTPUT, param))) + nr++; + if (!nr) + nr = 1; /* we'll always have at least one device */ + return nr; +} + void copyAudioFormat(AudioFormat * dest, AudioFormat * src) { if (!src) @@ -101,31 +113,21 @@ void initAudioDriver(void) loadAudioDrivers(); + audioOutputArraySize = audio_device_count(); pdAudioDevicesEnabled = (getPlayerData())->audioDeviceEnabled; + audioOutputArray = malloc(sizeof(AudioOutput *) * audioOutputArraySize); + myAudioDevicesEnabled = malloc(sizeof(mpd_sint8)*audioOutputArraySize); - for (i = 0; i < AUDIO_MAX_DEVICES; i++) { - pdAudioDevicesEnabled[i] = 1; - myAudioDevicesEnabled[i] = 1; - } + for (i = 0; i < audioOutputArraySize; i++) + myAudioDevicesEnabled[i] = pdAudioDevicesEnabled[i] = 1; + i = 0; param = getNextConfigParam(CONF_AUDIO_OUTPUT, param); do { AudioOutput *output; int j; - if (audioOutputArraySize == AUDIO_MAX_DEVICES) { - ERROR("only up to 255 audio output devices are " - "supported"); - exit(EXIT_FAILURE); - } - - i = audioOutputArraySize++; - - audioOutputArray = realloc(audioOutputArray, - audioOutputArraySize * - sizeof(AudioOutput *)); - output = newAudioOutput(param); if (!output && param) { ERROR("problems configuring output device defined at " @@ -141,7 +143,7 @@ void initAudioDriver(void) exit(EXIT_FAILURE); } } - audioOutputArray[i] = output; + audioOutputArray[i++] = output; } while ((param = getNextConfigParam(CONF_AUDIO_OUTPUT, param))); } @@ -271,7 +273,8 @@ static void syncAudioDevicesEnabledArrays(void) { int i; - memcpy(myAudioDevicesEnabled, pdAudioDevicesEnabled, AUDIO_MAX_DEVICES); + memcpy(myAudioDevicesEnabled, pdAudioDevicesEnabled, + audioOutputArraySize); for (i = 0; i < audioOutputArraySize; i++) { if (myAudioDevicesEnabled[i]) { @@ -292,7 +295,7 @@ static int flushAudioBuffer(void) return 0; if (0 != memcmp(pdAudioDevicesEnabled, myAudioDevicesEnabled, - AUDIO_MAX_DEVICES)) { + audioOutputArraySize)) { syncAudioDevicesEnabledArrays(); } @@ -385,7 +388,7 @@ void dropBufferedAudio(void) int i; if (0 != memcmp(pdAudioDevicesEnabled, myAudioDevicesEnabled, - AUDIO_MAX_DEVICES)) { + audioOutputArraySize)) { syncAudioDevicesEnabledArrays(); } -- cgit v1.2.3