All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v2] drm/crtc: Remove duplicated ioctl code
@ 2014-10-08 16:40 Chuck Ebbert
  2014-10-21 14:08 ` Ville Syrjälä
  0 siblings, 1 reply; 3+ messages in thread
From: Chuck Ebbert @ 2014-10-08 16:40 UTC (permalink / raw)
  To: David Airlie; +Cc: dri-devel@lists.freedesktop.org

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@gmail.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;
 }

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH v2] drm/crtc: Remove duplicated ioctl code
  2014-10-08 16:40 [PATCH v2] drm/crtc: Remove duplicated ioctl code Chuck Ebbert
@ 2014-10-21 14:08 ` Ville Syrjälä
  2014-10-22  8:39   ` Daniel Vetter
  0 siblings, 1 reply; 3+ messages in thread
From: Ville Syrjälä @ 2014-10-21 14:08 UTC (permalink / raw)
  To: Chuck Ebbert; +Cc: dri-devel@lists.freedesktop.org

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@gmail.com>

Looks good to me.

Reviewed-by: Ville Syrjälä <ville.syrjala@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@lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/dri-devel

-- 
Ville Syrjälä
Intel OTC

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH v2] drm/crtc: Remove duplicated ioctl code
  2014-10-21 14:08 ` Ville Syrjälä
@ 2014-10-22  8:39   ` Daniel Vetter
  0 siblings, 0 replies; 3+ messages in thread
From: Daniel Vetter @ 2014-10-22  8:39 UTC (permalink / raw)
  To: Ville Syrjälä; +Cc: Chuck Ebbert, dri-devel@lists.freedesktop.org

On Tue, Oct 21, 2014 at 05:08:10PM +0300, Ville Syrjälä wrote:
> 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@gmail.com>
> 
> Looks good to me.
> 
> Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>

Picked up into my drm core stuff queue.
-Daniel
-- 
Daniel Vetter
Software Engineer, Intel Corporation
+41 (0) 79 365 57 48 - http://blog.ffwll.ch

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2014-10-22  8:39 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-10-08 16:40 [PATCH v2] drm/crtc: Remove duplicated ioctl code Chuck Ebbert
2014-10-21 14:08 ` Ville Syrjälä
2014-10-22  8:39   ` Daniel Vetter

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.