From: Al Viro Signed-off-by: Al Viro Signed-off-by: Andrew Morton --- arch/powerpc/kernel/process.c | 10 ++++------ arch/ppc/kernel/process.c | 8 ++++---- 2 files changed, 8 insertions(+), 10 deletions(-) diff -puN arch/powerpc/kernel/process.c~powerpc-task_stack_page arch/powerpc/kernel/process.c --- devel/arch/powerpc/kernel/process.c~powerpc-task_stack_page 2006-01-04 22:02:56.000000000 -0800 +++ devel-akpm/arch/powerpc/kernel/process.c 2006-01-04 22:02:56.000000000 -0800 @@ -503,7 +503,7 @@ int copy_thread(int nr, unsigned long cl { struct pt_regs *childregs, *kregs; extern void ret_from_fork(void); - unsigned long sp = (unsigned long)p->thread_info + THREAD_SIZE; + unsigned long sp = (unsigned long)task_stack_page(p) + THREAD_SIZE; CHECK_FULL_REGS(regs); /* Copy registers */ @@ -588,10 +588,8 @@ void start_thread(struct pt_regs *regs, * set. Do it now. */ if (!current->thread.regs) { - unsigned long childregs = (unsigned long)current->thread_info + - THREAD_SIZE; - childregs -= sizeof(struct pt_regs); - current->thread.regs = (struct pt_regs *)childregs; + struct pt_regs *regs = task_stack_page(current) + THREAD_SIZE; + current->thread.regs = regs - 1; } memset(regs->gpr, 0, sizeof(regs->gpr)); @@ -767,7 +765,7 @@ out: static int validate_sp(unsigned long sp, struct task_struct *p, unsigned long nbytes) { - unsigned long stack_page = (unsigned long)p->thread_info; + unsigned long stack_page = (unsigned long)task_stack_page(p); if (sp >= stack_page + sizeof(struct thread_struct) && sp <= stack_page + THREAD_SIZE - nbytes) diff -puN arch/ppc/kernel/process.c~powerpc-task_stack_page arch/ppc/kernel/process.c --- devel/arch/ppc/kernel/process.c~powerpc-task_stack_page 2006-01-04 22:02:56.000000000 -0800 +++ devel-akpm/arch/ppc/kernel/process.c 2006-01-04 22:02:56.000000000 -0800 @@ -482,7 +482,7 @@ copy_thread(int nr, unsigned long clone_ { struct pt_regs *childregs, *kregs; extern void ret_from_fork(void); - unsigned long sp = (unsigned long)p->thread_info + THREAD_SIZE; + unsigned long sp = (unsigned long)task_stack_page(p) + THREAD_SIZE; unsigned long childframe; CHECK_FULL_REGS(regs); @@ -702,8 +702,8 @@ void show_stack(struct task_struct *tsk, sp = tsk->thread.ksp; } - prev_sp = (unsigned long) (tsk->thread_info + 1); - stack_top = (unsigned long) tsk->thread_info + THREAD_SIZE; + prev_sp = (unsigned long) end_of_stack(tsk); + stack_top = (unsigned long) task_stack_page(tsk) + THREAD_SIZE; while (count < 16 && sp > prev_sp && sp < stack_top && (sp & 3) == 0) { if (count == 0) { printk("Call trace:"); @@ -832,7 +832,7 @@ void __init ll_puts(const char *s) unsigned long get_wchan(struct task_struct *p) { unsigned long ip, sp; - unsigned long stack_page = (unsigned long) p->thread_info; + unsigned long stack_page = (unsigned long) task_stack_page(p); int count = 0; if (!p || p == current || p->state == TASK_RUNNING) return 0; _