diff options
author | Daniel Axtens <dja@axtens.net> | 2015-04-14 00:27:54 -0400 |
---|---|---|
committer | Michael Ellerman <mpe@ellerman.id.au> | 2015-05-22 01:50:55 -0400 |
commit | e059b105d157d0231e2f0a7fba996724d856114b (patch) | |
tree | d6ea4686a1fafc9f7d11d9f0b93b1fcd7127b111 /arch/powerpc/kernel/msi.c | |
parent | 81f2f7ce4c5bb688ad691cb3ee37e81ca26a8a3b (diff) |
powerpc: Add MSI operations to pci_controller_ops struct
Add MSI setup and teardown functions to pci_controller_ops.
Patch the callsites (arch_{setup,teardown}_msi_irqs) to prefer the
controller ops version if it's available.
Signed-off-by: Daniel Axtens <dja@axtens.net>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Diffstat (limited to 'arch/powerpc/kernel/msi.c')
-rw-r--r-- | arch/powerpc/kernel/msi.c | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/arch/powerpc/kernel/msi.c b/arch/powerpc/kernel/msi.c index 71bd161640cf..3d452f71fa25 100644 --- a/arch/powerpc/kernel/msi.c +++ b/arch/powerpc/kernel/msi.c | |||
@@ -15,7 +15,11 @@ | |||
15 | 15 | ||
16 | int arch_setup_msi_irqs(struct pci_dev *dev, int nvec, int type) | 16 | int arch_setup_msi_irqs(struct pci_dev *dev, int nvec, int type) |
17 | { | 17 | { |
18 | if (!ppc_md.setup_msi_irqs || !ppc_md.teardown_msi_irqs) { | 18 | struct pci_controller *phb = pci_bus_to_host(dev->bus); |
19 | |||
20 | if ((!phb->controller_ops.setup_msi_irqs || | ||
21 | !phb->controller_ops.teardown_msi_irqs) && | ||
22 | (!ppc_md.setup_msi_irqs || !ppc_md.teardown_msi_irqs)) { | ||
19 | pr_debug("msi: Platform doesn't provide MSI callbacks.\n"); | 23 | pr_debug("msi: Platform doesn't provide MSI callbacks.\n"); |
20 | return -ENOSYS; | 24 | return -ENOSYS; |
21 | } | 25 | } |
@@ -24,10 +28,18 @@ int arch_setup_msi_irqs(struct pci_dev *dev, int nvec, int type) | |||
24 | if (type == PCI_CAP_ID_MSI && nvec > 1) | 28 | if (type == PCI_CAP_ID_MSI && nvec > 1) |
25 | return 1; | 29 | return 1; |
26 | 30 | ||
27 | return ppc_md.setup_msi_irqs(dev, nvec, type); | 31 | if (phb->controller_ops.setup_msi_irqs) |
32 | return phb->controller_ops.setup_msi_irqs(dev, nvec, type); | ||
33 | else | ||
34 | return ppc_md.setup_msi_irqs(dev, nvec, type); | ||
28 | } | 35 | } |
29 | 36 | ||
30 | void arch_teardown_msi_irqs(struct pci_dev *dev) | 37 | void arch_teardown_msi_irqs(struct pci_dev *dev) |
31 | { | 38 | { |
32 | ppc_md.teardown_msi_irqs(dev); | 39 | struct pci_controller *phb = pci_bus_to_host(dev->bus); |
40 | |||
41 | if (phb->controller_ops.teardown_msi_irqs) | ||
42 | phb->controller_ops.teardown_msi_irqs(dev); | ||
43 | else | ||
44 | ppc_md.teardown_msi_irqs(dev); | ||
33 | } | 45 | } |