mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-24 17:23:25 -05:00
i2c: davinci: Avoid zero value of CLKH
If CLKH is set to 0 I2C clock is not generated at all, so avoid this value and stretch the clock in this case. Signed-off-by: Alexander Sverdlin <alexander.sverdlin@nokia.com> Acked-by: Sekhar Nori <nsekhar@ti.com> Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
This commit is contained in:
parent
d72e90f33a
commit
cc8de9a685
1 changed files with 6 additions and 2 deletions
|
@ -237,12 +237,16 @@ static void i2c_davinci_calc_clk_dividers(struct davinci_i2c_dev *dev)
|
||||||
/*
|
/*
|
||||||
* It's not always possible to have 1 to 2 ratio when d=7, so fall back
|
* It's not always possible to have 1 to 2 ratio when d=7, so fall back
|
||||||
* to minimal possible clkh in this case.
|
* to minimal possible clkh in this case.
|
||||||
|
*
|
||||||
|
* Note:
|
||||||
|
* CLKH is not allowed to be 0, in this case I2C clock is not generated
|
||||||
|
* at all
|
||||||
*/
|
*/
|
||||||
if (clk >= clkl + d) {
|
if (clk > clkl + d) {
|
||||||
clkh = clk - clkl - d;
|
clkh = clk - clkl - d;
|
||||||
clkl -= d;
|
clkl -= d;
|
||||||
} else {
|
} else {
|
||||||
clkh = 0;
|
clkh = 1;
|
||||||
clkl = clk - (d << 1);
|
clkl = clk - (d << 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue