mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 323e9a18d6
			
		
	
	
		323e9a18d6
		
	
	
	
	
		
			
			Use devm_kzalloc to create pipe data structure. This allows us to remove corresponding kfree and drop mdp5_pipe_destroy() function. Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org> Reviewed-by: Abhinav Kumar <quic_abhinavk@quicinc.com> Patchwork: https://patchwork.freedesktop.org/patch/546171/ Link: https://lore.kernel.org/r/20230708010407.3871346-6-dmitry.baryshkov@linaro.org
		
			
				
	
	
		
			47 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0-only */
 | |
| /*
 | |
|  * Copyright (C) 2016 Red Hat
 | |
|  * Author: Rob Clark <robdclark@gmail.com>
 | |
|  */
 | |
| 
 | |
| #ifndef __MDP5_PIPE_H__
 | |
| #define __MDP5_PIPE_H__
 | |
| 
 | |
| /* TODO: Add SSPP_MAX in mdp5.xml.h */
 | |
| #define SSPP_MAX	(SSPP_CURSOR1 + 1)
 | |
| 
 | |
| /* represents a hw pipe, which is dynamically assigned to a plane */
 | |
| struct mdp5_hw_pipe {
 | |
| 	int idx;
 | |
| 
 | |
| 	const char *name;
 | |
| 	enum mdp5_pipe pipe;
 | |
| 
 | |
| 	uint32_t reg_offset;
 | |
| 	uint32_t caps;
 | |
| 
 | |
| 	uint32_t flush_mask;      /* used to commit pipe registers */
 | |
| 
 | |
| 	/* number of smp blocks per plane, ie:
 | |
| 	 *   nblks_y | (nblks_u << 8) | (nblks_v << 16)
 | |
| 	 */
 | |
| 	uint32_t blkcfg;
 | |
| };
 | |
| 
 | |
| /* global atomic state of assignment between pipes and planes: */
 | |
| struct mdp5_hw_pipe_state {
 | |
| 	struct drm_plane *hwpipe_to_plane[SSPP_MAX];
 | |
| };
 | |
| 
 | |
| int mdp5_pipe_assign(struct drm_atomic_state *s, struct drm_plane *plane,
 | |
| 		     uint32_t caps, uint32_t blkcfg,
 | |
| 		     struct mdp5_hw_pipe **hwpipe,
 | |
| 		     struct mdp5_hw_pipe **r_hwpipe);
 | |
| int mdp5_pipe_release(struct drm_atomic_state *s, struct mdp5_hw_pipe *hwpipe);
 | |
| 
 | |
| struct mdp5_hw_pipe *mdp5_pipe_init(struct drm_device *dev,
 | |
| 		enum mdp5_pipe pipe,
 | |
| 		uint32_t reg_offset, uint32_t caps);
 | |
| 
 | |
| #endif /* __MDP5_PIPE_H__ */
 |