]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blame - include/linux/of_address.h
Merge branches 'for-4.4/upstream-fixes', 'for-4.5/async-suspend', 'for-4.5/container...
[mirror_ubuntu-artful-kernel.git] / include / linux / of_address.h
CommitLineData
6b884a8d
GL
1#ifndef __OF_ADDRESS_H
2#define __OF_ADDRESS_H
3#include <linux/ioport.h>
99ce39e3 4#include <linux/errno.h>
6b884a8d
GL
5#include <linux/of.h>
6
29b635c0
AM
7struct of_pci_range_parser {
8 struct device_node *node;
9 const __be32 *range;
10 const __be32 *end;
11 int np;
12 int pna;
13};
14
15struct of_pci_range {
16 u32 pci_space;
17 u64 pci_addr;
18 u64 cpu_addr;
19 u64 size;
20 u32 flags;
21};
22
23#define for_each_of_pci_range(parser, range) \
24 for (; of_pci_range_parser_one(parser, range);)
25
d0dfa16a
RH
26/* Translate a DMA address from device space to CPU space */
27extern u64 of_translate_dma_address(struct device_node *dev,
28 const __be32 *in_addr);
29
a850a755 30#ifdef CONFIG_OF_ADDRESS
0131d897 31extern u64 of_translate_address(struct device_node *np, const __be32 *addr);
1f5bef30
GL
32extern int of_address_to_resource(struct device_node *dev, int index,
33 struct resource *r);
90e33f62
GL
34extern struct device_node *of_find_matching_node_by_address(
35 struct device_node *from,
36 const struct of_device_id *matches,
37 u64 base_address);
6b884a8d
GL
38extern void __iomem *of_iomap(struct device_node *device, int index);
39
22ae782f
GL
40/* Extract an address from a device, returns the region size and
41 * the address space flags too. The PCI version uses a BAR number
42 * instead of an absolute index
43 */
47b1e689 44extern const __be32 *of_get_address(struct device_node *dev, int index,
22ae782f
GL
45 u64 *size, unsigned int *flags);
46
41f8bba7 47extern int pci_register_io_range(phys_addr_t addr, resource_size_t size);
25ff7944 48extern unsigned long pci_address_to_pio(phys_addr_t addr);
41f8bba7 49extern phys_addr_t pci_pio_to_address(unsigned long pio);
22ae782f 50
29b635c0
AM
51extern int of_pci_range_parser_init(struct of_pci_range_parser *parser,
52 struct device_node *node);
53extern struct of_pci_range *of_pci_range_parser_one(
54 struct of_pci_range_parser *parser,
55 struct of_pci_range *range);
18308c94
GS
56extern int of_dma_get_range(struct device_node *np, u64 *dma_addr,
57 u64 *paddr, u64 *size);
92ea637e 58extern bool of_dma_is_coherent(struct device_node *np);
a850a755 59#else /* CONFIG_OF_ADDRESS */
b1d06b60
GR
60
61static inline u64 of_translate_address(struct device_node *np,
62 const __be32 *addr)
63{
64 return OF_BAD_ADDR;
65}
66
a850a755
GL
67static inline struct device_node *of_find_matching_node_by_address(
68 struct device_node *from,
69 const struct of_device_id *matches,
70 u64 base_address)
71{
72 return NULL;
73}
4acf4b9c 74
47b1e689 75static inline const __be32 *of_get_address(struct device_node *dev, int index,
a850a755
GL
76 u64 *size, unsigned int *flags)
77{
78 return NULL;
79}
29b635c0 80
41f8bba7
LD
81static inline phys_addr_t pci_pio_to_address(unsigned long pio)
82{
83 return 0;
84}
85
29b635c0
AM
86static inline int of_pci_range_parser_init(struct of_pci_range_parser *parser,
87 struct device_node *node)
88{
89 return -1;
90}
91
92static inline struct of_pci_range *of_pci_range_parser_one(
93 struct of_pci_range_parser *parser,
94 struct of_pci_range *range)
95{
96 return NULL;
97}
18308c94
GS
98
99static inline int of_dma_get_range(struct device_node *np, u64 *dma_addr,
100 u64 *paddr, u64 *size)
101{
102 return -ENODEV;
103}
92ea637e
SS
104
105static inline bool of_dma_is_coherent(struct device_node *np)
106{
107 return false;
108}
a850a755
GL
109#endif /* CONFIG_OF_ADDRESS */
110
4acf4b9c
RH
111#ifdef CONFIG_OF
112extern int of_address_to_resource(struct device_node *dev, int index,
113 struct resource *r);
114void __iomem *of_iomap(struct device_node *node, int index);
efd342fb 115void __iomem *of_io_request_and_map(struct device_node *device,
b75b276b 116 int index, const char *name);
4acf4b9c 117#else
efd342fb
MB
118
119#include <linux/io.h>
120
4acf4b9c
RH
121static inline int of_address_to_resource(struct device_node *dev, int index,
122 struct resource *r)
123{
124 return -EINVAL;
125}
126
127static inline void __iomem *of_iomap(struct device_node *device, int index)
128{
129 return NULL;
130}
efd342fb
MB
131
132static inline void __iomem *of_io_request_and_map(struct device_node *device,
b75b276b 133 int index, const char *name)
efd342fb
MB
134{
135 return IOMEM_ERR_PTR(-EINVAL);
136}
4acf4b9c 137#endif
a850a755
GL
138
139#if defined(CONFIG_OF_ADDRESS) && defined(CONFIG_PCI)
0131d897 140extern const __be32 *of_get_pci_address(struct device_node *dev, int bar_no,
22ae782f
GL
141 u64 *size, unsigned int *flags);
142extern int of_pci_address_to_resource(struct device_node *dev, int bar,
143 struct resource *r);
0b0b0893
LD
144extern int of_pci_range_to_resource(struct of_pci_range *range,
145 struct device_node *np,
146 struct resource *res);
a850a755 147#else /* CONFIG_OF_ADDRESS && CONFIG_PCI */
22ae782f
GL
148static inline int of_pci_address_to_resource(struct device_node *dev, int bar,
149 struct resource *r)
150{
151 return -ENOSYS;
152}
153
0131d897 154static inline const __be32 *of_get_pci_address(struct device_node *dev,
22ae782f
GL
155 int bar_no, u64 *size, unsigned int *flags)
156{
157 return NULL;
158}
0b0b0893
LD
159static inline int of_pci_range_to_resource(struct of_pci_range *range,
160 struct device_node *np,
161 struct resource *res)
83bbde1c
LD
162{
163 return -ENOSYS;
164}
a850a755 165#endif /* CONFIG_OF_ADDRESS && CONFIG_PCI */
22ae782f 166
6b884a8d
GL
167#endif /* __OF_ADDRESS_H */
168