|
@@ -810,32 +810,6 @@ asmlinkage int ppc_rtas(struct rtas_args __user *uargs)
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
-#ifdef CONFIG_HOTPLUG_CPU
|
|
|
|
-/* This version can't take the spinlock, because it never returns */
|
|
|
|
-static struct rtas_args rtas_stop_self_args = {
|
|
|
|
- /* The token is initialized for real in setup_system() */
|
|
|
|
- .token = RTAS_UNKNOWN_SERVICE,
|
|
|
|
- .nargs = 0,
|
|
|
|
- .nret = 1,
|
|
|
|
- .rets = &rtas_stop_self_args.args[0],
|
|
|
|
-};
|
|
|
|
-
|
|
|
|
-void rtas_stop_self(void)
|
|
|
|
-{
|
|
|
|
- struct rtas_args *rtas_args = &rtas_stop_self_args;
|
|
|
|
-
|
|
|
|
- local_irq_disable();
|
|
|
|
-
|
|
|
|
- BUG_ON(rtas_args->token == RTAS_UNKNOWN_SERVICE);
|
|
|
|
-
|
|
|
|
- printk("cpu %u (hwid %u) Ready to die...\n",
|
|
|
|
- smp_processor_id(), hard_smp_processor_id());
|
|
|
|
- enter_rtas(__pa(rtas_args));
|
|
|
|
-
|
|
|
|
- panic("Alas, I survived.\n");
|
|
|
|
-}
|
|
|
|
-#endif
|
|
|
|
-
|
|
|
|
/*
|
|
/*
|
|
* Call early during boot, before mem init or bootmem, to retrieve the RTAS
|
|
* Call early during boot, before mem init or bootmem, to retrieve the RTAS
|
|
* informations from the device-tree and allocate the RMO buffer for userland
|
|
* informations from the device-tree and allocate the RMO buffer for userland
|
|
@@ -880,9 +854,6 @@ void __init rtas_initialize(void)
|
|
#endif
|
|
#endif
|
|
rtas_rmo_buf = lmb_alloc_base(RTAS_RMOBUF_MAX, PAGE_SIZE, rtas_region);
|
|
rtas_rmo_buf = lmb_alloc_base(RTAS_RMOBUF_MAX, PAGE_SIZE, rtas_region);
|
|
|
|
|
|
-#ifdef CONFIG_HOTPLUG_CPU
|
|
|
|
- rtas_stop_self_args.token = rtas_token("stop-self");
|
|
|
|
-#endif /* CONFIG_HOTPLUG_CPU */
|
|
|
|
#ifdef CONFIG_RTAS_ERROR_LOGGING
|
|
#ifdef CONFIG_RTAS_ERROR_LOGGING
|
|
rtas_last_error_token = rtas_token("rtas-last-error");
|
|
rtas_last_error_token = rtas_token("rtas-last-error");
|
|
#endif
|
|
#endif
|