aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sh/kernel
diff options
context:
space:
mode:
authorPaul Mundt <lethal@linux-sh.org>2008-12-16 22:20:15 -0500
committerPaul Mundt <lethal@linux-sh.org>2008-12-22 04:44:44 -0500
commit43f8f9b95b65dc05368cd82268895b9508b17d50 (patch)
treea0709b718dfadce2f80bb24c0ab1a27faf3b3016 /arch/sh/kernel
parent7b80fb32b39a51ce3e1afa051f5a616eb8ecbed3 (diff)
sh: Simplify kernel_thread_helper() for sh32.
This can use the same implementation as sh64, the generated assembly is the same between the new and old version, so there is not much point in leaving it open coded in inline assembly. This is preparatory work for future consolidation of the _32/_64 variants. Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh/kernel')
-rw-r--r--arch/sh/kernel/process_32.c19
1 files changed, 4 insertions, 15 deletions
diff --git a/arch/sh/kernel/process_32.c b/arch/sh/kernel/process_32.c
index 130817affa64..ddafbbbab2ab 100644
--- a/arch/sh/kernel/process_32.c
+++ b/arch/sh/kernel/process_32.c
@@ -97,21 +97,10 @@ void show_regs(struct pt_regs * regs)
97/* 97/*
98 * Create a kernel thread 98 * Create a kernel thread
99 */ 99 */
100 100ATTRIB_NORET void kernel_thread_helper(void *arg, int (*fn)(void *))
101/* 101{
102 * This is the mechanism for creating a new kernel thread. 102 do_exit(fn(arg));
103 * 103}
104 */
105extern void kernel_thread_helper(void);
106__asm__(".align 5\n"
107 "kernel_thread_helper:\n\t"
108 "jsr @r5\n\t"
109 " nop\n\t"
110 "mov.l 1f, r1\n\t"
111 "jsr @r1\n\t"
112 " mov r0, r4\n\t"
113 ".align 2\n\t"
114 "1:.long do_exit");
115 104
116/* Don't use this in BL=1(cli). Or else, CPU resets! */ 105/* Don't use this in BL=1(cli). Or else, CPU resets! */
117int kernel_thread(int (*fn)(void *), void * arg, unsigned long flags) 106int kernel_thread(int (*fn)(void *), void * arg, unsigned long flags)