• Alex Williamson's avatar
    vfio-pci: Release devices with BusMaster disabled · 9c22e660
    Alex Williamson authored
    Our current open/release path looks like this:
    
    vfio_pci_open
      vfio_pci_enable
        pci_enable_device
        pci_save_state
        pci_store_saved_state
    
    vfio_pci_release
      vfio_pci_disable
        pci_disable_device
        pci_restore_state
    
    pci_enable_device() doesn't modify PCI_COMMAND_MASTER, so if a device
    comes to us with it enabled, it persists through the open and gets
    stored as part of the device saved state.  We then restore that saved
    state when released, which can allow the device to attempt to continue
    to do DMA.  When the group is disconnected from the domain, this will
    get caught by the IOMMU, but if there are other devices in the group,
    the device may continue running and interfere with the user.  Even in
    the former case, IOMMUs don't necessarily behave well and a stream of
    blocked DMA can result in unpleasant behavior on the host.
    
    Explicitly disable Bus Master as we're enabling the device and
    slightly re-work release to make sure that pci_disable_device() is
    the last thing that touches the device.
    Signed-off-by: default avatarAlex Williamson <alex.williamson@redhat.com>
    9c22e660
vfio_pci.c 22.8 KB