mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-15 13:15:57 +00:00
0d5a6db3aa
This commit adds a very basic registry of msi_chip structures, so that an IRQ controller driver can register an msi_chip, and a PCIe host controller can find it, based on a 'struct device_node'. Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> Acked-by: Benjamin Herrenschmidt <benh@kernel.crashing.org> Acked-by: Rob Herring <rob.herring@calxeda.com> Signed-off-by: Jason Cooper <jason@lakedaemon.net>
29 lines
941 B
C
29 lines
941 B
C
#ifndef __OF_PCI_H
|
|
#define __OF_PCI_H
|
|
|
|
#include <linux/pci.h>
|
|
#include <linux/msi.h>
|
|
|
|
struct pci_dev;
|
|
struct of_irq;
|
|
int of_irq_map_pci(const struct pci_dev *pdev, struct of_irq *out_irq);
|
|
|
|
struct device_node;
|
|
struct device_node *of_pci_find_child_device(struct device_node *parent,
|
|
unsigned int devfn);
|
|
int of_pci_get_devfn(struct device_node *np);
|
|
int of_pci_parse_bus_range(struct device_node *node, struct resource *res);
|
|
|
|
#if defined(CONFIG_OF) && defined(CONFIG_PCI_MSI)
|
|
int of_pci_msi_chip_add(struct msi_chip *chip);
|
|
void of_pci_msi_chip_remove(struct msi_chip *chip);
|
|
struct msi_chip *of_pci_find_msi_chip_by_node(struct device_node *of_node);
|
|
#else
|
|
static inline int of_pci_msi_chip_add(struct msi_chip *chip) { return -EINVAL; }
|
|
static inline void of_pci_msi_chip_remove(struct msi_chip *chip) { }
|
|
static inline struct msi_chip *
|
|
of_pci_find_msi_chip_by_node(struct device_node *of_node) { return NULL; }
|
|
#endif
|
|
|
|
#endif
|