[PATCH] alpha: task_stack_page()

use task_stack_page() for accesses to stack page of task in alpha-specific
parts of tree

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>

authored by Al Viro and committed by Linus Torvalds 27f45130 37bfbaf9

+5 -5
+3 -3
arch/alpha/kernel/process.c
··· 276 { 277 extern void ret_from_fork(void); 278 279 - struct thread_info *childti = p->thread_info; 280 struct pt_regs * childregs; 281 struct switch_stack * childstack, *stack; 282 unsigned long stack_offset, settls; ··· 285 if (!(regs->ps & 8)) 286 stack_offset = (PAGE_SIZE-1) & (unsigned long) regs; 287 childregs = (struct pt_regs *) 288 - (stack_offset + PAGE_SIZE + (long) childti); 289 290 *childregs = *regs; 291 settls = regs->r20; ··· 492 unsigned long 493 thread_saved_pc(task_t *t) 494 { 495 - unsigned long base = (unsigned long)t->thread_info; 496 unsigned long fp, sp = task_thread_info(t)->pcb.ksp; 497 498 if (sp > base && sp+6*8 < base + 16*1024) {
··· 276 { 277 extern void ret_from_fork(void); 278 279 + struct thread_info *childti = task_thread_info(p); 280 struct pt_regs * childregs; 281 struct switch_stack * childstack, *stack; 282 unsigned long stack_offset, settls; ··· 285 if (!(regs->ps & 8)) 286 stack_offset = (PAGE_SIZE-1) & (unsigned long) regs; 287 childregs = (struct pt_regs *) 288 + (stack_offset + PAGE_SIZE + task_stack_page(p)); 289 290 *childregs = *regs; 291 settls = regs->r20; ··· 492 unsigned long 493 thread_saved_pc(task_t *t) 494 { 495 + unsigned long base = (unsigned long)task_stack_page(t); 496 unsigned long fp, sp = task_thread_info(t)->pcb.ksp; 497 498 if (sp > base && sp+6*8 < base + 16*1024) {
+1 -1
arch/alpha/kernel/ptrace.c
··· 110 zero = 0; 111 addr = &zero; 112 } else { 113 - addr = (void *)task->thread_info + regoff[regno]; 114 } 115 return addr; 116 }
··· 110 zero = 0; 111 addr = &zero; 112 } else { 113 + addr = task_stack_page(task) + regoff[regno]; 114 } 115 return addr; 116 }
+1 -1
include/asm-alpha/ptrace.h
··· 76 extern void show_regs(struct pt_regs *); 77 78 #define alpha_task_regs(task) \ 79 - ((struct pt_regs *) ((long) (task)->thread_info + 2*PAGE_SIZE) - 1) 80 81 #define force_successful_syscall_return() (alpha_task_regs(current)->r0 = 0) 82
··· 76 extern void show_regs(struct pt_regs *); 77 78 #define alpha_task_regs(task) \ 79 + ((struct pt_regs *) (task_stack_page(task) + 2*PAGE_SIZE) - 1) 80 81 #define force_successful_syscall_return() (alpha_task_regs(current)->r0 = 0) 82