aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>2016-02-15 00:25:15 -0500
committerMark Brown <broonie@kernel.org>2016-02-19 11:15:56 -0500
commitbbf2c46f46e23a496337e143cd012c013c6c7910 (patch)
tree984bbaa66791e185fae496d560413343f7e486f1
parente126edec184ea3049cc1f8b652c6eeb06aa65fda (diff)
regmap: merge regmap_fields_write() into macro
This patch merges regmap_fields_write() into macro by using regmap_fields_update_bits_base(). Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com> Signed-off-by: Mark Brown <broonie@kernel.org>
-rw-r--r--drivers/base/regmap/regmap.c22
-rw-r--r--include/linux/regmap.h5
2 files changed, 3 insertions, 24 deletions
diff --git a/drivers/base/regmap/regmap.c b/drivers/base/regmap/regmap.c
index 0c7773fadd48..4b14745249ba 100644
--- a/drivers/base/regmap/regmap.c
+++ b/drivers/base/regmap/regmap.c
@@ -1748,28 +1748,6 @@ int regmap_fields_update_bits_base(struct regmap_field *field, unsigned int id,
1748} 1748}
1749EXPORT_SYMBOL_GPL(regmap_fields_update_bits_base); 1749EXPORT_SYMBOL_GPL(regmap_fields_update_bits_base);
1750 1750
1751/**
1752 * regmap_fields_write(): Write a value to a single register field with port ID
1753 *
1754 * @field: Register field to write to
1755 * @id: port ID
1756 * @val: Value to be written
1757 *
1758 * A value of zero will be returned on success, a negative errno will
1759 * be returned in error cases.
1760 */
1761int regmap_fields_write(struct regmap_field *field, unsigned int id,
1762 unsigned int val)
1763{
1764 if (id >= field->id_size)
1765 return -EINVAL;
1766
1767 return regmap_update_bits(field->regmap,
1768 field->reg + (field->id_offset * id),
1769 field->mask, val << field->shift);
1770}
1771EXPORT_SYMBOL_GPL(regmap_fields_write);
1772
1773int regmap_fields_force_write(struct regmap_field *field, unsigned int id, 1751int regmap_fields_force_write(struct regmap_field *field, unsigned int id,
1774 unsigned int val) 1752 unsigned int val)
1775{ 1753{
diff --git a/include/linux/regmap.h b/include/linux/regmap.h
index 2735a3df7eab..5f438a4df5e6 100644
--- a/include/linux/regmap.h
+++ b/include/linux/regmap.h
@@ -79,6 +79,9 @@ struct reg_sequence {
79#define regmap_field_update_bits(field, mask, val)\ 79#define regmap_field_update_bits(field, mask, val)\
80 regmap_field_update_bits_base(field, mask, val, NULL, false, false) 80 regmap_field_update_bits_base(field, mask, val, NULL, false, false)
81 81
82#define regmap_fields_write(field, id, val) \
83 regmap_fields_update_bits_base(field, id, ~0, val, NULL, false, false)
84
82#ifdef CONFIG_REGMAP 85#ifdef CONFIG_REGMAP
83 86
84enum regmap_endian { 87enum regmap_endian {
@@ -780,8 +783,6 @@ int regmap_field_read(struct regmap_field *field, unsigned int *val);
780int regmap_field_update_bits_base(struct regmap_field *field, 783int regmap_field_update_bits_base(struct regmap_field *field,
781 unsigned int mask, unsigned int val, 784 unsigned int mask, unsigned int val,
782 bool *change, bool async, bool force); 785 bool *change, bool async, bool force);
783int regmap_fields_write(struct regmap_field *field, unsigned int id,
784 unsigned int val);
785int regmap_fields_force_write(struct regmap_field *field, unsigned int id, 786int regmap_fields_force_write(struct regmap_field *field, unsigned int id,
786 unsigned int val); 787 unsigned int val);
787int regmap_fields_read(struct regmap_field *field, unsigned int id, 788int regmap_fields_read(struct regmap_field *field, unsigned int id,