summaryrefslogtreecommitdiffstats
path: root/src/multimedia/audio/qsoundeffect_pulse_p.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/multimedia/audio/qsoundeffect_pulse_p.cpp')
-rw-r--r--src/multimedia/audio/qsoundeffect_pulse_p.cpp13
1 files changed, 11 insertions, 2 deletions
diff --git a/src/multimedia/audio/qsoundeffect_pulse_p.cpp b/src/multimedia/audio/qsoundeffect_pulse_p.cpp
index 8cc49004a..e38909044 100644
--- a/src/multimedia/audio/qsoundeffect_pulse_p.cpp
+++ b/src/multimedia/audio/qsoundeffect_pulse_p.cpp
@@ -114,12 +114,14 @@ public:
inline void lock()
{
- pa_threaded_mainloop_lock(m_mainLoop);
+ if (m_mainLoop)
+ pa_threaded_mainloop_lock(m_mainLoop);
}
inline void unlock()
{
- pa_threaded_mainloop_unlock(m_mainLoop);
+ if (m_mainLoop)
+ pa_threaded_mainloop_unlock(m_mainLoop);
}
inline pa_context *context() const
@@ -152,6 +154,7 @@ private:
{
m_vol = PA_VOLUME_NORM;
+ m_context = 0;
m_mainLoop = pa_threaded_mainloop_new();
if (m_mainLoop == 0) {
qWarning("PulseAudioService: unable to create pulseaudio mainloop");
@@ -173,14 +176,19 @@ private:
if (m_context == 0) {
qWarning("PulseAudioService: Unable to create new pulseaudio context");
+ pa_threaded_mainloop_unlock(m_mainLoop);
pa_threaded_mainloop_free(m_mainLoop);
+ m_mainLoop = 0;
return;
}
if (pa_context_connect(m_context, 0, (pa_context_flags_t)0, 0) < 0) {
qWarning("PulseAudioService: pa_context_connect() failed");
pa_context_unref(m_context);
+ pa_threaded_mainloop_unlock(m_mainLoop);
pa_threaded_mainloop_free(m_mainLoop);
+ m_mainLoop = 0;
+ m_context = 0;
return;
}
unlock();
@@ -191,6 +199,7 @@ private:
void release()
{
if (!m_prepared) return;
+ pa_context_unref(m_context);
pa_threaded_mainloop_stop(m_mainLoop);
pa_threaded_mainloop_free(m_mainLoop);
m_prepared = false;