read.c 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. /*
  2. * Copyright (c) 2017 Google, Inc
  3. * Written by Simon Glass <sjg@chromium.org>
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #include <common.h>
  8. #include <dm.h>
  9. #include <dm/of_access.h>
  10. int dev_read_u32_default(struct udevice *dev, const char *propname, int def)
  11. {
  12. return ofnode_read_u32_default(dev_ofnode(dev), propname, def);
  13. }
  14. const char *dev_read_string(struct udevice *dev, const char *propname)
  15. {
  16. return ofnode_read_string(dev_ofnode(dev), propname);
  17. }
  18. bool dev_read_bool(struct udevice *dev, const char *propname)
  19. {
  20. return ofnode_read_bool(dev_ofnode(dev), propname);
  21. }
  22. ofnode dev_read_subnode(struct udevice *dev, const char *subnode_name)
  23. {
  24. return ofnode_find_subnode(dev_ofnode(dev), subnode_name);
  25. }
  26. ofnode dev_read_first_subnode(struct udevice *dev)
  27. {
  28. return ofnode_first_subnode(dev_ofnode(dev));
  29. }
  30. ofnode dev_read_next_subnode(ofnode node)
  31. {
  32. return ofnode_next_subnode(node);
  33. }
  34. int dev_read_size(struct udevice *dev, const char *propname)
  35. {
  36. return ofnode_read_size(dev_ofnode(dev), propname);
  37. }
  38. fdt_addr_t dev_read_addr_index(struct udevice *dev, int index)
  39. {
  40. if (ofnode_is_np(dev_ofnode(dev)))
  41. return ofnode_get_addr_index(dev_ofnode(dev), index);
  42. else
  43. return devfdt_get_addr_index(dev, index);
  44. }
  45. fdt_addr_t dev_read_addr(struct udevice *dev)
  46. {
  47. return dev_read_addr_index(dev, 0);
  48. }
  49. fdt_addr_t dev_read_addr_size(struct udevice *dev, const char *property,
  50. fdt_size_t *sizep)
  51. {
  52. return ofnode_get_addr_size(dev_ofnode(dev), property, sizep);
  53. }
  54. const char *dev_read_name(struct udevice *dev)
  55. {
  56. return ofnode_get_name(dev_ofnode(dev));
  57. }
  58. int dev_read_stringlist_search(struct udevice *dev, const char *property,
  59. const char *string)
  60. {
  61. return ofnode_stringlist_search(dev_ofnode(dev), property, string);
  62. }
  63. int dev_read_phandle_with_args(struct udevice *dev, const char *list_name,
  64. const char *cells_name, int cell_count,
  65. int index,
  66. struct ofnode_phandle_args *out_args)
  67. {
  68. return ofnode_parse_phandle_with_args(dev_ofnode(dev), list_name,
  69. cells_name, cell_count, index,
  70. out_args);
  71. }
  72. int dev_read_addr_cells(struct udevice *dev)
  73. {
  74. return ofnode_read_addr_cells(dev_ofnode(dev));
  75. }
  76. int dev_read_size_cells(struct udevice *dev)
  77. {
  78. return ofnode_read_size_cells(dev_ofnode(dev));
  79. }
  80. int dev_read_phandle(struct udevice *dev)
  81. {
  82. ofnode node = dev_ofnode(dev);
  83. if (ofnode_is_np(node))
  84. return ofnode_to_np(node)->phandle;
  85. else
  86. return fdt_get_phandle(gd->fdt_blob, ofnode_to_offset(node));
  87. }
  88. const u32 *dev_read_prop(struct udevice *dev, const char *propname, int *lenp)
  89. {
  90. return ofnode_read_prop(dev_ofnode(dev), propname, lenp);
  91. }
  92. int dev_read_alias_seq(struct udevice *dev, int *devnump)
  93. {
  94. ofnode node = dev_ofnode(dev);
  95. const char *uc_name = dev->uclass->uc_drv->name;
  96. int ret;
  97. if (ofnode_is_np(node)) {
  98. ret = of_alias_get_id(ofnode_to_np(node), uc_name);
  99. if (ret >= 0)
  100. *devnump = ret;
  101. } else {
  102. ret = fdtdec_get_alias_seq(gd->fdt_blob, uc_name,
  103. ofnode_to_offset(node), devnump);
  104. }
  105. return ret;
  106. }
  107. int dev_read_u32_array(struct udevice *dev, const char *propname,
  108. u32 *out_values, size_t sz)
  109. {
  110. return ofnode_read_u32_array(dev_ofnode(dev), propname, out_values, sz);
  111. }
  112. const uint8_t *dev_read_u8_array_ptr(struct udevice *dev, const char *propname,
  113. size_t sz)
  114. {
  115. return ofnode_read_u8_array_ptr(dev_ofnode(dev), propname, sz);
  116. }