regmap: Skip patch application when the cache is not dirty on sync
Mark Brown [Wed, 25 Jan 2012 21:06:33 +0000 (21:06 +0000)]
On the basis that if we don't actually need to resync the cache then the
patches are probably also already applied.

Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
(cherry picked from commit d9db762708e27c2892db9d8a54e735a8e506e16e)

Change-Id: I1b41ea112ae97812be6c9e2e3ea8c490e0835732
Signed-off-by: Laxman Dewangan <ldewangan@nvidia.com>
Reviewed-on: http://git-master/r/87579

Rebase-Id: Rdbc40fe28a638ea6ddb720e486139647992fa8cf

drivers/base/regmap/regcache.c

index 920a8fa..df2c9e4 100644 (file)
@@ -267,6 +267,9 @@ int regcache_sync(struct regmap *map)
        name = map->cache_ops->name;
        trace_regcache_sync(map->dev, name, "start");
 
+       if (!map->cache_dirty)
+               goto out;
+
        /* Apply any patch first */
        for (i = 0; i < map->patch_regs; i++) {
                ret = _regmap_write(map, map->patch[i].reg, map->patch[i].def);
@@ -277,8 +280,6 @@ int regcache_sync(struct regmap *map)
                }
        }
 
-       if (!map->cache_dirty)
-               goto out;
        if (map->cache_ops->sync) {
                ret = map->cache_ops->sync(map);
        } else {