On 01/11/2013 08:18 PM, Tanu Kaskinen wrote:
On Fri, 2013-01-11 at 14:04 +0100, David Henningsson wrote:
This fixes a bug where pulseaudio would give up the device (due to
a request from JACK), but then immediately grab it again because
the monitor callback fired, telling that the device is now available.

(Note: the protocol does not specify a timeout, i e if pulseaudio
is requested to give its device up but JACK does not grab the dbus name,
at what point is PulseAudio allowed to re-grab it?)

Signed-off-by: David Henningsson <[email protected]>
---
  src/modules/reserve-monitor.c |   30 +++++++++++++++++++-----------
  1 file changed, 19 insertions(+), 11 deletions(-)

Will commit this to stable-3.x and master in a few days if there are
no objections.

@Lennart, would you mind committing this to the upstream reserve.git repo as 
well?

This seems pretty equivalent to a patch[1] that I sent earlier, with the
difference that with your patch change_cb() is called also in "busy ->
busy" transitions (i.e. when the bus name changes owner, and neither old
or new owner is pulseaudio).

[1] http://thread.gmane.org/gmane.comp.audio.pulseaudio.general/15053

There is the problem of busy not being correctly initialized, i e, the initial value of busy does not take ourselves into account. Explicitly checking is_really_busy(old) works around this issue. (Properly initializing busy is a more elegant solution though.)


--
David Henningsson, Canonical Ltd.
https://launchpad.net/~diwic
_______________________________________________
pulseaudio-discuss mailing list
[email protected]
http://lists.freedesktop.org/mailman/listinfo/pulseaudio-discuss

Reply via email to