summaryrefslogtreecommitdiff
path: root/sys/dev/i2c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/i2c')
-rw-r--r--sys/dev/i2c/adm1025.c56
1 files changed, 51 insertions, 5 deletions
diff --git a/sys/dev/i2c/adm1025.c b/sys/dev/i2c/adm1025.c
index 0d7f261f8b2..6429821493b 100644
--- a/sys/dev/i2c/adm1025.c
+++ b/sys/dev/i2c/adm1025.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: adm1025.c,v 1.14 2005/12/27 20:34:59 deraadt Exp $ */
+/* $OpenBSD: adm1025.c,v 1.15 2005/12/27 21:47:42 deraadt Exp $ */
/*
* Copyright (c) 2005 Theo de Raadt
@@ -38,6 +38,9 @@
#define ADM1025_STEPPING 0x3f /* contains 0x2? */
#define ADM1025_CONFIG 0x40
#define ADM1025_CONFIG_START 0x01
+#define SMSC47M192_V1_5 0x50
+#define SMSC47M192_V1_8 0x51
+#define SMSC47M192_TEMP2 0x52
/* Sensors */
#define ADMTM_INT 0
@@ -49,13 +52,18 @@
#define ADMTM_V12 6
#define ADMTM_Vcc 7
#define ADMTM_NUM_SENSORS 8
-
+#define SMSC_V1_5 8
+#define SMSC_V1_8 9
+#define SMSC_TEMP2 10
+#define SMSC_NUM_SENSORS 3
struct admtm_softc {
struct device sc_dev;
i2c_tag_t sc_tag;
i2c_addr_t sc_addr;
- struct sensor sc_sensor[ADMTM_NUM_SENSORS];
+ struct sensor sc_sensor[ADMTM_NUM_SENSORS + SMSC_NUM_SENSORS];
+ int sc_nsensors;
+ int sc_model;
};
int admtm_match(struct device *, void *, void *);
@@ -103,6 +111,13 @@ admtm_attach(struct device *parent, struct device *self, void *aux)
printf(": %s", ia->ia_name);
+ sc->sc_nsensors = ADMTM_NUM_SENSORS;
+ sc->sc_model = 1025;
+ if (strcmp(ia->ia_name, "47m192") == 0) {
+ sc->sc_nsensors += 3;
+ sc->sc_model = 192;
+ }
+
iic_acquire_bus(sc->sc_tag, 0);
cmd = ADM1025_CONFIG;
if (iic_exec(sc->sc_tag, I2C_OP_READ_WITH_STOP,
@@ -124,7 +139,7 @@ admtm_attach(struct device *parent, struct device *self, void *aux)
iic_release_bus(sc->sc_tag, 0);
/* Initialize sensor data. */
- for (i = 0; i < ADMTM_NUM_SENSORS; i++)
+ for (i = 0; i < ADMTM_NUM_SENSORS + SMSC_NUM_SENSORS; i++)
strlcpy(sc->sc_sensor[i].device, sc->sc_dev.dv_xname,
sizeof(sc->sc_sensor[i].device));
@@ -160,12 +175,24 @@ admtm_attach(struct device *parent, struct device *self, void *aux)
strlcpy(sc->sc_sensor[ADMTM_Vcc].desc, "Vcc",
sizeof(sc->sc_sensor[ADMTM_Vcc].desc));
+ sc->sc_sensor[SMSC_V1_5].type = SENSOR_VOLTS_DC;
+ strlcpy(sc->sc_sensor[SMSC_V1_5].desc, "1.5 V",
+ sizeof(sc->sc_sensor[SMSC_V1_5].desc));
+
+ sc->sc_sensor[SMSC_V1_8].type = SENSOR_VOLTS_DC;
+ strlcpy(sc->sc_sensor[SMSC_V1_8].desc, "1.8 V",
+ sizeof(sc->sc_sensor[SMSC_V1_8].desc));
+
+ sc->sc_sensor[SMSC_TEMP2].type = SENSOR_TEMP;
+ strlcpy(sc->sc_sensor[SMSC_TEMP2].desc, "External2",
+ sizeof(sc->sc_sensor[SMSC_TEMP2].desc));
+
if (sensor_task_register(sc, admtm_refresh, 5)) {
printf(", unable to register update task\n");
return;
}
- for (i = 0; i < ADMTM_NUM_SENSORS; i++)
+ for (i = 0; i < sc->sc_nsensors; i++)
SENSOR_ADD(&sc->sc_sensor[i]);
printf("\n");
@@ -229,5 +256,24 @@ admtm_refresh(void *arg)
sc->sc_addr, &cmd, sizeof cmd, &data, sizeof data, I2C_F_POLL) == 0)
sc->sc_sensor[ADMTM_Vcc].value = 3300000 * data / 192;
+ if (sc->sc_model == 192) {
+ cmd = SMSC47M192_V1_5;
+ if (iic_exec(sc->sc_tag, I2C_OP_READ_WITH_STOP,
+ sc->sc_addr, &cmd, sizeof cmd, &data, sizeof data, I2C_F_POLL) == 0)
+ sc->sc_sensor[SMSC_V1_5].value = 1500000 * data / 192;
+
+ cmd = SMSC47M192_V1_8;
+ if (iic_exec(sc->sc_tag, I2C_OP_READ_WITH_STOP,
+ sc->sc_addr, &cmd, sizeof cmd, &data, sizeof data, I2C_F_POLL) == 0)
+ sc->sc_sensor[SMSC_V1_8].value = 1800000 * data / 192;
+
+ cmd = SMSC47M192_TEMP2;
+ if (iic_exec(sc->sc_tag, I2C_OP_READ_WITH_STOP,
+ sc->sc_addr, &cmd, sizeof cmd, &sdata, sizeof sdata,
+ I2C_F_POLL) == 0)
+ sc->sc_sensor[SMSC_TEMP2].value = 273150000 + 1000000 * sdata;
+
+ }
+
iic_release_bus(sc->sc_tag, 0);
}