drm/omap: Move common display enable/disable code to encoder
All .enable() and .disable() handlers for panels and connectors share common code that validates and updates the device's state. Move it to common locations in the omap_encoder_enable() and omap_encoder_disable() handlers. The enabled check in the .disable() handler is left untouched, it will be addressed separately. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Sebastian Reichel <sebastian.reichel@collabora.com> Tested-by: Sebastian Reichel <sebastian.reichel@collabora.com> Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
This commit is contained in:

committed by
Tomi Valkeinen

parent
d2c53162f5
commit
b80bfc66b0
@@ -147,21 +147,45 @@ static void omap_encoder_disable(struct drm_encoder *encoder)
|
||||
{
|
||||
struct omap_encoder *omap_encoder = to_omap_encoder(encoder);
|
||||
struct omap_dss_device *dssdev = omap_encoder->display;
|
||||
struct drm_device *dev = encoder->dev;
|
||||
|
||||
dev_dbg(dev->dev, "disable(%s)\n", dssdev->name);
|
||||
|
||||
if (!omapdss_device_is_enabled(dssdev))
|
||||
return;
|
||||
|
||||
dssdev->ops->disable(dssdev);
|
||||
|
||||
dssdev->state = OMAP_DSS_DISPLAY_DISABLED;
|
||||
}
|
||||
|
||||
static void omap_encoder_enable(struct drm_encoder *encoder)
|
||||
{
|
||||
struct omap_encoder *omap_encoder = to_omap_encoder(encoder);
|
||||
struct omap_dss_device *dssdev = omap_encoder->display;
|
||||
struct drm_device *dev = encoder->dev;
|
||||
int r;
|
||||
|
||||
dev_dbg(dev->dev, "enable(%s)\n", dssdev->name);
|
||||
|
||||
if (!omapdss_device_is_connected(dssdev)) {
|
||||
r = -ENODEV;
|
||||
goto error;
|
||||
}
|
||||
|
||||
if (omapdss_device_is_enabled(dssdev))
|
||||
return;
|
||||
|
||||
r = dssdev->ops->enable(dssdev);
|
||||
if (r)
|
||||
dev_err(encoder->dev->dev,
|
||||
"Failed to enable display '%s': %d\n",
|
||||
dssdev->name, r);
|
||||
goto error;
|
||||
|
||||
dssdev->state = OMAP_DSS_DISPLAY_ACTIVE;
|
||||
return;
|
||||
|
||||
error:
|
||||
dev_err(dev->dev, "Failed to enable display '%s': %d\n",
|
||||
dssdev->name, r);
|
||||
}
|
||||
|
||||
static int omap_encoder_atomic_check(struct drm_encoder *encoder,
|
||||
|
Reference in New Issue
Block a user