summaryrefslogtreecommitdiff
path: root/drivers/base/regmap
diff options
context:
space:
mode:
authorColin Patrick McCabe <cmccabe@nvidia.com>2011-10-20 14:44:17 -0700
committerDan Willemsen <dwillemsen@nvidia.com>2011-11-30 21:50:22 -0800
commit9f655d719048c0eda67e041f365325f07ac0eef5 (patch)
tree2c27609462166c9f3ef58d1e028986827aa2fc0f /drivers/base/regmap
parentdb543c71362406d616fad89f11dff88e80ea71dd (diff)
regmap: add regmap_update_bits_lazy
Add regmap_update_bits_lazy. Like regmap_update_bits, this performs a read-modify-write cycle on a regmap register, but it skips the write if nothing has changed. Change-Id: Id075f711770a6bf15dea9ae085593fef268491ac Signed-off-by: Colin Patrick McCabe <cmccabe@nvidia.com> Reviewed-on: http://git-master/r/59460 Reviewed-by: Dan Willemsen <dwillemsen@nvidia.com> Rebase-Id: R93e1c3cf4a506cb17346f4e981a60350846a856e
Diffstat (limited to 'drivers/base/regmap')
-rw-r--r--drivers/base/regmap/regmap.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/drivers/base/regmap/regmap.c b/drivers/base/regmap/regmap.c
index 20663f8dae45..843f722ff9cd 100644
--- a/drivers/base/regmap/regmap.c
+++ b/drivers/base/regmap/regmap.c
@@ -450,3 +450,39 @@ out:
return ret;
}
EXPORT_SYMBOL_GPL(regmap_update_bits);
+
+/**
+ * remap_update_bits_lazy: Perform a read/modify/write cycle on the register
+ * map. Only write new contents if they differ from the previous ones.
+ *
+ * @map: Register map to update
+ * @reg: Register to update
+ * @mask: Bitmask to change
+ * @val: New value for bitmask
+ *
+ * Returns zero for success, a negative number on error.
+ */
+int regmap_update_bits_lazy(struct regmap *map, unsigned int reg,
+ unsigned int mask, unsigned int val)
+{
+ int ret, new;
+ unsigned int tmp;
+
+ mutex_lock(&map->lock);
+
+ ret = _regmap_read(map, reg, &tmp);
+ if (ret != 0)
+ goto out;
+
+ new = tmp & ~mask;
+ new |= val & mask;
+ if (new != tmp) {
+ ret = _regmap_write(map, reg, new);
+ }
+
+out:
+ mutex_unlock(&map->lock);
+
+ return ret;
+}
+EXPORT_SYMBOL_GPL(regmap_update_bits_lazy);