Skip to content

Commit ad22b3e

Browse files
Aidan MacDonaldbroonie
authored andcommitted
regmap-irq: Remove mask_writeonly and regmap_irq_update_bits()
Commit a71411d ("regmap: irq: add chip option mask_writeonly") introduced the mask_writeonly option, but it isn't used now and it appears it's never been used by any in-tree drivers. The motivation for the option is mentioned in the commit message, Some irq controllers have writeonly/multipurpose register layouts. In those cases we read invalid data back. [...] The option causes mask register updates to use regmap_write_bits() instead of regmap_update_bits(). However, regmap_write_bits() doesn't solve the reading invalid data problem. It's still a read-modify-write op like regmap_update_bits(). The difference is that 'update bits' will only write the new value if it is different from the current value, while 'write bits' will write the new value unconditionally, even if it's the same as the current value. This seems like a bit of a specialized use case and probably isn't that useful for regmap-irq, so let's just remove the option and go back to using an 'update bits' op for the mask registers. We can always add the option back if some driver ends up needing it in the future. Signed-off-by: Aidan MacDonald <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Mark Brown <[email protected]>
1 parent 6b0c317 commit ad22b3e

File tree

2 files changed

+7
-19
lines changed

2 files changed

+7
-19
lines changed

drivers/base/regmap/regmap-irq.c

Lines changed: 7 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -80,16 +80,6 @@ static void regmap_irq_lock(struct irq_data *data)
8080
mutex_lock(&d->lock);
8181
}
8282

83-
static int regmap_irq_update_bits(struct regmap_irq_chip_data *d,
84-
unsigned int reg, unsigned int mask,
85-
unsigned int val)
86-
{
87-
if (d->chip->mask_writeonly)
88-
return regmap_write_bits(d->map, reg, mask, val);
89-
else
90-
return regmap_update_bits(d->map, reg, mask, val);
91-
}
92-
9383
static void regmap_irq_sync_unlock(struct irq_data *data)
9484
{
9585
struct regmap_irq_chip_data *d = irq_data_get_irq_chip_data(data);
@@ -130,11 +120,11 @@ static void regmap_irq_sync_unlock(struct irq_data *data)
130120

131121
reg = sub_irq_reg(d, d->chip->mask_base, i);
132122
if (d->chip->mask_invert) {
133-
ret = regmap_irq_update_bits(d, reg,
123+
ret = regmap_update_bits(d->map, reg,
134124
d->mask_buf_def[i], ~d->mask_buf[i]);
135125
} else if (d->chip->unmask_base) {
136126
/* set mask with mask_base register */
137-
ret = regmap_irq_update_bits(d, reg,
127+
ret = regmap_update_bits(d->map, reg,
138128
d->mask_buf_def[i], ~d->mask_buf[i]);
139129
if (ret < 0)
140130
dev_err(d->map->dev,
@@ -143,12 +133,12 @@ static void regmap_irq_sync_unlock(struct irq_data *data)
143133
unmask_offset = d->chip->unmask_base -
144134
d->chip->mask_base;
145135
/* clear mask with unmask_base register */
146-
ret = regmap_irq_update_bits(d,
136+
ret = regmap_update_bits(d->map,
147137
reg + unmask_offset,
148138
d->mask_buf_def[i],
149139
d->mask_buf[i]);
150140
} else {
151-
ret = regmap_irq_update_bits(d, reg,
141+
ret = regmap_update_bits(d->map, reg,
152142
d->mask_buf_def[i], d->mask_buf[i]);
153143
}
154144
if (ret != 0)
@@ -763,17 +753,17 @@ int regmap_add_irq_chip_fwnode(struct fwnode_handle *fwnode,
763753
reg = sub_irq_reg(d, d->chip->mask_base, i);
764754

765755
if (chip->mask_invert)
766-
ret = regmap_irq_update_bits(d, reg,
756+
ret = regmap_update_bits(d->map, reg,
767757
d->mask_buf[i], ~d->mask_buf[i]);
768758
else if (d->chip->unmask_base) {
769759
unmask_offset = d->chip->unmask_base -
770760
d->chip->mask_base;
771-
ret = regmap_irq_update_bits(d,
761+
ret = regmap_update_bits(d->map,
772762
reg + unmask_offset,
773763
d->mask_buf[i],
774764
d->mask_buf[i]);
775765
} else
776-
ret = regmap_irq_update_bits(d, reg,
766+
ret = regmap_update_bits(d->map, reg,
777767
d->mask_buf[i], d->mask_buf[i]);
778768
if (ret != 0) {
779769
dev_err(map->dev, "Failed to set masks in 0x%x: %d\n",

include/linux/regmap.h

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1468,7 +1468,6 @@ struct regmap_irq_sub_irq_map {
14681468
*
14691469
* @status_base: Base status register address.
14701470
* @mask_base: Base mask register address.
1471-
* @mask_writeonly: Base mask register is write only.
14721471
* @unmask_base: Base unmask register address. for chips who have
14731472
* separate mask and unmask registers
14741473
* @ack_base: Base ack address. If zero then the chip is clear on read.
@@ -1534,7 +1533,6 @@ struct regmap_irq_chip {
15341533
unsigned int type_base;
15351534
unsigned int *virt_reg_base;
15361535
unsigned int irq_reg_stride;
1537-
unsigned int mask_writeonly:1;
15381536
unsigned int init_ack_masked:1;
15391537
unsigned int mask_invert:1;
15401538
unsigned int use_ack:1;

0 commit comments

Comments
 (0)