diff options
author | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2012-11-21 05:12:11 +0100 |
---|---|---|
committer | Wolfram Sang <w.sang@pengutronix.de> | 2012-11-22 22:34:40 +0100 |
commit | 31f313d9bebfc17e48c787c8c36b38662b4134a1 (patch) | |
tree | 7fcd40d17bac586a95ae21ed9f54fa0e642b4711 /drivers/i2c/busses/i2c-mxs.c | |
parent | i2c: ocores: Move grlib set/get functions into #ifdef CONFIG_OF block (diff) | |
download | linux-31f313d9bebfc17e48c787c8c36b38662b4134a1.tar.xz linux-31f313d9bebfc17e48c787c8c36b38662b4134a1.zip |
i2c: s3c2410: Remove recently introduced performance overheads
The changes in "i2c-s3c2410: use exponential back off while polling for
bus idle" remove the initial busy wait for I2C transfers to complete and
replace it with usleep_range() calls which will schedule.
Since for older SoCs I2C transfers would usually complete within an
extremely small number of CPU cycles there is a win from not having to
schedule. This happens because on the older SoCs the cores run at a
smaller multiple of the speeds that the I2C bus is operating at; on more
modern SoCs the busy wait is less likely to be effective.
Fix the issue by restoring the busy wait, reducing the number of spins
from 20 to 3 which covers the overwhelming majority of I2C transfers on
the SoCs where the busy wait is effective.
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Acked-by: Olof Johansson <olof@lixom.net>
Reviewed-by: Daniel Kurtz <djkurtz@chromium.org>
Reviewed-by: Doug Anderson <dianders@chromium.org>
Signed-off-by: Wolfram Sang <w.sang@pengutronix.de>
Diffstat (limited to 'drivers/i2c/busses/i2c-mxs.c')
0 files changed, 0 insertions, 0 deletions