At Tue, 14 Jan 2003 09:38:51 -0500,
Paul Davis wrote:
>
>
> [ cc'ed to alsa-devel ]
>
> >I think I've asked something to this effect before, but is there any
> >reason why the polling portion of alsa_driver_wait should not be in
> >libasound? It's a very complicated piece of code that performs an
> >operation that many programs are likely to want. What if it was written
> >as a companion function to snd_pcm_wait():
> >
> > int snd_pcm_wait_many( snd_pcm_t **handles, int num_handles,
> > int timeout);
> >
> >...not that JACK would have to give up its version with extra error
> >reporting and timing, but for programs with simpler needs it would be a
> >lot nicer than having to set and test all those poll conditions for all
> >of the pfds on all the handles.
> >
> >I should probably ask this on the ALSA list, but I'm more familiar with
> >the people here. Any reason why this couldn't go into libasound?
>
> seems like a good idea to me, although there is a small problem. the
> current snd_pcm_wait function waits till the handles is
> readable/writable, whereas the JACK code waits till the handles all
> have a certain minimum amount of data/space. this is a subtle but
> rather important difference.
i thought that snd_pcm_wait() waits until data/space of
swparams->avail_min become available, too?
>
> that said, i think it would be great if this found its way into libasound.
is the below code ok?
int snd_pcm_wait_many(snd_pcm_t **handles, int num_handles, int timeout)
{
struct pollfd *pfds;
int i, err;
pfds = (struct pollfd *)alloca(sizeof(*pfds) * num_handles);
if (! pfds)
reutrn -ENOMEM;
for (i = 0; i < num_handles; i++) {
err = snd_pcm_poll_descriptors(handles[i], &pfds[i], 1);
assert(err == 1);
}
err = poll(pfds, num_handles, timeout);
if (err < 0)
return -errno;
return err > 0 ? 1 : 0;
}
Takashi
-------------------------------------------------------
This SF.NET email is sponsored by: FREE SSL Guide from Thawte
are you planning your Web Server Security? Click here to get a FREE
Thawte SSL guide and find the answers to all your SSL security issues.
http://ads.sourceforge.net/cgi-bin/redirect.pl?thaw0026en
_______________________________________________
Alsa-devel mailing list
[EMAIL PROTECTED]
https://lists.sourceforge.net/lists/listinfo/alsa-devel