aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel/process_64.c
diff options
context:
space:
mode:
authorBrian Gerst <brgerst@gmail.com>2009-12-09 12:34:43 -0500
committerH. Peter Anvin <hpa@zytor.com>2009-12-10 18:55:39 -0500
commitf443ff4201dd25cd4dec183f9919ecba90c8edc2 (patch)
tree4da9d9c35e46c68b87b180285517cc6323bd5d03 /arch/x86/kernel/process_64.c
parente840227c141116171c89ab1abb5cc9fee6fdb488 (diff)
x86: Sync 32/64-bit kernel_thread
Signed-off-by: Brian Gerst <brgerst@gmail.com> LKML-Reference: <1260380084-3707-5-git-send-email-brgerst@gmail.com> Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Diffstat (limited to 'arch/x86/kernel/process_64.c')
-rw-r--r--arch/x86/kernel/process_64.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/arch/x86/kernel/process_64.c b/arch/x86/kernel/process_64.c
index 00ac66fa5c6..d49a9094f6f 100644
--- a/arch/x86/kernel/process_64.c
+++ b/arch/x86/kernel/process_64.c
@@ -248,10 +248,17 @@ int kernel_thread(int (*fn)(void *), void *arg, unsigned long flags)
248 regs.si = (unsigned long) fn; 248 regs.si = (unsigned long) fn;
249 regs.di = (unsigned long) arg; 249 regs.di = (unsigned long) arg;
250 250
251#ifdef CONFIG_X86_32
252 regs.ds = __USER_DS;
253 regs.es = __USER_DS;
254 regs.fs = __KERNEL_PERCPU;
255 regs.gs = __KERNEL_STACK_CANARY;
256#endif
257
251 regs.orig_ax = -1; 258 regs.orig_ax = -1;
252 regs.ip = (unsigned long) kernel_thread_helper; 259 regs.ip = (unsigned long) kernel_thread_helper;
253 regs.cs = __KERNEL_CS; 260 regs.cs = __KERNEL_CS | get_kernel_rpl();
254 regs.flags = X86_EFLAGS_IF; 261 regs.flags = X86_EFLAGS_IF | 0x2;
255 262
256 /* Ok, create the new process.. */ 263 /* Ok, create the new process.. */
257 return do_fork(flags | CLONE_VM | CLONE_UNTRACED, 0, &regs, 0, NULL, NULL); 264 return do_fork(flags | CLONE_VM | CLONE_UNTRACED, 0, &regs, 0, NULL, NULL);