2011-01-24 09:58:55 +05:30
|
|
|
#ifndef __OF_PCI_H
|
|
|
|
#define __OF_PCI_H
|
|
|
|
|
|
|
|
#include <linux/pci.h>
|
2013-08-09 22:27:09 +02:00
|
|
|
#include <linux/msi.h>
|
2011-01-24 09:58:55 +05:30
|
|
|
|
|
|
|
struct pci_dev;
|
2013-09-15 16:39:11 +01:00
|
|
|
struct of_phandle_args;
|
2011-04-11 11:37:07 +10:00
|
|
|
struct device_node;
|
2014-06-04 04:40:19 -05:00
|
|
|
|
2016-06-07 18:44:48 +01:00
|
|
|
#ifdef CONFIG_OF_PCI
|
2014-06-04 04:40:19 -05:00
|
|
|
int of_irq_parse_pci(const struct pci_dev *pdev, struct of_phandle_args *out_irq);
|
2011-04-11 11:37:07 +10:00
|
|
|
struct device_node *of_pci_find_child_device(struct device_node *parent,
|
|
|
|
unsigned int devfn);
|
2013-05-16 17:55:18 +02:00
|
|
|
int of_pci_get_devfn(struct device_node *np);
|
2014-06-04 04:40:19 -05:00
|
|
|
int of_irq_parse_and_map_pci(const struct pci_dev *dev, u8 slot, u8 pin);
|
2013-05-16 17:55:19 +02:00
|
|
|
int of_pci_parse_bus_range(struct device_node *node, struct resource *res);
|
2014-09-29 15:29:27 +01:00
|
|
|
int of_get_pci_domain_nr(struct device_node *node);
|
2015-09-04 17:50:08 +01:00
|
|
|
void of_pci_check_probe_only(void);
|
2014-06-04 04:40:19 -05:00
|
|
|
#else
|
|
|
|
static inline int of_irq_parse_pci(const struct pci_dev *pdev, struct of_phandle_args *out_irq)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct device_node *of_pci_find_child_device(struct device_node *parent,
|
|
|
|
unsigned int devfn)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int of_pci_get_devfn(struct device_node *np)
|
|
|
|
{
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int
|
|
|
|
of_irq_parse_and_map_pci(const struct pci_dev *dev, u8 slot, u8 pin)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int
|
|
|
|
of_pci_parse_bus_range(struct device_node *node, struct resource *res)
|
|
|
|
{
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
2014-09-29 15:29:27 +01:00
|
|
|
|
|
|
|
static inline int
|
|
|
|
of_get_pci_domain_nr(struct device_node *node)
|
|
|
|
{
|
|
|
|
return -1;
|
|
|
|
}
|
2015-03-03 12:52:12 -05:00
|
|
|
|
2015-09-04 17:50:08 +01:00
|
|
|
static inline void of_pci_check_probe_only(void) { }
|
2014-06-04 04:40:19 -05:00
|
|
|
#endif
|
2011-04-11 11:37:07 +10:00
|
|
|
|
2014-09-29 15:29:28 +01:00
|
|
|
#if defined(CONFIG_OF_ADDRESS)
|
|
|
|
int of_pci_get_host_bridge_resources(struct device_node *dev,
|
|
|
|
unsigned char busno, unsigned char bus_max,
|
|
|
|
struct list_head *resources, resource_size_t *io_base);
|
2015-12-18 16:02:41 +01:00
|
|
|
#else
|
|
|
|
static inline int of_pci_get_host_bridge_resources(struct device_node *dev,
|
|
|
|
unsigned char busno, unsigned char bus_max,
|
|
|
|
struct list_head *resources, resource_size_t *io_base)
|
|
|
|
{
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
2014-09-29 15:29:28 +01:00
|
|
|
#endif
|
|
|
|
|
2013-08-09 22:27:09 +02:00
|
|
|
#if defined(CONFIG_OF) && defined(CONFIG_PCI_MSI)
|
2014-11-11 17:45:45 -07:00
|
|
|
int of_pci_msi_chip_add(struct msi_controller *chip);
|
|
|
|
void of_pci_msi_chip_remove(struct msi_controller *chip);
|
|
|
|
struct msi_controller *of_pci_find_msi_chip_by_node(struct device_node *of_node);
|
2013-08-09 22:27:09 +02:00
|
|
|
#else
|
2014-11-11 17:45:45 -07:00
|
|
|
static inline int of_pci_msi_chip_add(struct msi_controller *chip) { return -EINVAL; }
|
|
|
|
static inline void of_pci_msi_chip_remove(struct msi_controller *chip) { }
|
|
|
|
static inline struct msi_controller *
|
2013-08-09 22:27:09 +02:00
|
|
|
of_pci_find_msi_chip_by_node(struct device_node *of_node) { return NULL; }
|
|
|
|
#endif
|
|
|
|
|
2011-01-24 09:58:55 +05:30
|
|
|
#endif
|