aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc/kernel/process.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/powerpc/kernel/process.c')
-rw-r--r--arch/powerpc/kernel/process.c28
1 files changed, 7 insertions, 21 deletions
diff --git a/arch/powerpc/kernel/process.c b/arch/powerpc/kernel/process.c
index a27910207c7e..703100d5e458 100644
--- a/arch/powerpc/kernel/process.c
+++ b/arch/powerpc/kernel/process.c
@@ -914,20 +914,6 @@ int validate_sp(unsigned long sp, struct task_struct *p,
914 return valid_irq_stack(sp, p, nbytes); 914 return valid_irq_stack(sp, p, nbytes);
915} 915}
916 916
917#ifdef CONFIG_PPC64
918#define MIN_STACK_FRAME 112 /* same as STACK_FRAME_OVERHEAD, in fact */
919#define FRAME_LR_SAVE 2
920#define INT_FRAME_SIZE (sizeof(struct pt_regs) + STACK_FRAME_OVERHEAD + 288)
921#define REGS_MARKER 0x7265677368657265ul
922#define FRAME_MARKER 12
923#else
924#define MIN_STACK_FRAME 16
925#define FRAME_LR_SAVE 1
926#define INT_FRAME_SIZE (sizeof(struct pt_regs) + STACK_FRAME_OVERHEAD)
927#define REGS_MARKER 0x72656773ul
928#define FRAME_MARKER 2
929#endif
930
931EXPORT_SYMBOL(validate_sp); 917EXPORT_SYMBOL(validate_sp);
932 918
933unsigned long get_wchan(struct task_struct *p) 919unsigned long get_wchan(struct task_struct *p)
@@ -939,15 +925,15 @@ unsigned long get_wchan(struct task_struct *p)
939 return 0; 925 return 0;
940 926
941 sp = p->thread.ksp; 927 sp = p->thread.ksp;
942 if (!validate_sp(sp, p, MIN_STACK_FRAME)) 928 if (!validate_sp(sp, p, STACK_FRAME_OVERHEAD))
943 return 0; 929 return 0;
944 930
945 do { 931 do {
946 sp = *(unsigned long *)sp; 932 sp = *(unsigned long *)sp;
947 if (!validate_sp(sp, p, MIN_STACK_FRAME)) 933 if (!validate_sp(sp, p, STACK_FRAME_OVERHEAD))
948 return 0; 934 return 0;
949 if (count > 0) { 935 if (count > 0) {
950 ip = ((unsigned long *)sp)[FRAME_LR_SAVE]; 936 ip = ((unsigned long *)sp)[STACK_FRAME_LR_SAVE];
951 if (!in_sched_functions(ip)) 937 if (!in_sched_functions(ip))
952 return ip; 938 return ip;
953 } 939 }
@@ -976,12 +962,12 @@ void show_stack(struct task_struct *tsk, unsigned long *stack)
976 lr = 0; 962 lr = 0;
977 printk("Call Trace:\n"); 963 printk("Call Trace:\n");
978 do { 964 do {
979 if (!validate_sp(sp, tsk, MIN_STACK_FRAME)) 965 if (!validate_sp(sp, tsk, STACK_FRAME_OVERHEAD))
980 return; 966 return;
981 967
982 stack = (unsigned long *) sp; 968 stack = (unsigned long *) sp;
983 newsp = stack[0]; 969 newsp = stack[0];
984 ip = stack[FRAME_LR_SAVE]; 970 ip = stack[STACK_FRAME_LR_SAVE];
985 if (!firstframe || ip != lr) { 971 if (!firstframe || ip != lr) {
986 printk("["REG"] ["REG"] ", sp, ip); 972 printk("["REG"] ["REG"] ", sp, ip);
987 print_symbol("%s", ip); 973 print_symbol("%s", ip);
@@ -995,8 +981,8 @@ void show_stack(struct task_struct *tsk, unsigned long *stack)
995 * See if this is an exception frame. 981 * See if this is an exception frame.
996 * We look for the "regshere" marker in the current frame. 982 * We look for the "regshere" marker in the current frame.
997 */ 983 */
998 if (validate_sp(sp, tsk, INT_FRAME_SIZE) 984 if (validate_sp(sp, tsk, STACK_INT_FRAME_SIZE)
999 && stack[FRAME_MARKER] == REGS_MARKER) { 985 && stack[STACK_FRAME_MARKER] == STACK_FRAME_REGS_MARKER) {
1000 struct pt_regs *regs = (struct pt_regs *) 986 struct pt_regs *regs = (struct pt_regs *)
1001 (sp + STACK_FRAME_OVERHEAD); 987 (sp + STACK_FRAME_OVERHEAD);
1002 printk("--- Exception: %lx", regs->trap); 988 printk("--- Exception: %lx", regs->trap);