X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=arch%2Fia64%2Fkernel%2Firq.c;h=9c72ea3f6432d115ca32090d0c8bd9c8365d5c07;hb=8f7c58814eb75bf97b8bc18d107b2e26f28b6585;hp=d33244c3275914f8ecdfeb769c1a9aad92710eff;hpb=2d8f6a521908e3563478347aecad4ab20dc48155;p=powerpc.git diff --git a/arch/ia64/kernel/irq.c b/arch/ia64/kernel/irq.c index d33244c327..9c72ea3f64 100644 --- a/arch/ia64/kernel/irq.c +++ b/arch/ia64/kernel/irq.c @@ -101,7 +101,6 @@ void set_irq_affinity_info (unsigned int irq, int hwid, int redir) if (irq < NR_IRQS) { irq_affinity[irq] = mask; - set_irq_info(irq, mask); irq_redir[irq] = (char) (redir & 0xff); } } @@ -163,8 +162,19 @@ void fixup_irqs(void) { unsigned int irq; extern void ia64_process_pending_intr(void); + extern void ia64_disable_timer(void); + extern volatile int time_keeper_id; + + ia64_disable_timer(); + + /* + * Find a new timesync master + */ + if (smp_processor_id() == time_keeper_id) { + time_keeper_id = first_cpu(cpu_online_map); + printk ("CPU %d is now promoted to time-keeper master\n", time_keeper_id); + } - ia64_set_itv(1<<16); /* * Phase 1: Locate irq's bound to this cpu and * relocate them for cpu removal.