drm_plane_helper.h 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. /*
  2. * Copyright (C) 2011-2013 Intel Corporation
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a
  5. * copy of this software and associated documentation files (the "Software"),
  6. * to deal in the Software without restriction, including without limitation
  7. * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  8. * and/or sell copies of the Software, and to permit persons to whom the
  9. * Software is furnished to do so, subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice (including the next
  12. * paragraph) shall be included in all copies or substantial portions of the
  13. * Software.
  14. *
  15. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  16. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  17. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  18. * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  19. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  20. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  21. * SOFTWARE.
  22. */
  23. #ifndef DRM_PLANE_HELPER_H
  24. #define DRM_PLANE_HELPER_H
  25. #include <drm/drm_rect.h>
  26. #include <drm/drm_crtc.h>
  27. /*
  28. * Drivers that don't allow primary plane scaling may pass this macro in place
  29. * of the min/max scale parameters of the update checker function.
  30. *
  31. * Due to src being in 16.16 fixed point and dest being in integer pixels,
  32. * 1<<16 represents no scaling.
  33. */
  34. #define DRM_PLANE_HELPER_NO_SCALING (1<<16)
  35. /**
  36. * DOC: plane helpers
  37. *
  38. * Helper functions to assist with creation and handling of CRTC primary
  39. * planes.
  40. */
  41. int drm_crtc_init(struct drm_device *dev, struct drm_crtc *crtc,
  42. const struct drm_crtc_funcs *funcs);
  43. /**
  44. * drm_plane_helper_funcs - helper operations for CRTCs
  45. * @prepare_fb: prepare a framebuffer for use by the plane
  46. * @cleanup_fb: cleanup a framebuffer when it's no longer used by the plane
  47. * @atomic_check: check that a given atomic state is valid and can be applied
  48. * @atomic_update: apply an atomic state to the plane (mandatory)
  49. * @atomic_disable: disable the plane
  50. *
  51. * The helper operations are called by the mid-layer CRTC helper.
  52. */
  53. struct drm_plane_helper_funcs {
  54. int (*prepare_fb)(struct drm_plane *plane,
  55. const struct drm_plane_state *new_state);
  56. void (*cleanup_fb)(struct drm_plane *plane,
  57. const struct drm_plane_state *old_state);
  58. int (*atomic_check)(struct drm_plane *plane,
  59. struct drm_plane_state *state);
  60. void (*atomic_update)(struct drm_plane *plane,
  61. struct drm_plane_state *old_state);
  62. void (*atomic_disable)(struct drm_plane *plane,
  63. struct drm_plane_state *old_state);
  64. };
  65. static inline void drm_plane_helper_add(struct drm_plane *plane,
  66. const struct drm_plane_helper_funcs *funcs)
  67. {
  68. plane->helper_private = funcs;
  69. }
  70. int drm_plane_helper_check_update(struct drm_plane *plane,
  71. struct drm_crtc *crtc,
  72. struct drm_framebuffer *fb,
  73. struct drm_rect *src,
  74. struct drm_rect *dest,
  75. const struct drm_rect *clip,
  76. int min_scale,
  77. int max_scale,
  78. bool can_position,
  79. bool can_update_disabled,
  80. bool *visible);
  81. int drm_primary_helper_update(struct drm_plane *plane,
  82. struct drm_crtc *crtc,
  83. struct drm_framebuffer *fb,
  84. int crtc_x, int crtc_y,
  85. unsigned int crtc_w, unsigned int crtc_h,
  86. uint32_t src_x, uint32_t src_y,
  87. uint32_t src_w, uint32_t src_h);
  88. int drm_primary_helper_disable(struct drm_plane *plane);
  89. void drm_primary_helper_destroy(struct drm_plane *plane);
  90. extern const struct drm_plane_funcs drm_primary_helper_funcs;
  91. int drm_plane_helper_update(struct drm_plane *plane, struct drm_crtc *crtc,
  92. struct drm_framebuffer *fb,
  93. int crtc_x, int crtc_y,
  94. unsigned int crtc_w, unsigned int crtc_h,
  95. uint32_t src_x, uint32_t src_y,
  96. uint32_t src_w, uint32_t src_h);
  97. int drm_plane_helper_disable(struct drm_plane *plane);
  98. /* For use by drm_crtc_helper.c */
  99. int drm_plane_helper_commit(struct drm_plane *plane,
  100. struct drm_plane_state *plane_state,
  101. struct drm_framebuffer *old_fb);
  102. #endif