summaryrefslogtreecommitdiff
path: root/sys/arch/macppc/dev/smu.c
diff options
context:
space:
mode:
authorMark Kettenis <kettenis@cvs.openbsd.org>2005-11-11 00:33:51 +0000
committerMark Kettenis <kettenis@cvs.openbsd.org>2005-11-11 00:33:51 +0000
commit2fa94798b04d3302efe3474676cd6b97a0b80c22 (patch)
tree3ad3ddfb092586ff3c4552993d71c722c14fee67 /sys/arch/macppc/dev/smu.c
parent7ee86e5c315e004e4a8146643c6084c8f81f55ec (diff)
Switch to sensors thread.
Diffstat (limited to 'sys/arch/macppc/dev/smu.c')
-rw-r--r--sys/arch/macppc/dev/smu.c35
1 files changed, 8 insertions, 27 deletions
diff --git a/sys/arch/macppc/dev/smu.c b/sys/arch/macppc/dev/smu.c
index 69a91dde729..092d3c519e9 100644
--- a/sys/arch/macppc/dev/smu.c
+++ b/sys/arch/macppc/dev/smu.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: smu.c,v 1.3 2005/10/23 13:47:49 kettenis Exp $ */
+/* $OpenBSD: smu.c,v 1.4 2005/11/11 00:33:50 kettenis Exp $ */
/*
* Copyright (c) 2005 Mark Kettenis
@@ -20,11 +20,9 @@
#include <sys/systm.h>
#include <sys/device.h>
#include <sys/kernel.h>
-#include <sys/kthread.h>
#include <sys/lock.h>
#include <sys/proc.h>
#include <sys/sensors.h>
-#include <sys/timeout.h>
#include <machine/autoconf.h>
@@ -79,8 +77,6 @@ struct smu_softc {
int16_t sc_cpu_volt_offset;
u_int16_t sc_cpu_curr_scale;
int16_t sc_cpu_curr_offset;
-
- struct timeout sc_timo;
};
struct cfattach smu_ca = {
@@ -120,7 +116,6 @@ struct smu_cmd {
#define SMU_MISC 0xee
#define SMU_MISC_GET_DATA 0x02
-void smu_create_thread(void *);
int smu_intr(void *);
int smu_do_cmd(struct smu_softc *, int);
@@ -318,20 +313,10 @@ smu_attach(struct device *parent, struct device *self, void *aux)
sc->sc_cpu_curr_scale = (data[8] << 8) + data[9];
sc->sc_cpu_curr_offset = (data[10] << 8) + data[11];
- kthread_create_deferred(smu_create_thread, sc);
+ sensor_task_register(sc, smu_refresh_sensors, 5);
printf("\n");
}
-void
-smu_create_thread(void *arg)
-{
- struct smu_softc *sc = arg;
-
- if (kthread_create(smu_refresh_sensors, sc, NULL,
- sc->sc_dev.dv_xname))
- panic("smu thread");
-}
-
int
smu_intr(void *arg)
{
@@ -558,14 +543,10 @@ smu_refresh_sensors(void *arg)
struct smu_softc *sc = arg;
int i;
- while (1) {
- lockmgr(&sc->sc_lock, LK_EXCLUSIVE, NULL, curproc);
- for (i = 0; i < sc->sc_num_sensors; i++)
- smu_sensor_refresh(sc, &sc->sc_sensors[i]);
- for (i = 0; i < sc->sc_num_fans; i++)
- smu_fan_refresh(sc, &sc->sc_fans[i]);
- lockmgr(&sc->sc_lock, LK_RELEASE, NULL, curproc);
-
- tsleep(smu_refresh_sensors, PWAIT, "timeout", 5 * hz);
- };
+ lockmgr(&sc->sc_lock, LK_EXCLUSIVE, NULL, curproc);
+ for (i = 0; i < sc->sc_num_sensors; i++)
+ smu_sensor_refresh(sc, &sc->sc_sensors[i]);
+ for (i = 0; i < sc->sc_num_fans; i++)
+ smu_fan_refresh(sc, &sc->sc_fans[i]);
+ lockmgr(&sc->sc_lock, LK_RELEASE, NULL, curproc);
}