ARC: Entry Handler tweaks: Optimize away redundant IRQ_DISABLE_SAVE
authorVineet Gupta <vgupta@synopsys.com>
Tue, 9 Jul 2013 11:36:40 +0000 (17:06 +0530)
committerVineet Gupta <vgupta@synopsys.com>
Mon, 26 Aug 2013 04:10:25 +0000 (09:40 +0530)
commitfce16bc35ae4a45634f3dc348d8d297a25c277cf
treead8bd83bf1ec3210208bad9a566a7585583ee876
parent37f3ac498c988536f0d42b4659fb5d2c050b2f96
ARC: Entry Handler tweaks: Optimize away redundant IRQ_DISABLE_SAVE

In the exception return path, for both U/K cases, intr are already
disabled (for various existing reasons). So when we drop down to
@restore_regs, we need not redo that.

There was subtle issue - when intr were NOT being disabled for
ret-to-kernel-but-no-preemption case - now fixed by moving the
IRQ_DISABLE further up in @resume_kernel_mode.

So what do we gain:

* Shaves off a few insn in return path.

* Eliminates the need for IRQ_DISABLE_SAVE assembler macro for ARCv2
  hence allows for entry code sharing.

Signed-off-by: Vineet Gupta <vgupta@synopsys.com>
arch/arc/include/asm/irqflags.h
arch/arc/kernel/entry.S