aboutsummaryrefslogtreecommitdiffstats
path: root/Alc/backends
diff options
context:
space:
mode:
authorChris Robinson <[email protected]>2012-06-19 10:37:09 -0700
committerChris Robinson <[email protected]>2012-06-19 10:37:09 -0700
commitacca3e5a21618b8403711dfe2c7d84a256f83269 (patch)
tree8644bc7e0a1b3ebb75a6a5c08002c25d91f4415d /Alc/backends
parentd17f835e748fcca4316c5c3cab0631dc97d21c6e (diff)
Use a proper method to wait for a PulseAudio operation
Diffstat (limited to 'Alc/backends')
-rw-r--r--Alc/backends/pulseaudio.c37
1 files changed, 19 insertions, 18 deletions
diff --git a/Alc/backends/pulseaudio.c b/Alc/backends/pulseaudio.c
index 516fe932..854421e4 100644
--- a/Alc/backends/pulseaudio.c
+++ b/Alc/backends/pulseaudio.c
@@ -687,14 +687,15 @@ static pa_stream *connect_record_stream(const char *device_name,
}
-#define WAIT_FOR_OPERATION(x, l) do { \
- pa_threaded_mainloop *_l = (l); \
- pa_operation *_o = (x); \
- if(!_o) break; \
- while(pa_operation_get_state(_o) == PA_OPERATION_RUNNING) \
- pa_threaded_mainloop_wait(_l); \
- pa_operation_unref(_o); \
-} while(0)
+static void wait_for_operation(pa_operation *op, pa_threaded_mainloop *loop)
+{
+ if(op)
+ {
+ while(pa_operation_get_state(op) == PA_OPERATION_RUNNING)
+ pa_threaded_mainloop_wait(loop);
+ pa_operation_unref(op);
+ }
+}
static void probe_devices(ALboolean capture)
@@ -735,7 +736,7 @@ static void probe_devices(ALboolean capture)
if(stream)
{
o = pa_context_get_sink_info_by_name(context, pa_stream_get_device_name(stream), sink_device_callback, loop);
- WAIT_FOR_OPERATION(o, loop);
+ wait_for_operation(o, loop);
pa_stream_disconnect(stream);
pa_stream_unref(stream);
@@ -762,7 +763,7 @@ static void probe_devices(ALboolean capture)
if(stream)
{
o = pa_context_get_source_info_by_name(context, pa_stream_get_device_name(stream), source_device_callback, loop);
- WAIT_FOR_OPERATION(o, loop);
+ wait_for_operation(o, loop);
pa_stream_disconnect(stream);
pa_stream_unref(stream);
@@ -771,7 +772,7 @@ static void probe_devices(ALboolean capture)
o = pa_context_get_source_info_list(context, source_device_callback, loop);
}
- WAIT_FOR_OPERATION(o, loop);
+ wait_for_operation(o, loop);
pa_context_disconnect(context);
pa_context_unref(context);
@@ -978,7 +979,7 @@ static ALCenum pulse_open_playback(ALCdevice *device, const ALCchar *device_name
data->device_name = strdup(pa_stream_get_device_name(data->stream));
o = pa_context_get_sink_info_by_name(data->context, data->device_name,
sink_name_callback, device);
- WAIT_FOR_OPERATION(o, data->loop);
+ wait_for_operation(o, data->loop);
pa_stream_set_moved_callback(data->stream, stream_moved_callback, device);
@@ -1016,7 +1017,7 @@ static ALCboolean pulse_reset_playback(ALCdevice *device)
{
pa_operation *o;
o = pa_context_get_sink_info_by_name(data->context, data->device_name, sink_info_callback, device);
- WAIT_FOR_OPERATION(o, data->loop);
+ wait_for_operation(o, data->loop);
}
if(!(device->Flags&DEVICE_FREQUENCY_REQUEST))
flags |= PA_STREAM_FIX_RATE;
@@ -1099,7 +1100,7 @@ static ALCboolean pulse_reset_playback(ALCdevice *device)
o = pa_stream_set_buffer_attr(data->stream, &data->attr,
stream_success_callback, device);
- WAIT_FOR_OPERATION(o, data->loop);
+ wait_for_operation(o, data->loop);
device->Frequency = data->spec.rate;
}
@@ -1150,7 +1151,7 @@ static void pulse_stop_playback(ALCdevice *device)
pa_threaded_mainloop_lock(data->loop);
o = pa_stream_cork(data->stream, 1, stream_success_callback, device);
- WAIT_FOR_OPERATION(o, data->loop);
+ wait_for_operation(o, data->loop);
pa_threaded_mainloop_unlock(data->loop);
}
@@ -1256,7 +1257,7 @@ static ALCenum pulse_open_capture(ALCdevice *device, const ALCchar *device_name)
data->device_name = strdup(pa_stream_get_device_name(data->stream));
o = pa_context_get_source_info_by_name(data->context, data->device_name,
source_name_callback, device);
- WAIT_FOR_OPERATION(o, data->loop);
+ wait_for_operation(o, data->loop);
pa_stream_set_moved_callback(data->stream, stream_moved_callback, device);
@@ -1280,7 +1281,7 @@ static void pulse_start_capture(ALCdevice *device)
pa_threaded_mainloop_lock(data->loop);
o = pa_stream_cork(data->stream, 0, stream_success_callback, device);
- WAIT_FOR_OPERATION(o, data->loop);
+ wait_for_operation(o, data->loop);
pa_threaded_mainloop_unlock(data->loop);
}
@@ -1291,7 +1292,7 @@ static void pulse_stop_capture(ALCdevice *device)
pa_threaded_mainloop_lock(data->loop);
o = pa_stream_cork(data->stream, 1, stream_success_callback, device);
- WAIT_FOR_OPERATION(o, data->loop);
+ wait_for_operation(o, data->loop);
pa_threaded_mainloop_unlock(data->loop);
}