of_reserved_mem.h 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef __OF_RESERVED_MEM_H
  3. #define __OF_RESERVED_MEM_H
  4. #include <linux/device.h>
  5. struct of_phandle_args;
  6. struct reserved_mem_ops;
  7. struct reserved_mem {
  8. const char *name;
  9. unsigned long fdt_node;
  10. unsigned long phandle;
  11. const struct reserved_mem_ops *ops;
  12. phys_addr_t base;
  13. phys_addr_t size;
  14. void *priv;
  15. };
  16. struct reserved_mem_ops {
  17. int (*device_init)(struct reserved_mem *rmem,
  18. struct device *dev);
  19. void (*device_release)(struct reserved_mem *rmem,
  20. struct device *dev);
  21. };
  22. typedef int (*reservedmem_of_init_fn)(struct reserved_mem *rmem);
  23. #define RESERVEDMEM_OF_DECLARE(name, compat, init) \
  24. _OF_DECLARE(reservedmem, name, compat, init, reservedmem_of_init_fn)
  25. #ifdef CONFIG_OF_RESERVED_MEM
  26. int of_reserved_mem_device_init_by_idx(struct device *dev,
  27. struct device_node *np, int idx);
  28. void of_reserved_mem_device_release(struct device *dev);
  29. int early_init_dt_alloc_reserved_memory_arch(phys_addr_t size,
  30. phys_addr_t align,
  31. phys_addr_t start,
  32. phys_addr_t end,
  33. bool nomap,
  34. phys_addr_t *res_base);
  35. void fdt_init_reserved_mem(void);
  36. void fdt_reserved_mem_save_node(unsigned long node, const char *uname,
  37. phys_addr_t base, phys_addr_t size);
  38. struct reserved_mem *of_reserved_mem_lookup(struct device_node *np);
  39. #else
  40. static inline int of_reserved_mem_device_init_by_idx(struct device *dev,
  41. struct device_node *np, int idx)
  42. {
  43. return -ENOSYS;
  44. }
  45. static inline void of_reserved_mem_device_release(struct device *pdev) { }
  46. static inline void fdt_init_reserved_mem(void) { }
  47. static inline void fdt_reserved_mem_save_node(unsigned long node,
  48. const char *uname, phys_addr_t base, phys_addr_t size) { }
  49. static inline struct reserved_mem *of_reserved_mem_lookup(struct device_node *np)
  50. {
  51. return NULL;
  52. }
  53. #endif
  54. /**
  55. * of_reserved_mem_device_init() - assign reserved memory region to given device
  56. * @dev: Pointer to the device to configure
  57. *
  58. * This function assigns respective DMA-mapping operations based on the first
  59. * reserved memory region specified by 'memory-region' property in device tree
  60. * node of the given device.
  61. *
  62. * Returns error code or zero on success.
  63. */
  64. static inline int of_reserved_mem_device_init(struct device *dev)
  65. {
  66. return of_reserved_mem_device_init_by_idx(dev, dev->of_node, 0);
  67. }
  68. #endif /* __OF_RESERVED_MEM_H */