* [PATCH 6/6] pulse: immediately trigger EIO when connection is dropped
@ 2009-08-04 21:56 Lennart Poettering
2009-08-04 22:01 ` Takashi Iwai
0 siblings, 1 reply; 2+ messages in thread
From: Lennart Poettering @ 2009-08-04 21:56 UTC (permalink / raw)
To: ALSA Development Mailing List
When the connection is dropped notify the application immediately
instead of waiting until the applications calls into us the next time.
This makes "aplay" handle connections shutdown similar to hardware
unplugs: an immediate EIO is thrown.
---
pulse/pulse.c | 9 ++++++++-
1 files changed, 8 insertions(+), 1 deletions(-)
diff --git a/pulse/pulse.c b/pulse/pulse.c
index 9c05171..a94caaf 100644
--- a/pulse/pulse.c
+++ b/pulse/pulse.c
@@ -77,10 +77,17 @@ int pulse_wait_operation(snd_pulse_t * p, pa_operation * o)
static void context_state_cb(pa_context * c, void *userdata)
{
+ pa_context_state_t state;
snd_pulse_t *p = userdata;
assert(c);
- switch (pa_context_get_state(c)) {
+ state = pa_context_get_state(c);
+
+ /* When we get disconnected, tell the process */x
+ if (!PA_CONTEXT_IS_GOOD(state))
+ pulse_poll_activate(p);
+
+ switch (state) {
case PA_CONTEXT_READY:
case PA_CONTEXT_TERMINATED:
case PA_CONTEXT_FAILED:
--
1.6.4
Lennart
--
Lennart Poettering Red Hat, Inc.
lennart [at] poettering [dot] net ICQ# 11060553
http://0pointer.net/lennart/ GnuPG 0x1A015CC4
^ permalink raw reply related [flat|nested] 2+ messages in thread* Re: [PATCH 6/6] pulse: immediately trigger EIO when connection is dropped
2009-08-04 21:56 [PATCH 6/6] pulse: immediately trigger EIO when connection is dropped Lennart Poettering
@ 2009-08-04 22:01 ` Takashi Iwai
0 siblings, 0 replies; 2+ messages in thread
From: Takashi Iwai @ 2009-08-04 22:01 UTC (permalink / raw)
To: Lennart Poettering; +Cc: ALSA Development Mailing List
At Tue, 4 Aug 2009 23:56:00 +0200,
Lennart Poettering wrote:
>
> diff --git a/pulse/pulse.c b/pulse/pulse.c
> index 9c05171..a94caaf 100644
> --- a/pulse/pulse.c
> +++ b/pulse/pulse.c
> @@ -77,10 +77,17 @@ int pulse_wait_operation(snd_pulse_t * p, pa_operation * o)
>
> static void context_state_cb(pa_context * c, void *userdata)
> {
> + pa_context_state_t state;
> snd_pulse_t *p = userdata;
> assert(c);
>
> - switch (pa_context_get_state(c)) {
> + state = pa_context_get_state(c);
> +
> + /* When we get disconnected, tell the process */x
^
This causes compile errors (already fixed manually :)
Takashi
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2009-08-04 22:01 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-08-04 21:56 [PATCH 6/6] pulse: immediately trigger EIO when connection is dropped Lennart Poettering
2009-08-04 22:01 ` Takashi Iwai
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.