Prepare v2023.10
[platform/kernel/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 <common.h>
8 #include <dm.h>
9 #include <dm/of_access.h>
10 #include <mapmem.h>
11 #include <asm/global_data.h>
12 #include <asm/types.h>
13 #include <asm/io.h>
14 #include <linux/ioport.h>
15
16 int dev_read_u8(const struct udevice *dev, const char *propname, u8 *outp)
17 {
18         return ofnode_read_u8(dev_ofnode(dev), propname, outp);
19 }
20
21 u8 dev_read_u8_default(const struct udevice *dev, const char *propname, u8 def)
22 {
23         return ofnode_read_u8_default(dev_ofnode(dev), propname, def);
24 }
25
26 int dev_read_u16(const struct udevice *dev, const char *propname, u16 *outp)
27 {
28         return ofnode_read_u16(dev_ofnode(dev), propname, outp);
29 }
30
31 u16 dev_read_u16_default(const struct udevice *dev, const char *propname,
32                          u16 def)
33 {
34         return ofnode_read_u16_default(dev_ofnode(dev), propname, def);
35 }
36
37 int dev_read_u32(const struct udevice *dev, const char *propname, u32 *outp)
38 {
39         return ofnode_read_u32(dev_ofnode(dev), propname, outp);
40 }
41
42 int dev_read_u32_default(const struct udevice *dev, const char *propname,
43                          int def)
44 {
45         return ofnode_read_u32_default(dev_ofnode(dev), propname, def);
46 }
47
48 int dev_read_u32_index(struct udevice *dev, const char *propname, int index,
49                        u32 *outp)
50 {
51         return ofnode_read_u32_index(dev_ofnode(dev), propname, index, outp);
52 }
53
54 u32 dev_read_u32_index_default(struct udevice *dev, const char *propname,
55                                int index, u32 def)
56 {
57         return ofnode_read_u32_index_default(dev_ofnode(dev), propname, index,
58                                              def);
59 }
60
61 int dev_read_s32(const struct udevice *dev, const char *propname, s32 *outp)
62 {
63         return ofnode_read_u32(dev_ofnode(dev), propname, (u32 *)outp);
64 }
65
66 int dev_read_s32_default(const struct udevice *dev, const char *propname,
67                          int def)
68 {
69         return ofnode_read_u32_default(dev_ofnode(dev), propname, def);
70 }
71
72 int dev_read_u32u(const struct udevice *dev, const char *propname, uint *outp)
73 {
74         u32 val;
75         int ret;
76
77         ret = ofnode_read_u32(dev_ofnode(dev), propname, &val);
78         if (ret)
79                 return ret;
80         *outp = val;
81
82         return 0;
83 }
84
85 int dev_read_u64(const struct udevice *dev, const char *propname, u64 *outp)
86 {
87         return ofnode_read_u64(dev_ofnode(dev), propname, outp);
88 }
89
90 u64 dev_read_u64_default(const struct udevice *dev, const char *propname,
91                          u64 def)
92 {
93         return ofnode_read_u64_default(dev_ofnode(dev), propname, def);
94 }
95
96 const char *dev_read_string(const struct udevice *dev, const char *propname)
97 {
98         return ofnode_read_string(dev_ofnode(dev), propname);
99 }
100
101 bool dev_read_bool(const struct udevice *dev, const char *propname)
102 {
103         return ofnode_read_bool(dev_ofnode(dev), propname);
104 }
105
106 ofnode dev_read_subnode(const struct udevice *dev, const char *subnode_name)
107 {
108         return ofnode_find_subnode(dev_ofnode(dev), subnode_name);
109 }
110
111 ofnode dev_read_first_subnode(const struct udevice *dev)
112 {
113         return ofnode_first_subnode(dev_ofnode(dev));
114 }
115
116 ofnode dev_read_next_subnode(ofnode node)
117 {
118         return ofnode_next_subnode(node);
119 }
120
121 int dev_read_size(const struct udevice *dev, const char *propname)
122 {
123         return ofnode_read_size(dev_ofnode(dev), propname);
124 }
125
126 fdt_addr_t dev_read_addr_index(const struct udevice *dev, int index)
127 {
128         if (ofnode_is_np(dev_ofnode(dev)))
129                 return ofnode_get_addr_index(dev_ofnode(dev), index);
130         else
131                 return devfdt_get_addr_index(dev, index);
132 }
133
134 void *dev_read_addr_index_ptr(const struct udevice *dev, int index)
135 {
136         fdt_addr_t addr = dev_read_addr_index(dev, index);
137
138         if (addr == FDT_ADDR_T_NONE)
139                 return NULL;
140
141         return map_sysmem(addr, 0);
142 }
143
144 fdt_addr_t dev_read_addr_size_index(const struct udevice *dev, int index,
145                                     fdt_size_t *size)
146 {
147         if (ofnode_is_np(dev_ofnode(dev)))
148                 return ofnode_get_addr_size_index(dev_ofnode(dev), index, size);
149         else
150                 return devfdt_get_addr_size_index(dev, index, size);
151 }
152
153 void *dev_read_addr_size_index_ptr(const struct udevice *dev, int index,
154                                    fdt_size_t *size)
155 {
156         fdt_addr_t addr = dev_read_addr_size_index(dev, index, size);
157
158         if (addr == FDT_ADDR_T_NONE)
159                 return NULL;
160
161         return map_sysmem(addr, 0);
162 }
163
164 void *dev_remap_addr_index(const struct udevice *dev, int index)
165 {
166         fdt_addr_t addr = dev_read_addr_index(dev, index);
167
168         if (addr == FDT_ADDR_T_NONE)
169                 return NULL;
170
171         return map_physmem(addr, 0, MAP_NOCACHE);
172 }
173
174 fdt_addr_t dev_read_addr_name(const struct udevice *dev, const char *name)
175 {
176         int index = dev_read_stringlist_search(dev, "reg-names", name);
177
178         if (index < 0)
179                 return FDT_ADDR_T_NONE;
180         else
181                 return dev_read_addr_index(dev, index);
182 }
183
184 fdt_addr_t dev_read_addr_size_name(const struct udevice *dev, const char *name,
185                                    fdt_size_t *size)
186 {
187         int index = dev_read_stringlist_search(dev, "reg-names", name);
188
189         if (index < 0)
190                 return FDT_ADDR_T_NONE;
191         else
192                 return dev_read_addr_size_index(dev, index, size);
193 }
194
195 void *dev_remap_addr_name(const struct udevice *dev, const char *name)
196 {
197         fdt_addr_t addr = dev_read_addr_name(dev, name);
198
199         if (addr == FDT_ADDR_T_NONE)
200                 return NULL;
201
202         return map_physmem(addr, 0, MAP_NOCACHE);
203 }
204
205 fdt_addr_t dev_read_addr(const struct udevice *dev)
206 {
207         return dev_read_addr_index(dev, 0);
208 }
209
210 void *dev_read_addr_ptr(const struct udevice *dev)
211 {
212         fdt_addr_t addr = dev_read_addr(dev);
213
214         if (addr == FDT_ADDR_T_NONE)
215                 return NULL;
216
217         return map_sysmem(addr, 0);
218 }
219
220 void *dev_remap_addr(const struct udevice *dev)
221 {
222         return dev_remap_addr_index(dev, 0);
223 }
224
225 fdt_addr_t dev_read_addr_size(const struct udevice *dev, fdt_size_t *sizep)
226 {
227         return dev_read_addr_size_index(dev, 0, sizep);
228 }
229
230 const char *dev_read_name(const struct udevice *dev)
231 {
232         return ofnode_get_name(dev_ofnode(dev));
233 }
234
235 int dev_read_stringlist_search(const struct udevice *dev, const char *property,
236                                const char *string)
237 {
238         return ofnode_stringlist_search(dev_ofnode(dev), property, string);
239 }
240
241 int dev_read_string_index(const struct udevice *dev, const char *propname,
242                           int index, const char **outp)
243 {
244         return ofnode_read_string_index(dev_ofnode(dev), propname, index, outp);
245 }
246
247 int dev_read_string_count(const struct udevice *dev, const char *propname)
248 {
249         return ofnode_read_string_count(dev_ofnode(dev), propname);
250 }
251
252 int dev_read_string_list(const struct udevice *dev, const char *propname,
253                          const char ***listp)
254 {
255         return ofnode_read_string_list(dev_ofnode(dev), propname, listp);
256 }
257
258 int dev_read_phandle_with_args(const struct udevice *dev, const char *list_name,
259                                const char *cells_name, int cell_count,
260                                int index, struct ofnode_phandle_args *out_args)
261 {
262         return ofnode_parse_phandle_with_args(dev_ofnode(dev), list_name,
263                                               cells_name, cell_count, index,
264                                               out_args);
265 }
266
267 int dev_count_phandle_with_args(const struct udevice *dev,
268                                 const char *list_name, const char *cells_name,
269                                 int cell_count)
270 {
271         return ofnode_count_phandle_with_args(dev_ofnode(dev), list_name,
272                                               cells_name, cell_count);
273 }
274
275 int dev_read_addr_cells(const struct udevice *dev)
276 {
277         return ofnode_read_addr_cells(dev_ofnode(dev));
278 }
279
280 int dev_read_size_cells(const struct udevice *dev)
281 {
282         return ofnode_read_size_cells(dev_ofnode(dev));
283 }
284
285 int dev_read_simple_addr_cells(const struct udevice *dev)
286 {
287         return ofnode_read_simple_addr_cells(dev_ofnode(dev));
288 }
289
290 int dev_read_simple_size_cells(const struct udevice *dev)
291 {
292         return ofnode_read_simple_size_cells(dev_ofnode(dev));
293 }
294
295 int dev_read_phandle(const struct udevice *dev)
296 {
297         ofnode node = dev_ofnode(dev);
298
299         if (ofnode_is_np(node))
300                 return ofnode_to_np(node)->phandle;
301         else
302                 return fdt_get_phandle(gd->fdt_blob, ofnode_to_offset(node));
303 }
304
305 const void *dev_read_prop(const struct udevice *dev, const char *propname,
306                           int *lenp)
307 {
308         return ofnode_get_property(dev_ofnode(dev), propname, lenp);
309 }
310
311 int dev_read_first_prop(const struct udevice *dev, struct ofprop *prop)
312 {
313         return ofnode_first_property(dev_ofnode(dev), prop);
314 }
315
316 int dev_read_next_prop(struct ofprop *prop)
317 {
318         return ofnode_next_property(prop);
319 }
320
321 const void *dev_read_prop_by_prop(struct ofprop *prop,
322                                   const char **propname, int *lenp)
323 {
324         return ofprop_get_property(prop, propname, lenp);
325 }
326
327 int dev_read_alias_seq(const struct udevice *dev, int *devnump)
328 {
329         ofnode node = dev_ofnode(dev);
330         const char *uc_name = dev->uclass->uc_drv->name;
331         int ret = -ENOTSUPP;
332
333         if (ofnode_is_np(node)) {
334                 ret = of_alias_get_id(ofnode_to_np(node), uc_name);
335                 if (ret >= 0) {
336                         *devnump = ret;
337                         ret = 0;
338                 }
339         } else {
340 #if CONFIG_IS_ENABLED(OF_CONTROL)
341                 ret = fdtdec_get_alias_seq(gd->fdt_blob, uc_name,
342                                            ofnode_to_offset(node), devnump);
343 #endif
344         }
345
346         return ret;
347 }
348
349 int dev_read_u32_array(const struct udevice *dev, const char *propname,
350                        u32 *out_values, size_t sz)
351 {
352         return ofnode_read_u32_array(dev_ofnode(dev), propname, out_values, sz);
353 }
354
355 const uint8_t *dev_read_u8_array_ptr(const struct udevice *dev,
356                                      const char *propname, size_t sz)
357 {
358         return ofnode_read_u8_array_ptr(dev_ofnode(dev), propname, sz);
359 }
360
361 int dev_read_enabled(const struct udevice *dev)
362 {
363         ofnode node = dev_ofnode(dev);
364
365         if (ofnode_is_np(node))
366                 return of_device_is_available(ofnode_to_np(node));
367         else
368                 return fdtdec_get_is_enabled(gd->fdt_blob,
369                                              ofnode_to_offset(node));
370 }
371
372 int dev_read_resource(const struct udevice *dev, uint index,
373                       struct resource *res)
374 {
375         return ofnode_read_resource(dev_ofnode(dev), index, res);
376 }
377
378 int dev_read_resource_byname(const struct udevice *dev, const char *name,
379                              struct resource *res)
380 {
381         return ofnode_read_resource_byname(dev_ofnode(dev), name, res);
382 }
383
384 u64 dev_translate_address(const struct udevice *dev, const fdt32_t *in_addr)
385 {
386         return ofnode_translate_address(dev_ofnode(dev), in_addr);
387 }
388
389 u64 dev_translate_dma_address(const struct udevice *dev, const fdt32_t *in_addr)
390 {
391         return ofnode_translate_dma_address(dev_ofnode(dev), in_addr);
392 }
393
394 int dev_get_dma_range(const struct udevice *dev, phys_addr_t *cpu,
395                       dma_addr_t *bus, u64 *size)
396 {
397         return ofnode_get_dma_range(dev_ofnode(dev), cpu, bus, size);
398 }
399
400 int dev_read_alias_highest_id(const char *stem)
401 {
402         if (of_live_active())
403                 return of_alias_get_highest_id(stem);
404
405         return fdtdec_get_alias_highest_id(gd->fdt_blob, stem);
406 }
407
408 fdt_addr_t dev_read_addr_pci(const struct udevice *dev)
409 {
410         ulong addr;
411
412         addr = dev_read_addr(dev);
413         if (addr == FDT_ADDR_T_NONE && !of_live_active())
414                 addr = devfdt_get_addr_pci(dev);
415
416         return addr;
417 }
418
419 int dev_get_child_count(const struct udevice *dev)
420 {
421         return ofnode_get_child_count(dev_ofnode(dev));
422 }
423
424 int dev_read_pci_bus_range(const struct udevice *dev,
425                            struct resource *res)
426 {
427         const u32 *values;
428         int len;
429
430         values = dev_read_prop(dev, "bus-range", &len);
431         if (!values || len < sizeof(*values) * 2)
432                 return -EINVAL;
433
434         res->start = *values++;
435         res->end = *values;
436
437         return 0;
438 }
439
440 int dev_decode_display_timing(const struct udevice *dev, int index,
441                               struct display_timing *config)
442 {
443         return ofnode_decode_display_timing(dev_ofnode(dev), index, config);
444 }
445
446 int dev_decode_panel_timing(const struct udevice *dev,
447                             struct display_timing *config)
448 {
449         return ofnode_decode_panel_timing(dev_ofnode(dev), config);
450 }
451
452 ofnode dev_get_phy_node(const struct udevice *dev)
453 {
454         return ofnode_get_phy_node(dev_ofnode(dev));
455 }
456
457 phy_interface_t dev_read_phy_mode(const struct udevice *dev)
458 {
459         return ofnode_read_phy_mode(dev_ofnode(dev));
460 }