projects
/
oweals
/
u-boot.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix e-mail address of Gary Jennejohn.
[oweals/u-boot.git]
/
cpu
/
mpc5xxx
/
i2c.c
diff --git
a/cpu/mpc5xxx/i2c.c
b/cpu/mpc5xxx/i2c.c
index 0f02e78a3bd3e25d04459b50c0b36c5d0e79cdc1..23419324ba592b6091fef2081d9ec9aec09605b6 100644
(file)
--- a/
cpu/mpc5xxx/i2c.c
+++ b/
cpu/mpc5xxx/i2c.c
@@
-30,15
+30,15
@@
DECLARE_GLOBAL_DATA_PTR;
#include <mpc5xxx.h>
#include <i2c.h>
#include <mpc5xxx.h>
#include <i2c.h>
-#if (C
FG
_I2C_MODULE == 2)
+#if (C
ONFIG_SYS
_I2C_MODULE == 2)
#define I2C_BASE MPC5XXX_I2C2
#define I2C_BASE MPC5XXX_I2C2
-#elif (C
FG
_I2C_MODULE == 1)
+#elif (C
ONFIG_SYS
_I2C_MODULE == 1)
#define I2C_BASE MPC5XXX_I2C1
#else
#define I2C_BASE MPC5XXX_I2C1
#else
-#error C
FG
_I2C_MODULE is not properly configured
+#error C
ONFIG_SYS
_I2C_MODULE is not properly configured
#endif
#endif
-#define I2C_TIMEOUT
100
+#define I2C_TIMEOUT
6667
#define I2C_RETRIES 3
struct mpc5xxx_i2c_tap {
#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
mpc_reg_out(®s->mcr, 0, 0);
mpc_reg_out(®s->mcr, I2C_EN, 0);
#endif
- udelay(1
000
);
+ udelay(1
5
);
status = mpc_reg_in(®s->msr);
}
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)) {
*status = mpc_reg_in(®s->msr);
while (timeout-- && !(*status & I2C_IF)) {
- udelay(1
000
);
+ udelay(1
5
);
*status = mpc_reg_in(®s->msr);
}
*status = mpc_reg_in(®s->msr);
}
@@
-269,7
+269,8
@@
static int mpc_get_fdr(int speed)
if (gd->flags & GD_FLG_RELOC) {
fdr = divider;
} else {
if (gd->flags & GD_FLG_RELOC) {
fdr = divider;
} else {
- printf("%ld kHz, ", best_speed / 1000);
+ if (gd->have_console)
+ printf("%ld kHz, ", best_speed / 1000);
return divider;
}
}
return divider;
}
}
@@
-310,29
+311,34
@@
int i2c_read(uchar chip, uint addr, int alen, uchar *buf, int len)
xaddr[3] = addr & 0xFF;
if (wait_for_bb()) {
xaddr[3] = addr & 0xFF;
if (wait_for_bb()) {
- printf("i2c_read: bus is busy\n");
+ if (gd->have_console)
+ printf("i2c_read: bus is busy\n");
goto Done;
}
mpc_reg_out(®s->mcr, I2C_STA, I2C_STA);
if (do_address(chip, 0)) {
goto Done;
}
mpc_reg_out(®s->mcr, I2C_STA, I2C_STA);
if (do_address(chip, 0)) {
- printf("i2c_read: failed to address chip\n");
+ if (gd->have_console)
+ printf("i2c_read: failed to address chip\n");
goto Done;
}
if (send_bytes(chip, &xaddr[4-alen], alen)) {
goto Done;
}
if (send_bytes(chip, &xaddr[4-alen], alen)) {
- printf("i2c_read: send_bytes failed\n");
+ if (gd->have_console)
+ printf("i2c_read: send_bytes failed\n");
goto Done;
}
mpc_reg_out(®s->mcr, I2C_RSTA, I2C_RSTA);
if (do_address(chip, 1)) {
goto Done;
}
mpc_reg_out(®s->mcr, I2C_RSTA, I2C_RSTA);
if (do_address(chip, 1)) {
- printf("i2c_read: failed to address chip\n");
+ if (gd->have_console)
+ printf("i2c_read: failed to address chip\n");
goto Done;
}
if (receive_bytes(chip, (char *)buf, len)) {
goto Done;
}
if (receive_bytes(chip, (char *)buf, len)) {
- printf("i2c_read: receive_bytes failed\n");
+ if (gd->have_console)
+ printf("i2c_read: receive_bytes failed\n");
goto Done;
}
goto Done;
}
@@
-354,23
+360,27
@@
int i2c_write(uchar chip, uint addr, int alen, uchar *buf, int len)
xaddr[3] = addr & 0xFF;
if (wait_for_bb()) {
xaddr[3] = addr & 0xFF;
if (wait_for_bb()) {
- printf("i2c_write: bus is busy\n");
+ if (gd->have_console)
+ printf("i2c_write: bus is busy\n");
goto Done;
}
mpc_reg_out(®s->mcr, I2C_STA, I2C_STA);
if (do_address(chip, 0)) {
goto Done;
}
mpc_reg_out(®s->mcr, I2C_STA, I2C_STA);
if (do_address(chip, 0)) {
- printf("i2c_write: failed to address chip\n");
+ if (gd->have_console)
+ printf("i2c_write: failed to address chip\n");
goto Done;
}
if (send_bytes(chip, &xaddr[4-alen], alen)) {
goto Done;
}
if (send_bytes(chip, &xaddr[4-alen], alen)) {
- printf("i2c_write: send_bytes failed\n");
+ if (gd->have_console)
+ printf("i2c_write: send_bytes failed\n");
goto Done;
}
if (send_bytes(chip, (char *)buf, len)) {
goto Done;
}
if (send_bytes(chip, (char *)buf, len)) {
- printf("i2c_write: send_bytes failed\n");
+ if (gd->have_console)
+ printf("i2c_write: send_bytes failed\n");
goto Done;
}
goto Done;
}
@@
-380,20
+390,4
@@
Done:
return ret;
}
return ret;
}
-uchar i2c_reg_read(uchar chip, uchar reg)
-{
- uchar buf;
-
- i2c_read(chip, reg, 1, &buf, 1);
-
- return buf;
-}
-
-void i2c_reg_write(uchar chip, uchar reg, uchar val)
-{
- i2c_write(chip, reg, 1, &val, 1);
-
- return;
-}
-
#endif /* CONFIG_HARD_I2C */
#endif /* CONFIG_HARD_I2C */