summaryrefslogtreecommitdiff
path: root/sys/arch/i386
diff options
context:
space:
mode:
authorKevin Lo <kevlo@cvs.openbsd.org>2009-10-07 02:15:49 +0000
committerKevin Lo <kevlo@cvs.openbsd.org>2009-10-07 02:15:49 +0000
commit913cfce4b8445d6ebee715b633da195797de6144 (patch)
treeea839ba9c84f62e265c70ae2686de60bc04948d3 /sys/arch/i386
parentb1852bac0a302c0bf5763ac719e7bd4bcbc02564 (diff)
add support for the temperature sensor of VIA Nano and C7-M CPUs.
some improvements suggested by jsg@ "commit" deraadt@
Diffstat (limited to 'sys/arch/i386')
-rw-r--r--sys/arch/i386/i386/machdep.c41
-rw-r--r--sys/arch/i386/include/specialreg.h6
2 files changed, 45 insertions, 2 deletions
diff --git a/sys/arch/i386/i386/machdep.c b/sys/arch/i386/i386/machdep.c
index 8fdd9528f0c..71217838978 100644
--- a/sys/arch/i386/i386/machdep.c
+++ b/sys/arch/i386/i386/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.461 2009/09/20 21:58:31 jsg Exp $ */
+/* $OpenBSD: machdep.c,v 1.462 2009/10/07 02:15:48 kevlo Exp $ */
/* $NetBSD: machdep.c,v 1.214 1996/11/10 03:16:17 thorpej Exp $ */
/*-
@@ -1075,6 +1075,20 @@ cyrix3_cpu_setup(struct cpu_info *ci)
/*
* C3 Nehemiah & later: fall through.
*/
+
+ case 10: /* C7-M Type A */
+ case 13: /* C7-M Type D */
+ case 15: /* Nano */
+#if !defined(SMALL_KERNEL)
+ /* Setup the sensors structures */
+ strlcpy(ci->ci_sensordev.xname, ci->ci_dev.dv_xname,
+ sizeof(ci->ci_sensordev.xname));
+ ci->ci_sensor.type = SENSOR_TEMP;
+ sensor_task_register(ci, via_update_sensor, 5);
+ sensor_attach(&ci->ci_sensordev, &ci->ci_sensor);
+ sensordev_install(&ci->ci_sensordev);
+#endif
+
default:
/*
* C3 Nehemiah/Esther & later models:
@@ -1168,6 +1182,31 @@ cyrix3_cpu_setup(struct cpu_info *ci)
}
}
+#if !defined(SMALL_KERNEL)
+void via_update_sensor(void *args);
+void
+via_update_sensor(void *args)
+{
+ struct cpu_info *ci = (struct cpu_info *) args;
+ u_int64_t msr;
+
+ switch (ci->ci_model) {
+ case 0xa:
+ case 0xd:
+ msr = rdmsr(MSR_C7M_TMTEMPERATURE);
+ break;
+ case 0xf:
+ msr = rdmsr(MSR_CENT_TMTEMPERATURE);
+ break;
+ }
+ ci->ci_sensor.value = (msr & 0xffffff);
+ /* micro degrees */
+ ci->ci_sensor.value *= 1000000;
+ ci->ci_sensor.value += 273150000;
+ ci->ci_sensor.flags &= ~SENSOR_FINVALID;
+}
+#endif
+
void
cyrix6x86_cpu_setup(struct cpu_info *ci)
{
diff --git a/sys/arch/i386/include/specialreg.h b/sys/arch/i386/include/specialreg.h
index c9d96b85368..c20cd56473c 100644
--- a/sys/arch/i386/include/specialreg.h
+++ b/sys/arch/i386/include/specialreg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: specialreg.h,v 1.36 2009/09/20 21:58:31 jsg Exp $ */
+/* $OpenBSD: specialreg.h,v 1.37 2009/10/07 02:15:48 kevlo Exp $ */
/* $NetBSD: specialreg.h,v 1.7 1994/10/27 04:16:26 cgd Exp $ */
/*-
@@ -244,6 +244,10 @@
#define MSR_MC3_ADDR 0x412
#define MSR_MC3_MISC 0x413
+/* VIA MSRs */
+#define MSR_CENT_TMTEMPERATURE 0x1423 /* Thermal monitor temperature */
+#define MSR_C7M_TMTEMPERATURE 0x1169
+
/* AMD MSRs */
#define MSR_K6_EPMR 0xc0000086
#define MSR_K7_EVNTSEL0 0xc0010000