From: Tanu Kaskinen Date: Tue, 15 Apr 2014 10:56:05 +0000 (+0300) Subject: sink, source: Return early from set_mute() X-Git-Url: https://code.delx.au/pulseaudio/commitdiff_plain/70441d40fb07b13cca85d08fe09c9ddb81eadaf0 sink, source: Return early from set_mute() This avoids redundant set_mute() callback calls. Some logging was added too. --- diff --git a/src/pulsecore/sink.c b/src/pulsecore/sink.c index 7dffedf8..210f3dcc 100644 --- a/src/pulsecore/sink.c +++ b/src/pulsecore/sink.c @@ -2199,16 +2199,21 @@ void pa_sink_set_mute(pa_sink *s, bool mute, bool save) { pa_assert(PA_SINK_IS_LINKED(s->state)); old_muted = s->muted; + + if (mute == old_muted) { + s->save_muted |= save; + return; + } + s->muted = mute; - s->save_muted = (old_muted == s->muted && s->save_muted) || save; + s->save_muted = save; if (!(s->flags & PA_SINK_DEFERRED_VOLUME) && s->set_mute) s->set_mute(s); + pa_log_debug("The mute of sink %s changed from %s to %s.", s->name, pa_yes_no(old_muted), pa_yes_no(mute)); pa_assert_se(pa_asyncmsgq_send(s->asyncmsgq, PA_MSGOBJECT(s), PA_SINK_MESSAGE_SET_MUTE, NULL, 0, NULL) == 0); - - if (old_muted != s->muted) - pa_subscription_post(s->core, PA_SUBSCRIPTION_EVENT_SINK|PA_SUBSCRIPTION_EVENT_CHANGE, s->index); + pa_subscription_post(s->core, PA_SUBSCRIPTION_EVENT_SINK|PA_SUBSCRIPTION_EVENT_CHANGE, s->index); } /* Called from main thread */ diff --git a/src/pulsecore/source.c b/src/pulsecore/source.c index 5c1847e1..da0dc685 100644 --- a/src/pulsecore/source.c +++ b/src/pulsecore/source.c @@ -1792,16 +1792,21 @@ void pa_source_set_mute(pa_source *s, bool mute, bool save) { pa_assert(PA_SOURCE_IS_LINKED(s->state)); old_muted = s->muted; + + if (mute == old_muted) { + s->save_muted |= save; + return; + } + s->muted = mute; - s->save_muted = (old_muted == s->muted && s->save_muted) || save; + s->save_muted = save; if (!(s->flags & PA_SOURCE_DEFERRED_VOLUME) && s->set_mute) s->set_mute(s); + pa_log_debug("The mute of source %s changed from %s to %s.", s->name, pa_yes_no(old_muted), pa_yes_no(mute)); pa_assert_se(pa_asyncmsgq_send(s->asyncmsgq, PA_MSGOBJECT(s), PA_SOURCE_MESSAGE_SET_MUTE, NULL, 0, NULL) == 0); - - if (old_muted != s->muted) - pa_subscription_post(s->core, PA_SUBSCRIPTION_EVENT_SOURCE|PA_SUBSCRIPTION_EVENT_CHANGE, s->index); + pa_subscription_post(s->core, PA_SUBSCRIPTION_EVENT_SOURCE|PA_SUBSCRIPTION_EVENT_CHANGE, s->index); } /* Called from main thread */