ARM: Realview/Versatile: don't use magic numbers for timer frequency
authorRussell King <rmk+kernel@arm.linux.org.uk>
Fri, 15 Jan 2010 18:19:56 +0000 (18:19 +0000)
committerRussell King <rmk+kernel@arm.linux.org.uk>
Sun, 2 May 2010 08:35:35 +0000 (09:35 +0100)
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
arch/arm/plat-versatile/timer-sp.c

index d1dbef5b17b181007358c34939ed79db673e0155..fb0d1c299718c1537ca27a88da17b5439bf8b21d 100644 (file)
 
 #include <asm/hardware/arm_timer.h>
 
-#include <mach/platform.h>
-
 #include <plat/timer-sp.h>
 
 /*
- * How long is the timer interval?
+ * These timers are currently always setup to be clocked at 1MHz.
  */
-#define TIMER_RELOAD   (TICKS_PER_uSEC * mSEC_10)
-
+#define TIMER_FREQ_KHZ (1000)
+#define TIMER_RELOAD   (TIMER_FREQ_KHZ * 1000 / HZ)
 
 static void __iomem *clksrc_base;
 
@@ -65,7 +63,7 @@ void __init sp804_clocksource_init(void __iomem *base)
        writel(TIMER_CTRL_32BIT | TIMER_CTRL_ENABLE | TIMER_CTRL_PERIODIC,
                clksrc_base + TIMER_CTRL);
 
-       cs->mult = clocksource_khz2mult(1000, cs->shift);
+       cs->mult = clocksource_khz2mult(TIMER_FREQ_KHZ, cs->shift);
        clocksource_register(cs);
 }
 
@@ -149,7 +147,7 @@ void __init sp804_clockevents_init(void __iomem *base, unsigned int timer_irq)
        clkevt_base = base;
 
        evt->irq = timer_irq;
-       evt->mult = div_sc(1000000, NSEC_PER_SEC, evt->shift);
+       evt->mult = div_sc(TIMER_FREQ_KHZ, NSEC_PER_MSEC, evt->shift);
        evt->max_delta_ns = clockevent_delta2ns(0xffffffff, evt);
        evt->min_delta_ns = clockevent_delta2ns(0xf, evt);