Merge tag 'u-boot-amlogic-20181207' of git://git.denx.de/u-boot-amlogic
[oweals/u-boot.git] / drivers / core / read.c
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * Copyright (c) 2017 Google, Inc
4  * Written by Simon Glass <sjg@chromium.org>
5  */
6
7 #include <asm/types.h>
8 #include <asm/io.h>
9 #include <common.h>
10 #include <dm.h>
11 #include <mapmem.h>
12 #include <dm/of_access.h>
13
14 int dev_read_u32(struct udevice *dev, const char *propname, u32 *outp)
15 {
16         return ofnode_read_u32(dev_ofnode(dev), propname, outp);
17 }
18
19 int dev_read_u32_default(struct udevice *dev, const char *propname, int def)
20 {
21         return ofnode_read_u32_default(dev_ofnode(dev), propname, def);
22 }
23
24 const char *dev_read_string(struct udevice *dev, const char *propname)
25 {
26         return ofnode_read_string(dev_ofnode(dev), propname);
27 }
28
29 bool dev_read_bool(struct udevice *dev, const char *propname)
30 {
31         return ofnode_read_bool(dev_ofnode(dev), propname);
32 }
33
34 ofnode dev_read_subnode(struct udevice *dev, const char *subnode_name)
35 {
36         return ofnode_find_subnode(dev_ofnode(dev), subnode_name);
37 }
38
39 ofnode dev_read_first_subnode(struct udevice *dev)
40 {
41         return ofnode_first_subnode(dev_ofnode(dev));
42 }
43
44 ofnode dev_read_next_subnode(ofnode node)
45 {
46         return ofnode_next_subnode(node);
47 }
48
49 int dev_read_size(struct udevice *dev, const char *propname)
50 {
51         return ofnode_read_size(dev_ofnode(dev), propname);
52 }
53
54 fdt_addr_t dev_read_addr_index(struct udevice *dev, int index)
55 {
56         if (ofnode_is_np(dev_ofnode(dev)))
57                 return ofnode_get_addr_index(dev_ofnode(dev), index);
58         else
59                 return devfdt_get_addr_index(dev, index);
60 }
61
62 void *dev_remap_addr_index(struct udevice *dev, int index)
63 {
64         fdt_addr_t addr = dev_read_addr_index(dev, index);
65
66         if (addr == FDT_ADDR_T_NONE)
67                 return NULL;
68
69         return map_physmem(addr, 0, MAP_NOCACHE);
70 }
71
72 fdt_addr_t dev_read_addr_name(struct udevice *dev, const char *name)
73 {
74         int index = dev_read_stringlist_search(dev, "reg-names", name);
75
76         if (index < 0)
77                 return FDT_ADDR_T_NONE;
78         else
79                 return dev_read_addr_index(dev, index);
80 }
81
82 void *dev_remap_addr_name(struct udevice *dev, const char *name)
83 {
84         fdt_addr_t addr = dev_read_addr_name(dev, name);
85
86         if (addr == FDT_ADDR_T_NONE)
87                 return NULL;
88
89         return map_physmem(addr, 0, MAP_NOCACHE);
90 }
91
92 fdt_addr_t dev_read_addr(struct udevice *dev)
93 {
94         return dev_read_addr_index(dev, 0);
95 }
96
97 void *dev_read_addr_ptr(struct udevice *dev)
98 {
99         fdt_addr_t addr = dev_read_addr(dev);
100
101         return (addr == FDT_ADDR_T_NONE) ? NULL : map_sysmem(addr, 0);
102 }
103
104 void *dev_remap_addr(struct udevice *dev)
105 {
106         return dev_remap_addr_index(dev, 0);
107 }
108
109 fdt_addr_t dev_read_addr_size(struct udevice *dev, const char *property,
110                               fdt_size_t *sizep)
111 {
112         return ofnode_get_addr_size(dev_ofnode(dev), property, sizep);
113 }
114
115 const char *dev_read_name(struct udevice *dev)
116 {
117         return ofnode_get_name(dev_ofnode(dev));
118 }
119
120 int dev_read_stringlist_search(struct udevice *dev, const char *property,
121                                const char *string)
122 {
123         return ofnode_stringlist_search(dev_ofnode(dev), property, string);
124 }
125
126 int dev_read_string_index(struct udevice *dev, const char *propname, int index,
127                           const char **outp)
128 {
129         return ofnode_read_string_index(dev_ofnode(dev), propname, index, outp);
130 }
131
132 int dev_read_string_count(struct udevice *dev, const char *propname)
133 {
134         return ofnode_read_string_count(dev_ofnode(dev), propname);
135 }
136
137 int dev_read_phandle_with_args(struct udevice *dev, const char *list_name,
138                                const char *cells_name, int cell_count,
139                                int index, struct ofnode_phandle_args *out_args)
140 {
141         return ofnode_parse_phandle_with_args(dev_ofnode(dev), list_name,
142                                               cells_name, cell_count, index,
143                                               out_args);
144 }
145
146 int dev_count_phandle_with_args(struct udevice *dev, const char *list_name,
147                                 const char *cells_name)
148 {
149         return ofnode_count_phandle_with_args(dev_ofnode(dev), list_name,
150                                               cells_name);
151 }
152
153 int dev_read_addr_cells(struct udevice *dev)
154 {
155         return ofnode_read_addr_cells(dev_ofnode(dev));
156 }
157
158 int dev_read_size_cells(struct udevice *dev)
159 {
160         return ofnode_read_size_cells(dev_ofnode(dev));
161 }
162
163 int dev_read_simple_addr_cells(struct udevice *dev)
164 {
165         return ofnode_read_simple_addr_cells(dev_ofnode(dev));
166 }
167
168 int dev_read_simple_size_cells(struct udevice *dev)
169 {
170         return ofnode_read_simple_size_cells(dev_ofnode(dev));
171 }
172
173 int dev_read_phandle(struct udevice *dev)
174 {
175         ofnode node = dev_ofnode(dev);
176
177         if (ofnode_is_np(node))
178                 return ofnode_to_np(node)->phandle;
179         else
180                 return fdt_get_phandle(gd->fdt_blob, ofnode_to_offset(node));
181 }
182
183 const void *dev_read_prop(struct udevice *dev, const char *propname, int *lenp)
184 {
185         return ofnode_get_property(dev_ofnode(dev), propname, lenp);
186 }
187
188 int dev_read_alias_seq(struct udevice *dev, int *devnump)
189 {
190         ofnode node = dev_ofnode(dev);
191         const char *uc_name = dev->uclass->uc_drv->name;
192         int ret;
193
194         if (ofnode_is_np(node)) {
195                 ret = of_alias_get_id(ofnode_to_np(node), uc_name);
196                 if (ret >= 0)
197                         *devnump = ret;
198         } else {
199                 ret = fdtdec_get_alias_seq(gd->fdt_blob, uc_name,
200                                            ofnode_to_offset(node), devnump);
201         }
202
203         return ret;
204 }
205
206 int dev_read_u32_array(struct udevice *dev, const char *propname,
207                        u32 *out_values, size_t sz)
208 {
209         return ofnode_read_u32_array(dev_ofnode(dev), propname, out_values, sz);
210 }
211
212 const uint8_t *dev_read_u8_array_ptr(struct udevice *dev, const char *propname,
213                                      size_t sz)
214 {
215         return ofnode_read_u8_array_ptr(dev_ofnode(dev), propname, sz);
216 }
217
218 int dev_read_enabled(struct udevice *dev)
219 {
220         ofnode node = dev_ofnode(dev);
221
222         if (ofnode_is_np(node))
223                 return of_device_is_available(ofnode_to_np(node));
224         else
225                 return fdtdec_get_is_enabled(gd->fdt_blob,
226                                              ofnode_to_offset(node));
227 }
228
229 int dev_read_resource(struct udevice *dev, uint index, struct resource *res)
230 {
231         return ofnode_read_resource(dev_ofnode(dev), index, res);
232 }
233
234 int dev_read_resource_byname(struct udevice *dev, const char *name,
235                              struct resource *res)
236 {
237         return ofnode_read_resource_byname(dev_ofnode(dev), name, res);
238 }
239
240 u64 dev_translate_address(struct udevice *dev, const fdt32_t *in_addr)
241 {
242         return ofnode_translate_address(dev_ofnode(dev), in_addr);
243 }