From: Lars-Peter Clausen Date: Fri, 23 Mar 2012 10:04:57 +0000 (+0100) Subject: regmap: rbtree: Fix register default look-up in sync X-Git-Tag: firefly_0821_release~3680^2~3138^2 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=4b4e9e43fd210e0cd2a5d29357e7c000e13e08ae;p=firefly-linux-kernel-4.4.55.git regmap: rbtree: Fix register default look-up in sync The code currently passes the register offset in the current block to regcache_lookup_reg. This works fine as long as there is only one block and with base register of 0, but in all other cases it will look-up the default for a wrong register, which can cause unnecessary register writes. This patch fixes it by passing the actual register number to regcache_lookup_reg. Signed-off-by: Lars-Peter Clausen Signed-off-by: Mark Brown Cc: --- diff --git a/drivers/base/regmap/regcache-rbtree.c b/drivers/base/regmap/regcache-rbtree.c index 5157fa04c2f0..fb14a6343d4f 100644 --- a/drivers/base/regmap/regcache-rbtree.c +++ b/drivers/base/regmap/regcache-rbtree.c @@ -396,7 +396,7 @@ static int regcache_rbtree_sync(struct regmap *map, unsigned int min, map->cache_word_size); /* Is this the hardware default? If so skip. */ - ret = regcache_lookup_reg(map, i); + ret = regcache_lookup_reg(map, regtmp); if (ret >= 0 && val == map->reg_defaults[ret].def) continue;