Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 116130
b: refs/heads/master
c: 5a89f1a
h: refs/heads/master
v: v3
  • Loading branch information
Paul Mundt committed Sep 12, 2008
1 parent 161dfa1 commit dd8f070
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 2 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 0e660d2d433393f983cd58fe8c54f831fa7c7713
refs/heads/master: 5a89f1adbc5ce44988aab0c370ae2f1478061307
4 changes: 4 additions & 0 deletions trunk/arch/sh/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,10 @@ config STACKTRACE_SUPPORT
config LOCKDEP_SUPPORT
def_bool y

config HAVE_LATENCYTOP_SUPPORT
def_bool y
depends on !SMP

config ARCH_HAS_ILOG2_U32
def_bool n

Expand Down
23 changes: 22 additions & 1 deletion trunk/arch/sh/kernel/stacktrace.c
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
*
* Stack trace management functions
*
* Copyright (C) 2006 Paul Mundt
* Copyright (C) 2006 - 2008 Paul Mundt
*
* This file is subject to the terms and conditions of the GNU General Public
* License. See the file "COPYING" in the main directory of this archive
Expand Down Expand Up @@ -36,3 +36,24 @@ void save_stack_trace(struct stack_trace *trace)
}
}
EXPORT_SYMBOL_GPL(save_stack_trace);

void save_stack_trace_tsk(struct task_struct *tsk, struct stack_trace *trace)
{
unsigned long *sp = (unsigned long *)tsk->thread.sp;

while (!kstack_end(sp)) {
unsigned long addr = *sp++;

if (__kernel_text_address(addr)) {
if (in_sched_functions(addr))
break;
if (trace->skip > 0)
trace->skip--;
else
trace->entries[trace->nr_entries++] = addr;
if (trace->nr_entries >= trace->max_entries)
break;
}
}
}
EXPORT_SYMBOL_GPL(save_stack_trace_tsk);

0 comments on commit dd8f070

Please sign in to comment.