of_address.h 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  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_pci_range_parser {
  9. struct device_node *node;
  10. const __be32 *range;
  11. const __be32 *end;
  12. int np;
  13. int pna;
  14. };
  15. struct of_pci_range {
  16. u32 pci_space;
  17. u64 pci_addr;
  18. u64 cpu_addr;
  19. u64 size;
  20. u32 flags;
  21. };
  22. #define for_each_of_pci_range(parser, range) \
  23. for (; of_pci_range_parser_one(parser, range);)
  24. /* Translate a DMA address from device space to CPU space */
  25. extern u64 of_translate_dma_address(struct device_node *dev,
  26. const __be32 *in_addr);
  27. #ifdef CONFIG_OF_ADDRESS
  28. extern u64 of_translate_address(struct device_node *np, const __be32 *addr);
  29. extern int of_address_to_resource(struct device_node *dev, int index,
  30. struct resource *r);
  31. extern struct device_node *of_find_matching_node_by_address(
  32. struct device_node *from,
  33. const struct of_device_id *matches,
  34. u64 base_address);
  35. extern void __iomem *of_iomap(struct device_node *device, int index);
  36. void __iomem *of_io_request_and_map(struct device_node *device,
  37. int index, const char *name);
  38. /* Extract an address from a device, returns the region size and
  39. * the address space flags too. The PCI version uses a BAR number
  40. * instead of an absolute index
  41. */
  42. extern const __be32 *of_get_address(struct device_node *dev, int index,
  43. u64 *size, unsigned int *flags);
  44. extern int of_pci_range_parser_init(struct of_pci_range_parser *parser,
  45. struct device_node *node);
  46. extern int of_pci_dma_range_parser_init(struct of_pci_range_parser *parser,
  47. struct device_node *node);
  48. extern struct of_pci_range *of_pci_range_parser_one(
  49. struct of_pci_range_parser *parser,
  50. struct of_pci_range *range);
  51. extern int of_dma_get_range(struct device_node *np, u64 *dma_addr,
  52. u64 *paddr, u64 *size);
  53. extern bool of_dma_is_coherent(struct device_node *np);
  54. #else /* CONFIG_OF_ADDRESS */
  55. static inline void __iomem *of_io_request_and_map(struct device_node *device,
  56. int index, const char *name)
  57. {
  58. return IOMEM_ERR_PTR(-EINVAL);
  59. }
  60. static inline u64 of_translate_address(struct device_node *np,
  61. const __be32 *addr)
  62. {
  63. return OF_BAD_ADDR;
  64. }
  65. static inline struct device_node *of_find_matching_node_by_address(
  66. struct device_node *from,
  67. const struct of_device_id *matches,
  68. u64 base_address)
  69. {
  70. return NULL;
  71. }
  72. static inline const __be32 *of_get_address(struct device_node *dev, int index,
  73. u64 *size, unsigned int *flags)
  74. {
  75. return NULL;
  76. }
  77. static inline int of_pci_range_parser_init(struct of_pci_range_parser *parser,
  78. struct device_node *node)
  79. {
  80. return -ENOSYS;
  81. }
  82. static inline int of_pci_dma_range_parser_init(struct of_pci_range_parser *parser,
  83. struct device_node *node)
  84. {
  85. return -ENOSYS;
  86. }
  87. static inline struct of_pci_range *of_pci_range_parser_one(
  88. struct of_pci_range_parser *parser,
  89. struct of_pci_range *range)
  90. {
  91. return NULL;
  92. }
  93. static inline int of_dma_get_range(struct device_node *np, u64 *dma_addr,
  94. u64 *paddr, u64 *size)
  95. {
  96. return -ENODEV;
  97. }
  98. static inline bool of_dma_is_coherent(struct device_node *np)
  99. {
  100. return false;
  101. }
  102. #endif /* CONFIG_OF_ADDRESS */
  103. #ifdef CONFIG_OF
  104. extern int of_address_to_resource(struct device_node *dev, int index,
  105. struct resource *r);
  106. void __iomem *of_iomap(struct device_node *node, int index);
  107. #else
  108. static inline int of_address_to_resource(struct device_node *dev, int index,
  109. struct resource *r)
  110. {
  111. return -EINVAL;
  112. }
  113. static inline void __iomem *of_iomap(struct device_node *device, int index)
  114. {
  115. return NULL;
  116. }
  117. #endif
  118. #if defined(CONFIG_OF_ADDRESS) && defined(CONFIG_PCI)
  119. extern const __be32 *of_get_pci_address(struct device_node *dev, int bar_no,
  120. u64 *size, unsigned int *flags);
  121. extern int of_pci_address_to_resource(struct device_node *dev, int bar,
  122. struct resource *r);
  123. extern int of_pci_range_to_resource(struct of_pci_range *range,
  124. struct device_node *np,
  125. struct resource *res);
  126. #else /* CONFIG_OF_ADDRESS && CONFIG_PCI */
  127. static inline int of_pci_address_to_resource(struct device_node *dev, int bar,
  128. struct resource *r)
  129. {
  130. return -ENOSYS;
  131. }
  132. static inline const __be32 *of_get_pci_address(struct device_node *dev,
  133. int bar_no, u64 *size, unsigned int *flags)
  134. {
  135. return NULL;
  136. }
  137. static inline int of_pci_range_to_resource(struct of_pci_range *range,
  138. struct device_node *np,
  139. struct resource *res)
  140. {
  141. return -ENOSYS;
  142. }
  143. #endif /* CONFIG_OF_ADDRESS && CONFIG_PCI */
  144. #endif /* __OF_ADDRESS_H */