powerpc: fixup hard_irq_disable semantics
authorBenjamin Herrenschmidt <benh@kernel.crashing.org>
Fri, 11 May 2007 05:22:45 +0000 (22:22 -0700)
committerLinus Torvalds <torvalds@woody.linux-foundation.org>
Fri, 11 May 2007 15:29:34 +0000 (08:29 -0700)
commite1fa2e136ff64a3814a98c03d46320b9e80d29c8
tree14620d6f3361274139cccded4b38dc7e0347a593
parent2acdb1694494eb6f17b44b2b3065879af32d0d46
powerpc: fixup hard_irq_disable semantics

This patch renames the raw hard_irq_{enable,disable} into
__hard_irq_{enable,disable} and introduces a higher level hard_irq_disable()
function that can be used by any code to enforce that IRQs are fully disabled,
not only lazy disabled.

The difference with the __ versions is that it will update some per-processor
fields so that the kernel keeps track and properly re-enables them in the next
local_irq_disable();

This prepares powerpc for my next patch that introduces hard_irq_disable()
generically.

Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Rusty Russell <rusty@rustcorp.com.au>
Cc: Paul Mackerras <paulus@samba.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
arch/powerpc/kernel/irq.c
arch/powerpc/kernel/swsusp.c
arch/powerpc/platforms/cell/pervasive.c
include/asm-powerpc/hw_irq.h