rockchip: i2c: don't sent stop bit after each message
That's not correct and it breaks SMBUS-style reads and and writes for some chips (e.g. SYR82X/SYR83X). Stop bit should be sent only after the last message. Signed-off-by: Vasily Khoruzhick <anarsoul@gmail.com> Reviewed-by: Kever Yang <kever.yang@rock-chips.com>
This commit is contained in:
parent
5ef1e02e99
commit
c9fca5ec88
@ -253,7 +253,6 @@ static int rk_i2c_read(struct rk_i2c *i2c, uchar chip, uint reg, uint r_len,
|
|||||||
}
|
}
|
||||||
|
|
||||||
i2c_exit:
|
i2c_exit:
|
||||||
rk_i2c_send_stop_bit(i2c);
|
|
||||||
rk_i2c_disable(i2c);
|
rk_i2c_disable(i2c);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
@ -332,7 +331,6 @@ static int rk_i2c_write(struct rk_i2c *i2c, uchar chip, uint reg, uint r_len,
|
|||||||
}
|
}
|
||||||
|
|
||||||
i2c_exit:
|
i2c_exit:
|
||||||
rk_i2c_send_stop_bit(i2c);
|
|
||||||
rk_i2c_disable(i2c);
|
rk_i2c_disable(i2c);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
@ -360,6 +358,9 @@ static int rockchip_i2c_xfer(struct udevice *bus, struct i2c_msg *msg,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
rk_i2c_send_stop_bit(i2c);
|
||||||
|
rk_i2c_disable(i2c);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user