[PATCH v2] drm/crtc: Remove duplicated ioctl code

Ville Syrjälä ville.syrjala at linux.intel.com
Tue Oct 21 07:08:10 PDT 2014


On Wed, Oct 08, 2014 at 11:40:34AM -0500, Chuck Ebbert wrote:
> Make drm_mode_add_fb() call drm_mode_add_fb2() after converting its
> args to the new internal format, instead of duplicating code.
> 
> Also picks up a lot more error checking, which the legacy modes
> should pass after being converted to the new format.
> 
> Signed-off-by: Chuck Ebbert <cebbert.lkml at gmail.com>

Looks good to me.

Reviewed-by: Ville Syrjälä <ville.syrjala at linux.intel.com>

> ---
>  drm_crtc.c |   31 +++++++------------------------
>  1 file changed, 7 insertions(+), 24 deletions(-)
> 
> Against 3.17.0, compile tested only.
> This time with the correct signed-off-by.
> 
> diff a/drivers/gpu/drm/drm_crtc.c b/drivers/gpu/drm/drm_crtc.c
> --- a/drivers/gpu/drm/drm_crtc.c
> +++ b/drivers/gpu/drm/drm_crtc.c
> @@ -2925,11 +2925,9 @@ int drm_mode_addfb(struct drm_device *dev,
>  {
>  	struct drm_mode_fb_cmd *or = data;
>  	struct drm_mode_fb_cmd2 r = {};
> -	struct drm_mode_config *config = &dev->mode_config;
> -	struct drm_framebuffer *fb;
> -	int ret = 0;
> +	int ret;
>  
> -	/* Use new struct with format internally */
> +	/* convert to new format and call new ioctl */
>  	r.fb_id = or->fb_id;
>  	r.width = or->width;
>  	r.height = or->height;
> @@ -2937,27 +2934,12 @@ int drm_mode_addfb(struct drm_device *dev,
>  	r.pixel_format = drm_mode_legacy_fb_format(or->bpp, or->depth);
>  	r.handles[0] = or->handle;
>  
> -	if (!drm_core_check_feature(dev, DRIVER_MODESET))
> -		return -EINVAL;
> -
> -	if ((config->min_width > r.width) || (r.width > config->max_width))
> -		return -EINVAL;
> -
> -	if ((config->min_height > r.height) || (r.height > config->max_height))
> -		return -EINVAL;
> -
> -	fb = dev->mode_config.funcs->fb_create(dev, file_priv, &r);
> -	if (IS_ERR(fb)) {
> -		DRM_DEBUG_KMS("could not create framebuffer\n");
> -		return PTR_ERR(fb);
> -	}
> +	ret = drm_mode_addfb2(dev, &r, file_priv);
> +	if (ret)
> +		return ret;
> +
> +	or->fb_id = r.fb_id;
>  
> -	mutex_lock(&file_priv->fbs_lock);
> -	or->fb_id = fb->base.id;
> -	list_add(&fb->filp_head, &file_priv->fbs);
> -	DRM_DEBUG_KMS("[FB:%d]\n", fb->base.id);
> -	mutex_unlock(&file_priv->fbs_lock);
> -
>  	return ret;
>  }
>  
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/dri-devel

-- 
Ville Syrjälä
Intel OTC


More information about the dri-devel mailing list