diff options
Diffstat (limited to 'drivers/gpu/drm/omapdrm/omap_plane.c')
| -rw-r--r-- | drivers/gpu/drm/omapdrm/omap_plane.c | 56 | 
1 files changed, 34 insertions, 22 deletions
| diff --git a/drivers/gpu/drm/omapdrm/omap_plane.c b/drivers/gpu/drm/omapdrm/omap_plane.c index 66ac8c40db26..82b2c23d6769 100644 --- a/drivers/gpu/drm/omapdrm/omap_plane.c +++ b/drivers/gpu/drm/omapdrm/omap_plane.c @@ -108,16 +108,12 @@ static void omap_plane_atomic_update(struct drm_plane *plane,  	win.src_x = state->src_x >> 16;  	win.src_y = state->src_y >> 16; -	switch (state->rotation & DRM_ROTATE_MASK) { -	case DRM_ROTATE_90: -	case DRM_ROTATE_270: +	if (drm_rotation_90_or_270(state->rotation)) {  		win.src_w = state->src_h >> 16;  		win.src_h = state->src_w >> 16; -		break; -	default: +	} else {  		win.src_w = state->src_w >> 16;  		win.src_h = state->src_h >> 16; -		break;  	}  	/* update scanout: */ @@ -135,7 +131,9 @@ static void omap_plane_atomic_update(struct drm_plane *plane,  	/* and finally, update omapdss: */  	ret = dispc_ovl_setup(omap_plane->id, &info, false,  			      omap_crtc_timings(state->crtc), false); -	if (WARN_ON(ret)) { +	if (ret) { +		dev_err(plane->dev->dev, "Failed to setup plane %s\n", +			omap_plane->name);  		dispc_ovl_enable(omap_plane->id, false);  		return;  	} @@ -161,12 +159,20 @@ static int omap_plane_atomic_check(struct drm_plane *plane,  {  	struct drm_crtc_state *crtc_state; -	if (!state->crtc) +	if (!state->fb)  		return 0; -	crtc_state = drm_atomic_get_crtc_state(state->state, state->crtc); -	if (IS_ERR(crtc_state)) -		return PTR_ERR(crtc_state); +	/* crtc should only be NULL when disabling (i.e., !state->fb) */ +	if (WARN_ON(!state->crtc)) +		return 0; + +	crtc_state = drm_atomic_get_existing_crtc_state(state->state, state->crtc); +	/* we should have a crtc state if the plane is attached to a crtc */ +	if (WARN_ON(!crtc_state)) +		return 0; + +	if (!crtc_state->enable) +		return 0;  	if (state->crtc_x < 0 || state->crtc_y < 0)  		return -EINVAL; @@ -177,11 +183,9 @@ static int omap_plane_atomic_check(struct drm_plane *plane,  	if (state->crtc_y + state->crtc_h > crtc_state->adjusted_mode.vdisplay)  		return -EINVAL; -	if (state->fb) { -		if (state->rotation != DRM_ROTATE_0 && -		    !omap_framebuffer_supports_rotation(state->fb)) -			return -EINVAL; -	} +	if (state->rotation != DRM_ROTATE_0 && +	    !omap_framebuffer_supports_rotation(state->fb)) +		return -EINVAL;  	return 0;  } @@ -215,9 +219,17 @@ void omap_plane_install_properties(struct drm_plane *plane,  	struct omap_drm_private *priv = dev->dev_private;  	if (priv->has_dmm) { -		struct drm_property *prop = dev->mode_config.rotation_property; - -		drm_object_attach_property(obj, prop, 0); +		if (!plane->rotation_property) +			drm_plane_create_rotation_property(plane, +							   DRM_ROTATE_0, +							   DRM_ROTATE_0 | DRM_ROTATE_90 | +							   DRM_ROTATE_180 | DRM_ROTATE_270 | +							   DRM_REFLECT_X | DRM_REFLECT_Y); + +		/* Attach the rotation property also to the crtc object */ +		if (plane->rotation_property && obj != &plane->base) +			drm_object_attach_property(obj, plane->rotation_property, +						   DRM_ROTATE_0);  	}  	drm_object_attach_property(obj, priv->zorder_prop, 0); @@ -344,9 +356,9 @@ static const uint32_t error_irqs[] = {  /* initialize plane */  struct drm_plane *omap_plane_init(struct drm_device *dev, -		int id, enum drm_plane_type type) +		int id, enum drm_plane_type type, +		u32 possible_crtcs)  { -	struct omap_drm_private *priv = dev->dev_private;  	struct drm_plane *plane;  	struct omap_plane *omap_plane;  	int ret; @@ -369,7 +381,7 @@ struct drm_plane *omap_plane_init(struct drm_device *dev,  	omap_plane->error_irq.irq = omap_plane_error_irq;  	omap_irq_register(dev, &omap_plane->error_irq); -	ret = drm_universal_plane_init(dev, plane, (1 << priv->num_crtcs) - 1, +	ret = drm_universal_plane_init(dev, plane, possible_crtcs,  				       &omap_plane_funcs, omap_plane->formats,  				       omap_plane->nformats, type, NULL);  	if (ret < 0) |