| 
									
										
										
										
											2014-04-01 15:22:35 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Copyright (C) 2011-2013 Intel Corporation | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Permission is hereby granted, free of charge, to any person obtaining a | 
					
						
							|  |  |  |  * copy of this software and associated documentation files (the "Software"), | 
					
						
							|  |  |  |  * to deal in the Software without restriction, including without limitation | 
					
						
							|  |  |  |  * the rights to use, copy, modify, merge, publish, distribute, sublicense, | 
					
						
							|  |  |  |  * and/or sell copies of the Software, and to permit persons to whom the | 
					
						
							|  |  |  |  * Software is furnished to do so, subject to the following conditions: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The above copyright notice and this permission notice (including the next | 
					
						
							|  |  |  |  * paragraph) shall be included in all copies or substantial portions of the | 
					
						
							|  |  |  |  * Software. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | 
					
						
							|  |  |  |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | 
					
						
							|  |  |  |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL | 
					
						
							|  |  |  |  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | 
					
						
							|  |  |  |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | 
					
						
							|  |  |  |  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | 
					
						
							|  |  |  |  * SOFTWARE. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef DRM_PLANE_HELPER_H
 | 
					
						
							|  |  |  | #define DRM_PLANE_HELPER_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-29 08:06:52 -07:00
										 |  |  | #include <drm/drm_rect.h>
 | 
					
						
							| 
									
										
										
										
											2014-10-29 10:03:57 +01:00
										 |  |  | #include <drm/drm_crtc.h>
 | 
					
						
							| 
									
										
										
										
											2014-05-29 08:06:52 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Drivers that don't allow primary plane scaling may pass this macro in place | 
					
						
							|  |  |  |  * of the min/max scale parameters of the update checker function. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Due to src being in 16.16 fixed point and dest being in integer pixels, | 
					
						
							|  |  |  |  * 1<<16 represents no scaling. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define DRM_PLANE_HELPER_NO_SCALING (1<<16)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-01 15:22:35 -07:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * DOC: plane helpers | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Helper functions to assist with creation and handling of CRTC primary | 
					
						
							|  |  |  |  * planes. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-29 10:03:57 +01:00
										 |  |  | extern int drm_crtc_init(struct drm_device *dev, | 
					
						
							|  |  |  | 			 struct drm_crtc *crtc, | 
					
						
							|  |  |  | 			 const struct drm_crtc_funcs *funcs); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-05 00:14:14 +01:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * drm_plane_helper_funcs - helper operations for CRTCs | 
					
						
							| 
									
										
										
										
											2014-11-25 12:09:45 +01:00
										 |  |  |  * @prepare_fb: prepare a framebuffer for use by the plane | 
					
						
							|  |  |  |  * @cleanup_fb: cleanup a framebuffer when it's no longer used by the plane | 
					
						
							|  |  |  |  * @atomic_check: check that a given atomic state is valid and can be applied | 
					
						
							|  |  |  |  * @atomic_update: apply an atomic state to the plane | 
					
						
							| 
									
										
										
										
											2014-11-05 00:14:14 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The helper operations are called by the mid-layer CRTC helper. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct drm_plane_helper_funcs { | 
					
						
							|  |  |  | 	int (*prepare_fb)(struct drm_plane *plane, | 
					
						
							|  |  |  | 			  struct drm_framebuffer *fb); | 
					
						
							|  |  |  | 	void (*cleanup_fb)(struct drm_plane *plane, | 
					
						
							|  |  |  | 			   struct drm_framebuffer *fb); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int (*atomic_check)(struct drm_plane *plane, | 
					
						
							|  |  |  | 			    struct drm_plane_state *state); | 
					
						
							| 
									
										
										
										
											2014-11-25 12:09:44 +01:00
										 |  |  | 	void (*atomic_update)(struct drm_plane *plane, | 
					
						
							|  |  |  | 			      struct drm_plane_state *old_state); | 
					
						
							| 
									
										
										
										
											2014-11-05 00:14:14 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void drm_plane_helper_add(struct drm_plane *plane, | 
					
						
							|  |  |  | 					const struct drm_plane_helper_funcs *funcs) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	plane->helper_private = (void *)funcs; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-29 08:06:52 -07:00
										 |  |  | extern int drm_plane_helper_check_update(struct drm_plane *plane, | 
					
						
							|  |  |  | 					 struct drm_crtc *crtc, | 
					
						
							|  |  |  | 					 struct drm_framebuffer *fb, | 
					
						
							|  |  |  | 					 struct drm_rect *src, | 
					
						
							|  |  |  | 					 struct drm_rect *dest, | 
					
						
							|  |  |  | 					 const struct drm_rect *clip, | 
					
						
							|  |  |  | 					 int min_scale, | 
					
						
							|  |  |  | 					 int max_scale, | 
					
						
							|  |  |  | 					 bool can_position, | 
					
						
							|  |  |  | 					 bool can_update_disabled, | 
					
						
							|  |  |  | 					 bool *visible); | 
					
						
							| 
									
										
										
										
											2014-04-01 15:22:35 -07:00
										 |  |  | extern int drm_primary_helper_update(struct drm_plane *plane, | 
					
						
							|  |  |  | 				     struct drm_crtc *crtc, | 
					
						
							|  |  |  | 				     struct drm_framebuffer *fb, | 
					
						
							|  |  |  | 				     int crtc_x, int crtc_y, | 
					
						
							|  |  |  | 				     unsigned int crtc_w, unsigned int crtc_h, | 
					
						
							|  |  |  | 				     uint32_t src_x, uint32_t src_y, | 
					
						
							|  |  |  | 				     uint32_t src_w, uint32_t src_h); | 
					
						
							|  |  |  | extern int drm_primary_helper_disable(struct drm_plane *plane); | 
					
						
							|  |  |  | extern void drm_primary_helper_destroy(struct drm_plane *plane); | 
					
						
							|  |  |  | extern const struct drm_plane_funcs drm_primary_helper_funcs; | 
					
						
							|  |  |  | extern struct drm_plane *drm_primary_helper_create_plane(struct drm_device *dev, | 
					
						
							| 
									
										
										
										
											2014-05-13 12:47:42 +02:00
										 |  |  | 							 const uint32_t *formats, | 
					
						
							| 
									
										
										
										
											2014-04-01 15:22:35 -07:00
										 |  |  | 							 int num_formats); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-29 15:33:05 +02:00
										 |  |  | int drm_plane_helper_update(struct drm_plane *plane, struct drm_crtc *crtc, | 
					
						
							|  |  |  | 			    struct drm_framebuffer *fb, | 
					
						
							|  |  |  | 			    int crtc_x, int crtc_y, | 
					
						
							|  |  |  | 			    unsigned int crtc_w, unsigned int crtc_h, | 
					
						
							|  |  |  | 			    uint32_t src_x, uint32_t src_y, | 
					
						
							|  |  |  | 			    uint32_t src_w, uint32_t src_h); | 
					
						
							|  |  |  | int drm_plane_helper_disable(struct drm_plane *plane); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-29 11:13:47 +01:00
										 |  |  | /* For use by drm_crtc_helper.c */ | 
					
						
							|  |  |  | int drm_plane_helper_commit(struct drm_plane *plane, | 
					
						
							|  |  |  | 			    struct drm_plane_state *plane_state, | 
					
						
							|  |  |  | 			    struct drm_framebuffer *old_fb); | 
					
						
							| 
									
										
										
										
											2014-04-01 15:22:35 -07:00
										 |  |  | #endif
 |