All of lore.kernel.org
 help / color / mirror / Atom feed
From: David Henningsson <david.henningsson@canonical.com>
To: Stefano Panella <stefano.panella@citrix.com>
Cc: alsa-devel@alsa-project.org
Subject: Re: paravirtualized alsa  kernel driver for XEN
Date: Tue, 20 Mar 2012 10:52:10 +0100	[thread overview]
Message-ID: <4F68534A.70203@canonical.com> (raw)
In-Reply-To: <4F6769A9.6090200@citrix.com>

On 03/19/2012 06:15 PM, Stefano Panella wrote:
> Hi,
>
> I am Stefano Panella, I am new to the list and I would like to take the
> opportunity to ask some questions since I am trying to write a
> paravirtualized alsa driver for XEN.
>
> If all goes well I would also like to upstream it on linux.
>
> I have been reading the documentation on "Writing an ALSA Driver" and I
> am still not completely clear on the meaning of the "pointer" callback
> in the pcm operations.
>
> The description say:
>
> "This callback is called when the PCM middle layer inquires the current
> hardware position on the buffer."
>
> My question are:
>
> 1) In case of a playback stream, is the pointer referring to wich sample
> is currently playing on the DAC or to which is it the last frame read by
> the HW from the alsa memory buffer?
>
> 2) What does the pointer mean in case of a capture stream? Is it the
> position of the current frame on the ADC or is the latest frame written
> into the alsa buffer?

I'd say that for both, it is being used by applications to know what 
memory they can read from or write to. But other people here might know 
better.

> 3) in case it is the frame on the DAC/ADC, what happens if the callback
> does not return the real DAC/ADC frame position but an approximate
> value, let say rounded to 64 frames only?

For the JACK sound server, I think it only needs to be as accurate as 
the period (i e if you have 4 periods with 64 samples each, you need to 
be able to return 0, 64, 128 and 192).

For PulseAudio it's worse. The worse granularity, the more difficult for 
PulseAudio to have low-latency operation. PulseAudio also 
rewinds/rewrites the buffer occasionally and uses the pointer to know 
from when it should start rewriting.

> 4) is there any test I could run to check I have implemented correctly
> the "pointer" callback? Or any application which would need very high
> "pointer" precision like frame precision?

PulseAudio has an alsa-time-test application that relies heavily on the 
pointer callback being accurate. It's only for playback and I've never 
used it myself so I'm not completely sure about how to interpret the 
numbers.

In general, I believe PulseAudio (especially with timer-scheduling mode 
enabled) stress tests the driver quite hard and as such it is sometimes 
being used as a measure to see if the audio driver is successful. :-)

Hopefully this provides some initial insights.

-- 
David Henningsson, Canonical Ltd.
http://launchpad.net/~diwic

  reply	other threads:[~2012-03-20  9:52 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-03-19 17:15 paravirtualized alsa kernel driver for XEN Stefano Panella
2012-03-20  9:52 ` David Henningsson [this message]
2012-03-21 10:11   ` Stefano Panella
2012-03-20 13:10 ` Clemens Ladisch
2012-03-21 10:16   ` Stefano Panella
2012-03-21 13:37     ` Clemens Ladisch
2012-03-22 11:22       ` Stefano Panella
2012-03-22 12:09         ` Clemens Ladisch
2012-04-11 17:08           ` Stefano Panella
2012-04-11 18:41             ` Clemens Ladisch

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4F68534A.70203@canonical.com \
    --to=david.henningsson@canonical.com \
    --cc=alsa-devel@alsa-project.org \
    --cc=stefano.panella@citrix.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
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.