[PATCH 09/13] drm/exynos: check NV12M format specific to Exynos properly

Joonyoung Shim jy0922.shim at samsung.com
Sun Aug 19 18:17:19 PDT 2012


On 08/17/2012 06:50 PM, Inki Dae wrote:
> this patch adds buf_cnt variable in exynos_drm_fb structure and
> that means a buffer count to drm framebuffer and also adds two
> functions to get/set the buffer count from/to exynos_drm_fb structure.
> if pixel format is not DRM_FORMAT_NV12MT then it gets a buffer count
> to drm framebuffer refering to mode_cmd->handles and offsets.
> but when booted, the buffer count will always be 1 because pixel
> format of console framebuffer is RGB format.
>
> Signed-off-by: Inki Dae <inki.dae at samsung.com>
> Signed-off-by: Kyungmin Park <kyungmin.park at samsung.com>
> ---
>   drivers/gpu/drm/exynos/exynos_drm_fb.c    |   65 +++++++++++++++++++++++++++-
>   drivers/gpu/drm/exynos/exynos_drm_fb.h    |   20 +++------
>   drivers/gpu/drm/exynos/exynos_drm_fbdev.c |    3 +
>   drivers/gpu/drm/exynos/exynos_drm_plane.c |    2 +-
>   4 files changed, 73 insertions(+), 17 deletions(-)
>
> diff --git a/drivers/gpu/drm/exynos/exynos_drm_fb.c b/drivers/gpu/drm/exynos/exynos_drm_fb.c
> index 4ccfe43..2d1bc3a 100644
> --- a/drivers/gpu/drm/exynos/exynos_drm_fb.c
> +++ b/drivers/gpu/drm/exynos/exynos_drm_fb.c
> @@ -41,10 +41,12 @@
>    * exynos specific framebuffer structure.
>    *
>    * @fb: drm framebuffer obejct.
> + * @buf_cnt: a buffer count to drm framebuffer.
>    * @exynos_gem_obj: array of exynos specific gem object containing a gem object.
>    */
>   struct exynos_drm_fb {
>   	struct drm_framebuffer		fb;
> +	unsigned int			buf_cnt;
>   	struct exynos_drm_gem_obj	*exynos_gem_obj[MAX_FB_BUFFER];
>   };
>   
> @@ -101,6 +103,25 @@ static struct drm_framebuffer_funcs exynos_drm_fb_funcs = {
>   	.dirty		= exynos_drm_fb_dirty,
>   };
>   
> +void exynos_drm_fb_set_buf_cnt(struct drm_framebuffer *fb,
> +						unsigned int cnt)
> +{
> +	struct exynos_drm_fb *exynos_fb;
> +
> +	exynos_fb = to_exynos_fb(fb);
> +
> +	exynos_fb->buf_cnt = cnt;
> +}
> +
> +unsigned int exynos_drm_fb_get_buf_cnt(struct drm_framebuffer *fb)
> +{
> +	struct exynos_drm_fb *exynos_fb;
> +
> +	exynos_fb = to_exynos_fb(fb);
> +
> +	return exynos_fb->buf_cnt;
> +}
> +
>   struct drm_framebuffer *
>   exynos_drm_framebuffer_init(struct drm_device *dev,
>   			    struct drm_mode_fb_cmd2 *mode_cmd,
> @@ -127,6 +148,43 @@ exynos_drm_framebuffer_init(struct drm_device *dev,
>   	return &exynos_fb->fb;
>   }
>   
> +static u32 exynos_drm_format_num_buffers(struct drm_mode_fb_cmd2 *mode_cmd)
> +{
> +	unsigned int cnt = 0;
> +
> +	if (mode_cmd->pixel_format == DRM_FORMAT_NV12MT)
> +		return 2;
> +
> +	while (cnt != MAX_FB_BUFFER) {
> +		if (!mode_cmd->handles[cnt])
> +			break;
> +		cnt++;
> +	}
> +
> +	/*
> +	 * check if NV12 or NV12M.
> +	 *
> +	 * NV12
> +	 * handles[0] = base1, offsets[0] = 0
> +	 * handles[1] = base1, offsets[1] = Y_size
> +	 *
> +	 * NV12M
> +	 * handles[0] = base1, offsets[0] = 0
> +	 * handles[1] = base2, offsets[1] = 0
> +	 */
> +	if (cnt == 2) {
> +		/*
> +		 * in case of NV12 format, offsets[1] is not 0 and
> +		 * handles[0] is same as handles[1].
> +		 */
> +		if (mode_cmd->offsets[1] &&
> +			mode_cmd->handles[0] == mode_cmd->handles[1])
> +			cnt = 1;
> +	}
> +
> +	return cnt;
> +}

No, please don't add specific function. There is already 
drm_format_num_planes() function

> +
>   static struct drm_framebuffer *
>   exynos_user_fb_create(struct drm_device *dev, struct drm_file *file_priv,
>   		      struct drm_mode_fb_cmd2 *mode_cmd)
> @@ -134,7 +192,6 @@ exynos_user_fb_create(struct drm_device *dev, struct drm_file *file_priv,
>   	struct drm_gem_object *obj;
>   	struct drm_framebuffer *fb;
>   	struct exynos_drm_fb *exynos_fb;
> -	int nr;
>   	int i;
>   
>   	DRM_DEBUG_KMS("%s\n", __FILE__);
> @@ -152,9 +209,11 @@ exynos_user_fb_create(struct drm_device *dev, struct drm_file *file_priv,
>   	}
>   
>   	exynos_fb = to_exynos_fb(fb);
> -	nr = exynos_drm_format_num_buffers(fb->pixel_format);
> +	exynos_fb->buf_cnt = exynos_drm_format_num_buffers(mode_cmd);
> +
> +	DRM_DEBUG_KMS("buf_cnt = %d\n", exynos_fb->buf_cnt);
>   
> -	for (i = 1; i < nr; i++) {
> +	for (i = 1; i < exynos_fb->buf_cnt; i++) {
>   		obj = drm_gem_object_lookup(dev, file_priv,
>   				mode_cmd->handles[i]);
>   		if (!obj) {
> diff --git a/drivers/gpu/drm/exynos/exynos_drm_fb.h b/drivers/gpu/drm/exynos/exynos_drm_fb.h
> index 5082375..96262e5 100644
> --- a/drivers/gpu/drm/exynos/exynos_drm_fb.h
> +++ b/drivers/gpu/drm/exynos/exynos_drm_fb.h
> @@ -28,19 +28,6 @@
>   #ifndef _EXYNOS_DRM_FB_H_
>   #define _EXYNOS_DRM_FB_H
>   
> -static inline int exynos_drm_format_num_buffers(uint32_t format)
> -{
> -	switch (format) {
> -	case DRM_FORMAT_NV12:
> -	case DRM_FORMAT_NV12MT:
> -		return 2;
> -	case DRM_FORMAT_YUV420:
> -		return 3;
> -	default:
> -		return 1;
> -	}
> -}
> -
>   struct drm_framebuffer *
>   exynos_drm_framebuffer_init(struct drm_device *dev,
>   			    struct drm_mode_fb_cmd2 *mode_cmd,
> @@ -52,4 +39,11 @@ struct exynos_drm_gem_buf *exynos_drm_fb_buffer(struct drm_framebuffer *fb,
>   
>   void exynos_drm_mode_config_init(struct drm_device *dev);
>   
> +/* set a buffer count to drm framebuffer. */
> +void exynos_drm_fb_set_buf_cnt(struct drm_framebuffer *fb,
> +						unsigned int cnt);
> +
> +/* get a buffer count to drm framebuffer. */
> +unsigned int exynos_drm_fb_get_buf_cnt(struct drm_framebuffer *fb);
> +
>   #endif
> diff --git a/drivers/gpu/drm/exynos/exynos_drm_fbdev.c b/drivers/gpu/drm/exynos/exynos_drm_fbdev.c
> index d5586cc..5b125fe 100644
> --- a/drivers/gpu/drm/exynos/exynos_drm_fbdev.c
> +++ b/drivers/gpu/drm/exynos/exynos_drm_fbdev.c
> @@ -79,6 +79,9 @@ static int exynos_drm_fbdev_update(struct drm_fb_helper *helper,
>   		return -EFAULT;
>   	}
>   
> +	/* buffer count to framebuffer always is 1 at booting time. */
> +	exynos_drm_fb_set_buf_cnt(fb, 1);
> +
>   	offset = fbi->var.xoffset * (fb->bits_per_pixel >> 3);
>   	offset += fbi->var.yoffset * fb->pitches[0];
>   
> diff --git a/drivers/gpu/drm/exynos/exynos_drm_plane.c b/drivers/gpu/drm/exynos/exynos_drm_plane.c
> index b89829e..777e142 100644
> --- a/drivers/gpu/drm/exynos/exynos_drm_plane.c
> +++ b/drivers/gpu/drm/exynos/exynos_drm_plane.c
> @@ -48,7 +48,7 @@ int exynos_plane_mode_set(struct drm_plane *plane, struct drm_crtc *crtc,
>   
>   	DRM_DEBUG_KMS("[%d] %s\n", __LINE__, __func__);
>   
> -	nr = exynos_drm_format_num_buffers(fb->pixel_format);
> +	nr = exynos_drm_fb_get_buf_cnt(fb);
>   	for (i = 0; i < nr; i++) {
>   		struct exynos_drm_gem_buf *buffer = exynos_drm_fb_buffer(fb, i);
>   



More information about the dri-devel mailing list