diff options
author | Linus Walleij <linus.walleij@linaro.org> | 2012-01-31 17:38:23 -0500 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2012-03-24 05:38:51 -0400 |
commit | a9d6d15131b0519363b0c94734ee80955c411093 (patch) | |
tree | 95c534c441e26e11a10fa06abeacbc6fd8b40070 /arch/arm/mach-integrator | |
parent | f9d4861fc32b995b1616775614459b8f266c803c (diff) |
ARM: 7310/1: integrator: implement sched_clock across all boards
Now that we can select a sched_clock at runtime, let's implement
it for the Integrator AP, default-select the one found in all
other board it for all plat-versatile boards and make the right
clock kick in at runtime.
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm/mach-integrator')
-rw-r--r-- | arch/arm/mach-integrator/Kconfig | 1 | ||||
-rw-r--r-- | arch/arm/mach-integrator/integrator_ap.c | 7 |
2 files changed, 8 insertions, 0 deletions
diff --git a/arch/arm/mach-integrator/Kconfig b/arch/arm/mach-integrator/Kconfig index 350e26636a06..5a6148ab6dac 100644 --- a/arch/arm/mach-integrator/Kconfig +++ b/arch/arm/mach-integrator/Kconfig | |||
@@ -5,6 +5,7 @@ menu "Integrator Options" | |||
5 | config ARCH_INTEGRATOR_AP | 5 | config ARCH_INTEGRATOR_AP |
6 | bool "Support Integrator/AP and Integrator/PP2 platforms" | 6 | bool "Support Integrator/AP and Integrator/PP2 platforms" |
7 | select CLKSRC_MMIO | 7 | select CLKSRC_MMIO |
8 | select HAVE_SCHED_CLOCK | ||
8 | select MIGHT_HAVE_PCI | 9 | select MIGHT_HAVE_PCI |
9 | select SERIAL_AMBA_PL010 | 10 | select SERIAL_AMBA_PL010 |
10 | select SERIAL_AMBA_PL010_CONSOLE | 11 | select SERIAL_AMBA_PL010_CONSOLE |
diff --git a/arch/arm/mach-integrator/integrator_ap.c b/arch/arm/mach-integrator/integrator_ap.c index 21a1d6cbef40..4dde28b9dc07 100644 --- a/arch/arm/mach-integrator/integrator_ap.c +++ b/arch/arm/mach-integrator/integrator_ap.c | |||
@@ -42,6 +42,7 @@ | |||
42 | #include <asm/setup.h> | 42 | #include <asm/setup.h> |
43 | #include <asm/param.h> /* HZ */ | 43 | #include <asm/param.h> /* HZ */ |
44 | #include <asm/mach-types.h> | 44 | #include <asm/mach-types.h> |
45 | #include <asm/sched_clock.h> | ||
45 | 46 | ||
46 | #include <mach/lm.h> | 47 | #include <mach/lm.h> |
47 | 48 | ||
@@ -325,6 +326,11 @@ static void __init ap_init(void) | |||
325 | 326 | ||
326 | static unsigned long timer_reload; | 327 | static unsigned long timer_reload; |
327 | 328 | ||
329 | static u32 notrace integrator_read_sched_clock(void) | ||
330 | { | ||
331 | return -readl((void __iomem *) TIMER2_VA_BASE + TIMER_VALUE); | ||
332 | } | ||
333 | |||
328 | static void integrator_clocksource_init(unsigned long inrate) | 334 | static void integrator_clocksource_init(unsigned long inrate) |
329 | { | 335 | { |
330 | void __iomem *base = (void __iomem *)TIMER2_VA_BASE; | 336 | void __iomem *base = (void __iomem *)TIMER2_VA_BASE; |
@@ -341,6 +347,7 @@ static void integrator_clocksource_init(unsigned long inrate) | |||
341 | 347 | ||
342 | clocksource_mmio_init(base + TIMER_VALUE, "timer2", | 348 | clocksource_mmio_init(base + TIMER_VALUE, "timer2", |
343 | rate, 200, 16, clocksource_mmio_readl_down); | 349 | rate, 200, 16, clocksource_mmio_readl_down); |
350 | setup_sched_clock(integrator_read_sched_clock, 16, rate); | ||
344 | } | 351 | } |
345 | 352 | ||
346 | static void __iomem * const clkevt_base = (void __iomem *)TIMER1_VA_BASE; | 353 | static void __iomem * const clkevt_base = (void __iomem *)TIMER1_VA_BASE; |