aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-integrator
diff options
context:
space:
mode:
authorRussell King <rmk+kernel@arm.linux.org.uk>2010-01-15 13:10:33 -0500
committerRussell King <rmk+kernel@arm.linux.org.uk>2010-04-29 13:04:15 -0400
commitb9cedda230793cbf58eb012ddadedd490cc8e129 (patch)
tree5c1e21e04206d68d9089299e6b9f61347c3f8070 /arch/arm/mach-integrator
parentba02a21544b41a65e58506f1d79353203d94b8b6 (diff)
ARM: Integrator: convert to generic time support
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/common.h1
-rw-r--r--arch/arm/mach-integrator/core.c62
-rw-r--r--arch/arm/mach-integrator/integrator_ap.c1
-rw-r--r--arch/arm/mach-integrator/integrator_cp.c1
4 files changed, 30 insertions, 35 deletions
diff --git a/arch/arm/mach-integrator/common.h b/arch/arm/mach-integrator/common.h
index 609c49de3d4..7dc24bb9bdc 100644
--- a/arch/arm/mach-integrator/common.h
+++ b/arch/arm/mach-integrator/common.h
@@ -1,2 +1 @@
1extern void integrator_time_init(unsigned long, unsigned int); extern void integrator_time_init(unsigned long, unsigned int);
2extern unsigned long integrator_gettimeoffset(void);
diff --git a/arch/arm/mach-integrator/core.c b/arch/arm/mach-integrator/core.c
index 096f899625f..87c6f980944 100644
--- a/arch/arm/mach-integrator/core.c
+++ b/arch/arm/mach-integrator/core.c
@@ -19,6 +19,7 @@
19#include <linux/termios.h> 19#include <linux/termios.h>
20#include <linux/amba/bus.h> 20#include <linux/amba/bus.h>
21#include <linux/amba/serial.h> 21#include <linux/amba/serial.h>
22#include <linux/clocksource.h>
22#include <linux/io.h> 23#include <linux/io.h>
23 24
24#include <asm/clkdev.h> 25#include <asm/clkdev.h>
@@ -225,7 +226,6 @@ EXPORT_SYMBOL(cm_control);
225#define TIMER0_VA_BASE (IO_ADDRESS(INTEGRATOR_CT_BASE)+0x00000000) 226#define TIMER0_VA_BASE (IO_ADDRESS(INTEGRATOR_CT_BASE)+0x00000000)
226#define TIMER1_VA_BASE (IO_ADDRESS(INTEGRATOR_CT_BASE)+0x00000100) 227#define TIMER1_VA_BASE (IO_ADDRESS(INTEGRATOR_CT_BASE)+0x00000100)
227#define TIMER2_VA_BASE (IO_ADDRESS(INTEGRATOR_CT_BASE)+0x00000200) 228#define TIMER2_VA_BASE (IO_ADDRESS(INTEGRATOR_CT_BASE)+0x00000200)
228#define VA_IC_BASE IO_ADDRESS(INTEGRATOR_IC_BASE)
229 229
230/* 230/*
231 * How long is the timer interval? 231 * How long is the timer interval?
@@ -241,42 +241,38 @@ EXPORT_SYMBOL(cm_control);
241 241
242static unsigned long timer_reload; 242static unsigned long timer_reload;
243 243
244/* 244static void __iomem * const clksrc_base = (void __iomem *)TIMER2_VA_BASE;
245 * Returns number of ms since last clock interrupt. Note that interrupts 245
246 * will have been disabled by do_gettimeoffset() 246static cycle_t timersp_read(struct clocksource *cs)
247 */
248unsigned long integrator_gettimeoffset(void)
249{ 247{
250 unsigned long ticks1, ticks2, status; 248 return ~(readl(clksrc_base + TIMER_VALUE) & 0xffff);
249}
251 250
252 /* 251static struct clocksource clocksource_timersp = {
253 * Get the current number of ticks. Note that there is a race 252 .name = "timer2",
254 * condition between us reading the timer and checking for 253 .rating = 200,
255 * an interrupt. We get around this by ensuring that the 254 .read = timersp_read,
256 * counter has not reloaded between our two reads. 255 .mask = CLOCKSOURCE_MASK(16),
257 */ 256 .shift = 16,
258 ticks2 = readl(TIMER1_VA_BASE + TIMER_VALUE) & 0xffff; 257 .flags = CLOCK_SOURCE_IS_CONTINUOUS,
259 do { 258};
260 ticks1 = ticks2;
261 status = __raw_readl(VA_IC_BASE + IRQ_RAW_STATUS);
262 ticks2 = readl(TIMER1_VA_BASE + TIMER_VALUE) & 0xffff;
263 } while (ticks2 > ticks1);
264 259
265 /* 260static void integrator_clocksource_init(u32 khz)
266 * Number of ticks since last interrupt. 261{
267 */ 262 struct clocksource *cs = &clocksource_timersp;
268 ticks1 = timer_reload - ticks2; 263 void __iomem *base = clksrc_base;
264 u32 ctrl = TIMER_CTRL_ENABLE;
269 265
270 /* 266 if (khz >= 1500) {
271 * Interrupt pending? If so, we've reloaded once already. 267 khz /= 16;
272 */ 268 ctrl = TIMER_CTRL_DIV16;
273 if (status & (1 << IRQ_TIMERINT1)) 269 }
274 ticks1 += timer_reload;
275 270
276 /* 271 writel(ctrl, base + TIMER_CTRL);
277 * Convert the ticks to usecs 272 writel(0xffff, base + TIMER_LOAD);
278 */ 273
279 return TICKS2USECS(ticks1); 274 cs->mult = clocksource_khz2mult(khz, cs->shift);
275 clocksource_register(cs);
280} 276}
281 277
282/* 278/*
@@ -308,6 +304,8 @@ void __init integrator_time_init(unsigned long reload, unsigned int ctrl)
308{ 304{
309 unsigned int timer_ctrl = TIMER_CTRL_ENABLE | TIMER_CTRL_PERIODIC; 305 unsigned int timer_ctrl = TIMER_CTRL_ENABLE | TIMER_CTRL_PERIODIC;
310 306
307 integrator_clocksource_init(reload * HZ / 1000);
308
311 timer_reload = reload; 309 timer_reload = reload;
312 timer_ctrl |= ctrl; 310 timer_ctrl |= ctrl;
313 311
diff --git a/arch/arm/mach-integrator/integrator_ap.c b/arch/arm/mach-integrator/integrator_ap.c
index 018c32da4c8..cfb718fe31a 100644
--- a/arch/arm/mach-integrator/integrator_ap.c
+++ b/arch/arm/mach-integrator/integrator_ap.c
@@ -342,7 +342,6 @@ static void __init ap_init_timer(void)
342 342
343static struct sys_timer ap_timer = { 343static struct sys_timer ap_timer = {
344 .init = ap_init_timer, 344 .init = ap_init_timer,
345 .offset = integrator_gettimeoffset,
346}; 345};
347 346
348MACHINE_START(INTEGRATOR, "ARM-Integrator") 347MACHINE_START(INTEGRATOR, "ARM-Integrator")
diff --git a/arch/arm/mach-integrator/integrator_cp.c b/arch/arm/mach-integrator/integrator_cp.c
index c66e8fa0e62..3e84732163e 100644
--- a/arch/arm/mach-integrator/integrator_cp.c
+++ b/arch/arm/mach-integrator/integrator_cp.c
@@ -577,7 +577,6 @@ static void __init intcp_timer_init(void)
577 577
578static struct sys_timer cp_timer = { 578static struct sys_timer cp_timer = {
579 .init = intcp_timer_init, 579 .init = intcp_timer_init,
580 .offset = integrator_gettimeoffset,
581}; 580};
582 581
583MACHINE_START(CINTEGRATOR, "ARM-IntegratorCP") 582MACHINE_START(CINTEGRATOR, "ARM-IntegratorCP")