Module Name: src
Committed By: jdc
Date: Mon Nov 4 15:06:26 UTC 2013
Modified Files:
src/sys/dev/i2c: lm87.c
Log Message:
Add missing braces.
Fix logic error - check the data read from the chip against 0xff.
To generate a diff of this commit:
cvs rdiff -u -r1.3 -r1.4 src/sys/dev/i2c/lm87.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/dev/i2c/lm87.c
diff -u src/sys/dev/i2c/lm87.c:1.3 src/sys/dev/i2c/lm87.c:1.4
--- src/sys/dev/i2c/lm87.c:1.3 Sat Oct 26 18:28:15 2013
+++ src/sys/dev/i2c/lm87.c Mon Nov 4 15:06:26 2013
@@ -1,4 +1,4 @@
-/* $NetBSD: lm87.c,v 1.3 2013/10/26 18:28:15 jdc Exp $ */
+/* $NetBSD: lm87.c,v 1.4 2013/11/04 15:06:26 jdc Exp $ */
/* $OpenBSD: lm87.c,v 1.20 2008/11/10 05:19:48 cnst Exp $ */
/*
@@ -18,7 +18,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: lm87.c,v 1.3 2013/10/26 18:28:15 jdc Exp $");
+__KERNEL_RCSID(0, "$NetBSD: lm87.c,v 1.4 2013/11/04 15:06:26 jdc Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -354,9 +354,10 @@ lmenv_refresh(struct sysmon_envsys *sme,
case LMENV_INT_TEMP:
if (data == 0x80)
edata->state = ENVSYS_SINVALID;
- else
+ else {
edata->value_cur = (int8_t)data * 1000000 + 273150000;
edata->state = ENVSYS_SVALID;
+ }
break;
case LMENV_FAN1:
if (edata->units == ENVSYS_SVOLTS_DC) {
@@ -364,12 +365,17 @@ lmenv_refresh(struct sysmon_envsys *sme,
edata->state = ENVSYS_SVALID;
break;
}
+ if (data == 0xff) {
+ edata->state = ENVSYS_SINVALID;
+ break;
+ }
tmp = data * sc->sc_fan1_div;
- if (tmp == 0 || tmp == 0xff)
+ if (tmp == 0)
edata->state = ENVSYS_SINVALID;
- else
+ else {
edata->value_cur = 1350000 / tmp;
edata->state = ENVSYS_SVALID;
+ }
break;
case LMENV_FAN2:
if (edata->units == ENVSYS_SVOLTS_DC) {
@@ -377,12 +383,17 @@ lmenv_refresh(struct sysmon_envsys *sme,
edata->state = ENVSYS_SVALID;
break;
}
+ if (data == 0xff) {
+ edata->state = ENVSYS_SINVALID;
+ break;
+ }
tmp = data * sc->sc_fan2_div;
- if (tmp == 0 || tmp == 0xff)
+ if (tmp == 0)
edata->state = ENVSYS_SINVALID;
- else
+ else {
edata->value_cur = 1350000 / tmp;
edata->state = ENVSYS_SVALID;
+ }
break;
default:
edata->state = ENVSYS_SINVALID;