aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorPaul Mundt <lethal@linux-sh.org>2010-01-12 04:52:00 -0500
committerPaul Mundt <lethal@linux-sh.org>2010-01-12 04:52:00 -0500
commit70e068eef97d05c97c3512f82352f39fdadfa8cb (patch)
tree22f06f18334038993023f78fc199810ea2cfb387 /arch
parent94cd049522136c2f3bbe063d2e98b2b8d4286fd3 (diff)
sh: Move start_thread() out of line.
start_thread() will become a bit heavier with the xstate freeing to be added in, so move it out-of-line in preparation. Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch')
-rw-r--r--arch/sh/include/asm/processor_32.h13
-rw-r--r--arch/sh/kernel/process_32.c12
2 files changed, 14 insertions, 11 deletions
diff --git a/arch/sh/include/asm/processor_32.h b/arch/sh/include/asm/processor_32.h
index 1f3d6fab660c..50b8c9c3fa4c 100644
--- a/arch/sh/include/asm/processor_32.h
+++ b/arch/sh/include/asm/processor_32.h
@@ -119,19 +119,10 @@ extern int ubc_usercnt;
119 .sp = sizeof(init_stack) + (long) &init_stack, \ 119 .sp = sizeof(init_stack) + (long) &init_stack, \
120} 120}
121 121
122/*
123 * Do necessary setup to start up a newly executed thread.
124 */
125#define start_thread(_regs, new_pc, new_sp) \
126 set_fs(USER_DS); \
127 _regs->pr = 0; \
128 _regs->sr = SR_FD; /* User mode. */ \
129 _regs->pc = new_pc; \
130 _regs->regs[15] = new_sp
131
132/* Forward declaration, a strange C thing */ 122/* Forward declaration, a strange C thing */
133struct task_struct; 123struct task_struct;
134struct mm_struct; 124
125extern void start_thread(struct pt_regs *regs, unsigned long new_pc, unsigned long new_sp);
135 126
136/* Free all resources held by a thread. */ 127/* Free all resources held by a thread. */
137extern void release_thread(struct task_struct *); 128extern void release_thread(struct task_struct *);
diff --git a/arch/sh/kernel/process_32.c b/arch/sh/kernel/process_32.c
index d8af889366a4..c4361402ec5e 100644
--- a/arch/sh/kernel/process_32.c
+++ b/arch/sh/kernel/process_32.c
@@ -147,6 +147,18 @@ int kernel_thread(int (*fn)(void *), void * arg, unsigned long flags)
147} 147}
148EXPORT_SYMBOL(kernel_thread); 148EXPORT_SYMBOL(kernel_thread);
149 149
150void start_thread(struct pt_regs *regs, unsigned long new_pc,
151 unsigned long new_sp)
152{
153 set_fs(USER_DS);
154
155 regs->pr = 0;
156 regs->sr = SR_FD;
157 regs->pc = new_pc;
158 regs->regs[15] = new_sp;
159}
160EXPORT_SYMBOL(start_thread);
161
150/* 162/*
151 * Free current thread data structures etc.. 163 * Free current thread data structures etc..
152 */ 164 */