Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/macppc/dev report fan speeds



details:   https://anonhg.NetBSD.org/src/rev/de9e844a30ad
branches:  trunk
changeset: 465428:de9e844a30ad
user:      macallan <macallan%NetBSD.org@localhost>
date:      Fri Nov 22 05:16:54 2019 +0000

description:
report fan speeds
disclaimer:
this is guesswork obtained from watching temperatures, listening to fan noise
and staring at register dumps. Use with caution.

diffstat:

 sys/arch/macppc/dev/psoc.c |  86 +++++++++++++++++++++++++++++----------------
 1 files changed, 55 insertions(+), 31 deletions(-)

diffs (164 lines):

diff -r c463480f41c4 -r de9e844a30ad sys/arch/macppc/dev/psoc.c
--- a/sys/arch/macppc/dev/psoc.c        Fri Nov 22 05:01:44 2019 +0000
+++ b/sys/arch/macppc/dev/psoc.c        Fri Nov 22 05:16:54 2019 +0000
@@ -1,4 +1,4 @@
- /* $NetBSD: psoc.c,v 1.1 2019/11/01 17:51:56 macallan Exp $ */
+ /* $NetBSD: psoc.c,v 1.2 2019/11/22 05:16:54 macallan Exp $ */
 
 /*-
  * Copyright (c) 2018 Michael Lorenz
@@ -30,15 +30,19 @@
  * fan controller found in 1GHz TiBook
  *
  * register values from OF:
- * fan1 - 0x20 ( status ), 0x31 ( data)
+ * fan1 - 0x20 ( status ), 0x31 ( data )
  * fan2 - 0x26 ( status ), 0x45 ( data )
- * fan3 - 0x59
+ * fan status byte 0:
+ * 0x5* - fan is running, 0x6* - fan stopped
+ * byte 1: unknown, 0x80 seems always set, lower bits seem to fluctuate
+ * byte 2: lower 6 bit seem to indicate speed
+ * fan speed may be lower 6 bit of byte 2 and lower 6 of byte 1 
  * temperature sensors start at 6, two bytes each, first appears to be
  * the temperature in degrees Celsius
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: psoc.c,v 1.1 2019/11/01 17:51:56 macallan Exp $");
+__KERNEL_RCSID(0, "$NetBSD: psoc.c,v 1.2 2019/11/22 05:16:54 macallan Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -71,6 +75,8 @@
 
 static void    psoc_sensors_refresh(struct sysmon_envsys *, envsys_data_t *);
 
+static void    psoc_dump(struct psoc_softc *);
+
 CFATTACH_DECL_NEW(psoc, sizeof(struct psoc_softc),
     psoc_match, psoc_attach, NULL, NULL);
 
@@ -98,7 +104,7 @@
        struct i2c_attach_args *ia = aux;
        char path[256];
        envsys_data_t *s;
-       int error, ih, r;
+       int error, ih, r, i;
 
        sc->sc_dev = self;
        sc->sc_i2c = ia->ia_tag;
@@ -122,19 +128,8 @@
        sc->sc_sme->sme_refresh = psoc_sensors_refresh;
        sc->sc_nsensors = 0;
 
-       int i, j;
-       uint8_t data, cmd;
-       for (i = 0; i < 0x7f; i+= 8) {
-               printf("%02x:", i);
-               for (j = 0; j < 8; j++) {
-                       cmd = i + j;
-                       data = 0;
-                       iic_exec(sc->sc_i2c, I2C_OP_READ_WITH_STOP,
-                           sc->sc_addr, &cmd, 1, &data, 1, 0);
-                       printf(" %02x", data);
-               }
-               printf("\n");
-       }
+       psoc_dump(sc);
+
        for (i = 0; i < 4; i++) {
                r = i * 2 + 6;
                s = &sc->sc_sensors[sc->sc_nsensors];
@@ -145,8 +140,8 @@
                sysmon_envsys_sensor_attach(sc->sc_sme, s);
                sc->sc_nsensors++;
        }
-#if 0
-       for (r = 0x31; r < 0x50; r += 0x14) {
+
+       for (r = 0x20; r < 0x2b; r += 0x06) {
                s = &sc->sc_sensors[sc->sc_nsensors];
                s->state = ENVSYS_SINVALID;
                s->units = ENVSYS_SFANRPM;
@@ -155,7 +150,7 @@
                sysmon_envsys_sensor_attach(sc->sc_sme, s);
                sc->sc_nsensors++;
        }
-#endif
+
        sysmon_envsys_register(sc->sc_sme);
 }
 
@@ -164,8 +159,8 @@
 {
        struct psoc_softc *sc = sme->sme_cookie;
        uint8_t cmd = 6;
-       uint8_t buf[0x28];
-       int error = 1, data, i;
+       uint8_t buf[0x28], *bptr;
+       int error = 1, data;
 
        if ( edata->private < 0x20) {
                cmd = 0;
@@ -183,19 +178,30 @@
                        /* Celsius -> microkelvin */
                        edata->value_cur = ((int)data * 1000000) + 273150000;
                }
+#ifdef PSOC_DEBUG
+               if (edata->private == 6)
+                       psoc_dump(sc);
+#endif
        } else {
-               cmd = 0x31;
+               cmd = 0x20;
                iic_acquire_bus(sc->sc_i2c, 0);
                error = iic_exec(sc->sc_i2c, I2C_OP_READ_WITH_STOP,
-                           sc->sc_addr, &cmd, 1, buf, 0x28, 0);
+                           sc->sc_addr, &cmd, 1, buf, 12, 0);
                iic_release_bus(sc->sc_i2c, 0);
                if (error) return;
-               if (edata->private > 0) {
-                       data = buf[edata->private - 0x20];
-                       edata->value_cur = data;
-                       for (i = 0; i < 14; i++)
-                               printf(" %02x", buf[edata->private - 0x31 + i]);
-                       printf("\n");
+               if (edata->private >= 0x20) {
+                       bptr = &buf[edata->private - 0x20];
+                       switch (bptr[0] & 0xf0) {
+                               case 0x50:
+                                       data = bptr[edata->private - 0x20];
+                                       edata->value_cur = ((bptr[2] & 0x3f) << 6) | (bptr[1] & 0x3f);
+                                       break;
+                               case 0x60:
+                                       edata->value_cur = 0;
+                                       break;
+                               default:
+                                       error = -1;
+                       }       
                }
        }
        if (error) {
@@ -204,3 +210,21 @@
                edata->state = ENVSYS_SVALID;
        }
 }
+
+static void
+psoc_dump(struct psoc_softc *sc)
+{
+       int i, j;
+       uint8_t data, cmd;
+       for (i = 0x20; i < 0x5f; i+= 8) {
+               printf("%02x:", i);
+               for (j = 0; j < 8; j++) {
+                       cmd = i + j;
+                       data = 0;
+                       iic_exec(sc->sc_i2c, I2C_OP_READ_WITH_STOP,
+                           sc->sc_addr, &cmd, 1, &data, 1, 0);
+                       printf(" %02x", data);
+               }
+               printf("\n");
+       }
+}



Home | Main Index | Thread Index | Old Index