mirror of https://gitee.com/openkylin/linux.git
x86: Merge kernel_thread()
Signed-off-by: Brian Gerst <brgerst@gmail.com> LKML-Reference: <1260380084-3707-6-git-send-email-brgerst@gmail.com> Signed-off-by: H. Peter Anvin <hpa@zytor.com>
This commit is contained in:
parent
f443ff4201
commit
df59e7bf43
|
@ -243,6 +243,41 @@ sys_clone(unsigned long clone_flags, unsigned long newsp,
|
||||||
return do_fork(clone_flags, newsp, regs, 0, parent_tid, child_tid);
|
return do_fork(clone_flags, newsp, regs, 0, parent_tid, child_tid);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This gets run with %si containing the
|
||||||
|
* function to call, and %di containing
|
||||||
|
* the "args".
|
||||||
|
*/
|
||||||
|
extern void kernel_thread_helper(void);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Create a kernel thread
|
||||||
|
*/
|
||||||
|
int kernel_thread(int (*fn)(void *), void *arg, unsigned long flags)
|
||||||
|
{
|
||||||
|
struct pt_regs regs;
|
||||||
|
|
||||||
|
memset(®s, 0, sizeof(regs));
|
||||||
|
|
||||||
|
regs.si = (unsigned long) fn;
|
||||||
|
regs.di = (unsigned long) arg;
|
||||||
|
|
||||||
|
#ifdef CONFIG_X86_32
|
||||||
|
regs.ds = __USER_DS;
|
||||||
|
regs.es = __USER_DS;
|
||||||
|
regs.fs = __KERNEL_PERCPU;
|
||||||
|
regs.gs = __KERNEL_STACK_CANARY;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
regs.orig_ax = -1;
|
||||||
|
regs.ip = (unsigned long) kernel_thread_helper;
|
||||||
|
regs.cs = __KERNEL_CS | get_kernel_rpl();
|
||||||
|
regs.flags = X86_EFLAGS_IF | 0x2;
|
||||||
|
|
||||||
|
/* Ok, create the new process.. */
|
||||||
|
return do_fork(flags | CLONE_VM | CLONE_UNTRACED, 0, ®s, 0, NULL, NULL);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(kernel_thread);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* sys_execve() executes a new program.
|
* sys_execve() executes a new program.
|
||||||
|
|
|
@ -192,42 +192,6 @@ void show_regs(struct pt_regs *regs)
|
||||||
show_trace(NULL, regs, ®s->sp, regs->bp);
|
show_trace(NULL, regs, ®s->sp, regs->bp);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* This gets run with %si containing the
|
|
||||||
* function to call, and %di containing
|
|
||||||
* the "args".
|
|
||||||
*/
|
|
||||||
extern void kernel_thread_helper(void);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create a kernel thread
|
|
||||||
*/
|
|
||||||
int kernel_thread(int (*fn)(void *), void *arg, unsigned long flags)
|
|
||||||
{
|
|
||||||
struct pt_regs regs;
|
|
||||||
|
|
||||||
memset(®s, 0, sizeof(regs));
|
|
||||||
|
|
||||||
regs.si = (unsigned long) fn;
|
|
||||||
regs.di = (unsigned long) arg;
|
|
||||||
|
|
||||||
#ifdef CONFIG_X86_32
|
|
||||||
regs.ds = __USER_DS;
|
|
||||||
regs.es = __USER_DS;
|
|
||||||
regs.fs = __KERNEL_PERCPU;
|
|
||||||
regs.gs = __KERNEL_STACK_CANARY;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
regs.orig_ax = -1;
|
|
||||||
regs.ip = (unsigned long) kernel_thread_helper;
|
|
||||||
regs.cs = __KERNEL_CS | get_kernel_rpl();
|
|
||||||
regs.flags = X86_EFLAGS_IF | 0x2;
|
|
||||||
|
|
||||||
/* Ok, create the new process.. */
|
|
||||||
return do_fork(flags | CLONE_VM | CLONE_UNTRACED, 0, ®s, 0, NULL, NULL);
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(kernel_thread);
|
|
||||||
|
|
||||||
void release_thread(struct task_struct *dead_task)
|
void release_thread(struct task_struct *dead_task)
|
||||||
{
|
{
|
||||||
BUG_ON(dead_task->mm);
|
BUG_ON(dead_task->mm);
|
||||||
|
|
|
@ -229,42 +229,6 @@ void show_regs(struct pt_regs *regs)
|
||||||
show_trace(NULL, regs, (void *)(regs + 1), regs->bp);
|
show_trace(NULL, regs, (void *)(regs + 1), regs->bp);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* This gets run with %si containing the
|
|
||||||
* function to call, and %di containing
|
|
||||||
* the "args".
|
|
||||||
*/
|
|
||||||
extern void kernel_thread_helper(void);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create a kernel thread
|
|
||||||
*/
|
|
||||||
int kernel_thread(int (*fn)(void *), void *arg, unsigned long flags)
|
|
||||||
{
|
|
||||||
struct pt_regs regs;
|
|
||||||
|
|
||||||
memset(®s, 0, sizeof(regs));
|
|
||||||
|
|
||||||
regs.si = (unsigned long) fn;
|
|
||||||
regs.di = (unsigned long) arg;
|
|
||||||
|
|
||||||
#ifdef CONFIG_X86_32
|
|
||||||
regs.ds = __USER_DS;
|
|
||||||
regs.es = __USER_DS;
|
|
||||||
regs.fs = __KERNEL_PERCPU;
|
|
||||||
regs.gs = __KERNEL_STACK_CANARY;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
regs.orig_ax = -1;
|
|
||||||
regs.ip = (unsigned long) kernel_thread_helper;
|
|
||||||
regs.cs = __KERNEL_CS | get_kernel_rpl();
|
|
||||||
regs.flags = X86_EFLAGS_IF | 0x2;
|
|
||||||
|
|
||||||
/* Ok, create the new process.. */
|
|
||||||
return do_fork(flags | CLONE_VM | CLONE_UNTRACED, 0, ®s, 0, NULL, NULL);
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(kernel_thread);
|
|
||||||
|
|
||||||
void release_thread(struct task_struct *dead_task)
|
void release_thread(struct task_struct *dead_task)
|
||||||
{
|
{
|
||||||
if (dead_task->mm) {
|
if (dead_task->mm) {
|
||||||
|
|
Loading…
Reference in New Issue