Re: [PATCH kvmtool v2 3/3] vfio-pci: Re-enable INTx mode when disable MSI/MSIX

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Jean-Philippe,

On Mon, Mar 25, 2019 at 06:28:40PM +0000, Jean-Philippe Brucker wrote:

[...]

> > @@ -162,7 +160,34 @@ static int vfio_pci_disable_msis(struct kvm *kvm, struct vfio_device *vdev,
> >  	msi_set_enabled(msis->phys_state, false);
> >  	msi_set_empty(msis->phys_state, true);
> >  
> > -	return 0;
> > +	/*
> > +	 * When MSI or MSIX is disabled, this might be called when
> > +	 * PCI driver detects the MSI interrupt failure and wants to
> > +	 * rollback to INTx mode.  Thus enable INTx if the device
> > +	 * supports INTx mode in this case.
> > +	 */
> > +	if (pdev->irq_modes & VFIO_PCI_IRQ_MODE_INTX) {
> > +		/*
> > +		 * Struct pci_device_header is not only used for header,
> > +		 * it also is used for PCI configuration; and in the function
> > +		 * vfio_pci_cfg_write() it firstly writes configuration space
> > +		 * and then read back the configuration space data into the
> > +		 * header structure; thus 'irq_pin' and 'irq_line' in the
> > +		 * header will be overwritten.
> > +		 *
> > +		 * If want to enable INTx mode properly, firstly needs to
> > +		 * restore 'irq_pin' and 'irq_line' values; we can simply set 1
> > +		 * to 'irq_pin', and 'pdev->intx_gsi' keeps gsi value when
> > +		 * enable INTx mode previously so we can simply use it to
> > +		 * recover irq line number by adding offset KVM_IRQ_OFFSET.
> > +		 */
> > +		pdev->hdr.irq_pin = 1;
> > +		pdev->hdr.irq_line = pdev->intx_gsi + KVM_IRQ_OFFSET;
> 
> That doesn't look right. We shouldn't change irq_line at runtime, it's
> reserved to the guest (and irq_pin is static). Maybe move the bits that
> should only be done once (intx_gsi setup, and also the
> VFIO_DEVICE_GET_IRQ_INFO sanity check) outside of the enable() function,
> like we do for msis?

Agree this and another comment in patch 0002.  Will spin new patch
set with following these good suggestions.

Thanks a lot for reviewing!

Thanks,
Leo Yan



[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux