diff options
Diffstat (limited to 'arch/x86/kernel/dumpstack.c')
| -rw-r--r-- | arch/x86/kernel/dumpstack.c | 22 |
1 files changed, 10 insertions, 12 deletions
diff --git a/arch/x86/kernel/dumpstack.c b/arch/x86/kernel/dumpstack.c index 2bb25c3fe2e8..ef8017ca5ba9 100644 --- a/arch/x86/kernel/dumpstack.c +++ b/arch/x86/kernel/dumpstack.c | |||
| @@ -42,16 +42,14 @@ void printk_address(unsigned long address) | |||
| 42 | static void | 42 | static void |
| 43 | print_ftrace_graph_addr(unsigned long addr, void *data, | 43 | print_ftrace_graph_addr(unsigned long addr, void *data, |
| 44 | const struct stacktrace_ops *ops, | 44 | const struct stacktrace_ops *ops, |
| 45 | struct thread_info *tinfo, int *graph) | 45 | struct task_struct *task, int *graph) |
| 46 | { | 46 | { |
| 47 | struct task_struct *task; | ||
| 48 | unsigned long ret_addr; | 47 | unsigned long ret_addr; |
| 49 | int index; | 48 | int index; |
| 50 | 49 | ||
| 51 | if (addr != (unsigned long)return_to_handler) | 50 | if (addr != (unsigned long)return_to_handler) |
| 52 | return; | 51 | return; |
| 53 | 52 | ||
| 54 | task = tinfo->task; | ||
| 55 | index = task->curr_ret_stack; | 53 | index = task->curr_ret_stack; |
| 56 | 54 | ||
| 57 | if (!task->ret_stack || index < *graph) | 55 | if (!task->ret_stack || index < *graph) |
| @@ -68,7 +66,7 @@ print_ftrace_graph_addr(unsigned long addr, void *data, | |||
| 68 | static inline void | 66 | static inline void |
| 69 | print_ftrace_graph_addr(unsigned long addr, void *data, | 67 | print_ftrace_graph_addr(unsigned long addr, void *data, |
| 70 | const struct stacktrace_ops *ops, | 68 | const struct stacktrace_ops *ops, |
| 71 | struct thread_info *tinfo, int *graph) | 69 | struct task_struct *task, int *graph) |
| 72 | { } | 70 | { } |
| 73 | #endif | 71 | #endif |
| 74 | 72 | ||
| @@ -79,10 +77,10 @@ print_ftrace_graph_addr(unsigned long addr, void *data, | |||
| 79 | * severe exception (double fault, nmi, stack fault, debug, mce) hardware stack | 77 | * severe exception (double fault, nmi, stack fault, debug, mce) hardware stack |
| 80 | */ | 78 | */ |
| 81 | 79 | ||
| 82 | static inline int valid_stack_ptr(struct thread_info *tinfo, | 80 | static inline int valid_stack_ptr(struct task_struct *task, |
| 83 | void *p, unsigned int size, void *end) | 81 | void *p, unsigned int size, void *end) |
| 84 | { | 82 | { |
| 85 | void *t = tinfo; | 83 | void *t = task_stack_page(task); |
| 86 | if (end) { | 84 | if (end) { |
| 87 | if (p < end && p >= (end-THREAD_SIZE)) | 85 | if (p < end && p >= (end-THREAD_SIZE)) |
| 88 | return 1; | 86 | return 1; |
| @@ -93,14 +91,14 @@ static inline int valid_stack_ptr(struct thread_info *tinfo, | |||
| 93 | } | 91 | } |
| 94 | 92 | ||
| 95 | unsigned long | 93 | unsigned long |
| 96 | print_context_stack(struct thread_info *tinfo, | 94 | print_context_stack(struct task_struct *task, |
| 97 | unsigned long *stack, unsigned long bp, | 95 | unsigned long *stack, unsigned long bp, |
| 98 | const struct stacktrace_ops *ops, void *data, | 96 | const struct stacktrace_ops *ops, void *data, |
| 99 | unsigned long *end, int *graph) | 97 | unsigned long *end, int *graph) |
| 100 | { | 98 | { |
| 101 | struct stack_frame *frame = (struct stack_frame *)bp; | 99 | struct stack_frame *frame = (struct stack_frame *)bp; |
| 102 | 100 | ||
| 103 | while (valid_stack_ptr(tinfo, stack, sizeof(*stack), end)) { | 101 | while (valid_stack_ptr(task, stack, sizeof(*stack), end)) { |
| 104 | unsigned long addr; | 102 | unsigned long addr; |
| 105 | 103 | ||
| 106 | addr = *stack; | 104 | addr = *stack; |
| @@ -112,7 +110,7 @@ print_context_stack(struct thread_info *tinfo, | |||
| 112 | } else { | 110 | } else { |
| 113 | ops->address(data, addr, 0); | 111 | ops->address(data, addr, 0); |
| 114 | } | 112 | } |
| 115 | print_ftrace_graph_addr(addr, data, ops, tinfo, graph); | 113 | print_ftrace_graph_addr(addr, data, ops, task, graph); |
| 116 | } | 114 | } |
| 117 | stack++; | 115 | stack++; |
| 118 | } | 116 | } |
| @@ -121,7 +119,7 @@ print_context_stack(struct thread_info *tinfo, | |||
| 121 | EXPORT_SYMBOL_GPL(print_context_stack); | 119 | EXPORT_SYMBOL_GPL(print_context_stack); |
| 122 | 120 | ||
| 123 | unsigned long | 121 | unsigned long |
| 124 | print_context_stack_bp(struct thread_info *tinfo, | 122 | print_context_stack_bp(struct task_struct *task, |
| 125 | unsigned long *stack, unsigned long bp, | 123 | unsigned long *stack, unsigned long bp, |
| 126 | const struct stacktrace_ops *ops, void *data, | 124 | const struct stacktrace_ops *ops, void *data, |
| 127 | unsigned long *end, int *graph) | 125 | unsigned long *end, int *graph) |
| @@ -129,7 +127,7 @@ print_context_stack_bp(struct thread_info *tinfo, | |||
| 129 | struct stack_frame *frame = (struct stack_frame *)bp; | 127 | struct stack_frame *frame = (struct stack_frame *)bp; |
| 130 | unsigned long *ret_addr = &frame->return_address; | 128 | unsigned long *ret_addr = &frame->return_address; |
| 131 | 129 | ||
| 132 | while (valid_stack_ptr(tinfo, ret_addr, sizeof(*ret_addr), end)) { | 130 | while (valid_stack_ptr(task, ret_addr, sizeof(*ret_addr), end)) { |
| 133 | unsigned long addr = *ret_addr; | 131 | unsigned long addr = *ret_addr; |
| 134 | 132 | ||
| 135 | if (!__kernel_text_address(addr)) | 133 | if (!__kernel_text_address(addr)) |
| @@ -139,7 +137,7 @@ print_context_stack_bp(struct thread_info *tinfo, | |||
| 139 | break; | 137 | break; |
| 140 | frame = frame->next_frame; | 138 | frame = frame->next_frame; |
| 141 | ret_addr = &frame->return_address; | 139 | ret_addr = &frame->return_address; |
| 142 | print_ftrace_graph_addr(addr, data, ops, tinfo, graph); | 140 | print_ftrace_graph_addr(addr, data, ops, task, graph); |
| 143 | } | 141 | } |
| 144 | 142 | ||
| 145 | return (unsigned long)frame; | 143 | return (unsigned long)frame; |
