Commit 4fb8d027 authored by Li Zhong's avatar Li Zhong Committed by Benjamin Herrenschmidt

powerpc: Fix Oops in rtas_stop_self()

commit 41dd03a9 may cause Oops in rtas_stop_self().

The reason is that the rtas_args was moved into stack space. For a box
with more that 4GB RAM, the stack could easily be outside 32bit range,
but RTAS is 32bit.

So the patch moves rtas_args away from stack by adding static before
it.
Signed-off-by: default avatarLi Zhong <zhong@linux.vnet.ibm.com>
Signed-off-by: default avatarAnton Blanchard <anton@samba.org>
Cc: stable@vger.kernel.org # 3.14+
Signed-off-by: default avatarBenjamin Herrenschmidt <benh@kernel.crashing.org>
parent 28ea3c75
...@@ -88,13 +88,14 @@ void set_default_offline_state(int cpu) ...@@ -88,13 +88,14 @@ void set_default_offline_state(int cpu)
static void rtas_stop_self(void) static void rtas_stop_self(void)
{ {
struct rtas_args args = { static struct rtas_args args = {
.token = cpu_to_be32(rtas_stop_self_token),
.nargs = 0, .nargs = 0,
.nret = 1, .nret = 1,
.rets = &args.args[0], .rets = &args.args[0],
}; };
args.token = cpu_to_be32(rtas_stop_self_token);
local_irq_disable(); local_irq_disable();
BUG_ON(rtas_stop_self_token == RTAS_UNKNOWN_SERVICE); BUG_ON(rtas_stop_self_token == RTAS_UNKNOWN_SERVICE);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment