diff options
author | Jon Smirl <jonsmirl@gmail.com> | 2009-04-04 17:44:51 -0400 |
---|---|---|
committer | Wolfgang Denk <wd@denx.de> | 2009-04-05 01:34:08 +0200 |
commit | 3c853f31d6a8e4407f73a2ca2c63d383a245f237 (patch) | |
tree | 47f3d741b2cfa59ffe8650c79e6755e847212d5b | |
parent | c0a14aedc3440d6591b8c86d45861a0a8b46e11d (diff) | |
download | bootable_bootloader_goldelico_gta04-3c853f31d6a8e4407f73a2ca2c63d383a245f237.zip bootable_bootloader_goldelico_gta04-3c853f31d6a8e4407f73a2ca2c63d383a245f237.tar.gz bootable_bootloader_goldelico_gta04-3c853f31d6a8e4407f73a2ca2c63d383a245f237.tar.bz2 |
mpc5200: reduce delays in i2c
The previous code waited 1000us before checking i2c
status. Measurement shows i2c is usually ready in
under 50us. Change the polling interval to 15us,
loop 6,667 times to keep the polling timeout constant
at 100ms.
-rw-r--r-- | cpu/mpc5xxx/i2c.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/cpu/mpc5xxx/i2c.c b/cpu/mpc5xxx/i2c.c index e2506d8..2341932 100644 --- a/cpu/mpc5xxx/i2c.c +++ b/cpu/mpc5xxx/i2c.c @@ -38,7 +38,7 @@ DECLARE_GLOBAL_DATA_PTR; #error CONFIG_SYS_I2C_MODULE is not properly configured #endif -#define I2C_TIMEOUT 100 +#define I2C_TIMEOUT 6667 #define I2C_RETRIES 3 struct mpc5xxx_i2c_tap { @@ -94,7 +94,7 @@ static int wait_for_bb(void) mpc_reg_out(®s->mcr, 0, 0); mpc_reg_out(®s->mcr, I2C_EN, 0); #endif - udelay(1000); + udelay(15); status = mpc_reg_in(®s->msr); } @@ -109,7 +109,7 @@ static int wait_for_pin(int *status) *status = mpc_reg_in(®s->msr); while (timeout-- && !(*status & I2C_IF)) { - udelay(1000); + udelay(15); *status = mpc_reg_in(®s->msr); } |