Commit 339e5b44 authored by Lucas Stach's avatar Lucas Stach Committed by Bjorn Helgaas

PCI: Add msi_controller setup_irqs() method for special multivector setup

Add a msi_controller setup_irqs() method so MSI chip providers can
implement their own multivector MSI setup.

[bhelgaas: changelog]
Signed-off-by: default avatarLucas Stach <l.stach@pengutronix.de>
Signed-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
Reviewed-by: default avatarPratyush Anand <pratyush.anand@gmail.com>
parent ed8b472d
...@@ -105,9 +105,12 @@ void __weak arch_teardown_msi_irq(unsigned int irq) ...@@ -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) 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; struct msi_desc *entry;
int ret; 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 * If an architecture wants to support multiple MSI, it needs to
* override arch_setup_msi_irqs() * override arch_setup_msi_irqs()
......
...@@ -163,6 +163,8 @@ struct msi_controller { ...@@ -163,6 +163,8 @@ struct msi_controller {
int (*setup_irq)(struct msi_controller *chip, struct pci_dev *dev, int (*setup_irq)(struct msi_controller *chip, struct pci_dev *dev,
struct msi_desc *desc); struct msi_desc *desc);
int (*setup_irqs)(struct msi_controller *chip, struct pci_dev *dev,
int nvec, int type);
void (*teardown_irq)(struct msi_controller *chip, unsigned int irq); void (*teardown_irq)(struct msi_controller *chip, unsigned int irq);
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment