1c46c24bbSjames qian wang (Arm Technology China) /* SPDX-License-Identifier: GPL-2.0 */
2c46c24bbSjames qian wang (Arm Technology China) /*
3c46c24bbSjames qian wang (Arm Technology China)  * (C) COPYRIGHT 2018 ARM Limited. All rights reserved.
4c46c24bbSjames qian wang (Arm Technology China)  * Author: James.Qian.Wang <james.qian.wang@arm.com>
5c46c24bbSjames qian wang (Arm Technology China)  *
6c46c24bbSjames qian wang (Arm Technology China)  */
7c46c24bbSjames qian wang (Arm Technology China) #ifndef _KOMEDA_FRAMEBUFFER_H_
8c46c24bbSjames qian wang (Arm Technology China) #define _KOMEDA_FRAMEBUFFER_H_
9c46c24bbSjames qian wang (Arm Technology China) 
10c46c24bbSjames qian wang (Arm Technology China) #include <drm/drm_framebuffer.h>
11c46c24bbSjames qian wang (Arm Technology China) #include "komeda_format_caps.h"
12c46c24bbSjames qian wang (Arm Technology China) 
138c919745Sjames qian wang (Arm Technology China) /**
148c919745Sjames qian wang (Arm Technology China)  * struct komeda_fb - Entending drm_framebuffer with komeda attribute
158c919745Sjames qian wang (Arm Technology China)  */
16c46c24bbSjames qian wang (Arm Technology China) struct komeda_fb {
17c46c24bbSjames qian wang (Arm Technology China) 	/** @base: &drm_framebuffer */
18c46c24bbSjames qian wang (Arm Technology China) 	struct drm_framebuffer base;
198c919745Sjames qian wang (Arm Technology China) 	/**
208c919745Sjames qian wang (Arm Technology China) 	 * @format_caps:
218c919745Sjames qian wang (Arm Technology China) 	 * extends drm_format_info for komeda specific information
228c919745Sjames qian wang (Arm Technology China) 	 */
23c46c24bbSjames qian wang (Arm Technology China) 	const struct komeda_format_caps *format_caps;
24e87cae37SLowry Li (Arm Technology China) 	/** @is_va: if smmu is enabled, it will be true */
25e87cae37SLowry Li (Arm Technology China) 	bool is_va;
26c46c24bbSjames qian wang (Arm Technology China) 	/** @aligned_w: aligned frame buffer width */
27c46c24bbSjames qian wang (Arm Technology China) 	u32 aligned_w;
28c46c24bbSjames qian wang (Arm Technology China) 	/** @aligned_h: aligned frame buffer height */
29c46c24bbSjames qian wang (Arm Technology China) 	u32 aligned_h;
3065ad2392Sjames qian wang (Arm Technology China) 	/** @afbc_size: minimum size of afbc */
3165ad2392Sjames qian wang (Arm Technology China) 	u32 afbc_size;
3265ad2392Sjames qian wang (Arm Technology China) 	/** @offset_payload: start of afbc body buffer */
3365ad2392Sjames qian wang (Arm Technology China) 	u32 offset_payload;
34c46c24bbSjames qian wang (Arm Technology China) };
35c46c24bbSjames qian wang (Arm Technology China) 
36c46c24bbSjames qian wang (Arm Technology China) #define to_kfb(dfb)	container_of(dfb, struct komeda_fb, base)
37c46c24bbSjames qian wang (Arm Technology China) 
38c46c24bbSjames qian wang (Arm Technology China) struct drm_framebuffer *
39c46c24bbSjames qian wang (Arm Technology China) komeda_fb_create(struct drm_device *dev, struct drm_file *file,
40c46c24bbSjames qian wang (Arm Technology China) 		const struct drm_mode_fb_cmd2 *mode_cmd);
41df860f98Sjames qian wang (Arm Technology China) int komeda_fb_check_src_coords(const struct komeda_fb *kfb,
42df860f98Sjames qian wang (Arm Technology China) 			       u32 src_x, u32 src_y, u32 src_w, u32 src_h);
43c46c24bbSjames qian wang (Arm Technology China) dma_addr_t
44c46c24bbSjames qian wang (Arm Technology China) komeda_fb_get_pixel_addr(struct komeda_fb *kfb, int x, int y, int plane);
4519358630SLowry Li (Arm Technology China) bool komeda_fb_is_layer_supported(struct komeda_fb *kfb, u32 layer_type,
4619358630SLowry Li (Arm Technology China) 		u32 rot);
47c46c24bbSjames qian wang (Arm Technology China) 
48c46c24bbSjames qian wang (Arm Technology China) #endif
49