]> git.baikalelectronics.ru Git - kernel.git/commit
powerpc: Re-enable dynticks
authorPaul Clarke <pc@us.ibm.com>
Fri, 20 Feb 2015 17:13:33 +0000 (11:13 -0600)
committerMichael Ellerman <mpe@ellerman.id.au>
Mon, 23 Feb 2015 03:52:04 +0000 (14:52 +1100)
commit6523dac2e3cd80f051d890362231721ab357c4b6
tree12e443a85eb0440b2ff4f41c7d01991759f5d1b4
parent9cbe621030a9cce16d27329dac74fd4b1c1d9412
powerpc: Re-enable dynticks

Implement arch_irq_work_has_interrupt() for powerpc

Commit 9cdc07863 introduced a dependency on "IRQ work self-IPIs" for
full dynamic ticks to be enabled, by expecting architectures to
implement a suitable arch_irq_work_has_interrupt() routine.

Several arches have implemented this routine, including x86 (48d32e0b)
and arm (3c600c04), but powerpc was omitted.

This patch implements this routine for powerpc.

The symptom, at boot (on powerpc systems) with "nohz_full=<CPU list>"
is displayed:

     NO_HZ: Can't run full dynticks because arch doesn't support irq work self-IPIs

after this patch:

     NO_HZ: Full dynticks CPUs: <CPU list>.

Tested against 3.19.

powerpc implements "IRQ work self-IPIs" by setting the decrementer to 1 in
arch_irq_work_raise(), which causes a decrementer exception on the next
timebase tick. We then handle the work in __timer_interrupt().

CC: Frederic Weisbecker <fweisbec@gmail.com>
Signed-off-by: Paul A. Clarke <pc@us.ibm.com>
Reviewed-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
[mpe: Flesh out change log, fix ws & include guards, remove include of processor.h]
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
arch/powerpc/include/asm/irq_work.h [new file with mode: 0644]