[alsa-devel] paravirtualized alsa kernel driver for XEN
stefano.panella at citrix.com
Thu Mar 22 12:22:46 CET 2012
On 21/03/12 13:37, Clemens Ladisch wrote:
> Stefano Panella wrote:
>> On 20/03/12 13:10, Clemens Ladisch wrote:
>>> The delay between the DMA and the DAC output would be reported by
>>> adjusting runtime->delay, but drivers usually do not bother to do this,
>>> except when this delay becomes rather large because of additional
>>> queueing, e.g., in the USB driver.
>> ok, I was wondering about applications like skype, trying to do some
>> background noise cancellation, or to eliminate echo when using speakers.
>> I was thinking in this case the delay should be accurate for Playback
>> and Capture as well, or am I wrong?
> If the sound data is regularly moved from the VM's buffer to the host's
> buffer, then the additional latency of the host is big enough that it's
> worth reporting.
> If you map the host's buffer into the VM's address space, there is no
> additional latency, but I don't know if this is feasible. If not, you
> could also use the pcm_ops.copy callback to copy the data from the VM
> to the host as soon as the application writes it.
My PV alsa driver is allocating some non contiguous pages for the audio
buffer and the get_page callback is called to retrieve the position of
every page. These pages are also mapped from the backend in dom0.
The backend in dom0 is a userspace process using portaudio on top of alsa.
The process is running in realtime priority and is calling a callback to
feed data every 64 frames.
In the callback I copy 64 frames from the shared pages to the portaudio
buffer and update the HW pointer in an other shared page accordingly.
Would it be possible to run the backend in dom0 kernel space and to use
my shared pages from the alsa-driver in the VM as real pages for the HW
instead to go all the way from
>> Who is currently the linux kernel alsa driver mantainer?
> See "SOUND" in the MAINTAINERS file.
Thanks again very much and regards,
More information about the Alsa-devel