Skip to content

Commit 66b9231

Browse files
Michael Wuwsakernel
authored andcommitted
i2c: designware: call i2c_dw_read_clear_intrbits_slave() once
If some bits were cleared by i2c_dw_read_clear_intrbits_slave() in i2c_dw_isr_slave() and not handled immediately, those cleared bits would not be shown again by later i2c_dw_read_clear_intrbits_slave(). They therefore were forgotten to be handled. i2c_dw_read_clear_intrbits_slave() should be called once in an ISR and take its returned state for all later handlings. Signed-off-by: Michael Wu <michael.wu@vatics.com> Acked-by: Jarkko Nikula <jarkko.nikula@linux.intel.com> Signed-off-by: Wolfram Sang <wsa@kernel.org>
1 parent 9890923 commit 66b9231

1 file changed

Lines changed: 1 addition & 6 deletions

File tree

drivers/i2c/busses/i2c-designware-slave.c

Lines changed: 1 addition & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -159,7 +159,6 @@ static int i2c_dw_irq_handler_slave(struct dw_i2c_dev *dev)
159159
u32 raw_stat, stat, enabled, tmp;
160160
u8 val = 0, slave_activity;
161161

162-
regmap_read(dev->map, DW_IC_INTR_STAT, &stat);
163162
regmap_read(dev->map, DW_IC_ENABLE, &enabled);
164163
regmap_read(dev->map, DW_IC_RAW_INTR_STAT, &raw_stat);
165164
regmap_read(dev->map, DW_IC_STATUS, &tmp);
@@ -168,6 +167,7 @@ static int i2c_dw_irq_handler_slave(struct dw_i2c_dev *dev)
168167
if (!enabled || !(raw_stat & ~DW_IC_INTR_ACTIVITY) || !dev->slave)
169168
return 0;
170169

170+
stat = i2c_dw_read_clear_intrbits_slave(dev);
171171
dev_dbg(dev->dev,
172172
"%#x STATUS SLAVE_ACTIVITY=%#x : RAW_INTR_STAT=%#x : INTR_STAT=%#x\n",
173173
enabled, slave_activity, raw_stat, stat);
@@ -188,11 +188,9 @@ static int i2c_dw_irq_handler_slave(struct dw_i2c_dev *dev)
188188
val);
189189
}
190190
regmap_read(dev->map, DW_IC_CLR_RD_REQ, &tmp);
191-
stat = i2c_dw_read_clear_intrbits_slave(dev);
192191
} else {
193192
regmap_read(dev->map, DW_IC_CLR_RD_REQ, &tmp);
194193
regmap_read(dev->map, DW_IC_CLR_RX_UNDER, &tmp);
195-
stat = i2c_dw_read_clear_intrbits_slave(dev);
196194
}
197195
if (!i2c_slave_event(dev->slave,
198196
I2C_SLAVE_READ_REQUESTED,
@@ -207,7 +205,6 @@ static int i2c_dw_irq_handler_slave(struct dw_i2c_dev *dev)
207205
regmap_read(dev->map, DW_IC_CLR_RX_DONE, &tmp);
208206

209207
i2c_slave_event(dev->slave, I2C_SLAVE_STOP, &val);
210-
stat = i2c_dw_read_clear_intrbits_slave(dev);
211208
return 1;
212209
}
213210

@@ -219,7 +216,6 @@ static int i2c_dw_irq_handler_slave(struct dw_i2c_dev *dev)
219216
dev_vdbg(dev->dev, "Byte %X acked!", val);
220217
} else {
221218
i2c_slave_event(dev->slave, I2C_SLAVE_STOP, &val);
222-
stat = i2c_dw_read_clear_intrbits_slave(dev);
223219
}
224220

225221
return 1;
@@ -230,7 +226,6 @@ static irqreturn_t i2c_dw_isr_slave(int this_irq, void *dev_id)
230226
struct dw_i2c_dev *dev = dev_id;
231227
int ret;
232228

233-
i2c_dw_read_clear_intrbits_slave(dev);
234229
ret = i2c_dw_irq_handler_slave(dev);
235230
if (ret > 0)
236231
complete(&dev->cmd_complete);

0 commit comments

Comments
 (0)