aboutsummaryrefslogtreecommitdiffstats
path: root/Alc/portaudio.c
diff options
context:
space:
mode:
authorChris Robinson <[email protected]>2011-08-18 23:56:11 -0700
committerChris Robinson <[email protected]>2011-08-18 23:56:11 -0700
commit0b0588cc37c7be4c94563366d6d3e004f3a6e9fb (patch)
treefde7fb7a33801cd8c65c92a21e9f3393dd3c3f77 /Alc/portaudio.c
parent742bb12498bd144388a7f2347d9c941c228a7270 (diff)
Load backend libs on init
Diffstat (limited to 'Alc/portaudio.c')
-rw-r--r--Alc/portaudio.c20
1 files changed, 7 insertions, 13 deletions
diff --git a/Alc/portaudio.c b/Alc/portaudio.c
index e1447c02..4f3dfd5f 100644
--- a/Alc/portaudio.c
+++ b/Alc/portaudio.c
@@ -58,7 +58,7 @@ MAKE_FUNC(Pa_GetStreamInfo);
#define Pa_GetStreamInfo pPa_GetStreamInfo
#endif
-void *pa_load(void)
+static ALCboolean pa_load(void)
{
if(!pa_handle)
{
@@ -77,7 +77,7 @@ void *pa_load(void)
pa_handle = LoadLib(PALIB);
if(!pa_handle)
- return NULL;
+ return ALC_FALSE;
#define LOAD_FUNC(f) do { \
p##f = GetSymbol(pa_handle, #f); \
@@ -85,7 +85,7 @@ void *pa_load(void)
{ \
CloseLib(pa_handle); \
pa_handle = NULL; \
- return NULL; \
+ return ALC_FALSE; \
} \
} while(0)
LOAD_FUNC(Pa_Initialize);
@@ -107,10 +107,10 @@ void *pa_load(void)
ERR("Pa_Initialize() returned an error: %s\n", Pa_GetErrorText(err));
CloseLib(pa_handle);
pa_handle = NULL;
- return NULL;
+ return ALC_FALSE;
}
}
- return pa_handle;
+ return ALC_TRUE;
}
@@ -163,9 +163,6 @@ static ALCboolean pa_open_playback(ALCdevice *device, const ALCchar *deviceName)
else if(strcmp(deviceName, pa_device) != 0)
return ALC_FALSE;
- if(!pa_load())
- return ALC_FALSE;
-
data = (pa_data*)calloc(1, sizeof(pa_data));
data->update_size = device->UpdateSize;
@@ -293,9 +290,6 @@ static ALCboolean pa_open_capture(ALCdevice *device, const ALCchar *deviceName)
else if(strcmp(deviceName, pa_device) != 0)
return ALC_FALSE;
- if(!pa_load())
- return ALC_FALSE;
-
data = (pa_data*)calloc(1, sizeof(pa_data));
if(data == NULL)
{
@@ -420,6 +414,8 @@ static const BackendFuncs pa_funcs = {
ALCboolean alc_pa_init(BackendFuncs *func_list)
{
+ if(!pa_load())
+ return ALC_FALSE;
*func_list = pa_funcs;
return ALC_TRUE;
}
@@ -438,8 +434,6 @@ void alc_pa_deinit(void)
void alc_pa_probe(enum DevProbe type)
{
- if(!pa_load()) return;
-
switch(type)
{
case DEVICE_PROBE: