diff options
author | Dale Rahn <drahn@cvs.openbsd.org> | 2010-02-22 23:16:48 +0000 |
---|---|---|
committer | Dale Rahn <drahn@cvs.openbsd.org> | 2010-02-22 23:16:48 +0000 |
commit | b2994f709b0292574a7f1739a5b1389e89b11853 (patch) | |
tree | 9be88aa3143ad3584f7421c63bcc8d7054b38f45 /sys/arch | |
parent | 5ca7aba1b915e0011b188970b7bfb2849a534250 (diff) |
It is bad to have HAVE_TIMECOUNTER but the clock/timer not configure a
timecounter.
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/beagle/dev/gptimer.c | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/sys/arch/beagle/dev/gptimer.c b/sys/arch/beagle/dev/gptimer.c index cb90c785079..3258819dd90 100644 --- a/sys/arch/beagle/dev/gptimer.c +++ b/sys/arch/beagle/dev/gptimer.c @@ -1,4 +1,4 @@ -/* $OpenBSD: gptimer.c,v 1.2 2009/05/24 00:36:09 drahn Exp $ */ +/* $OpenBSD: gptimer.c,v 1.3 2010/02/22 23:16:47 drahn Exp $ */ /* * Copyright (c) 2007,2009 Dale Rahn <drahn@openbsd.org> * @@ -116,6 +116,12 @@ bus_space_tag_t gptimer_iot; bus_space_handle_t gptimer_ioh0, gptimer_ioh1; int gptimer_irq = 0; +u_int gptimer_get_timecount(struct timecounter *); + +static struct timecounter gptimer_timecounter = { + gptimer_get_timecount, NULL, 0x7fffffff, 0, "gptimer", 0, NULL +}; + volatile u_int32_t nexttickevent; volatile u_int32_t nextstatevent; u_int32_t ticks_per_second; @@ -167,6 +173,8 @@ gptimer_attach(struct device *parent, struct device *self, void *args) GP_TCLR_AR | GP_TCLR_ST); gptimer_delay(GP_TWPS_ALL); + gptimer_timecounter.tc_frequency = TIMER_FREQUENCY; + tc_init(&gptimer_timecounter); } else panic("attaching too many gptimers at %x\n", aa->aa_addr); @@ -510,3 +518,8 @@ resettodr(void) printf("resettodr: failed to set time\n"); } +u_int +gptimer_get_timecount(struct timecounter *tc) +{ + return bus_space_read_4(gptimer_iot, gptimer_ioh1, GP_TCRR); +} |