diff options
Diffstat (limited to 'sys/arch/arm')
-rw-r--r-- | sys/arch/arm/xscale/pxa2x0.c | 16 | ||||
-rw-r--r-- | sys/arch/arm/xscale/pxa2x0_clock.c | 51 |
2 files changed, 28 insertions, 39 deletions
diff --git a/sys/arch/arm/xscale/pxa2x0.c b/sys/arch/arm/xscale/pxa2x0.c index a3fed5406d9..5fdd3a4b607 100644 --- a/sys/arch/arm/xscale/pxa2x0.c +++ b/sys/arch/arm/xscale/pxa2x0.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pxa2x0.c,v 1.11 2005/11/11 23:59:58 deraadt Exp $ */ +/* $OpenBSD: pxa2x0.c,v 1.12 2008/01/03 17:59:32 kettenis Exp $ */ /* $NetBSD: pxa2x0.c,v 1.5 2003/12/12 16:42:44 thorpej Exp $ */ /* @@ -108,6 +108,7 @@ __KERNEL_RCSID(0, "$NetBSD: pxa2x0.c,v 1.5 2003/12/12 16:42:44 thorpej Exp $"); #include <sys/device.h> #include <sys/kernel.h> #include <sys/reboot.h> +#include <sys/timetc.h> #include <machine/cpu.h> #include <machine/bus.h> @@ -437,15 +438,19 @@ void resettodr(void) { struct pxaip_softc *sc = pxaip_sc; + struct timeval tv; + + microtime(&tv); bus_space_write_4(sc->sc_bust, sc->sc_bush_rtc, RTC_RCNR, - (u_int32_t)time.tv_sec); + (u_int32_t)tv.tv_sec); } void inittodr(time_t base) { struct pxaip_softc *sc = pxaip_sc; + struct timespec ts; u_int32_t rcnr; /* XXX decide if RCNR can be valid, based on the last reset @@ -454,11 +459,12 @@ inittodr(time_t base) /* XXX check how much RCNR differs from the filesystem date. */ if (rcnr > base) - time.tv_sec = rcnr; + ts.tv_sec = rcnr; else { printf("WARNING: using filesystem date -- CHECK AND RESET THE DATE!\n"); - time.tv_sec = base; + ts.tv_sec = base; } - time.tv_usec = 0; + ts.tv_nsec = 0; + tc_setclock(&ts); } diff --git a/sys/arch/arm/xscale/pxa2x0_clock.c b/sys/arch/arm/xscale/pxa2x0_clock.c index efbc4d2be57..89b9c444614 100644 --- a/sys/arch/arm/xscale/pxa2x0_clock.c +++ b/sys/arch/arm/xscale/pxa2x0_clock.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pxa2x0_clock.c,v 1.5 2007/01/11 07:24:52 robert Exp $ */ +/* $OpenBSD: pxa2x0_clock.c,v 1.6 2008/01/03 17:59:32 kettenis Exp $ */ /* * Copyright (c) 2005 Dale Rahn <drahn@openbsd.org> @@ -16,12 +16,11 @@ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ -#include <sys/types.h> #include <sys/param.h> #include <sys/systm.h> #include <sys/kernel.h> -#include <sys/time.h> #include <sys/device.h> +#include <sys/timetc.h> #include <machine/bus.h> #include <machine/intr.h> @@ -72,6 +71,13 @@ struct cfdriver pxaost_cd = { NULL, "pxaost", DV_DULL }; +u_int pxaost_get_timecount(struct timecounter *tc); + +static struct timecounter pxaost_timecounter = { + pxaost_get_timecount, NULL, 0xffffffff, CLK4_TIMER_FREQUENCY, + "pxaost", 0, NULL +}; + int pxaost_match(parent, match, aux) struct device *parent; @@ -117,6 +123,13 @@ pxaost_attach(parent, self, aux) } +u_int +pxaost_get_timecount(struct timecounter *tc) +{ + return bus_space_read_4(pxaost_sc->sc_iot, pxaost_sc->sc_ioh, + OST_OSCR4); +} + int clockintr(arg) void *arg; @@ -239,38 +252,8 @@ cpu_initclocks() clk + pxaost_sc->sc_clock_count); bus_space_write_4(pxaost_sc->sc_iot, pxaost_sc->sc_ioh, OST_OSMR5, clk + pxaost_sc->sc_statclock_count); -} - -void -microtime(tvp) - register struct timeval *tvp; -{ - int s, deltacnt; - u_int32_t counter, expected; - - if (pxaost_sc == NULL) { - tvp->tv_sec = 0; - tvp->tv_usec = 0; - return; - } - - s = splhigh(); - counter = bus_space_read_4(pxaost_sc->sc_iot, pxaost_sc->sc_ioh, - OST_OSCR4); - expected = pxaost_sc->sc_clock_count; - - *tvp = time; - splx(s); - - /* number of CLK4_TIMER_FREQUENCY ticks past time */ - deltacnt = counter - expected + pxaost_sc->sc_clock_step; - tvp->tv_usec += deltacnt * 1000000ULL / CLK4_TIMER_FREQUENCY; - - while (tvp->tv_usec >= 1000000) { - tvp->tv_sec++; - tvp->tv_usec -= 1000000; - } + tc_init(&pxaost_timecounter); } void |