Re: [PATCH] i2c: designware: do not disable adapter after transfer

From: Lucas De Marchi
Date: Mon Apr 25 2016 - 11:04:55 EST




On 04/25/2016 08:51 AM, Jarkko Nikula wrote:

[ ... ]

@@ -413,8 +416,16 @@ static void i2c_dw_xfer_init(struct dw_i2c_dev *dev)
struct i2c_msg *msgs = dev->msgs;
u32 ic_con, ic_tar = 0;

- /* Disable the adapter */
- __i2c_dw_enable(dev, false);
+ if (dev->enabled) {
+ u32 ic_status;
+
+ /* check ic_tar and ic_con can be dynamically updated */
+ ic_status = dw_readl(dev, DW_IC_STATUS);
+ if (ic_status & DW_IC_STATUS_ACTIVITY
+ || !(ic_status & DW_IC_STATUS_TX_EMPTY)) {
+ __i2c_dw_enable(dev, false);
+ }
+ }

Worth to double check this. I see bit 1 means TX FIFO not full and bit 2
is TX FIFO completely empty.

the conditions to be able to update IC_TAR dynamically are:

- Adapter isn't doing any TX/RX operation (IC_STATUS[5] == 0) and
- There are no entries in TX FIFO (IC_STATUS[2] == 1)

So... yeah, the condition above seems wrong. I should be reading bit 5, not bit 1. Thanks! However:

IC_STATUS[5] signals activity for master mode
IC_STATUS[6] signals activity for slave mode
IC_STATUS[0] is IC_STATUS[5]|IC_STATUS[6]

And this controller is never in slave mode, only master mode, so it should be equivalent.

I wonder if I even have to check bit 5 since AFAICS we wouldn't be able to even call this function if there were any operation on tx/rx.


Otherwise I'm fine with the patch as long as it works for Christian.


Anyway, I'll re-test with bit 5 checked and send an update.


Lucas De Marchi