[PATCH] i2c: mvtwsi: Swab the register address if its size is > 1

Stefan Roese sr at denx.de
Sat Dec 18 14:42:51 CET 2021


Hi Heiko,

On 11/18/21 09:18, Stefan Roese wrote:
> Testing on Armada XP with an EEPROM using register address with size
> of 2 has shown, that the register address bytes are sent to the I2C
> EEPROM in the incorrect order. This patch swabs the address bytes so
> that the correct address is transferred to the I2C device.
> 
> BTW: This worked without any issues before migrating Armada XP to
> DM I2C.
> 
> Signed-off-by: Stefan Roese <sr at denx.de>
> Cc: Heiko Schocher <hs at denx.de>
> Cc: Samuel Holland <samuel at sholland.org>
> Cc: Baruch Siach <baruch at tkos.co.il>
> Cc: Pali Rohár <pali at kernel.org>
> Cc: Marek Behún <marek.behun at nic.cz>
> ---
> It would be good if other users of this I2C driver could test this change
> with e.g. I2C EEPROM devices using 2 bytes (or more) for addressing.

Could you and other please take a look at this? Would be great, if this
could be pulled in the next merge window.

Thanks,
Stefan

>   drivers/i2c/mvtwsi.c | 12 ++++++++++--
>   1 file changed, 10 insertions(+), 2 deletions(-)
> 
> diff --git a/drivers/i2c/mvtwsi.c b/drivers/i2c/mvtwsi.c
> index 236bfb8d8e7f..ff21e3c52b58 100644
> --- a/drivers/i2c/mvtwsi.c
> +++ b/drivers/i2c/mvtwsi.c
> @@ -860,6 +860,9 @@ static int mvtwsi_i2c_xfer(struct udevice *bus, struct i2c_msg *msg, int nmsgs)
>   {
>   	struct mvtwsi_i2c_dev *dev = dev_get_priv(bus);
>   	struct i2c_msg *dmsg, *omsg, dummy;
> +	u8 *addr_buf_ptr;
> +	u8 addr_buf[4];
> +	int i;
>   
>   	memset(&dummy, 0, sizeof(struct i2c_msg));
>   
> @@ -873,12 +876,17 @@ static int mvtwsi_i2c_xfer(struct udevice *bus, struct i2c_msg *msg, int nmsgs)
>   	omsg = nmsgs == 1 ? &dummy : msg;
>   	dmsg = nmsgs == 1 ? msg : msg + 1;
>   
> +	/* We need to swap the register address if its size is > 1 */
> +	addr_buf_ptr = &addr_buf[0];
> +	for (i = omsg->len; i > 0; i--)
> +		*addr_buf_ptr++ = omsg->buf[i - 1];
> +
>   	if (dmsg->flags & I2C_M_RD)
> -		return __twsi_i2c_read(dev->base, dmsg->addr, omsg->buf,
> +		return __twsi_i2c_read(dev->base, dmsg->addr, addr_buf,
>   				       omsg->len, dmsg->buf, dmsg->len,
>   				       dev->tick);
>   	else
> -		return __twsi_i2c_write(dev->base, dmsg->addr, omsg->buf,
> +		return __twsi_i2c_write(dev->base, dmsg->addr, addr_buf,
>   					omsg->len, dmsg->buf, dmsg->len,
>   					dev->tick);
>   }
> 

Viele Grüße,
Stefan Roese

-- 
DENX Software Engineering GmbH,      Managing Director: Wolfgang Denk
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: (+49)-8142-66989-51 Fax: (+49)-8142-66989-80 Email: sr at denx.de


More information about the U-Boot mailing list