// SPDX-License-Identifier: GPL-2.0-or-later /* * Copyright 2006-2007, Michael Ellerman, IBM Corporation. */ #include <linux/kernel.h> #include <linux/msi.h> #include <linux/pci.h> #include <asm/machdep.h> int arch_setup_msi_irqs(struct pci_dev *dev, int nvec, int type) { struct pci_controller *phb = pci_bus_to_host(dev->bus); if (!phb->controller_ops.setup_msi_irqs || !phb->controller_ops.teardown_msi_irqs) { pr_debug("msi: Platform doesn't provide MSI callbacks.\n"); return -ENOSYS; } /* PowerPC doesn't support multiple MSI yet */ if (type == PCI_CAP_ID_MSI && nvec > 1) return 1; return phb->controller_ops.setup_msi_irqs(dev, nvec, type); } void arch_teardown_msi_irqs(struct pci_dev *dev) { struct pci_controller *phb = pci_bus_to_host(dev->bus); /* * We can be called even when arch_setup_msi_irqs() returns -ENOSYS, * so check the pointer again. */ if (phb->controller_ops.teardown_msi_irqs) phb->controller_ops.teardown_msi_irqs(dev); }