Re: [PATCH] i2c: designware: slave should do WRITE_RECEIVED before SLAVE_STOP
From: Andy Shevchenko
Date: Mon Oct 10 2022 - 02:58:15 EST
On Mon, Oct 10, 2022 at 11:40:15AM +0800, tianye@xxxxxxxxx wrote:
> From: Tian Ye <tianye@xxxxxxxxx>
>
> Sometimes when designware slave receive 3byte in high speed mode:
DesignWare
3 bytes
> 0x1 STATUS SLAVE_ACTIVITY=0x1 : RAW_INTR_STAT=0x514 : INTR_STAT=0x4
> I2C_SLAVE_WRITE_REQUESTED
> I2C_SLAVE_WRITE_RECEIVED
> 0x1 STATUS SLAVE_ACTIVITY=0 : RAW_INTR_STAT=0x714 : INTR_STAT=0x204
> I2C_SLAVE_WRITE_RECEIVED
> I2C_SLAVE_STOP
> 0x1 STATUS SLAVE_ACTIVITY=0x1 : RAW_INTR_STAT=0x514 : INTR_STAT=0x4
> I2C_SLAVE_WRITE_REQUESTED
> I2C_SLAVE_WRITE_RECEIVED
>
> When second slave interrupt occus:slave rx fifo receive two bytes and
occurs: slave Rx FIFO receives 2 bytes
> stop interrupt occus at the same time.
occurs
...
Please, do a spell check / proof reading of the commit messages.
...
> + u32 rx_valid;
> + regmap_read(dev, DW_IC_RXFLR, &rx_valid);
If regmap_read() fails, rx_valid will contain garbage...
> + for (; rx_valid > 0; rx_valid--) {
...and this will go far beyond the expected boundaries.
> + regmap_read(dev->map, DW_IC_DATA_CMD, &tmp);
> + val = tmp;
> + if (!i2c_slave_event(dev->slave, I2C_SLAVE_WRITE_RECEIVED,
> + &val))
> + dev_vdbg(dev->dev, "Byte %X acked!", val);
Why do you need this? regmap has it's own trace event mechanism, isn't it
enough?
> + }
--
With Best Regards,
Andy Shevchenko