Merge remote-tracking branches 'regulator/topic/isl9305', 'regulator/topic/lp872x...
[deliverable/linux.git] / include / linux / of_iommu.h
CommitLineData
4e0ee78f
HD
1#ifndef __OF_IOMMU_H
2#define __OF_IOMMU_H
3
7eba1d51 4#include <linux/device.h>
1cd076bf
WD
5#include <linux/iommu.h>
6#include <linux/of.h>
7
4e0ee78f
HD
8#ifdef CONFIG_OF_IOMMU
9
10extern int of_get_dma_window(struct device_node *dn, const char *prefix,
11 int index, unsigned long *busno, dma_addr_t *addr,
12 size_t *size);
13
1cd076bf 14extern void of_iommu_init(void);
7eba1d51 15extern struct iommu_ops *of_iommu_configure(struct device *dev);
1cd076bf 16
4e0ee78f
HD
17#else
18
19static inline int of_get_dma_window(struct device_node *dn, const char *prefix,
20 int index, unsigned long *busno, dma_addr_t *addr,
21 size_t *size)
22{
23 return -EINVAL;
24}
25
1cd076bf 26static inline void of_iommu_init(void) { }
7eba1d51
WD
27static inline struct iommu_ops *of_iommu_configure(struct device *dev)
28{
29 return NULL;
30}
1cd076bf 31
4e0ee78f
HD
32#endif /* CONFIG_OF_IOMMU */
33
a42a7a1f
RM
34void of_iommu_set_ops(struct device_node *np, struct iommu_ops *ops);
35struct iommu_ops *of_iommu_get_ops(struct device_node *np);
1cd076bf
WD
36
37extern struct of_device_id __iommu_of_table;
38
39typedef int (*of_iommu_init_fn)(struct device_node *);
40
41#define IOMMU_OF_DECLARE(name, compat, fn) \
42 _OF_DECLARE(iommu, name, compat, fn, of_iommu_init_fn)
43
4e0ee78f 44#endif /* __OF_IOMMU_H */
This page took 0.251866 seconds and 5 git commands to generate.