diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-05-23 18:15:27 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-05-23 18:15:27 -0400 |
commit | 42cd71bf1e3a081b3150018bbf448cb6c8a844a5 (patch) | |
tree | 4a5d2eb0444255e4ad827a76dbd1417dd3876db6 /arch/arm/mach-u300/timer.c | |
parent | f5039935ac685b3b9b8c13fbc33cac8643dee32e (diff) | |
parent | 9a55d9752d8abfc62f1ab05ccc790d22a0c8e7c0 (diff) |
Merge branch 'for-linus' of master.kernel.org:/home/rmk/linux-2.6-arm
* 'for-linus' of master.kernel.org:/home/rmk/linux-2.6-arm: (137 commits)
ARM: bcmring: convert to use sp804 clockevents
ARM: bcmring: convert to sp804 clocksource
ARM: 6912/1: bcmring: Add clkdev table in init_early
clockevents: ARM sp804: obtain sp804 timer rate via clks
clockevents: ARM sp804: allow clockevent name to be specified
clocksource: ARM sp804: obtain sp804 timer rate via clks
clocksource: ARM sp804: allow clocksource name to be specified
clocksource: convert OMAP1 to 32-bit down counting clocksource
clocksource: convert MXS timrotv2 to 32-bit down counting clocksource
clocksource: convert SPEAr platforms 16-bit up counting clocksource
clocksource: convert Integrator/AP 16-bit down counting clocksource
clocksource: convert W90x900 24-bit down counting clocksource
clocksource: convert ARM 32-bit down counting clocksources
clocksource: convert ARM 32-bit up counting clocksources
clocksource: add common mmio clocksource
ARM: update sa1100 to reflect PXA updates
ARM: omap1: convert to using readl/writel instead of volatile struct
ARM: omap1: delete useless interrupt handler
ARM: s5p: consolidate selection of timer register
ARM: 6939/1: fix missing 'cpu_relax()' declaration
...
Diffstat (limited to 'arch/arm/mach-u300/timer.c')
-rw-r--r-- | arch/arm/mach-u300/timer.c | 18 |
1 files changed, 3 insertions, 15 deletions
diff --git a/arch/arm/mach-u300/timer.c b/arch/arm/mach-u300/timer.c index 3ec58bd2d6e4..891cf44591e0 100644 --- a/arch/arm/mach-u300/timer.c +++ b/arch/arm/mach-u300/timer.c | |||
@@ -333,20 +333,6 @@ static struct irqaction u300_timer_irq = { | |||
333 | .handler = u300_timer_interrupt, | 333 | .handler = u300_timer_interrupt, |
334 | }; | 334 | }; |
335 | 335 | ||
336 | /* Use general purpose timer 2 as clock source */ | ||
337 | static cycle_t u300_get_cycles(struct clocksource *cs) | ||
338 | { | ||
339 | return (cycles_t) readl(U300_TIMER_APP_VBASE + U300_TIMER_APP_GPT2CC); | ||
340 | } | ||
341 | |||
342 | static struct clocksource clocksource_u300_1mhz = { | ||
343 | .name = "GPT2", | ||
344 | .rating = 300, /* Reasonably fast and accurate clock source */ | ||
345 | .read = u300_get_cycles, | ||
346 | .mask = CLOCKSOURCE_MASK(32), /* 32 bits */ | ||
347 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
348 | }; | ||
349 | |||
350 | /* | 336 | /* |
351 | * Override the global weak sched_clock symbol with this | 337 | * Override the global weak sched_clock symbol with this |
352 | * local implementation which uses the clocksource to get some | 338 | * local implementation which uses the clocksource to get some |
@@ -422,7 +408,9 @@ static void __init u300_timer_init(void) | |||
422 | writel(U300_TIMER_APP_EGPT2_TIMER_ENABLE, | 408 | writel(U300_TIMER_APP_EGPT2_TIMER_ENABLE, |
423 | U300_TIMER_APP_VBASE + U300_TIMER_APP_EGPT2); | 409 | U300_TIMER_APP_VBASE + U300_TIMER_APP_EGPT2); |
424 | 410 | ||
425 | if (clocksource_register_hz(&clocksource_u300_1mhz, rate)) | 411 | /* Use general purpose timer 2 as clock source */ |
412 | if (clocksource_mmio_init(U300_TIMER_APP_VBASE + U300_TIMER_APP_GPT2CC, | ||
413 | "GPT2", rate, 300, 32, clocksource_mmio_readl_up)) | ||
426 | printk(KERN_ERR "timer: failed to initialize clock " | 414 | printk(KERN_ERR "timer: failed to initialize clock " |
427 | "source %s\n", clocksource_u300_1mhz.name); | 415 | "source %s\n", clocksource_u300_1mhz.name); |
428 | 416 | ||