Module Name: src
Committed By: kardel
Date: Sun Jun 29 09:52:43 UTC 2014
Modified Files:
src/sys/dev/i2c: hytp14.c
Log Message:
allow i2c address 0x01-0x7F
igore responses if the sensor is in command mode
To generate a diff of this commit:
cvs rdiff -u -r1.1 -r1.2 src/sys/dev/i2c/hytp14.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/hytp14.c
diff -u src/sys/dev/i2c/hytp14.c:1.1 src/sys/dev/i2c/hytp14.c:1.2
--- src/sys/dev/i2c/hytp14.c:1.1 Sun May 18 11:46:23 2014
+++ src/sys/dev/i2c/hytp14.c Sun Jun 29 09:52:43 2014
@@ -37,7 +37,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: hytp14.c,v 1.1 2014/05/18 11:46:23 kardel Exp $");
+__KERNEL_RCSID(0, "$NetBSD: hytp14.c,v 1.2 2014/06/29 09:52:43 kardel Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -98,8 +98,8 @@ hytp14_match(device_t parent, cfdata_t m
if (strcmp(ia->ia_name, "hythygtemp") == 0)
return 1;
} else {
- /* indirect config - check typical address */
- if (ia->ia_addr == HYTP14_DEFAULT_ADDR)
+ /* indirect config - check for configured address */
+ if ((ia->ia_addr > 0) && (ia->ia_addr <= 0x7F))
return 1;
}
return 0;
@@ -189,15 +189,17 @@ hytp14_refresh_sensor(struct hytp14_sc *
/* send MR command */
/* avoid quick read/write by providing a result buffer */
- if ((error = iic_exec(sc->sc_tag, I2C_OP_WRITE_WITH_STOP,
- sc->sc_addr, NULL, 0, buf, sizeof buf, 0)) == 0) {
+ error = iic_exec(sc->sc_tag, I2C_OP_WRITE_WITH_STOP,
+ sc->sc_addr, NULL, 0, buf, sizeof buf, 0);
+ if (error == 0) {
DPRINTF(3, ("hytp14_refresh_sensor(%s): MR sent\n",
device_xname(sc->sc_dev)));
/* send DF command - read data from sensor */
- if ((error = iic_exec(sc->sc_tag, I2C_OP_READ_WITH_STOP,
- sc->sc_addr, NULL, 0, sc->sc_data,
- sizeof sc->sc_data, 0)) != 0) {
+ error = iic_exec(sc->sc_tag, I2C_OP_READ_WITH_STOP,
+ sc->sc_addr, NULL, 0, sc->sc_data,
+ sizeof sc->sc_data, 0);
+ if (error != 0) {
DPRINTF(2, ("%s: %s: failed read from 0x%02x - error %d\n",
device_xname(sc->sc_dev),
__func__, sc->sc_addr, error));
@@ -224,7 +226,8 @@ hytp14_refresh_sensor(struct hytp14_sc *
sc->sc_refresh = hardclock_ticks;
- if (error == 0) {
+ /* skip data if sensor is in command mode */
+ if (error == 0 && (sc->sc_data[0] & HYTP14_RESP_CMDMODE) == 0) {
sc->sc_valid = ENVSYS_SVALID;
} else {
sc->sc_valid = ENVSYS_SINVALID;