drm_gem_cma_helper.h 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. #ifndef __DRM_GEM_CMA_HELPER_H__
  2. #define __DRM_GEM_CMA_HELPER_H__
  3. struct drm_gem_cma_object {
  4. struct drm_gem_object base;
  5. dma_addr_t paddr;
  6. void *vaddr;
  7. };
  8. static inline struct drm_gem_cma_object *
  9. to_drm_gem_cma_obj(struct drm_gem_object *gem_obj)
  10. {
  11. return container_of(gem_obj, struct drm_gem_cma_object, base);
  12. }
  13. /* free gem object. */
  14. void drm_gem_cma_free_object(struct drm_gem_object *gem_obj);
  15. /* create memory region for drm framebuffer. */
  16. int drm_gem_cma_dumb_create(struct drm_file *file_priv,
  17. struct drm_device *drm, struct drm_mode_create_dumb *args);
  18. /* map memory region for drm framebuffer to user space. */
  19. int drm_gem_cma_dumb_map_offset(struct drm_file *file_priv,
  20. struct drm_device *drm, uint32_t handle, uint64_t *offset);
  21. /* set vm_flags and we can change the vm attribute to other one at here. */
  22. int drm_gem_cma_mmap(struct file *filp, struct vm_area_struct *vma);
  23. /*
  24. * destroy memory region allocated.
  25. * - a gem handle and physical memory region pointed by a gem object
  26. * would be released by drm_gem_handle_delete().
  27. */
  28. int drm_gem_cma_dumb_destroy(struct drm_file *file_priv,
  29. struct drm_device *drm, unsigned int handle);
  30. /* allocate physical memory. */
  31. struct drm_gem_cma_object *drm_gem_cma_create(struct drm_device *drm,
  32. unsigned int size);
  33. extern const struct vm_operations_struct drm_gem_cma_vm_ops;
  34. #endif /* __DRM_GEM_CMA_HELPER_H__ */