• B
    PCI/portdrv: Compute MSI/MSI-X IRQ vectors after final allocation · a579ba49
    Bjorn Helgaas 提交于
    When setting up portdrv MSI/MSI-X interrupts, we previously allocated the
    maximum possible number of vectors, read the Interrupt Message Numbers for
    each service, saved the IRQ for each, freed the vectors, and finally used
    the largest Message Number to reallocate only as many vectors as we need.
    
    The problem is that freeing the vectors invalidates their IRQs, so the
    saved IRQ numbers may now be invalid, which can result in errors like
    this:
    
      pcie_pme: probe of 0000:00:00.0:pcie001 failed with error -22
      pciehp 0000:00:00.0:pcie004: Cannot get irq 20 for the hotplug controller
      aer: probe of 0000:00:00.0:pcie002 failed with error -22
      dpc 0000:00:00.0:pcie010: request IRQ22 failed: -22
    
    Change the setup so we save the Interrupt Message Numbers (not the IRQs)
    before we free the original setup, then use the Message Numbers to compute
    the IRQs (via pci_irq_vector()) *after* we reallocate the vectors.
    
    This should always be safe for MSI-X because the Message Numbers are fixed.
    For MSI, the hardware is allowed to change Message Numbers when we update
    the MSI Multiple Message Enable field when reallocating the vectors, but
    since we allocate enough vectors to accommodate the largest Message Number
    we found, that's unlikely.  See PCIe r3.1, sec 7.8.2, 7.10.10, 7.31.2.
    
    Fixes: 3674cc49 ("PCI/portdrv: Use pci_irq_alloc_vectors()")
    Based-on-patch-by: NDongdong Liu <liudongdong3@huawei.com>
    Tested-by: Dongdong Liu <liudongdong3@huawei.com>  # HiSilicon hip08
    Signed-off-by: NBjorn Helgaas <bhelgaas@google.com>
    Reviewed-by: NChristoph Hellwig <hch@lst.de>
    a579ba49
portdrv_core.c 14.2 KB