diff options
Diffstat (limited to 'arch/parisc')
-rw-r--r-- | arch/parisc/kernel/irq.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/arch/parisc/kernel/irq.c b/arch/parisc/kernel/irq.c index 2626405e70c4..144fc25b3872 100644 --- a/arch/parisc/kernel/irq.c +++ b/arch/parisc/kernel/irq.c | |||
@@ -261,13 +261,17 @@ int txn_alloc_irq(unsigned int bits_wide) | |||
261 | return -1; | 261 | return -1; |
262 | } | 262 | } |
263 | 263 | ||
264 | |||
264 | unsigned long txn_affinity_addr(unsigned int irq, int cpu) | 265 | unsigned long txn_affinity_addr(unsigned int irq, int cpu) |
265 | { | 266 | { |
267 | #ifdef CONFIG_SMP | ||
266 | irq_affinity[irq] = cpumask_of_cpu(cpu); | 268 | irq_affinity[irq] = cpumask_of_cpu(cpu); |
269 | #endif | ||
267 | 270 | ||
268 | return cpu_data[cpu].txn_addr; | 271 | return cpu_data[cpu].txn_addr; |
269 | } | 272 | } |
270 | 273 | ||
274 | |||
271 | unsigned long txn_alloc_addr(unsigned int virt_irq) | 275 | unsigned long txn_alloc_addr(unsigned int virt_irq) |
272 | { | 276 | { |
273 | static int next_cpu = -1; | 277 | static int next_cpu = -1; |
@@ -321,14 +325,16 @@ void do_cpu_irq_mask(struct pt_regs *regs) | |||
321 | 325 | ||
322 | /* Work our way from MSb to LSb...same order we alloc EIRs */ | 326 | /* Work our way from MSb to LSb...same order we alloc EIRs */ |
323 | for (irq = TIMER_IRQ; eirr_val && bit; bit>>=1, irq++) { | 327 | for (irq = TIMER_IRQ; eirr_val && bit; bit>>=1, irq++) { |
328 | #ifdef CONFIG_SMP | ||
324 | cpumask_t dest = irq_affinity[irq]; | 329 | cpumask_t dest = irq_affinity[irq]; |
325 | 330 | #endif | |
326 | if (!(bit & eirr_val)) | 331 | if (!(bit & eirr_val)) |
327 | continue; | 332 | continue; |
328 | 333 | ||
329 | /* clear bit in mask - can exit loop sooner */ | 334 | /* clear bit in mask - can exit loop sooner */ |
330 | eirr_val &= ~bit; | 335 | eirr_val &= ~bit; |
331 | 336 | ||
337 | #ifdef CONFIG_SMP | ||
332 | /* FIXME: because generic set affinity mucks | 338 | /* FIXME: because generic set affinity mucks |
333 | * with the affinity before sending it to us | 339 | * with the affinity before sending it to us |
334 | * we can get the situation where the affinity is | 340 | * we can get the situation where the affinity is |
@@ -337,12 +343,13 @@ void do_cpu_irq_mask(struct pt_regs *regs) | |||
337 | !cpu_isset(smp_processor_id(), dest)) { | 343 | !cpu_isset(smp_processor_id(), dest)) { |
338 | int cpu = first_cpu(dest); | 344 | int cpu = first_cpu(dest); |
339 | 345 | ||
340 | printk("rethrowing irq %d from %d to %d\n", | 346 | printk("redirecting irq %d from CPU %d to %d\n", |
341 | irq, smp_processor_id(), cpu); | 347 | irq, smp_processor_id(), cpu); |
342 | gsc_writel(irq + CPU_IRQ_BASE, | 348 | gsc_writel(irq + CPU_IRQ_BASE, |
343 | cpu_data[cpu].hpa); | 349 | cpu_data[cpu].hpa); |
344 | continue; | 350 | continue; |
345 | } | 351 | } |
352 | #endif | ||
346 | 353 | ||
347 | __do_IRQ(irq, regs); | 354 | __do_IRQ(irq, regs); |
348 | } | 355 | } |