drm_gem_cma_helper.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. #ifndef __DRM_GEM_CMA_HELPER_H__
  2. #define __DRM_GEM_CMA_HELPER_H__
  3. #include <drm/drmP.h>
  4. #include <drm/drm_gem.h>
  5. /**
  6. * struct drm_gem_cma_object - GEM object backed by CMA memory allocations
  7. * @base: base GEM object
  8. * @paddr: physical address of the backing memory
  9. * @sgt: scatter/gather table for imported PRIME buffers
  10. * @vaddr: kernel virtual address of the backing memory
  11. */
  12. struct drm_gem_cma_object {
  13. struct drm_gem_object base;
  14. dma_addr_t paddr;
  15. struct sg_table *sgt;
  16. /* For objects with DMA memory allocated by GEM CMA */
  17. void *vaddr;
  18. };
  19. static inline struct drm_gem_cma_object *
  20. to_drm_gem_cma_obj(struct drm_gem_object *gem_obj)
  21. {
  22. return container_of(gem_obj, struct drm_gem_cma_object, base);
  23. }
  24. /**
  25. * DEFINE_DRM_GEM_CMA_FOPS() - macro to generate file operations for CMA drivers
  26. * @name: name for the generated structure
  27. *
  28. * This macro autogenerates a suitable &struct file_operations for CMA based
  29. * drivers, which can be assigned to &drm_driver.fops. Note that this structure
  30. * cannot be shared between drivers, because it contains a reference to the
  31. * current module using THIS_MODULE.
  32. *
  33. * Note that the declaration is already marked as static - if you need a
  34. * non-static version of this you're probably doing it wrong and will break the
  35. * THIS_MODULE reference by accident.
  36. */
  37. #define DEFINE_DRM_GEM_CMA_FOPS(name) \
  38. static const struct file_operations name = {\
  39. .owner = THIS_MODULE,\
  40. .open = drm_open,\
  41. .release = drm_release,\
  42. .unlocked_ioctl = drm_ioctl,\
  43. .compat_ioctl = drm_compat_ioctl,\
  44. .poll = drm_poll,\
  45. .read = drm_read,\
  46. .llseek = noop_llseek,\
  47. .mmap = drm_gem_cma_mmap,\
  48. }
  49. /* free GEM object */
  50. void drm_gem_cma_free_object(struct drm_gem_object *gem_obj);
  51. /* create memory region for DRM framebuffer */
  52. int drm_gem_cma_dumb_create_internal(struct drm_file *file_priv,
  53. struct drm_device *drm,
  54. struct drm_mode_create_dumb *args);
  55. /* create memory region for DRM framebuffer */
  56. int drm_gem_cma_dumb_create(struct drm_file *file_priv,
  57. struct drm_device *drm,
  58. struct drm_mode_create_dumb *args);
  59. /* map memory region for DRM framebuffer to user space */
  60. int drm_gem_cma_dumb_map_offset(struct drm_file *file_priv,
  61. struct drm_device *drm, u32 handle,
  62. u64 *offset);
  63. /* set vm_flags and we can change the VM attribute to other one at here */
  64. int drm_gem_cma_mmap(struct file *filp, struct vm_area_struct *vma);
  65. /* allocate physical memory */
  66. struct drm_gem_cma_object *drm_gem_cma_create(struct drm_device *drm,
  67. size_t size);
  68. extern const struct vm_operations_struct drm_gem_cma_vm_ops;
  69. #ifndef CONFIG_MMU
  70. unsigned long drm_gem_cma_get_unmapped_area(struct file *filp,
  71. unsigned long addr,
  72. unsigned long len,
  73. unsigned long pgoff,
  74. unsigned long flags);
  75. #else
  76. static inline unsigned long drm_gem_cma_get_unmapped_area(struct file *filp,
  77. unsigned long addr,
  78. unsigned long len,
  79. unsigned long pgoff,
  80. unsigned long flags)
  81. {
  82. return -EINVAL;
  83. }
  84. #endif
  85. #ifdef CONFIG_DEBUG_FS
  86. void drm_gem_cma_describe(struct drm_gem_cma_object *obj, struct seq_file *m);
  87. #endif
  88. struct sg_table *drm_gem_cma_prime_get_sg_table(struct drm_gem_object *obj);
  89. struct drm_gem_object *
  90. drm_gem_cma_prime_import_sg_table(struct drm_device *dev,
  91. struct dma_buf_attachment *attach,
  92. struct sg_table *sgt);
  93. int drm_gem_cma_prime_mmap(struct drm_gem_object *obj,
  94. struct vm_area_struct *vma);
  95. void *drm_gem_cma_prime_vmap(struct drm_gem_object *obj);
  96. void drm_gem_cma_prime_vunmap(struct drm_gem_object *obj, void *vaddr);
  97. #endif /* __DRM_GEM_CMA_HELPER_H__ */