Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/i2c remove some unused code, add comments for credit...
details: https://anonhg.NetBSD.org/src/rev/b9e340f0cc2e
branches: trunk
changeset: 360415:b9e340f0cc2e
user: macallan <macallan%NetBSD.org@localhost>
date: Fri Mar 09 22:27:15 2018 +0000
description:
remove some unused code, add comments for credits & explanations
diffstat:
sys/dev/i2c/adadc.c | 37 ++++++++++++++++++++++++++++---------
1 files changed, 28 insertions(+), 9 deletions(-)
diffs (108 lines):
diff -r 00172e8b1700 -r b9e340f0cc2e sys/dev/i2c/adadc.c
--- a/sys/dev/i2c/adadc.c Fri Mar 09 21:49:55 2018 +0000
+++ b/sys/dev/i2c/adadc.c Fri Mar 09 22:27:15 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: adadc.c,v 1.1 2018/03/09 20:16:54 macallan Exp $ */
+/* $NetBSD: adadc.c,v 1.2 2018/03/09 22:27:15 macallan Exp $ */
/*-
* Copyright (c) 2018 Michael Lorenz
@@ -26,10 +26,15 @@
* POSSIBILITY OF SUCH DAMAGE.
*/
-/* a driver for Analog Devices AD7417 temperature sensors / ADCs */
+/*
+ * a driver for Analog Devices AD7417 temperature sensors / ADCs
+ * very much macppc only for now since we need calibaration data to make sense
+ * of the ADC inputs
+ * info on how to get these from FreeBSD and Linux
+ */
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: adadc.c,v 1.1 2018/03/09 20:16:54 macallan Exp $");
+__KERNEL_RCSID(0, "$NetBSD: adadc.c,v 1.2 2018/03/09 22:27:15 macallan Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -93,6 +98,7 @@
NULL
};
+/* calibaration table from Darwin via Linux */
static int slope[5] = {0, 0, 0x0320, 0x00a0, 0x1f40};
static int
@@ -101,7 +107,11 @@
struct i2c_attach_args *ia = aux;
if (ia->ia_name == NULL) {
- /* no ID registers on this chip */
+ /*
+ * XXX
+ * this driver is pretty much useless without OF, should
+ * probably remove this
+ */
if ((ia->ia_addr & 0x2b) == 0x2b)
return 1;
return 0;
@@ -118,7 +128,6 @@
envsys_data_t *s;
int error, ch, cpuid;
uint32_t eeprom[40];
- uint8_t cmd, data;
char loc[256];
int which_cpu;
@@ -129,16 +138,17 @@
aprint_naive("\n");
aprint_normal(": AD7417\n");
- cmd = ADADC_CONFIG;
- error = iic_exec(sc->sc_i2c, I2C_OP_READ_WITH_STOP,
- sc->sc_addr, &cmd, 1, &data, 1, 0);
-
sc->sc_sme = sysmon_envsys_create();
sc->sc_sme->sme_name = device_xname(self);
sc->sc_sme->sme_cookie = sc;
sc->sc_sme->sme_refresh = adadc_sensors_refresh;
sc->sc_nsensors = 0;
+ /*
+ * XXX
+ * without OpenFirmware telling us how to interpret the ADC inputs we
+ * should probably just expose the temperature and four ENVSYS_INTEGERs
+ */
which_cpu = 0;
ch = OF_child(ia->ia_cookie);
while (ch != 0) {
@@ -146,6 +156,10 @@
int reg = 0;
OF_getprop(ch, "reg", ®, sizeof(reg));
s = &sc->sc_sensors[sc->sc_nsensors];
+ /*
+ * this setup matches my 2x 2.5GHz PCI-X G5, Linux and
+ * FreeBSD hardcode these as well so we should be safe
+ */
switch (reg) {
case 0:
if (strstr(loc, "CPU B") != NULL)
@@ -220,6 +234,10 @@
/* 16.16 fixed point */
edata->value_cur = (temp >> 12) * 62500 + 273150000;
} else {
+ /*
+ * the input is 10bit, so converting to 8.4 fixed point
+ * is more than enough
+ */
int temp = rdata * slope[edata->private];
edata->value_cur = (temp >> 12) * 62500;
}
@@ -228,6 +246,7 @@
/* just read the temperature register */
error = iic_exec(sc->sc_i2c, I2C_OP_READ_WITH_STOP,
sc->sc_addr, &cmd, 1, &data, 2, 0);
+ /* 8.2 bit fixed point Celsius -> microkelvin */
edata->value_cur = ((data >> 6) * 250000) + 273150000;
}
iic_release_bus(sc->sc_i2c, 0);
Home |
Main Index |
Thread Index |
Old Index