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 24 #ifndef DRM_PLANE_HELPER_H 25 #define DRM_PLANE_HELPER_H 26 27 #include <drm/drm_rect.h> 28 #include <drm/drm_crtc.h> 29 30 /* 31 * Drivers that don't allow primary plane scaling may pass this macro in place 32 * of the min/max scale parameters of the update checker function. 33 * 34 * Due to src being in 16.16 fixed point and dest being in integer pixels, 35 * 1<<16 represents no scaling. 36 */ 37 #define DRM_PLANE_HELPER_NO_SCALING (1<<16) 38 39 /** 40 * DOC: plane helpers 41 * 42 * Helper functions to assist with creation and handling of CRTC primary 43 * planes. 44 */ 45 46 extern int drm_crtc_init(struct drm_device *dev, 47 struct drm_crtc *crtc, 48 const struct drm_crtc_funcs *funcs); 49 50 /** 51 * drm_plane_helper_funcs - helper operations for CRTCs 52 * @prepare_fb: prepare a framebuffer for use by the plane 53 * @cleanup_fb: cleanup a framebuffer when it's no longer used by the plane 54 * @atomic_check: check that a given atomic state is valid and can be applied 55 * @atomic_update: apply an atomic state to the plane (mandatory) 56 * @atomic_disable: disable the plane 57 * 58 * The helper operations are called by the mid-layer CRTC helper. 59 */ 60 struct drm_plane_helper_funcs { 61 int (*prepare_fb)(struct drm_plane *plane, 62 struct drm_framebuffer *fb); 63 void (*cleanup_fb)(struct drm_plane *plane, 64 struct drm_framebuffer *fb); 65 66 int (*atomic_check)(struct drm_plane *plane, 67 struct drm_plane_state *state); 68 void (*atomic_update)(struct drm_plane *plane, 69 struct drm_plane_state *old_state); 70 void (*atomic_disable)(struct drm_plane *plane, 71 struct drm_plane_state *old_state); 72 }; 73 74 static inline void drm_plane_helper_add(struct drm_plane *plane, 75 const struct drm_plane_helper_funcs *funcs) 76 { 77 plane->helper_private = (void *)funcs; 78 } 79 80 extern int drm_plane_helper_check_update(struct drm_plane *plane, 81 struct drm_crtc *crtc, 82 struct drm_framebuffer *fb, 83 struct drm_rect *src, 84 struct drm_rect *dest, 85 const struct drm_rect *clip, 86 int min_scale, 87 int max_scale, 88 bool can_position, 89 bool can_update_disabled, 90 bool *visible); 91 extern int drm_primary_helper_update(struct drm_plane *plane, 92 struct drm_crtc *crtc, 93 struct drm_framebuffer *fb, 94 int crtc_x, int crtc_y, 95 unsigned int crtc_w, unsigned int crtc_h, 96 uint32_t src_x, uint32_t src_y, 97 uint32_t src_w, uint32_t src_h); 98 extern int drm_primary_helper_disable(struct drm_plane *plane); 99 extern void drm_primary_helper_destroy(struct drm_plane *plane); 100 extern const struct drm_plane_funcs drm_primary_helper_funcs; 101 extern struct drm_plane *drm_primary_helper_create_plane(struct drm_device *dev, 102 const uint32_t *formats, 103 int num_formats); 104 105 106 int drm_plane_helper_update(struct drm_plane *plane, struct drm_crtc *crtc, 107 struct drm_framebuffer *fb, 108 int crtc_x, int crtc_y, 109 unsigned int crtc_w, unsigned int crtc_h, 110 uint32_t src_x, uint32_t src_y, 111 uint32_t src_w, uint32_t src_h); 112 int drm_plane_helper_disable(struct drm_plane *plane); 113 114 /* For use by drm_crtc_helper.c */ 115 int drm_plane_helper_commit(struct drm_plane *plane, 116 struct drm_plane_state *plane_state, 117 struct drm_framebuffer *old_fb); 118 #endif 119