Commit 47094194 authored by Laurent Pinchart's avatar Laurent Pinchart

drm: rcar-du: Replace plane crtc and enabled fields by plane state

The crtc and enabled fields duplicates information stored in the plane
state. Use the plane state instead and remove the fields.
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
parent f398f344
...@@ -212,7 +212,7 @@ static void rcar_du_crtc_update_planes(struct drm_crtc *crtc) ...@@ -212,7 +212,7 @@ static void rcar_du_crtc_update_planes(struct drm_crtc *crtc)
struct rcar_du_plane *plane = &rcrtc->group->planes.planes[i]; struct rcar_du_plane *plane = &rcrtc->group->planes.planes[i];
unsigned int j; unsigned int j;
if (plane->crtc != &rcrtc->crtc || !plane->enabled) if (plane->plane.state->crtc != &rcrtc->crtc)
continue; continue;
/* Insert the plane in the sorted planes array. */ /* Insert the plane in the sorted planes array. */
...@@ -379,7 +379,7 @@ static void rcar_du_crtc_start(struct rcar_du_crtc *rcrtc) ...@@ -379,7 +379,7 @@ static void rcar_du_crtc_start(struct rcar_du_crtc *rcrtc)
for (i = 0; i < ARRAY_SIZE(rcrtc->group->planes.planes); ++i) { for (i = 0; i < ARRAY_SIZE(rcrtc->group->planes.planes); ++i) {
struct rcar_du_plane *plane = &rcrtc->group->planes.planes[i]; struct rcar_du_plane *plane = &rcrtc->group->planes.planes[i];
if (plane->crtc != crtc || !plane->enabled) if (plane->plane.state->crtc != crtc)
continue; continue;
rcar_du_plane_setup(plane); rcar_du_plane_setup(plane);
...@@ -608,8 +608,6 @@ int rcar_du_crtc_create(struct rcar_du_group *rgrp, unsigned int index) ...@@ -608,8 +608,6 @@ int rcar_du_crtc_create(struct rcar_du_group *rgrp, unsigned int index)
rcrtc->enabled = false; rcrtc->enabled = false;
rcrtc->plane = &rgrp->planes.planes[index % 2]; rcrtc->plane = &rgrp->planes.planes[index % 2];
rcrtc->plane->crtc = crtc;
ret = drm_crtc_init_with_planes(rcdu->ddev, crtc, &rcrtc->plane->plane, ret = drm_crtc_init_with_planes(rcdu->ddev, crtc, &rcrtc->plane->plane,
NULL, &crtc_funcs); NULL, &crtc_funcs);
if (ret < 0) if (ret < 0)
......
...@@ -140,7 +140,8 @@ static void rcar_du_plane_setup_fb(struct rcar_du_plane *plane) ...@@ -140,7 +140,8 @@ static void rcar_du_plane_setup_fb(struct rcar_du_plane *plane)
bool interlaced; bool interlaced;
u32 mwr; u32 mwr;
interlaced = plane->crtc->mode.flags & DRM_MODE_FLAG_INTERLACE; interlaced = plane->plane.state->crtc->state->adjusted_mode.flags
& DRM_MODE_FLAG_INTERLACE;
/* Memory pitch (expressed in pixels). Must be doubled for interlaced /* Memory pitch (expressed in pixels). Must be doubled for interlaced
* operation with 32bpp formats. * operation with 32bpp formats.
...@@ -354,16 +355,11 @@ static int rcar_du_plane_atomic_check(struct drm_plane *plane, ...@@ -354,16 +355,11 @@ static int rcar_du_plane_atomic_check(struct drm_plane *plane,
static void rcar_du_plane_disable(struct rcar_du_plane *rplane) static void rcar_du_plane_disable(struct rcar_du_plane *rplane)
{ {
if (!rplane->enabled) if (!rplane->plane.state->crtc)
return; return;
mutex_lock(&rplane->group->planes.lock);
rplane->enabled = false;
mutex_unlock(&rplane->group->planes.lock);
rcar_du_plane_release(rplane); rcar_du_plane_release(rplane);
rplane->crtc = NULL;
rplane->format = NULL; rplane->format = NULL;
} }
...@@ -391,14 +387,9 @@ static void rcar_du_plane_atomic_update(struct drm_plane *plane, ...@@ -391,14 +387,9 @@ static void rcar_du_plane_atomic_update(struct drm_plane *plane,
rcar_du_plane_reserve(rplane, format); rcar_du_plane_reserve(rplane, format);
} }
rplane->crtc = state->crtc;
rplane->format = format; rplane->format = format;
rcar_du_plane_setup(rplane); rcar_du_plane_setup(rplane);
mutex_lock(&rplane->group->planes.lock);
rplane->enabled = true;
mutex_unlock(&rplane->group->planes.lock);
} }
static const struct drm_plane_helper_funcs rcar_du_plane_helper_funcs = { static const struct drm_plane_helper_funcs rcar_du_plane_helper_funcs = {
......
...@@ -34,9 +34,6 @@ struct rcar_du_plane { ...@@ -34,9 +34,6 @@ struct rcar_du_plane {
struct drm_plane plane; struct drm_plane plane;
struct rcar_du_group *group; struct rcar_du_group *group;
struct drm_crtc *crtc;
bool enabled;
int hwindex; /* 0-based, -1 means unused */ int hwindex; /* 0-based, -1 means unused */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment