|
@@ -105,9 +105,12 @@ void __weak arch_teardown_msi_irq(unsigned int irq)
|
|
|
|
|
|
int __weak arch_setup_msi_irqs(struct pci_dev *dev, int nvec, int type)
|
|
|
{
|
|
|
+ struct msi_controller *chip = dev->bus->msi;
|
|
|
struct msi_desc *entry;
|
|
|
int ret;
|
|
|
|
|
|
+ if (chip && chip->setup_irqs)
|
|
|
+ return chip->setup_irqs(chip, dev, nvec, type);
|
|
|
/*
|
|
|
* If an architecture wants to support multiple MSI, it needs to
|
|
|
* override arch_setup_msi_irqs()
|