]> Pileus Git - ~andy/linux/commitdiff
OMAPDSS: APPLY: skip enable/disable if already enabled/disabled
authorTomi Valkeinen <tomi.valkeinen@ti.com>
Wed, 16 Nov 2011 14:01:33 +0000 (16:01 +0200)
committerTomi Valkeinen <tomi.valkeinen@ti.com>
Fri, 2 Dec 2011 06:54:50 +0000 (08:54 +0200)
Add checks to dss_mgr_enable, dss_mgr_disable, dss_ovl_enable,
dss_ovl_disable that check if the state is already the same as given in
the parameters, and exit if so.

Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
drivers/video/omap2/dss/apply.c

index ec21837216425038e54b5b7cc6e38e1056477e1d..27d13bd9ed1045abe5e63abd0fa10d7ba3a56f47 100644 (file)
@@ -724,6 +724,9 @@ void dss_mgr_enable(struct omap_overlay_manager *mgr)
 
        mutex_lock(&apply_lock);
 
+       if (mp->enabled)
+               goto out;
+
        spin_lock_irqsave(&data_lock, flags);
 
        mp->enabled = true;
@@ -740,6 +743,7 @@ void dss_mgr_enable(struct omap_overlay_manager *mgr)
        if (!mgr_manual_update(mgr))
                dispc_mgr_enable(mgr->id, true);
 
+out:
        mutex_unlock(&apply_lock);
 }
 
@@ -750,6 +754,9 @@ void dss_mgr_disable(struct omap_overlay_manager *mgr)
 
        mutex_lock(&apply_lock);
 
+       if (!mp->enabled)
+               goto out;
+
        if (!mgr_manual_update(mgr))
                dispc_mgr_enable(mgr->id, false);
 
@@ -760,6 +767,7 @@ void dss_mgr_disable(struct omap_overlay_manager *mgr)
 
        spin_unlock_irqrestore(&data_lock, flags);
 
+out:
        mutex_unlock(&apply_lock);
 }
 
@@ -1005,6 +1013,11 @@ int dss_ovl_enable(struct omap_overlay *ovl)
 
        mutex_lock(&apply_lock);
 
+       if (op->enabled) {
+               r = 0;
+               goto err;
+       }
+
        if (ovl->manager == NULL || ovl->manager->device == NULL) {
                r = -EINVAL;
                goto err;
@@ -1036,6 +1049,11 @@ int dss_ovl_disable(struct omap_overlay *ovl)
 
        mutex_lock(&apply_lock);
 
+       if (!op->enabled) {
+               r = 0;
+               goto err;
+       }
+
        if (ovl->manager == NULL || ovl->manager->device == NULL) {
                r = -EINVAL;
                goto err;