aboutsummaryrefslogtreecommitdiffstats
path: root/arch/i386/mach-voyager/voyager_smp.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/i386/mach-voyager/voyager_smp.c')
-rw-r--r--arch/i386/mach-voyager/voyager_smp.c10
1 files changed, 4 insertions, 6 deletions
diff --git a/arch/i386/mach-voyager/voyager_smp.c b/arch/i386/mach-voyager/voyager_smp.c
index 2e73f353f165..f3fea2ad50fe 100644
--- a/arch/i386/mach-voyager/voyager_smp.c
+++ b/arch/i386/mach-voyager/voyager_smp.c
@@ -1141,9 +1141,9 @@ smp_apic_timer_interrupt(struct pt_regs *regs)
1141fastcall void 1141fastcall void
1142smp_qic_timer_interrupt(struct pt_regs *regs) 1142smp_qic_timer_interrupt(struct pt_regs *regs)
1143{ 1143{
1144 ack_QIC_CPI(QIC_TIMER_CPI);
1145 struct pt_regs *old_regs = set_irq_regs(regs); 1144 struct pt_regs *old_regs = set_irq_regs(regs);
1146 wrapper_smp_local_timer_interrupt(void); 1145 ack_QIC_CPI(QIC_TIMER_CPI);
1146 wrapper_smp_local_timer_interrupt();
1147 set_irq_regs(old_regs); 1147 set_irq_regs(old_regs);
1148} 1148}
1149 1149
@@ -1267,12 +1267,10 @@ smp_send_stop(void)
1267/* this function is triggered in time.c when a clock tick fires 1267/* this function is triggered in time.c when a clock tick fires
1268 * we need to re-broadcast the tick to all CPUs */ 1268 * we need to re-broadcast the tick to all CPUs */
1269void 1269void
1270smp_vic_timer_interrupt(struct pt_regs *regs) 1270smp_vic_timer_interrupt(void)
1271{ 1271{
1272 struct pt_regs *old_regs = set_irq_regs(regs);
1273 send_CPI_allbutself(VIC_TIMER_CPI); 1272 send_CPI_allbutself(VIC_TIMER_CPI);
1274 smp_local_timer_interrupt(); 1273 smp_local_timer_interrupt();
1275 set_irq_regs(old_regs);
1276} 1274}
1277 1275
1278/* local (per CPU) timer interrupt. It does both profiling and 1276/* local (per CPU) timer interrupt. It does both profiling and
@@ -1307,7 +1305,7 @@ smp_local_timer_interrupt(void)
1307 per_cpu(prof_counter, cpu); 1305 per_cpu(prof_counter, cpu);
1308 } 1306 }
1309 1307
1310 update_process_times(user_mode_vm(irq_regs)); 1308 update_process_times(user_mode_vm(get_irq_regs()));
1311 } 1309 }
1312 1310
1313 if( ((1<<cpu) & voyager_extended_vic_processors) == 0) 1311 if( ((1<<cpu) & voyager_extended_vic_processors) == 0)