uml: move register initialization

Calling init_registers inside the skas3 checking causes mysterious crashes if
it doesn't happen because the skas3 checking is bypassed.  This patch moves it
to os_early_checks.

Signed-off-by: Jeff Dike <jdike@linux.intel.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
Jeff Dike 2008-02-04 22:31:22 -08:00 committed by Linus Torvalds
parent b54988325c
commit 576c013df0

View File

@ -342,6 +342,8 @@ static void __init check_coredump_limit(void)
void __init os_early_checks(void) void __init os_early_checks(void)
{ {
int pid;
/* Print out the core dump limits early */ /* Print out the core dump limits early */
check_coredump_limit(); check_coredump_limit();
@ -351,6 +353,11 @@ void __init os_early_checks(void)
* kernel is running. * kernel is running.
*/ */
check_tmpexec(); check_tmpexec();
pid = start_ptraced_child();
if (init_registers(pid))
fatal("Failed to initialize default registers");
stop_ptraced_child(pid, 1, 1);
} }
static int __init noprocmm_cmd_param(char *str, int* add) static int __init noprocmm_cmd_param(char *str, int* add)
@ -412,9 +419,6 @@ static inline void check_skas3_ptrace_faultinfo(void)
non_fatal("found\n"); non_fatal("found\n");
} }
if (init_registers(pid))
fatal("Failed to initialize default registers");
stop_ptraced_child(pid, 1, 1); stop_ptraced_child(pid, 1, 1);
} }