]> git.baikalelectronics.ru Git - kernel.git/commit
powerpc: Fix bad stack check in exception entry
authorMichael Neuling <mikey@neuling.org>
Mon, 16 Dec 2013 04:12:43 +0000 (15:12 +1100)
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>
Mon, 30 Dec 2013 03:02:28 +0000 (14:02 +1100)
commit54f282dc0cba941d12c3c79fdd815bdb7348901f
tree8d1788a6a1b88190379926ce726bc6867ad98dd2
parentce711476f0f63a53b31bed8554641b7f4d1216df
powerpc: Fix bad stack check in exception entry

In EXCEPTION_PROLOG_COMMON() we check to see if the stack pointer (r1)
is valid when coming from the kernel.  If it's not valid, we die but
with a nice oops message.

Currently we allocate a stack frame (subtract INT_FRAME_SIZE) before we
check to see if the stack pointer is negative.  Unfortunately, this
won't detect a bad stack where r1 is less than INT_FRAME_SIZE.

This patch fixes the check to compare the modified r1 with
-INT_FRAME_SIZE.  With this, bad kernel stack pointers (including NULL
pointers) are correctly detected again.

Kudos to Paulus for finding this.

Signed-off-by: Michael Neuling <mikey@neuling.org>
cc: stable@vger.kernel.org
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
arch/powerpc/include/asm/exception-64s.h