diff options
author | Wolfgang Denk <wd@nyx.denx.de> | 2005-07-28 10:42:26 +0200 |
---|---|---|
committer | Wolfgang Denk <wd@nyx.denx.de> | 2005-07-28 10:42:26 +0200 |
commit | 15f36a5efd31fe608b43dc197ebbd80d3cecbe44 (patch) | |
tree | 0c3e6451f2cc4c3ede4302b13458ae5385c9780c | |
parent | e82bc62c038859b5bf7daae1bc24b7226f9ed74a (diff) | |
download | u-boot-imx-15f36a5efd31fe608b43dc197ebbd80d3cecbe44.zip u-boot-imx-15f36a5efd31fe608b43dc197ebbd80d3cecbe44.tar.gz u-boot-imx-15f36a5efd31fe608b43dc197ebbd80d3cecbe44.tar.bz2 |
Fix sysmon POST problem: check I2C error codes
This fixes a problem of displaying bogus voltages when the voltages
are so low that the I2C devices start failing while the rest of the
system keeps running.
-rw-r--r-- | CHANGELOG | 5 | ||||
-rw-r--r-- | post/sysmon.c | 13 |
2 files changed, 16 insertions, 2 deletions
@@ -2,6 +2,11 @@ Changes for U-Boot 1.1.3: ====================================================================== +* Fix sysmon POST problem: check I2C error codes + This fixes a problem of displaying bogus voltages when the voltages + are so low that the I2C devices start failing while the rest of the + system keeps running. + * Patch by Cedric Vincent, 6 Jul 2005: Fix CFG_CMD_SETGETDCR handling in "common/cmd_dcr.c" diff --git a/post/sysmon.c b/post/sysmon.c index 8758ccd..72fcac3 100644 --- a/post/sysmon.c +++ b/post/sysmon.c @@ -185,6 +185,10 @@ static char *sysmon_unit_value (sysmon_table_t *s, uint val) char *p, sign; int dec, frac; + if (val == -1) { + return "I/O ERROR"; + } + if (unit_val < 0) { sign = '-'; unit_val = -unit_val; @@ -297,8 +301,13 @@ int sysmon_post_test (int flags) } val = t->sysmon->read(t->sysmon, t->addr); - t->val_valid = val >= t->val_min && val <= t->val_max; - t->val_valid_alt = val >= t->val_min_alt && val <= t->val_max_alt; + if (val != -1) { + t->val_valid = val >= t->val_min && val <= t->val_max; + t->val_valid_alt = val >= t->val_min_alt && val <= t->val_max_alt; + } else { + t->val_valid = 0; + t->val_valid_alt = 0; + } if (t->exec_after) { t->exec_after(t); |