summaryrefslogtreecommitdiffstats
path: root/drivers/i2c/algos
diff options
context:
space:
mode:
authorAaro Koskinen <aaro.koskinen@nokia.com>2009-05-27 16:54:45 +0200
committerBen Dooks <ben-linux@fluff.org>2009-06-13 11:39:25 +0200
commitbaf46b4e378d7950dff7ba30cfd50ff585987cb4 (patch)
tree571bd77cb953d1fc6a206c250b3cf8dd4718546f /drivers/i2c/algos
parenti2c: Blackfin TWI: implement I2C_FUNC_SMBUS_I2C_BLOCK functionality (diff)
downloadlinux-baf46b4e378d7950dff7ba30cfd50ff585987cb4.tar.xz
linux-baf46b4e378d7950dff7ba30cfd50ff585987cb4.zip
i2c: OMAP2/3: Fix scll/sclh calculations
Fix scll/sclh calculations for HS and fast modes. Currently the driver uses equal (roughly) low/high times which will result in too short low time. OMAP3430 TRM gives the following equations: F/S: tLow = (scll + 7) * internal_clk tHigh = (sclh + 5) * internal_clk HS: tLow = (scll + 7) * fclk tHigh = (sclh + 5) * fclk Furthermore, the I2C specification sets the following minimum values for HS tLow/tHigh for capacitive bus loads 100 pF (maximum speed 3400) and 400 pF (maximum speed 1700): speed tLow tHigh 3400 160 ns 60 ns 1700 320 ns 120 ns and for F/S: speed tLow tHigh 400 1300 ns 600 ns 100 4700 ns 4000 ns By using duty cycles 33/66 (HS, F) and 50/50 (S) we stay above these minimum values. Signed-off-by: Aaro Koskinen <aaro.koskinen@nokia.com> Acked-by: Tony Lindgren <tony@atomide.com> Signed-off-by: Ben Dooks <ben-linux@fluff.org>
Diffstat (limited to 'drivers/i2c/algos')
0 files changed, 0 insertions, 0 deletions