diff options
-rw-r--r-- | arch/c6x/Kconfig | 1 | ||||
-rw-r--r-- | arch/c6x/include/asm/processor.h | 2 | ||||
-rw-r--r-- | arch/c6x/kernel/process.c | 24 |
3 files changed, 6 insertions, 21 deletions
diff --git a/arch/c6x/Kconfig b/arch/c6x/Kconfig index 983c859e40b7..45268b50c0c8 100644 --- a/arch/c6x/Kconfig +++ b/arch/c6x/Kconfig | |||
@@ -17,6 +17,7 @@ config C6X | |||
17 | select OF | 17 | select OF |
18 | select OF_EARLY_FLATTREE | 18 | select OF_EARLY_FLATTREE |
19 | select GENERIC_CLOCKEVENTS | 19 | select GENERIC_CLOCKEVENTS |
20 | select GENERIC_KERNEL_THREAD | ||
20 | 21 | ||
21 | config MMU | 22 | config MMU |
22 | def_bool n | 23 | def_bool n |
diff --git a/arch/c6x/include/asm/processor.h b/arch/c6x/include/asm/processor.h index c50af7ef1c96..b9eb3da7f278 100644 --- a/arch/c6x/include/asm/processor.h +++ b/arch/c6x/include/asm/processor.h | |||
@@ -92,8 +92,6 @@ static inline void release_thread(struct task_struct *dead_task) | |||
92 | { | 92 | { |
93 | } | 93 | } |
94 | 94 | ||
95 | extern int kernel_thread(int (*fn)(void *), void * arg, unsigned long flags); | ||
96 | |||
97 | #define copy_segments(tsk, mm) do { } while (0) | 95 | #define copy_segments(tsk, mm) do { } while (0) |
98 | #define release_segments(mm) do { } while (0) | 96 | #define release_segments(mm) do { } while (0) |
99 | 97 | ||
diff --git a/arch/c6x/kernel/process.c b/arch/c6x/kernel/process.c index f98616d92f2d..2770d9a9a84e 100644 --- a/arch/c6x/kernel/process.c +++ b/arch/c6x/kernel/process.c | |||
@@ -104,22 +104,6 @@ void machine_power_off(void) | |||
104 | halt_loop(); | 104 | halt_loop(); |
105 | } | 105 | } |
106 | 106 | ||
107 | /* | ||
108 | * Create a kernel thread | ||
109 | */ | ||
110 | int kernel_thread(int (*fn)(void *), void * arg, unsigned long flags) | ||
111 | { | ||
112 | struct pt_regs regs = { | ||
113 | .a0 = (unsigned long)fn, | ||
114 | .a1 = (unsigned long)arg, | ||
115 | .tsr = 0, /* kernel mode */ | ||
116 | }; | ||
117 | |||
118 | /* Ok, create the new process.. */ | ||
119 | return do_fork(flags | CLONE_VM | CLONE_UNTRACED, -1, ®s, | ||
120 | 0, NULL, NULL); | ||
121 | } | ||
122 | |||
123 | void flush_thread(void) | 107 | void flush_thread(void) |
124 | { | 108 | { |
125 | } | 109 | } |
@@ -177,14 +161,16 @@ int copy_thread(unsigned long clone_flags, unsigned long usp, | |||
177 | 161 | ||
178 | childregs = task_pt_regs(p); | 162 | childregs = task_pt_regs(p); |
179 | 163 | ||
180 | *childregs = *regs; | 164 | if (!regs) { |
181 | |||
182 | if (usp == -1) { | ||
183 | /* case of __kernel_thread: we return to supervisor space */ | 165 | /* case of __kernel_thread: we return to supervisor space */ |
166 | memset(childregs, 0, sizeof(struct pt_regs)); | ||
184 | childregs->sp = (unsigned long)(childregs + 1); | 167 | childregs->sp = (unsigned long)(childregs + 1); |
185 | p->thread.pc = (unsigned long) ret_from_kernel_thread; | 168 | p->thread.pc = (unsigned long) ret_from_kernel_thread; |
169 | childregs->a0 = usp; /* function */ | ||
170 | childregs->a1 = ustk_size; /* argument */ | ||
186 | } else { | 171 | } else { |
187 | /* Otherwise use the given stack */ | 172 | /* Otherwise use the given stack */ |
173 | *childregs = *regs; | ||
188 | childregs->sp = usp; | 174 | childregs->sp = usp; |
189 | p->thread.pc = (unsigned long) ret_from_fork; | 175 | p->thread.pc = (unsigned long) ret_from_fork; |
190 | } | 176 | } |