of_address.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef __OF_ADDRESS_H
  3. #define __OF_ADDRESS_H
  4. #include <linux/ioport.h>
  5. #include <linux/errno.h>
  6. #include <linux/of.h>
  7. #include <linux/io.h>
  8. struct of_bus;
  9. struct of_pci_range_parser {
  10. struct device_node *node;
  11. struct of_bus *bus;
  12. const __be32 *range;
  13. const __be32 *end;
  14. int na;
  15. int ns;
  16. int pna;
  17. bool dma;
  18. };
  19. #define of_range_parser of_pci_range_parser
  20. struct of_pci_range {
  21. union {
  22. u64 pci_addr;
  23. u64 bus_addr;
  24. };
  25. u64 cpu_addr;
  26. u64 size;
  27. u32 flags;
  28. };
  29. #define of_range of_pci_range
  30. #define for_each_of_pci_range(parser, range) \
  31. for (; of_pci_range_parser_one(parser, range);)
  32. #define for_each_of_range for_each_of_pci_range
  33. /* Translate a DMA address from device space to CPU space */
  34. extern u64 of_translate_dma_address(struct device_node *dev,
  35. const __be32 *in_addr);
  36. extern const __be32 *of_translate_dma_region(struct device_node *dev, const __be32 *addr,
  37. phys_addr_t *start, size_t *length);
  38. #ifdef CONFIG_OF_ADDRESS
  39. extern u64 of_translate_address(struct device_node *np, const __be32 *addr);
  40. extern int of_address_to_resource(struct device_node *dev, int index,
  41. struct resource *r);
  42. extern void __iomem *of_iomap(struct device_node *device, int index);
  43. void __iomem *of_io_request_and_map(struct device_node *device,
  44. int index, const char *name);
  45. /* Extract an address from a device, returns the region size and
  46. * the address space flags too. The PCI version uses a BAR number
  47. * instead of an absolute index
  48. */
  49. extern const __be32 *__of_get_address(struct device_node *dev, int index, int bar_no,
  50. u64 *size, unsigned int *flags);
  51. extern int of_pci_range_parser_init(struct of_pci_range_parser *parser,
  52. struct device_node *node);
  53. extern int of_pci_dma_range_parser_init(struct of_pci_range_parser *parser,
  54. struct device_node *node);
  55. extern struct of_pci_range *of_pci_range_parser_one(
  56. struct of_pci_range_parser *parser,
  57. struct of_pci_range *range);
  58. extern int of_pci_address_to_resource(struct device_node *dev, int bar,
  59. struct resource *r);
  60. extern int of_pci_range_to_resource(struct of_pci_range *range,
  61. struct device_node *np,
  62. struct resource *res);
  63. extern bool of_dma_is_coherent(struct device_node *np);
  64. #else /* CONFIG_OF_ADDRESS */
  65. static inline void __iomem *of_io_request_and_map(struct device_node *device,
  66. int index, const char *name)
  67. {
  68. return IOMEM_ERR_PTR(-EINVAL);
  69. }
  70. static inline u64 of_translate_address(struct device_node *np,
  71. const __be32 *addr)
  72. {
  73. return OF_BAD_ADDR;
  74. }
  75. static inline const __be32 *__of_get_address(struct device_node *dev, int index, int bar_no,
  76. u64 *size, unsigned int *flags)
  77. {
  78. return NULL;
  79. }
  80. static inline int of_pci_range_parser_init(struct of_pci_range_parser *parser,
  81. struct device_node *node)
  82. {
  83. return -ENOSYS;
  84. }
  85. static inline int of_pci_dma_range_parser_init(struct of_pci_range_parser *parser,
  86. struct device_node *node)
  87. {
  88. return -ENOSYS;
  89. }
  90. static inline struct of_pci_range *of_pci_range_parser_one(
  91. struct of_pci_range_parser *parser,
  92. struct of_pci_range *range)
  93. {
  94. return NULL;
  95. }
  96. static inline int of_pci_address_to_resource(struct device_node *dev, int bar,
  97. struct resource *r)
  98. {
  99. return -ENOSYS;
  100. }
  101. static inline int of_pci_range_to_resource(struct of_pci_range *range,
  102. struct device_node *np,
  103. struct resource *res)
  104. {
  105. return -ENOSYS;
  106. }
  107. static inline bool of_dma_is_coherent(struct device_node *np)
  108. {
  109. return false;
  110. }
  111. #endif /* CONFIG_OF_ADDRESS */
  112. #ifdef CONFIG_OF
  113. extern int of_address_to_resource(struct device_node *dev, int index,
  114. struct resource *r);
  115. void __iomem *of_iomap(struct device_node *node, int index);
  116. #else
  117. static inline int of_address_to_resource(struct device_node *dev, int index,
  118. struct resource *r)
  119. {
  120. return -EINVAL;
  121. }
  122. static inline void __iomem *of_iomap(struct device_node *device, int index)
  123. {
  124. return NULL;
  125. }
  126. #endif
  127. #define of_range_parser_init of_pci_range_parser_init
  128. static inline const __be32 *of_get_address(struct device_node *dev, int index,
  129. u64 *size, unsigned int *flags)
  130. {
  131. return __of_get_address(dev, index, -1, size, flags);
  132. }
  133. static inline const __be32 *of_get_pci_address(struct device_node *dev, int bar_no,
  134. u64 *size, unsigned int *flags)
  135. {
  136. return __of_get_address(dev, -1, bar_no, size, flags);
  137. }
  138. #endif /* __OF_ADDRESS_H */