summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
authorMarc Balmer <mbalmer@cvs.openbsd.org>2007-10-25 08:24:56 +0000
committerMarc Balmer <mbalmer@cvs.openbsd.org>2007-10-25 08:24:56 +0000
commit0c9a6901fbbd5dedcd9e679593373f8f8d771916 (patch)
tree0a7ceb2aac9a736437454b4bab955c26f9260f1b /sys/dev
parent1bd16d5bba1725792c1d290e6b7c5406b1e7622e (diff)
Factor out common code to update the timedelta sensor into
mbg_update_sensor().
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/pci/mbg.c82
1 files changed, 37 insertions, 45 deletions
diff --git a/sys/dev/pci/mbg.c b/sys/dev/pci/mbg.c
index d9fd5cee8e2..1c46ef71987 100644
--- a/sys/dev/pci/mbg.c
+++ b/sys/dev/pci/mbg.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mbg.c,v 1.17 2007/10/24 15:41:55 mbalmer Exp $ */
+/* $OpenBSD: mbg.c,v 1.18 2007/10/25 08:24:55 mbalmer Exp $ */
/*
* Copyright (c) 2006, 2007 Marc Balmer <mbalmer@openbsd.org>
@@ -119,6 +119,8 @@ int mbg_probe(struct device *, void *, void *);
void mbg_attach(struct device *, struct device *, void *);
void mbg_task(void *);
void mbg_task_hr(void *);
+void mbg_update_sensor(struct mbg_softc *sc, struct timespec *tstamp,
+ int64_t timedelta, u_int8_t rsignal, u_int8_t status);
int mbg_read_amcc_s5933(struct mbg_softc *, int cmd, char *buf, size_t len,
struct timespec *tstamp);
int mbg_read_asic(struct mbg_softc *, int cmd, char *buf, size_t len,
@@ -232,6 +234,11 @@ mbg_attach(struct device *parent, struct device *self, void *aux)
printf("\n");
}
+/*
+ * mbg_task() reads a timestamp from cards that to not provide a high
+ * resolution timestamp. The precsion is limited to 1/100 sec. in this
+ * case.
+ */
void
mbg_task(void *arg)
{
@@ -239,8 +246,8 @@ mbg_task(void *arg)
struct mbg_time tframe;
struct clock_ymdhms ymdhms;
struct timespec tstamp;
+ int64_t timedelta;
time_t trecv;
- int signal;
if (sc->sc_read(sc, MBG_GET_TIME, (char *)&tframe, sizeof(tframe),
&tstamp)) {
@@ -260,41 +267,17 @@ mbg_task(void *arg)
ymdhms.dt_sec = tframe.sec;
trecv = clock_ymdhms_to_secs(&ymdhms) - tframe.utc_off * 3600;
- sc->sc_timedelta.value = (int64_t)((tstamp.tv_sec - trecv) * 100
+ timedelta = (int64_t)((tstamp.tv_sec - trecv) * 100
- tframe.hundreds) * 10000000LL + tstamp.tv_nsec;
- sc->sc_timedelta.status = SENSOR_S_OK;
- sc->sc_timedelta.tv.tv_sec = tstamp.tv_sec;
- sc->sc_timedelta.tv.tv_usec = tstamp.tv_nsec / 1000;
-
- signal = tframe.signal - MBG_SIG_BIAS;
- if (signal < 0)
- signal = 0;
- else if (signal > MBG_SIG_MAX)
- signal = MBG_SIG_MAX;
-
- sc->sc_signal.value = signal * 100000 / MBG_SIG_MAX;
- sc->sc_signal.status = SENSOR_S_OK;
- sc->sc_signal.tv.tv_sec = sc->sc_timedelta.tv.tv_sec;
- sc->sc_signal.tv.tv_usec = sc->sc_timedelta.tv.tv_usec;
- tframe.status &= MBG_STATMASK;
- if (tframe.status != sc->sc_status) {
- if (tframe.status & MBG_SYNC)
- log(LOG_INFO, "%s: clock is synchronized",
- sc->sc_dev.dv_xname);
- if (tframe.status & MBG_FREERUN)
- log(LOG_INFO, "%s: clock is free running on xtal",
- sc->sc_dev.dv_xname);
- if (tframe.status & MBG_LEAP)
- log(LOG_INFO, "%s: leap second announced",
- sc->sc_dev.dv_xname);
- if (tframe.status & MBG_IFTM)
- log(LOG_INFO, "%s: time set from host",
- sc->sc_dev.dv_xname);
- sc->sc_status = tframe.status;
- }
+ mbg_update_sensor(sc, &tstamp, timedelta, tframe.signal,
+ tframe.status);
}
+/*
+ * mbg_task_hr() reads a timestamp from cars that do provide high
+ * resolution timestamp.
+ */
void
mbg_task_hr(void *arg)
{
@@ -302,7 +285,6 @@ mbg_task_hr(void *arg)
struct mbg_time_hr tframe;
struct timespec tstamp;
int64_t tlocal, trecv;
- int signal;
if (sc->sc_read(sc, MBG_GET_TIME_HR, (char *)&tframe, sizeof(tframe),
&tstamp)) {
@@ -319,13 +301,23 @@ mbg_task_hr(void *arg)
tlocal = tstamp.tv_sec * NSECPERSEC + tstamp.tv_nsec;
trecv = tframe.sec * NSECPERSEC + (tframe.frac * NSECPERSEC >> 32);
- sc->sc_timedelta.value = tlocal - trecv;
+ mbg_update_sensor(sc, &tstamp, tlocal - trecv, tframe.signal,
+ tframe.status);
+}
+
+/* update the sensor value, common to all cards */
+void
+mbg_update_sensor(struct mbg_softc *sc, struct timespec *tstamp,
+ int64_t timedelta, u_int8_t rsignal, u_int8_t status)
+{
+ int signal;
+ sc->sc_timedelta.value = timedelta;
sc->sc_timedelta.status = SENSOR_S_OK;
- sc->sc_timedelta.tv.tv_sec = tstamp.tv_sec;
- sc->sc_timedelta.tv.tv_usec = tstamp.tv_nsec / 1000;
+ sc->sc_timedelta.tv.tv_sec = tstamp->tv_sec;
+ sc->sc_timedelta.tv.tv_usec = tstamp->tv_nsec / 1000;
- signal = tframe.signal - MBG_SIG_BIAS;
+ signal = rsignal - MBG_SIG_BIAS;
if (signal < 0)
signal = 0;
else if (signal > MBG_SIG_MAX)
@@ -336,21 +328,21 @@ mbg_task_hr(void *arg)
sc->sc_signal.tv.tv_sec = sc->sc_timedelta.tv.tv_sec;
sc->sc_signal.tv.tv_usec = sc->sc_timedelta.tv.tv_usec;
- tframe.status &= MBG_STATMASK;
- if (tframe.status != sc->sc_status) {
- if (tframe.status & MBG_SYNC)
+ status &= MBG_STATMASK;
+ if (status != sc->sc_status) {
+ if (status & MBG_SYNC)
log(LOG_INFO, "%s: clock is synchronized",
sc->sc_dev.dv_xname);
- else if (tframe.status & MBG_FREERUN)
+ if (status & MBG_FREERUN)
log(LOG_INFO, "%s: clock is free running on xtal",
sc->sc_dev.dv_xname);
- if (tframe.status & MBG_LEAP)
+ if (status & MBG_LEAP)
log(LOG_INFO, "%s: leap second announced",
sc->sc_dev.dv_xname);
- if (tframe.status & MBG_IFTM)
+ if (status & MBG_IFTM)
log(LOG_INFO, "%s: time set from host",
sc->sc_dev.dv_xname);
- sc->sc_status = tframe.status;
+ sc->sc_status = status;
}
}