aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/plat-iop/time.c
diff options
context:
space:
mode:
authorRussell King <rmk+kernel@arm.linux.org.uk>2010-12-19 10:43:34 -0500
committerRussell King <rmk+kernel@arm.linux.org.uk>2010-12-19 10:44:53 -0500
commit40cc52440073903f3b7477a3391c4ca0761445d0 (patch)
tree3f1f0cdf4180746acb32e3b1089b3a771fb8258c /arch/arm/plat-iop/time.c
parent83cf1eecfe9afee99d6b86f963187acd414c019d (diff)
ARM: clockevents: fix IOP clock events initialization
Ensure that no interrupt is pending before registering the clock event device, and properly initialize the periodic tick in the ->set_mode callback. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm/plat-iop/time.c')
-rw-r--r--arch/arm/plat-iop/time.c5
1 files changed, 2 insertions, 3 deletions
diff --git a/arch/arm/plat-iop/time.c b/arch/arm/plat-iop/time.c
index 85d3e55ca4a9..d615e6fbe502 100644
--- a/arch/arm/plat-iop/time.c
+++ b/arch/arm/plat-iop/time.c
@@ -87,6 +87,7 @@ static void iop_set_mode(enum clock_event_mode mode,
87 case CLOCK_EVT_MODE_PERIODIC: 87 case CLOCK_EVT_MODE_PERIODIC:
88 write_tmr0(tmr & ~IOP_TMR_EN); 88 write_tmr0(tmr & ~IOP_TMR_EN);
89 write_tcr0(ticks_per_jiffy - 1); 89 write_tcr0(ticks_per_jiffy - 1);
90 write_trr0(ticks_per_jiffy - 1);
90 tmr |= (IOP_TMR_RELOAD | IOP_TMR_EN); 91 tmr |= (IOP_TMR_RELOAD | IOP_TMR_EN);
91 break; 92 break;
92 case CLOCK_EVT_MODE_ONESHOT: 93 case CLOCK_EVT_MODE_ONESHOT:
@@ -152,6 +153,7 @@ void __init iop_init_time(unsigned long tick_rate)
152 * Set up interrupting clockevent timer 0. 153 * Set up interrupting clockevent timer 0.
153 */ 154 */
154 write_tmr0(timer_ctl & ~IOP_TMR_EN); 155 write_tmr0(timer_ctl & ~IOP_TMR_EN);
156 write_tisr(1);
155 setup_irq(IRQ_IOP_TIMER0, &iop_timer_irq); 157 setup_irq(IRQ_IOP_TIMER0, &iop_timer_irq);
156 clockevents_calc_mult_shift(&iop_clockevent, 158 clockevents_calc_mult_shift(&iop_clockevent,
157 tick_rate, IOP_MIN_RANGE); 159 tick_rate, IOP_MIN_RANGE);
@@ -161,9 +163,6 @@ void __init iop_init_time(unsigned long tick_rate)
161 clockevent_delta2ns(0xf, &iop_clockevent); 163 clockevent_delta2ns(0xf, &iop_clockevent);
162 iop_clockevent.cpumask = cpumask_of(0); 164 iop_clockevent.cpumask = cpumask_of(0);
163 clockevents_register_device(&iop_clockevent); 165 clockevents_register_device(&iop_clockevent);
164 write_trr0(ticks_per_jiffy - 1);
165 write_tcr0(ticks_per_jiffy - 1);
166 write_tmr0(timer_ctl);
167 166
168 /* 167 /*
169 * Set up free-running clocksource timer 1. 168 * Set up free-running clocksource timer 1.