regmap: cache: Handle stride > 1 in sync_block_raw_flush
authorDylan Reid <dgreid@chromium.org>
Fri, 24 Jan 2014 23:40:39 +0000 (15:40 -0800)
committerMark Brown <broonie@linaro.org>
Mon, 27 Jan 2014 18:25:11 +0000 (18:25 +0000)
regcache_sync_block_raw_flush takes the address of the base register
and the address of one past the last register to write to.  "count" is
the number of registers in the range, not the number of bytes, it
should be (end addr - start addr) / stride. Without accounting for
strides greater than one, registers past the end might be synced or
the writeable_reg callback at the beginning of _regmap_raw_write will
fail and nothing will be written.

Signed-off-by: Dylan Reid <dgreid@chromium.org>
Signed-off-by: Mark Brown <broonie@linaro.org>
drivers/base/regmap/regcache.c

index d4dd77134814bac1a8ba2bc91a817c1cc2002454..dd56177b7010823407a6ec4074c307eac9ad5ec2 100644 (file)
@@ -636,10 +636,10 @@ static int regcache_sync_block_raw_flush(struct regmap *map, const void **data,
        if (*data == NULL)
                return 0;
 
-       count = cur - base;
+       count = (cur - base) / map->reg_stride;
 
        dev_dbg(map->dev, "Writing %zu bytes for %d registers from 0x%x-0x%x\n",
-               count * val_bytes, count, base, cur - 1);
+               count * val_bytes, count, base, cur - map->reg_stride);
 
        map->cache_bypass = 1;