aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/base
diff options
context:
space:
mode:
authorMark Brown <broonie@opensource.wolfsonmicro.com>2011-10-09 07:54:25 -0400
committerMark Brown <broonie@opensource.wolfsonmicro.com>2011-10-10 05:26:48 -0400
commitb03622a80d2206c4179d6a41a0dc5cfbdfc853ee (patch)
tree7f0e02bbddfd3930e3aabe553d9efb4c423c47fa /drivers/base
parente42c5a9a4230c38ceba0a890b30a2d0dd9314bff (diff)
regmap: Ensure rbtree syncs registers set to zero properly
Simplify the check for registers set at their default value by avoiding picking a default value in the case where we don't have one. Instead we only compare the current value to the current value when we looked one up. This fixes the case where we don't have a default stored but the value was set to zero when that isn't the chip default. Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com> Acked-by: Dimitris Papastamos <dp@opensource.wolfsonmicro.com>
Diffstat (limited to 'drivers/base')
-rw-r--r--drivers/base/regmap/regcache-rbtree.c11
1 files changed, 5 insertions, 6 deletions
diff --git a/drivers/base/regmap/regcache-rbtree.c b/drivers/base/regmap/regcache-rbtree.c
index 52511f95857..e31498499b0 100644
--- a/drivers/base/regmap/regcache-rbtree.c
+++ b/drivers/base/regmap/regcache-rbtree.c
@@ -304,7 +304,7 @@ static int regcache_rbtree_sync(struct regmap *map)
304 struct rb_node *node; 304 struct rb_node *node;
305 struct regcache_rbtree_node *rbnode; 305 struct regcache_rbtree_node *rbnode;
306 unsigned int regtmp; 306 unsigned int regtmp;
307 unsigned int val, def; 307 unsigned int val;
308 int ret; 308 int ret;
309 int i; 309 int i;
310 310
@@ -315,13 +315,12 @@ static int regcache_rbtree_sync(struct regmap *map)
315 regtmp = rbnode->base_reg + i; 315 regtmp = rbnode->base_reg + i;
316 val = regcache_rbtree_get_register(rbnode, i, 316 val = regcache_rbtree_get_register(rbnode, i,
317 map->cache_word_size); 317 map->cache_word_size);
318
319 /* Is this the hardware default? If so skip. */
318 ret = regcache_lookup_reg(map, i); 320 ret = regcache_lookup_reg(map, i);
319 if (ret < 0) 321 if (ret > 0 && val == map->reg_defaults[ret].def)
320 def = 0;
321 else
322 def = map->reg_defaults[ret].def;
323 if (val == def)
324 continue; 322 continue;
323
325 map->cache_bypass = 1; 324 map->cache_bypass = 1;
326 ret = _regmap_write(map, regtmp, val); 325 ret = _regmap_write(map, regtmp, val);
327 map->cache_bypass = 0; 326 map->cache_bypass = 0;