xref: /openbmc/linux/drivers/gpu/drm/arm/display/komeda/komeda_framebuffer.c (revision 4f2c0a4acffbec01079c28f839422e64ddeff004)
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)  */
76649a95dSSam Ravnborg #include <drm/drm_device.h>
86bcfe8eaSDanilo Krummrich #include <drm/drm_fb_dma_helper.h>
96649a95dSSam Ravnborg #include <drm/drm_gem.h>
104a83c26aSDanilo Krummrich #include <drm/drm_gem_dma_helper.h>
116649a95dSSam Ravnborg #include <drm/drm_gem_framebuffer_helper.h>
126649a95dSSam Ravnborg 
13c46c24bbSjames qian wang (Arm Technology China) #include "komeda_framebuffer.h"
14c46c24bbSjames qian wang (Arm Technology China) #include "komeda_dev.h"
15c46c24bbSjames qian wang (Arm Technology China) 
komeda_fb_destroy(struct drm_framebuffer * fb)16c46c24bbSjames qian wang (Arm Technology China) static void komeda_fb_destroy(struct drm_framebuffer *fb)
17c46c24bbSjames qian wang (Arm Technology China) {
18c46c24bbSjames qian wang (Arm Technology China) 	struct komeda_fb *kfb = to_kfb(fb);
19c46c24bbSjames qian wang (Arm Technology China) 	u32 i;
20c46c24bbSjames qian wang (Arm Technology China) 
21c46c24bbSjames qian wang (Arm Technology China) 	for (i = 0; i < fb->format->num_planes; i++)
2238e7abf7SEmil Velikov 		drm_gem_object_put(fb->obj[i]);
23c46c24bbSjames qian wang (Arm Technology China) 
24c46c24bbSjames qian wang (Arm Technology China) 	drm_framebuffer_cleanup(fb);
25c46c24bbSjames qian wang (Arm Technology China) 	kfree(kfb);
26c46c24bbSjames qian wang (Arm Technology China) }
27c46c24bbSjames qian wang (Arm Technology China) 
komeda_fb_create_handle(struct drm_framebuffer * fb,struct drm_file * file,u32 * handle)28c46c24bbSjames qian wang (Arm Technology China) static int komeda_fb_create_handle(struct drm_framebuffer *fb,
29c46c24bbSjames qian wang (Arm Technology China) 				   struct drm_file *file, u32 *handle)
30c46c24bbSjames qian wang (Arm Technology China) {
31c46c24bbSjames qian wang (Arm Technology China) 	return drm_gem_handle_create(file, fb->obj[0], handle);
32c46c24bbSjames qian wang (Arm Technology China) }
33c46c24bbSjames qian wang (Arm Technology China) 
34c46c24bbSjames qian wang (Arm Technology China) static const struct drm_framebuffer_funcs komeda_fb_funcs = {
35c46c24bbSjames qian wang (Arm Technology China) 	.destroy	= komeda_fb_destroy,
36c46c24bbSjames qian wang (Arm Technology China) 	.create_handle	= komeda_fb_create_handle,
37c46c24bbSjames qian wang (Arm Technology China) };
38c46c24bbSjames qian wang (Arm Technology China) 
39c46c24bbSjames qian wang (Arm Technology China) static int
komeda_fb_afbc_size_check(struct komeda_fb * kfb,struct drm_file * file,const struct drm_mode_fb_cmd2 * mode_cmd)4065ad2392Sjames qian wang (Arm Technology China) komeda_fb_afbc_size_check(struct komeda_fb *kfb, struct drm_file *file,
4165ad2392Sjames qian wang (Arm Technology China) 			  const struct drm_mode_fb_cmd2 *mode_cmd)
4265ad2392Sjames qian wang (Arm Technology China) {
4365ad2392Sjames qian wang (Arm Technology China) 	struct drm_framebuffer *fb = &kfb->base;
4465ad2392Sjames qian wang (Arm Technology China) 	const struct drm_format_info *info = fb->format;
4565ad2392Sjames qian wang (Arm Technology China) 	struct drm_gem_object *obj;
46a9577f19SLowry Li (Arm Technology China) 	u32 alignment_w = 0, alignment_h = 0, alignment_header, n_blocks, bpp;
47a6c60604Sjames qian wang (Arm Technology China) 	u64 min_size;
4865ad2392Sjames qian wang (Arm Technology China) 
4965ad2392Sjames qian wang (Arm Technology China) 	obj = drm_gem_object_lookup(file, mode_cmd->handles[0]);
5065ad2392Sjames qian wang (Arm Technology China) 	if (!obj) {
5165ad2392Sjames qian wang (Arm Technology China) 		DRM_DEBUG_KMS("Failed to lookup GEM object\n");
5265ad2392Sjames qian wang (Arm Technology China) 		return -ENOENT;
5365ad2392Sjames qian wang (Arm Technology China) 	}
5465ad2392Sjames qian wang (Arm Technology China) 
5565ad2392Sjames qian wang (Arm Technology China) 	switch (fb->modifier & AFBC_FORMAT_MOD_BLOCK_SIZE_MASK) {
5665ad2392Sjames qian wang (Arm Technology China) 	case AFBC_FORMAT_MOD_BLOCK_SIZE_32x8:
5765ad2392Sjames qian wang (Arm Technology China) 		alignment_w = 32;
5865ad2392Sjames qian wang (Arm Technology China) 		alignment_h = 8;
5965ad2392Sjames qian wang (Arm Technology China) 		break;
6065ad2392Sjames qian wang (Arm Technology China) 	case AFBC_FORMAT_MOD_BLOCK_SIZE_16x16:
6165ad2392Sjames qian wang (Arm Technology China) 		alignment_w = 16;
6265ad2392Sjames qian wang (Arm Technology China) 		alignment_h = 16;
6365ad2392Sjames qian wang (Arm Technology China) 		break;
6465ad2392Sjames qian wang (Arm Technology China) 	default:
6565ad2392Sjames qian wang (Arm Technology China) 		WARN(1, "Invalid AFBC_FORMAT_MOD_BLOCK_SIZE: %lld.\n",
6665ad2392Sjames qian wang (Arm Technology China) 		     fb->modifier & AFBC_FORMAT_MOD_BLOCK_SIZE_MASK);
6765ad2392Sjames qian wang (Arm Technology China) 		break;
6865ad2392Sjames qian wang (Arm Technology China) 	}
6965ad2392Sjames qian wang (Arm Technology China) 
7065ad2392Sjames qian wang (Arm Technology China) 	/* tiled header afbc */
7165ad2392Sjames qian wang (Arm Technology China) 	if (fb->modifier & AFBC_FORMAT_MOD_TILED) {
7265ad2392Sjames qian wang (Arm Technology China) 		alignment_w *= AFBC_TH_LAYOUT_ALIGNMENT;
7365ad2392Sjames qian wang (Arm Technology China) 		alignment_h *= AFBC_TH_LAYOUT_ALIGNMENT;
7465ad2392Sjames qian wang (Arm Technology China) 		alignment_header = AFBC_TH_BODY_START_ALIGNMENT;
7565ad2392Sjames qian wang (Arm Technology China) 	} else {
7665ad2392Sjames qian wang (Arm Technology China) 		alignment_header = AFBC_BODY_START_ALIGNMENT;
7765ad2392Sjames qian wang (Arm Technology China) 	}
7865ad2392Sjames qian wang (Arm Technology China) 
7965ad2392Sjames qian wang (Arm Technology China) 	kfb->aligned_w = ALIGN(fb->width, alignment_w);
8065ad2392Sjames qian wang (Arm Technology China) 	kfb->aligned_h = ALIGN(fb->height, alignment_h);
8165ad2392Sjames qian wang (Arm Technology China) 
8265ad2392Sjames qian wang (Arm Technology China) 	if (fb->offsets[0] % alignment_header) {
8365ad2392Sjames qian wang (Arm Technology China) 		DRM_DEBUG_KMS("afbc offset alignment check failed.\n");
8465ad2392Sjames qian wang (Arm Technology China) 		goto check_failed;
8565ad2392Sjames qian wang (Arm Technology China) 	}
8665ad2392Sjames qian wang (Arm Technology China) 
8765ad2392Sjames qian wang (Arm Technology China) 	n_blocks = (kfb->aligned_w * kfb->aligned_h) / AFBC_SUPERBLK_PIXELS;
8865ad2392Sjames qian wang (Arm Technology China) 	kfb->offset_payload = ALIGN(n_blocks * AFBC_HEADER_SIZE,
8965ad2392Sjames qian wang (Arm Technology China) 				    alignment_header);
9065ad2392Sjames qian wang (Arm Technology China) 
91a9577f19SLowry Li (Arm Technology China) 	bpp = komeda_get_afbc_format_bpp(info, fb->modifier);
9265ad2392Sjames qian wang (Arm Technology China) 	kfb->afbc_size = kfb->offset_payload + n_blocks *
93a9577f19SLowry Li (Arm Technology China) 			 ALIGN(bpp * AFBC_SUPERBLK_PIXELS / 8,
9465ad2392Sjames qian wang (Arm Technology China) 			       AFBC_SUPERBLK_ALIGNMENT);
9565ad2392Sjames qian wang (Arm Technology China) 	min_size = kfb->afbc_size + fb->offsets[0];
9665ad2392Sjames qian wang (Arm Technology China) 	if (min_size > obj->size) {
97a6c60604Sjames qian wang (Arm Technology China) 		DRM_DEBUG_KMS("afbc size check failed, obj_size: 0x%zx. min_size 0x%llx.\n",
9865ad2392Sjames qian wang (Arm Technology China) 			      obj->size, min_size);
9965ad2392Sjames qian wang (Arm Technology China) 		goto check_failed;
10065ad2392Sjames qian wang (Arm Technology China) 	}
10165ad2392Sjames qian wang (Arm Technology China) 
10265ad2392Sjames qian wang (Arm Technology China) 	fb->obj[0] = obj;
10365ad2392Sjames qian wang (Arm Technology China) 	return 0;
10465ad2392Sjames qian wang (Arm Technology China) 
10565ad2392Sjames qian wang (Arm Technology China) check_failed:
10638e7abf7SEmil Velikov 	drm_gem_object_put(obj);
10765ad2392Sjames qian wang (Arm Technology China) 	return -EINVAL;
10865ad2392Sjames qian wang (Arm Technology China) }
10965ad2392Sjames qian wang (Arm Technology China) 
11065ad2392Sjames qian wang (Arm Technology China) static int
komeda_fb_none_afbc_size_check(struct komeda_dev * mdev,struct komeda_fb * kfb,struct drm_file * file,const struct drm_mode_fb_cmd2 * mode_cmd)111c46c24bbSjames qian wang (Arm Technology China) komeda_fb_none_afbc_size_check(struct komeda_dev *mdev, struct komeda_fb *kfb,
112c46c24bbSjames qian wang (Arm Technology China) 			       struct drm_file *file,
113c46c24bbSjames qian wang (Arm Technology China) 			       const struct drm_mode_fb_cmd2 *mode_cmd)
114c46c24bbSjames qian wang (Arm Technology China) {
115c46c24bbSjames qian wang (Arm Technology China) 	struct drm_framebuffer *fb = &kfb->base;
11604e84545Sjames qian wang (Arm Technology China) 	const struct drm_format_info *info = fb->format;
117c46c24bbSjames qian wang (Arm Technology China) 	struct drm_gem_object *obj;
118a6c60604Sjames qian wang (Arm Technology China) 	u32 i, block_h;
119a6c60604Sjames qian wang (Arm Technology China) 	u64 min_size;
120c46c24bbSjames qian wang (Arm Technology China) 
12104e84545Sjames qian wang (Arm Technology China) 	if (komeda_fb_check_src_coords(kfb, 0, 0, fb->width, fb->height))
12204e84545Sjames qian wang (Arm Technology China) 		return -EINVAL;
12304e84545Sjames qian wang (Arm Technology China) 
12404e84545Sjames qian wang (Arm Technology China) 	for (i = 0; i < info->num_planes; i++) {
125c46c24bbSjames qian wang (Arm Technology China) 		obj = drm_gem_object_lookup(file, mode_cmd->handles[i]);
126c46c24bbSjames qian wang (Arm Technology China) 		if (!obj) {
127c46c24bbSjames qian wang (Arm Technology China) 			DRM_DEBUG_KMS("Failed to lookup GEM object\n");
128c46c24bbSjames qian wang (Arm Technology China) 			return -ENOENT;
129c46c24bbSjames qian wang (Arm Technology China) 		}
13004e84545Sjames qian wang (Arm Technology China) 		fb->obj[i] = obj;
131c46c24bbSjames qian wang (Arm Technology China) 
13204e84545Sjames qian wang (Arm Technology China) 		block_h = drm_format_info_block_height(info, i);
13304e84545Sjames qian wang (Arm Technology China) 		if ((fb->pitches[i] * block_h) % mdev->chip.bus_width) {
134c46c24bbSjames qian wang (Arm Technology China) 			DRM_DEBUG_KMS("Pitch[%d]: 0x%x doesn't align to 0x%x\n",
135c46c24bbSjames qian wang (Arm Technology China) 				      i, fb->pitches[i], mdev->chip.bus_width);
136c46c24bbSjames qian wang (Arm Technology China) 			return -EINVAL;
137c46c24bbSjames qian wang (Arm Technology China) 		}
138c46c24bbSjames qian wang (Arm Technology China) 
13904e84545Sjames qian wang (Arm Technology China) 		min_size = komeda_fb_get_pixel_addr(kfb, 0, fb->height, i)
140*8c30eeccSDanilo Krummrich 			 - to_drm_gem_dma_obj(obj)->dma_addr;
141c46c24bbSjames qian wang (Arm Technology China) 		if (obj->size < min_size) {
142a6c60604Sjames qian wang (Arm Technology China) 			DRM_DEBUG_KMS("The fb->obj[%d] size: 0x%zx lower than the minimum requirement: 0x%llx.\n",
14304e84545Sjames qian wang (Arm Technology China) 				      i, obj->size, min_size);
144c46c24bbSjames qian wang (Arm Technology China) 			return -EINVAL;
145c46c24bbSjames qian wang (Arm Technology China) 		}
146c46c24bbSjames qian wang (Arm Technology China) 	}
147c46c24bbSjames qian wang (Arm Technology China) 
148c46c24bbSjames qian wang (Arm Technology China) 	if (fb->format->num_planes == 3) {
149c46c24bbSjames qian wang (Arm Technology China) 		if (fb->pitches[1] != fb->pitches[2]) {
150c46c24bbSjames qian wang (Arm Technology China) 			DRM_DEBUG_KMS("The pitch[1] and [2] are not same\n");
151c46c24bbSjames qian wang (Arm Technology China) 			return -EINVAL;
152c46c24bbSjames qian wang (Arm Technology China) 		}
153c46c24bbSjames qian wang (Arm Technology China) 	}
154c46c24bbSjames qian wang (Arm Technology China) 
155c46c24bbSjames qian wang (Arm Technology China) 	return 0;
156c46c24bbSjames qian wang (Arm Technology China) }
157c46c24bbSjames qian wang (Arm Technology China) 
158c46c24bbSjames qian wang (Arm Technology China) struct drm_framebuffer *
komeda_fb_create(struct drm_device * dev,struct drm_file * file,const struct drm_mode_fb_cmd2 * mode_cmd)159c46c24bbSjames qian wang (Arm Technology China) komeda_fb_create(struct drm_device *dev, struct drm_file *file,
160c46c24bbSjames qian wang (Arm Technology China) 		 const struct drm_mode_fb_cmd2 *mode_cmd)
161c46c24bbSjames qian wang (Arm Technology China) {
162c46c24bbSjames qian wang (Arm Technology China) 	struct komeda_dev *mdev = dev->dev_private;
163c46c24bbSjames qian wang (Arm Technology China) 	struct komeda_fb *kfb;
164c46c24bbSjames qian wang (Arm Technology China) 	int ret = 0, i;
165c46c24bbSjames qian wang (Arm Technology China) 
166c46c24bbSjames qian wang (Arm Technology China) 	kfb = kzalloc(sizeof(*kfb), GFP_KERNEL);
167c46c24bbSjames qian wang (Arm Technology China) 	if (!kfb)
168c46c24bbSjames qian wang (Arm Technology China) 		return ERR_PTR(-ENOMEM);
169c46c24bbSjames qian wang (Arm Technology China) 
170c46c24bbSjames qian wang (Arm Technology China) 	kfb->format_caps = komeda_get_format_caps(&mdev->fmt_tbl,
171c46c24bbSjames qian wang (Arm Technology China) 						  mode_cmd->pixel_format,
172c46c24bbSjames qian wang (Arm Technology China) 						  mode_cmd->modifier[0]);
173c46c24bbSjames qian wang (Arm Technology China) 	if (!kfb->format_caps) {
174c46c24bbSjames qian wang (Arm Technology China) 		DRM_DEBUG_KMS("FMT %x is not supported.\n",
175c46c24bbSjames qian wang (Arm Technology China) 			      mode_cmd->pixel_format);
176c46c24bbSjames qian wang (Arm Technology China) 		kfree(kfb);
177c46c24bbSjames qian wang (Arm Technology China) 		return ERR_PTR(-EINVAL);
178c46c24bbSjames qian wang (Arm Technology China) 	}
179c46c24bbSjames qian wang (Arm Technology China) 
180c46c24bbSjames qian wang (Arm Technology China) 	drm_helper_mode_fill_fb_struct(dev, &kfb->base, mode_cmd);
181c46c24bbSjames qian wang (Arm Technology China) 
18265ad2392Sjames qian wang (Arm Technology China) 	if (kfb->base.modifier)
18365ad2392Sjames qian wang (Arm Technology China) 		ret = komeda_fb_afbc_size_check(kfb, file, mode_cmd);
18465ad2392Sjames qian wang (Arm Technology China) 	else
185c46c24bbSjames qian wang (Arm Technology China) 		ret = komeda_fb_none_afbc_size_check(mdev, kfb, file, mode_cmd);
186c46c24bbSjames qian wang (Arm Technology China) 	if (ret < 0)
187c46c24bbSjames qian wang (Arm Technology China) 		goto err_cleanup;
188c46c24bbSjames qian wang (Arm Technology China) 
189c46c24bbSjames qian wang (Arm Technology China) 	ret = drm_framebuffer_init(dev, &kfb->base, &komeda_fb_funcs);
190c46c24bbSjames qian wang (Arm Technology China) 	if (ret < 0) {
191c46c24bbSjames qian wang (Arm Technology China) 		DRM_DEBUG_KMS("failed to initialize fb\n");
192c46c24bbSjames qian wang (Arm Technology China) 
193c46c24bbSjames qian wang (Arm Technology China) 		goto err_cleanup;
194c46c24bbSjames qian wang (Arm Technology China) 	}
195c46c24bbSjames qian wang (Arm Technology China) 
196e87cae37SLowry Li (Arm Technology China) 	kfb->is_va = mdev->iommu ? true : false;
197e87cae37SLowry Li (Arm Technology China) 
198c46c24bbSjames qian wang (Arm Technology China) 	return &kfb->base;
199c46c24bbSjames qian wang (Arm Technology China) 
200c46c24bbSjames qian wang (Arm Technology China) err_cleanup:
201c46c24bbSjames qian wang (Arm Technology China) 	for (i = 0; i < kfb->base.format->num_planes; i++)
20238e7abf7SEmil Velikov 		drm_gem_object_put(kfb->base.obj[i]);
203c46c24bbSjames qian wang (Arm Technology China) 
204c46c24bbSjames qian wang (Arm Technology China) 	kfree(kfb);
205c46c24bbSjames qian wang (Arm Technology China) 	return ERR_PTR(ret);
206c46c24bbSjames qian wang (Arm Technology China) }
207c46c24bbSjames qian wang (Arm Technology China) 
komeda_fb_check_src_coords(const struct komeda_fb * kfb,u32 src_x,u32 src_y,u32 src_w,u32 src_h)208df860f98Sjames qian wang (Arm Technology China) int komeda_fb_check_src_coords(const struct komeda_fb *kfb,
209df860f98Sjames qian wang (Arm Technology China) 			       u32 src_x, u32 src_y, u32 src_w, u32 src_h)
210df860f98Sjames qian wang (Arm Technology China) {
211df860f98Sjames qian wang (Arm Technology China) 	const struct drm_framebuffer *fb = &kfb->base;
212df860f98Sjames qian wang (Arm Technology China) 	const struct drm_format_info *info = fb->format;
21304e84545Sjames qian wang (Arm Technology China) 	u32 block_w = drm_format_info_block_width(fb->format, 0);
21404e84545Sjames qian wang (Arm Technology China) 	u32 block_h = drm_format_info_block_height(fb->format, 0);
215df860f98Sjames qian wang (Arm Technology China) 
216df860f98Sjames qian wang (Arm Technology China) 	if ((src_x + src_w > fb->width) || (src_y + src_h > fb->height)) {
217df860f98Sjames qian wang (Arm Technology China) 		DRM_DEBUG_ATOMIC("Invalid source coordinate.\n");
218df860f98Sjames qian wang (Arm Technology China) 		return -EINVAL;
219df860f98Sjames qian wang (Arm Technology China) 	}
220df860f98Sjames qian wang (Arm Technology China) 
221df860f98Sjames qian wang (Arm Technology China) 	if ((src_x % info->hsub) || (src_w % info->hsub) ||
222df860f98Sjames qian wang (Arm Technology China) 	    (src_y % info->vsub) || (src_h % info->vsub)) {
223df860f98Sjames qian wang (Arm Technology China) 		DRM_DEBUG_ATOMIC("Wrong subsampling dimension x:%d, y:%d, w:%d, h:%d for format: %x.\n",
224df860f98Sjames qian wang (Arm Technology China) 				 src_x, src_y, src_w, src_h, info->format);
225df860f98Sjames qian wang (Arm Technology China) 		return -EINVAL;
226df860f98Sjames qian wang (Arm Technology China) 	}
227df860f98Sjames qian wang (Arm Technology China) 
22804e84545Sjames qian wang (Arm Technology China) 	if ((src_x % block_w) || (src_w % block_w) ||
22904e84545Sjames qian wang (Arm Technology China) 	    (src_y % block_h) || (src_h % block_h)) {
23004e84545Sjames qian wang (Arm Technology China) 		DRM_DEBUG_ATOMIC("x:%d, y:%d, w:%d, h:%d should be multiple of block_w/h for format: %x.\n",
23104e84545Sjames qian wang (Arm Technology China) 				 src_x, src_y, src_w, src_h, info->format);
23204e84545Sjames qian wang (Arm Technology China) 		return -EINVAL;
23304e84545Sjames qian wang (Arm Technology China) 	}
23404e84545Sjames qian wang (Arm Technology China) 
235df860f98Sjames qian wang (Arm Technology China) 	return 0;
236df860f98Sjames qian wang (Arm Technology China) }
237df860f98Sjames qian wang (Arm Technology China) 
238c46c24bbSjames qian wang (Arm Technology China) dma_addr_t
komeda_fb_get_pixel_addr(struct komeda_fb * kfb,int x,int y,int plane)239c46c24bbSjames qian wang (Arm Technology China) komeda_fb_get_pixel_addr(struct komeda_fb *kfb, int x, int y, int plane)
240c46c24bbSjames qian wang (Arm Technology China) {
241c46c24bbSjames qian wang (Arm Technology China) 	struct drm_framebuffer *fb = &kfb->base;
2424a83c26aSDanilo Krummrich 	const struct drm_gem_dma_object *obj;
24304e84545Sjames qian wang (Arm Technology China) 	u32 offset, plane_x, plane_y, block_w, block_sz;
244c46c24bbSjames qian wang (Arm Technology China) 
245dcc9d76bSDan Carpenter 	if (plane >= fb->format->num_planes) {
246c46c24bbSjames qian wang (Arm Technology China) 		DRM_DEBUG_KMS("Out of max plane num.\n");
247c46c24bbSjames qian wang (Arm Technology China) 		return -EINVAL;
248c46c24bbSjames qian wang (Arm Technology China) 	}
249c46c24bbSjames qian wang (Arm Technology China) 
2506bcfe8eaSDanilo Krummrich 	obj = drm_fb_dma_get_gem_obj(fb, plane);
251c46c24bbSjames qian wang (Arm Technology China) 
252c46c24bbSjames qian wang (Arm Technology China) 	offset = fb->offsets[plane];
253c46c24bbSjames qian wang (Arm Technology China) 	if (!fb->modifier) {
25404e84545Sjames qian wang (Arm Technology China) 		block_w = drm_format_info_block_width(fb->format, plane);
25504e84545Sjames qian wang (Arm Technology China) 		block_sz = fb->format->char_per_block[plane];
256c46c24bbSjames qian wang (Arm Technology China) 		plane_x = x / (plane ? fb->format->hsub : 1);
257c46c24bbSjames qian wang (Arm Technology China) 		plane_y = y / (plane ? fb->format->vsub : 1);
25804e84545Sjames qian wang (Arm Technology China) 
25904e84545Sjames qian wang (Arm Technology China) 		offset += (plane_x / block_w) * block_sz
26004e84545Sjames qian wang (Arm Technology China) 			+ plane_y * fb->pitches[plane];
261c46c24bbSjames qian wang (Arm Technology China) 	}
262c46c24bbSjames qian wang (Arm Technology China) 
263*8c30eeccSDanilo Krummrich 	return obj->dma_addr + offset;
264c46c24bbSjames qian wang (Arm Technology China) }
2655d51f6c0Sjames qian wang (Arm Technology China) 
2665d51f6c0Sjames qian wang (Arm Technology China) /* if the fb can be supported by a specific layer */
komeda_fb_is_layer_supported(struct komeda_fb * kfb,u32 layer_type,u32 rot)26719358630SLowry Li (Arm Technology China) bool komeda_fb_is_layer_supported(struct komeda_fb *kfb, u32 layer_type,
26819358630SLowry Li (Arm Technology China) 				  u32 rot)
2695d51f6c0Sjames qian wang (Arm Technology China) {
2705d51f6c0Sjames qian wang (Arm Technology China) 	struct drm_framebuffer *fb = &kfb->base;
2715d51f6c0Sjames qian wang (Arm Technology China) 	struct komeda_dev *mdev = fb->dev->dev_private;
2725d51f6c0Sjames qian wang (Arm Technology China) 	u32 fourcc = fb->format->format;
2735d51f6c0Sjames qian wang (Arm Technology China) 	u64 modifier = fb->modifier;
27419358630SLowry Li (Arm Technology China) 	bool supported;
2755d51f6c0Sjames qian wang (Arm Technology China) 
27619358630SLowry Li (Arm Technology China) 	supported = komeda_format_mod_supported(&mdev->fmt_tbl, layer_type,
27719358630SLowry Li (Arm Technology China) 						fourcc, modifier, rot);
27819358630SLowry Li (Arm Technology China) 	if (!supported)
27992f1d09cSSakari Ailus 		DRM_DEBUG_ATOMIC("Layer TYPE: %d doesn't support fb FMT: %p4cc with modifier: 0x%llx.\n",
28092f1d09cSSakari Ailus 				 layer_type, &fourcc, modifier);
2815d51f6c0Sjames qian wang (Arm Technology China) 
28219358630SLowry Li (Arm Technology China) 	return supported;
2835d51f6c0Sjames qian wang (Arm Technology China) }
284