[PATCH v3 00/12] Introduce new methods for verifying ownership in vfio PCI hot reset
Duan, Zhenzhong
zhenzhong.duan at intel.com
Tue Apr 4 10:55:29 UTC 2023
> -----Original Message-----
> From: Liu, Yi L <mailto:yi.l.liu at intel.com>
> Sent: Saturday, April 1, 2023 10:44 PM
> Subject: [PATCH v3 00/12] Introduce new methods for verifying
> ownership in vfio PCI hot reset
>
> VFIO_DEVICE_PCI_HOT_RESET requires user to pass an array of group fds
> to prove that it owns all devices affected by resetting the calling
> device. This series introduces several extensions to allow the
> ownership check better aligned with iommufd and coming vfio device cdev support.
>
> First, resetting an unopened device is always safe given nobody is
> using it. So relax the check to allow such devices not covered by
> group fd array. [1]
>
> When iommufd is used we can simply verify that all affected devices
> are bound to a same iommufd then no need for the user to provide extra
> fd information. This is enabled by the user passing a zero-length fd
> array and moving forward this should be the preferred way for hot
> reset. [2]
>
> However the iommufd method has difficulty working with noiommu devices
> since those devices don't have a valid iommufd, unless the noiommu
> device is in a singleton dev_set hence no ownership check is required.
> [3]
>
> For noiommu backward compatibility a 3rd method is introduced by
> allowing the user to pass an array of device fds to prove ownership.
> [4]
>
> As suggested by Jason [5], we have this series to introduce the above
> stuffs to the vfio PCI hot reset. Per the dicussion in [6] [7], in the
> end of this series, the VFIO_DEVICE_GET_PCI_HOT_RESET_INFO is extended
> to report devid for the devices opened as cdev. This is goging to
> support the device fd passing usage.
>
> The new hot reset method and updated _INFO ioctl are tested with two
> test commits in below qemu:
>
> https://github.com/yiliu1765/qemu/commits/iommufd_rfcv3
> (requires to test with cdev kernel)
Test pass with qemu supporting new uAPI, played trick to bypass FLR and trigger
hot reset intentionally. 81:00.0 and 81:00.1 are dependent devices from same slot
and passed to one VM, see below qemu trace for details.
vfio_pci_hot_reset (0000:81:00.1) multi
vfio_intx_disable_kvm (0000:81:00.1) KVM INTx accel disabled
vfio_region_mmaps_set_enabled Region 0000:81:00.1 BAR 0 mmaps enabled: 1
vfio_region_mmaps_set_enabled Region 0000:81:00.1 BAR 3 mmaps enabled: 1
vfio_intx_disable (0000:81:00.1)
vfio_pci_read_config (0000:81:00.1, @0x44, len=0x2) 0x2008
vfio_pci_read_config (0000:81:00.1, @0x4, len=0x2) 0x142
vfio_pci_write_config (0000:81:00.1, @0x4, 0x140, len=0x2)
vfio_pci_hot_reset_has_dep_devices 0000:81:00.1: hot reset dependent devices:
vfio_pci_hot_reset_dep_devices_iommufd 0000:81:00.0 devid 2
vfio_intx_disable_kvm (0000:81:00.0) KVM INTx accel disabled
vfio_region_mmaps_set_enabled Region 0000:81:00.0 BAR 0 mmaps enabled: 1
vfio_region_mmaps_set_enabled Region 0000:81:00.0 BAR 3 mmaps enabled: 1
vfio_intx_disable (0000:81:00.0)
vfio_pci_read_config (0000:81:00.0, @0x44, len=0x2) 0x2008
vfio_pci_read_config (0000:81:00.0, @0x4, len=0x2) 0x142
vfio_pci_write_config (0000:81:00.0, @0x4, 0x140, len=0x2)
vfio_pci_hot_reset_dep_devices_iommufd 0000:81:00.1 devid 5
vfio_pci_hot_reset_result 0000:81:00.1 hot reset: Success
vfio_pci_read_config (0000:81:00.0, @0x3d, len=0x1) 0x1
vfio_intx_enable_kvm (0000:81:00.0) KVM INTx accel enabled
vfio_intx_enable (0000:81:00.0)
vfio_pci_read_config (0000:81:00.1, @0x3d, len=0x1) 0x1
vfio_intx_enable_kvm (0000:81:00.1) KVM INTx accel enabled
vfio_intx_enable (0000:81:00.1)
vfio_pci_hot_reset (0000:81:00.0) multi
vfio_intx_disable_kvm (0000:81:00.0) KVM INTx accel disabled
vfio_region_mmaps_set_enabled Region 0000:81:00.0 BAR 0 mmaps enabled: 1
vfio_region_mmaps_set_enabled Region 0000:81:00.0 BAR 3 mmaps enabled: 1
vfio_intx_disable (0000:81:00.0)
vfio_pci_read_config (0000:81:00.0, @0x44, len=0x2) 0x2008
vfio_pci_read_config (0000:81:00.0, @0x4, len=0x2) 0x140
vfio_pci_write_config (0000:81:00.0, @0x4, 0x140, len=0x2)
vfio_pci_hot_reset_has_dep_devices 0000:81:00.0: hot reset dependent devices:
vfio_pci_hot_reset_dep_devices_iommufd 0000:81:00.0 devid 2
vfio_pci_hot_reset_dep_devices_iommufd 0000:81:00.1 devid 5
vfio_intx_disable_kvm (0000:81:00.1) KVM INTx accel disabled
vfio_region_mmaps_set_enabled Region 0000:81:00.1 BAR 0 mmaps enabled: 1
vfio_region_mmaps_set_enabled Region 0000:81:00.1 BAR 3 mmaps enabled: 1
vfio_intx_disable (0000:81:00.1)
vfio_pci_read_config (0000:81:00.1, @0x44, len=0x2) 0x2008
vfio_pci_read_config (0000:81:00.1, @0x4, len=0x2) 0x140
vfio_pci_write_config (0000:81:00.1, @0x4, 0x140, len=0x2)
vfio_pci_hot_reset_result 0000:81:00.0 hot reset: Success
vfio_pci_read_config (0000:81:00.1, @0x3d, len=0x1) 0x1
vfio_intx_enable_kvm (0000:81:00.1) KVM INTx accel enabled
vfio_intx_enable (0000:81:00.1)
vfio_pci_read_config (0000:81:00.0, @0x3d, len=0x1) 0x1
vfio_intx_enable_kvm (0000:81:00.0) KVM INTx accel enabled
vfio_intx_enable (0000:81:00.0)
......
vfio_pci_reset (0000:81:00.1)
vfio_intx_disable_kvm (0000:81:00.1) KVM INTx accel disabled
vfio_region_mmaps_set_enabled Region 0000:81:00.1 BAR 0 mmaps enabled: 1
vfio_region_mmaps_set_enabled Region 0000:81:00.1 BAR 3 mmaps enabled: 1
vfio_intx_disable (0000:81:00.1)
vfio_pci_read_config (0000:81:00.1, @0x44, len=0x2) 0x2008
vfio_pci_read_config (0000:81:00.1, @0x4, len=0x2) 0x140
vfio_pci_write_config (0000:81:00.1, @0x4, 0x140, len=0x2)
vfio_pci_hot_reset (0000:81:00.1) one
vfio_pci_hot_reset_has_dep_devices 0000:81:00.1: hot reset dependent devices:
vfio_pci_hot_reset_dep_devices_iommufd 0000:81:00.0 devid 2
vfio_pci_read_config (0000:81:00.1, @0x3d, len=0x1) 0x1
vfio_intx_enable_kvm (0000:81:00.1) KVM INTx accel enabled
vfio_intx_enable (0000:81:00.1)
vfio_pci_reset (0000:81:00.0)
vfio_intx_disable_kvm (0000:81:00.0) KVM INTx accel disabled
vfio_region_mmaps_set_enabled Region 0000:81:00.0 BAR 0 mmaps enabled: 1
vfio_region_mmaps_set_enabled Region 0000:81:00.0 BAR 3 mmaps enabled: 1
vfio_intx_disable (0000:81:00.0)
vfio_pci_read_config (0000:81:00.0, @0x44, len=0x2) 0x2008
vfio_pci_read_config (0000:81:00.0, @0x4, len=0x2) 0x140
vfio_pci_write_config (0000:81:00.0, @0x4, 0x140, len=0x2)
vfio_pci_hot_reset (0000:81:00.0) one
vfio_pci_hot_reset_has_dep_devices 0000:81:00.0: hot reset dependent devices:
vfio_pci_hot_reset_dep_devices_iommufd 0000:81:00.0 devid 2
vfio_pci_hot_reset_dep_devices_iommufd 0000:81:00.1 devid 5
vfio_pci_read_config (0000:81:00.0, @0x3d, len=0x1) 0x1
vfio_intx_enable_kvm (0000:81:00.0) KVM INTx accel enabled
vfio_intx_enable (0000:81:00.0)
More information about the intel-gvt-dev
mailing list