[vfio-users] Stuttering audio when passing through USB controller

Tmplt tmplt at dragons.rocks
Fri Feb 3 19:53:03 UTC 2017


I saw on an older thread here that passing a USB controller through and
using a USB soundcard through it solved that users audio issues. I tried
that myself by adding

    <hostdev mode='subsystem' type='pci' managed='no'>
      <source>
        <address domain='0x0000' bus='0x00' slot='0x14' function='0x0'/>
      </source>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x02'
function='0x0'/>
    </hostdev>

to the .xml-file, but I can still hear frequent audio stutters akin to
my quoted thread. Am I passing the controller incorrectly? The device
I'm trying to play through is a FiiO e10k DAC which works without issue
on the host and on bare-metal Windows 8.1.

Here follows my windows-pciusb.xml:

<domain type='kvm'>
  <name>windows-pciusb</name>
  <uuid>7353cd48-34ee-4a26-b8ac-7c5d1735777a</uuid>
  <memory unit='KiB'>8388608</memory>
  <currentMemory unit='KiB'>8388608</currentMemory>
  <vcpu placement='static'>4</vcpu>
  <iothreads>2</iothreads>
  <cputune>
    <vcpupin vcpu='0' cpuset='0'/>
    <vcpupin vcpu='1' cpuset='1'/>
    <vcpupin vcpu='2' cpuset='2'/>
    <vcpupin vcpu='3' cpuset='3'/>
  </cputune>
  <os>
    <type arch='x86_64' machine='pc-i440fx-2.7'>hvm</type>
    <loader readonly='yes'
type='pflash'>/usr/share/ovmf/x64/ovmf_x64.bin</loader>
    <nvram>/var/lib/libvirt/qemu/nvram/windows_VARS.fd</nvram>
    <bootmenu enable='no'/>
  </os>
  <features>
    <acpi/>
    <apic/>
    <hyperv>
      <relaxed state='on'/>
      <vapic state='on'/>
      <spinlocks state='on' retries='8191'/>
    </hyperv>
    <vmport state='off'/>
  </features>
  <cpu mode='host-passthrough'>
    <topology sockets='1' cores='4' threads='1'/>
  </cpu>
  <clock offset='localtime'>
    <timer name='rtc' tickpolicy='catchup'/>
    <timer name='pit' tickpolicy='delay'/>
    <timer name='hpet' present='no'/>
    <timer name='hypervclock' present='yes'/>
  </clock>
  <on_poweroff>destroy</on_poweroff>
  <on_reboot>restart</on_reboot>
  <on_crash>restart</on_crash>
  <pm>
    <suspend-to-mem enabled='no'/>
    <suspend-to-disk enabled='no'/>
  </pm>
  <devices>
    <emulator>/usr/sbin/qemu-system-x86_64</emulator>
    <disk type='block' device='disk'>
      <driver name='qemu' type='raw' cache='none' io='threads'
iothread='1'/>
      <source dev='/dev/sda'/>
      <target dev='vdb' bus='virtio'/>
      <boot order='3'/>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x08'
function='0x0'/>
    </disk>
    <disk type='block' device='disk'>
      <driver name='qemu' type='raw' cache='none' io='threads'
iothread='2'/>
      <source dev='/dev/sde2'/>
      <target dev='vdc' bus='virtio'/>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x0c'
function='0x0'/>
    </disk>
    <controller type='usb' index='0' model='ich9-ehci1'>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x05'
function='0x7'/>
    </controller>
    <controller type='usb' index='0' model='ich9-uhci1'>
      <master startport='0'/>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x05'
function='0x0' multifunction='on'/>
    </controller>
    <controller type='usb' index='0' model='ich9-uhci2'>
      <master startport='2'/>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x05'
function='0x1'/>
    </controller>
    <controller type='usb' index='0' model='ich9-uhci3'>
      <master startport='4'/>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x05'
function='0x2'/>
    </controller>
    <controller type='pci' index='0' model='pci-root'/>
    <controller type='ide' index='0'>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x01'
function='0x1'/>
    </controller>
    <controller type='virtio-serial' index='0'>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x06'
function='0x0'/>
    </controller>
    <interface type='network'>
      <mac address='52:54:00:0d:18:bf'/>
      <source network='default'/>
      <model type='virtio'/>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x03'
function='0x0'/>
    </interface>
    <input type='mouse' bus='ps2'/>
    <input type='keyboard' bus='ps2'/>
    <sound model='ich6'>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x04'
function='0x0'/>
    </sound>
    <hostdev mode='subsystem' type='pci' managed='yes'>
      <source>
        <address domain='0x0000' bus='0x02' slot='0x00' function='0x0'/>
      </source>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x09'
function='0x0'/>
    </hostdev>
    <hostdev mode='subsystem' type='pci' managed='yes'>
      <source>
        <address domain='0x0000' bus='0x02' slot='0x00' function='0x1'/>
      </source>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x0a'
function='0x0'/>
    </hostdev>
    <hostdev mode='subsystem' type='pci' managed='yes'>
      <source>
        <address domain='0x0000' bus='0x07' slot='0x00' function='0x0'/>
      </source>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x0b'
function='0x0'/>
    </hostdev>
    <hostdev mode='subsystem' type='usb' managed='yes'>
      <source>
        <vendor id='0x045e'/>
        <product id='0x028e'/>
      </source>
      <address type='usb' bus='0' port='1'/>
    </hostdev>
    <hostdev mode='subsystem' type='pci' managed='no'>
      <source>
        <address domain='0x0000' bus='0x00' slot='0x14' function='0x0'/>
      </source>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x02'
function='0x0'/>
    </hostdev>
    <memballoon model='virtio'>
      <address type='pci' domain='0x0000' bus='0x00' slot='0x07'
function='0x0'/>
    </memballoon>
  </devices>
</domain>

lsusb reports that everything goes to the same, single USB controller,
which is what I pass. Could that be the issue? I'm qouting my last
thread in case any info there helps.

Thanks in advance!

On 01/29/2017 12:38 AM, Tmplt wrote:
> I forgot to mention: I'm using the linux-vfio kernel, v4.8.13, and my
> only kernel options are intel_iommu=on and pcie_acs_override=downstream.
> 
> On 01/28/2017 06:13 AM, Tmplt wrote:
>> Having spent some hours (unsucessfully) to get stutter-free audio via
>> Pulseaudio (and ALSA) have left me with the options of either dual
>> booting or letting dedicated hardware handle the audio, which I can then
>> mix together into a single output.
>>
>> However, passing only the GPU as a soundcard and listening to the audio
>> via my monitor's headphone jack, there is some noticable audio
>> stuttering. While only noticable when running some more heavier games
>> (e.g. Battlefield 1), I'm guessing this shouldn't be the case, and that
>> I've configured something incorrectly. Especially since I've enabled
>> MSIs for both the GPU and the GPUs audio device.
>>
>> Here is what my system is:
>> CPU:  i5-6600k @ stock
>> MOBO: ASUS Z170-A
>> RAM:  16GB DDR4 at 2133Mhz (I think, could be 1600)
>> GPU:  ASUS R9 290 (for the VM; reference card)
>>
>> HOST OS:  Arch Linux
>> GUEST OS: Windows 8.1
>>
>> I run my VM via qemu (2.8.0) and libvirt (2.4.0).
>>
>> When Windows was installed it automatically enabled MSI for the GPU. I
>> manually enabled it for the audio device, rebooted, and confirmed that
>> they both appeared below the IRQ drop-down in the device manager.
>>
>> It can be worth of note that I flashed my card with a UEFI-bios some
>> time ago so that it got passed-through without issue. I can't recall
>> whether this was required for my qemu config at the time or if a
>> non-UEFI card can't be passed through. I'm also not sure if both BIOSes
>> (there is a switch to toggle between the two on my card) are overwritten
>> during the flash, or just the current one. Either case, the topical
>> issue is present on both settings.




More information about the vfio-users mailing list