clocksource: convert W90x900 24-bit down counting clocksource
authorRussell King <rmk+kernel@arm.linux.org.uk>
Sun, 8 May 2011 14:34:39 +0000 (15:34 +0100)
committerRussell King <rmk+kernel@arm.linux.org.uk>
Mon, 23 May 2011 17:04:52 +0000 (18:04 +0100)
Convert the W90x900 24-bit down-counting clocksource to the generic
mmio clocksource infrastructure

Acked-by: Wan ZongShun <mcuos.com@gmail.com>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
arch/arm/Kconfig
arch/arm/mach-w90x900/time.c

index 0a05a57449e34d88c931654413e38f33e0e90816..bab25a0ba1070a9a7fafa624184a6c55e3734289 100644 (file)
@@ -575,6 +575,7 @@ config ARCH_W90X900
        select CPU_ARM926T
        select ARCH_REQUIRE_GPIOLIB
        select CLKDEV_LOOKUP
+       select CLKSRC_MMIO
        select GENERIC_CLOCKEVENTS
        help
          Support for Nuvoton (Winbond logic dept.) ARM9 processor,
index 4b089cb930dc8f7dbcaddb3dc86a473bd03f4518..a2c4e2d0a0d4b6d510c2e81c33bb617a53cbdc2e 100644 (file)
@@ -43,7 +43,6 @@
 #define PRESCALE       0x63 /* Divider = prescale + 1 */
 
 #define        TDR_SHIFT       24
-#define        TDR_MASK        ((1 << TDR_SHIFT) - 1)
 
 static unsigned int timer0_load;
 
@@ -143,19 +142,6 @@ static void __init nuc900_clockevents_init(void)
        clockevents_register_device(&nuc900_clockevent_device);
 }
 
-static cycle_t nuc900_get_cycles(struct clocksource *cs)
-{
-       return (~__raw_readl(REG_TDR1)) & TDR_MASK;
-}
-
-static struct clocksource clocksource_nuc900 = {
-       .name   = "nuc900-timer1",
-       .rating = 200,
-       .read   = nuc900_get_cycles,
-       .mask   = CLOCKSOURCE_MASK(TDR_SHIFT),
-       .flags  = CLOCK_SOURCE_IS_CONTINUOUS,
-};
-
 static void __init nuc900_clocksource_init(void)
 {
        unsigned int val;
@@ -175,7 +161,8 @@ static void __init nuc900_clocksource_init(void)
        val |= (COUNTEN | PERIOD | PRESCALE);
        __raw_writel(val, REG_TCSR1);
 
-       clocksource_register_hz(&clocksource_nuc900, rate);
+       clocksource_mmio_init(REG_TDR1, "nuc900-timer1", rate, 200,
+               TDR_SHIFT, clocksource_mmio_readl_down);
 }
 
 static void __init nuc900_timer_init(void)