drm/omap: Remove duplicate calls to .set_timings() operation
authorLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Mon, 4 Jun 2018 23:06:54 +0000 (02:06 +0300)
committerTomi Valkeinen <tomi.valkeinen@ti.com>
Mon, 3 Sep 2018 13:13:29 +0000 (16:13 +0300)
The omap_dss_device .set_timings() operations are called directly from
omap_encoder_update(), and indirectly from the omap_dss_device .enable()
operation. The latter is called from omap_encoder_enable(), right after
calling omap_encoder_update(). The .set_timings() operation it thus
called twice in a row. Fix it by removing the indirect call.

Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Reviewed-by: Sebastian Reichel <sebastian.reichel@collabora.co.uk>
Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
13 files changed:
drivers/gpu/drm/omapdrm/displays/connector-analog-tv.c
drivers/gpu/drm/omapdrm/displays/connector-dvi.c
drivers/gpu/drm/omapdrm/displays/connector-hdmi.c
drivers/gpu/drm/omapdrm/displays/encoder-opa362.c
drivers/gpu/drm/omapdrm/displays/encoder-tfp410.c
drivers/gpu/drm/omapdrm/displays/encoder-tpd12s015.c
drivers/gpu/drm/omapdrm/displays/panel-dpi.c
drivers/gpu/drm/omapdrm/displays/panel-lgphilips-lb035q02.c
drivers/gpu/drm/omapdrm/displays/panel-nec-nl8048hl11.c
drivers/gpu/drm/omapdrm/displays/panel-sharp-ls037v7dw01.c
drivers/gpu/drm/omapdrm/displays/panel-sony-acx565akm.c
drivers/gpu/drm/omapdrm/displays/panel-tpo-td028ttec1.c
drivers/gpu/drm/omapdrm/displays/panel-tpo-td043mtea1.c

index 22bc2e7..fb6d4fc 100644 (file)
@@ -66,8 +66,6 @@ static int tvc_enable(struct omap_dss_device *dssdev)
        if (omapdss_device_is_enabled(dssdev))
                return 0;
 
-       src->ops->set_timings(src, &ddata->vm);
-
        r = src->ops->enable(src);
        if (r)
                return r;
index 8f95330..b89555e 100644 (file)
@@ -69,7 +69,6 @@ static void dvic_disconnect(struct omap_dss_device *src,
 
 static int dvic_enable(struct omap_dss_device *dssdev)
 {
-       struct panel_drv_data *ddata = to_panel_data(dssdev);
        struct omap_dss_device *src = dssdev->src;
        int r;
 
@@ -79,8 +78,6 @@ static int dvic_enable(struct omap_dss_device *dssdev)
        if (omapdss_device_is_enabled(dssdev))
                return 0;
 
-       src->ops->set_timings(src, &ddata->vm);
-
        r = src->ops->enable(src);
        if (r)
                return r;
index 1cbc593..898eb58 100644 (file)
@@ -71,8 +71,6 @@ static int hdmic_enable(struct omap_dss_device *dssdev)
        if (omapdss_device_is_enabled(dssdev))
                return 0;
 
-       src->ops->set_timings(src, &ddata->vm);
-
        r = src->ops->enable(src);
        if (r)
                return r;
index 19d1804..824f302 100644 (file)
@@ -57,8 +57,6 @@ static int opa362_enable(struct omap_dss_device *dssdev)
        if (omapdss_device_is_enabled(dssdev))
                return 0;
 
-       src->ops->set_timings(src, &ddata->vm);
-
        r = src->ops->enable(src);
        if (r)
                return r;
index fa6ed1e..de42339 100644 (file)
@@ -50,8 +50,6 @@ static int tfp410_enable(struct omap_dss_device *dssdev)
        if (omapdss_device_is_enabled(dssdev))
                return 0;
 
-       src->ops->set_timings(src, &ddata->vm);
-
        r = src->ops->enable(src);
        if (r)
                return r;
index 21c2667..d9a5902 100644 (file)
@@ -66,15 +66,12 @@ static void tpd_disconnect(struct omap_dss_device *src,
 
 static int tpd_enable(struct omap_dss_device *dssdev)
 {
-       struct panel_drv_data *ddata = to_panel_data(dssdev);
        struct omap_dss_device *src = dssdev->src;
        int r;
 
        if (dssdev->state == OMAP_DSS_DISPLAY_ACTIVE)
                return 0;
 
-       src->ops->set_timings(src, &ddata->vm);
-
        r = src->ops->enable(src);
        if (r)
                return r;
index b2f17b2..32efed4 100644 (file)
@@ -57,8 +57,6 @@ static int panel_dpi_enable(struct omap_dss_device *dssdev)
        if (omapdss_device_is_enabled(dssdev))
                return 0;
 
-       src->ops->set_timings(src, &ddata->vm);
-
        r = src->ops->enable(src);
        if (r)
                return r;
index 1121d1e..ffa69fd 100644 (file)
@@ -142,8 +142,6 @@ static int lb035q02_enable(struct omap_dss_device *dssdev)
        if (omapdss_device_is_enabled(dssdev))
                return 0;
 
-       src->ops->set_timings(src, &ddata->vm);
-
        r = src->ops->enable(src);
        if (r)
                return r;
index 248a8f1..26af95a 100644 (file)
@@ -132,8 +132,6 @@ static int nec_8048_enable(struct omap_dss_device *dssdev)
        if (omapdss_device_is_enabled(dssdev))
                return 0;
 
-       src->ops->set_timings(src, &ddata->vm);
-
        r = src->ops->enable(src);
        if (r)
                return r;
index ef696e1..a83cd9f 100644 (file)
@@ -80,8 +80,6 @@ static int sharp_ls_enable(struct omap_dss_device *dssdev)
        if (omapdss_device_is_enabled(dssdev))
                return 0;
 
-       src->ops->set_timings(src, &ddata->vm);
-
        if (ddata->vcc) {
                r = regulator_enable(ddata->vcc);
                if (r != 0)
index 7be58da..8e45c5e 100644 (file)
@@ -523,8 +523,6 @@ static int acx565akm_panel_power_on(struct omap_dss_device *dssdev)
 
        dev_dbg(&ddata->spi->dev, "%s\n", __func__);
 
-       src->ops->set_timings(src, &ddata->vm);
-
        r = src->ops->enable(src);
        if (r) {
                pr_err("%s sdi enable failed\n", __func__);
index 087f62f..b2a16c4 100644 (file)
@@ -187,8 +187,6 @@ static int td028ttec1_panel_enable(struct omap_dss_device *dssdev)
        if (omapdss_device_is_enabled(dssdev))
                return 0;
 
-       src->ops->set_timings(src, &ddata->vm);
-
        r = src->ops->enable(src);
        if (r)
                return r;
index 7bc602d..42f80b3 100644 (file)
@@ -338,8 +338,6 @@ static int tpo_td043_enable(struct omap_dss_device *dssdev)
        if (omapdss_device_is_enabled(dssdev))
                return 0;
 
-       src->ops->set_timings(src, &ddata->vm);
-
        r = src->ops->enable(src);
        if (r)
                return r;