Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/i2c Don't use I2C_F_POLL when getting/setting limits.
details: https://anonhg.NetBSD.org/src/rev/62ae4c151acd
branches: trunk
changeset: 813005:62ae4c151acd
user: jdc <jdc%NetBSD.org@localhost>
date: Mon Jan 11 18:23:11 2016 +0000
description:
Don't use I2C_F_POLL when getting/setting limits.
Save/restore the correct values for LM77.
diffstat:
sys/dev/i2c/lm75.c | 48 ++++++++++++++++++++++++++++--------------------
1 files changed, 28 insertions(+), 20 deletions(-)
diffs (134 lines):
diff -r cc4a97713bf3 -r 62ae4c151acd sys/dev/i2c/lm75.c
--- a/sys/dev/i2c/lm75.c Mon Jan 11 17:09:25 2016 +0000
+++ b/sys/dev/i2c/lm75.c Mon Jan 11 18:23:11 2016 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lm75.c,v 1.28 2016/01/03 17:27:57 jdc Exp $ */
+/* $NetBSD: lm75.c,v 1.29 2016/01/11 18:23:11 jdc Exp $ */
/*
* Copyright (c) 2003 Wasabi Systems, Inc.
@@ -36,7 +36,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: lm75.c,v 1.28 2016/01/03 17:27:57 jdc Exp $");
+__KERNEL_RCSID(0, "$NetBSD: lm75.c,v 1.29 2016/01/11 18:23:11 jdc Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -206,16 +206,16 @@
iic_acquire_bus(sc->sc_tag, I2C_F_POLL);
/* Read temperature limit(s) and remember initial value(s). */
- if (lmtemp_temp_read(sc, LM75_REG_TOS_SET_POINT, &sc->sc_smax, 1)
- != 0) {
- aprint_error_dev(self, "unable to read Tos register\n");
- iic_release_bus(sc->sc_tag, I2C_F_POLL);
- return;
- }
- sc->sc_tmax = sc->sc_smax;
if (i == lmtemp_lm77) {
+ if (lmtemp_temp_read(sc, LM77_REG_TCRIT_SET_POINT,
+ &sc->sc_scrit, 1) != 0) {
+ aprint_error_dev(self,
+ "unable to read low register\n");
+ iic_release_bus(sc->sc_tag, I2C_F_POLL);
+ return;
+ }
if (lmtemp_temp_read(sc, LM77_REG_TLOW_SET_POINT,
- &sc->sc_smax, 1) != 0) {
+ &sc->sc_smin, 1) != 0) {
aprint_error_dev(self,
"unable to read low register\n");
iic_release_bus(sc->sc_tag, I2C_F_POLL);
@@ -228,7 +228,15 @@
iic_release_bus(sc->sc_tag, I2C_F_POLL);
return;
}
+ } else { /* LM75 or compatible */
+ if (lmtemp_temp_read(sc, LM75_REG_TOS_SET_POINT,
+ &sc->sc_smax, 1) != 0) {
+ aprint_error_dev(self, "unable to read Tos register\n");
+ iic_release_bus(sc->sc_tag, I2C_F_POLL);
+ return;
+ }
}
+ sc->sc_tmax = sc->sc_smax;
if (i == lmtemp_lm75)
lmtemp_setup_sysctl(sc);
@@ -349,12 +357,12 @@
*props &= ~(PROP_CRITMAX);
- iic_acquire_bus(sc->sc_tag, I2C_F_POLL);
+ iic_acquire_bus(sc->sc_tag, 0);
if (lmtemp_temp_read(sc, LM75_REG_TOS_SET_POINT, &val, 0) == 0) {
limits->sel_critmax = val;
*props |= PROP_CRITMAX;
}
- iic_release_bus(sc->sc_tag, I2C_F_POLL);
+ iic_release_bus(sc->sc_tag, 0);
}
static void
@@ -366,7 +374,7 @@
*props &= ~(PROP_CRITMAX | PROP_WARNMAX | PROP_WARNMIN);
- iic_acquire_bus(sc->sc_tag, I2C_F_POLL);
+ iic_acquire_bus(sc->sc_tag, 0);
if (lmtemp_temp_read(sc, LM77_REG_TCRIT_SET_POINT, &val, 0) == 0) {
limits->sel_critmax = val;
*props |= PROP_CRITMAX;
@@ -379,7 +387,7 @@
limits->sel_warnmin = val;
*props |= PROP_WARNMIN;
}
- iic_release_bus(sc->sc_tag, I2C_F_POLL);
+ iic_release_bus(sc->sc_tag, 0);
}
static void
@@ -394,11 +402,11 @@
limit = sc->sc_smax;
else
limit = limits->sel_critmax;
- iic_acquire_bus(sc->sc_tag, I2C_F_POLL);
+ iic_acquire_bus(sc->sc_tag, 0);
lmtemp_temp_write(sc, LM75_REG_THYST_SET_POINT,
limit - 5000000, 0);
lmtemp_temp_write(sc, LM75_REG_TOS_SET_POINT, limit, 0);
- iic_release_bus(sc->sc_tag, I2C_F_POLL);
+ iic_release_bus(sc->sc_tag, 0);
/* Synchronise sysctl */
sc->sc_tmax = (limit - 273150000) / 1000000;
@@ -412,10 +420,10 @@
struct lmtemp_softc *sc = sme->sme_cookie;
int32_t limit;
- iic_acquire_bus(sc->sc_tag, I2C_F_POLL);
+ iic_acquire_bus(sc->sc_tag, 0);
if (*props & PROP_CRITMAX) {
if (limits == NULL) /* Restore defaults */
- limit = sc->sc_smax;
+ limit = sc->sc_scrit;
else
limit = limits->sel_critmax;
lmtemp_temp_write(sc, LM77_REG_TCRIT_SET_POINT, limit, 0);
@@ -429,12 +437,12 @@
}
if (*props & PROP_WARNMIN) {
if (limits == NULL) /* Restore defaults */
- limit = sc->sc_smax;
+ limit = sc->sc_smin;
else
limit = limits->sel_warnmin;
lmtemp_temp_write(sc, LM77_REG_TLOW_SET_POINT, limit, 0);
}
- iic_release_bus(sc->sc_tag, I2C_F_POLL);
+ iic_release_bus(sc->sc_tag, 0);
}
static uint32_t
Home |
Main Index |
Thread Index |
Old Index