RE: [RFC PATCH V2 14/18] vfio/pci: Add core IMS support
From: Tian, Kevin
Date: Fri Oct 13 2023 - 04:11:33 EST
> From: Chatre, Reinette <reinette.chatre@xxxxxxxxx>
> Sent: Saturday, October 7, 2023 12:41 AM
>
> A virtual device driver starts by initializing the backend
> using new vfio_pci_ims_init_intr_ctx(), cleanup using new
> vfio_pci_ims_release_intr_ctx(). Once initialized the virtual
> device driver can call vfio_pci_set_irqs_ioctl() to handle the
> VFIO_DEVICE_SET_IRQS ioctl() after it has validated the parameters
> to be appropriate for the particular device.
I wonder whether the code sharing can go deeper from
vfio_pci_set_irqs_ioctl() all the way down to set_vector_signal()
with proper abstraction. Then handle emulated interrupt in the
common code instead of ims specific path. intel gvt also uses
emulated interrupt, which could be converted to use this library
too.
There is some subtle difference between pci/ims backends
regarding to how set_vector_signal() is coded in this series. But
it is not intuitive to me whether such a difference is conceptual
or simply from a coding preference.
Would you mind doing an exercise whether that is achievable?
Thanks
Kevin