msi: Fix msi_remove_pci_irq_vectors.
Since msi_remove_pci_irq_vectors is designed to be called during hotplug remove it is actively wrong to query the hardware and expect meaningful results back. To that end remove the pci_find_capability calls. Testing dev->msi_enabled and dev->msix_enabled gives us all of the information we need. Signed-off-by: Eric W. Biederman <ebiederm@xmission.com> Acked-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
parent
d40f540ce6
commit
866a8c87c4
|
@ -854,13 +854,10 @@ void pci_disable_msix(struct pci_dev* dev)
|
||||||
**/
|
**/
|
||||||
void msi_remove_pci_irq_vectors(struct pci_dev* dev)
|
void msi_remove_pci_irq_vectors(struct pci_dev* dev)
|
||||||
{
|
{
|
||||||
int pos;
|
|
||||||
|
|
||||||
if (!pci_msi_enable || !dev)
|
if (!pci_msi_enable || !dev)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
pos = pci_find_capability(dev, PCI_CAP_ID_MSI);
|
if (dev->msi_enabled) {
|
||||||
if (pos > 0 && dev->msi_enabled) {
|
|
||||||
if (irq_has_action(dev->first_msi_irq)) {
|
if (irq_has_action(dev->first_msi_irq)) {
|
||||||
printk(KERN_WARNING "PCI: %s: msi_remove_pci_irq_vectors() "
|
printk(KERN_WARNING "PCI: %s: msi_remove_pci_irq_vectors() "
|
||||||
"called without free_irq() on MSI irq %d\n",
|
"called without free_irq() on MSI irq %d\n",
|
||||||
|
@ -869,8 +866,7 @@ void msi_remove_pci_irq_vectors(struct pci_dev* dev)
|
||||||
} else /* Release MSI irq assigned to this device */
|
} else /* Release MSI irq assigned to this device */
|
||||||
msi_free_irq(dev, dev->first_msi_irq);
|
msi_free_irq(dev, dev->first_msi_irq);
|
||||||
}
|
}
|
||||||
pos = pci_find_capability(dev, PCI_CAP_ID_MSIX);
|
if (dev->msix_enabled) {
|
||||||
if (pos > 0 && dev->msix_enabled) {
|
|
||||||
int irq, head, tail = 0, warning = 0;
|
int irq, head, tail = 0, warning = 0;
|
||||||
void __iomem *base = NULL;
|
void __iomem *base = NULL;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue