[alsa-devel] [PATCH] alsa-plugins: Pulse: only underrun if no more data has been written
Takashi Iwai
tiwai at suse.de
Tue Aug 23 17:07:54 CEST 2011
At Tue, 23 Aug 2011 15:57:05 +0200,
David Henningsson wrote:
>
> On 2011-08-23 15:40, Takashi Iwai wrote:
> > At Tue, 23 Aug 2011 13:56:58 +0200,
> > David Henningsson wrote:
> >>
> >> Behold the third version of the patch.
> >>
> >> On 08/19/2011 02:46 PM, Takashi Iwai wrote:
> >>> At Fri, 19 Aug 2011 11:49:25 +0200,
> >>> David Henningsson wrote:
> >>>>
> >>>>> From 8098c77a447a80d2860588387d18b3aa6d23b6bb Mon Sep 17 00:00:00 2001
> >>>> From: David Henningsson<david.henningsson at canonical.com>
> >>>> Date: Fri, 19 Aug 2011 11:47:07 +0200
> >>>> Subject: [PATCH] alsa-plugins: Pulse: only underrun if no more data has been
> >>>> written
> >>>>
> >>>> If more data has already been written after the underrun, the underrun
> >>>> will automatically end and therefore we should not report it or
> >>>> restart the stream.
> >>>>
> >>>> Signed-off-by: David Henningsson<david.henningsson at canonical.com>
> >>>> ---
> >>>> configure.in | 7 +++++++
> >>>> pulse/pcm_pulse.c | 28 ++++++++++++++++++++++++++--
> >>>> 2 files changed, 33 insertions(+), 2 deletions(-)
> >>>>
> >>>> diff --git a/configure.in b/configure.in
> >>>> index ccf59ba..f6886b1 100644
> >>>> --- a/configure.in
> >>>> +++ b/configure.in
> >>>> @@ -31,8 +31,14 @@ AC_ARG_ENABLE([pulseaudio],
> >>>>
> >>>> if test "x$enable_pulseaudio" != "xno"; then
> >>>> PKG_CHECK_MODULES(pulseaudio, [libpulse>= 0.9.11], [HAVE_PULSE=yes], [HAVE_PULSE=no])
> >>>> + PKG_CHECK_MODULES(pulseaudio_099, [libpulse>= 0.99.1],
> >>>> + [HAVE_PULSE_UNDERRUN_INDEX=yes], [HAVE_PULSE_UNDERRUN_INDEX=no])
> >>>
> >>> Hm, can we use PA_CHECK_VERSION() or such simply in the code?
> >>
> >> Ok, good idea.
> >>
> >>>
> >>>> diff --git a/pulse/pcm_pulse.c b/pulse/pcm_pulse.c
> >>>> index d6c6792..61f1c0c 100644
> >>>> --- a/pulse/pcm_pulse.c
> >>>> +++ b/pulse/pcm_pulse.c
> >>>> @@ -26,6 +26,10 @@
> >>>> #include<alsa/asoundlib.h>
> >>>> #include<alsa/pcm_external.h>
> >>>>
> >>>> +#ifdef HAVE_CONFIG_H
> >>>> +#include<config.h>
> >>>> +#endif
> >>>> +
> >>>> #include "pulse.h"
> >>>>
> >>>> typedef struct snd_pcm_pulse {
> >>>> @@ -39,9 +43,10 @@ typedef struct snd_pcm_pulse {
> >>>> size_t last_size;
> >>>> size_t ptr;
> >>>> int underrun;
> >>>> - int handle_underrun;
> >>>> + int handle_underrun; /* can be 0=never, 1=always or 2,3=only if more data has not been written */
> >>>
> >>> I think it'd be simpler to introduce one more boolean variable.
> >>> Otherwise the logic looks too complex than needed.
> >>
> >> I've now done that. I don't know if it became simpler though.
> >
> > Hm, indeed.
> >
> > I think we can start off from more simple. With the new PA, the
> > underrun detection should work better. So why we do we need yet
> > another mode to disable it? It should be enough just to have a
> > boolean for underrun_detect yes/no.
> >
> > So, the patch would be like below.
> >
> > What do you think?
>
> Sure. For me, I'd go with the new functionality without ever configuring
> anything else. So I'm happy to exchange "always underrun" for the new
> underrun detection or even to remove the configuration functionality
> entirely.
The configuration is still needed for older PA, so let's keep it for
now. I committed the previous patch now to git tree.
Thanks!
Takashi
More information about the Alsa-devel
mailing list