Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 101138
b: refs/heads/master
c: 4e6a053
h: refs/heads/master
v: v3
  • Loading branch information
Vegard Nossum authored and Ingo Molnar committed Jun 27, 2008
1 parent d53843c commit f073065
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 12 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: ad118c54a3587b2c69a769d0ba37d4d8dce4559d
refs/heads/master: 4e6a0535dd036377961027262aecb138099f925d
37 changes: 26 additions & 11 deletions trunk/kernel/backtracetest.c
Original file line number Diff line number Diff line change
Expand Up @@ -10,18 +10,39 @@
* of the License.
*/

#include <linux/completion.h>
#include <linux/delay.h>
#include <linux/interrupt.h>
#include <linux/module.h>
#include <linux/sched.h>
#include <linux/stacktrace.h>

static struct timer_list backtrace_timer;
static void backtrace_test_normal(void)
{
printk("Testing a backtrace from process context.\n");
printk("The following trace is a kernel self test and not a bug!\n");

dump_stack();
}

static DECLARE_COMPLETION(backtrace_work);

static void backtrace_test_irq_callback(unsigned long data)
{
dump_stack();
complete(&backtrace_work);
}

static DECLARE_TASKLET(backtrace_tasklet, &backtrace_test_irq_callback, 0);

static void backtrace_test_timer(unsigned long data)
static void backtrace_test_irq(void)
{
printk("Testing a backtrace from irq context.\n");
printk("The following trace is a kernel self test and not a bug!\n");
dump_stack();

init_completion(&backtrace_work);
tasklet_schedule(&backtrace_tasklet);
wait_for_completion(&backtrace_work);
}

#ifdef CONFIG_STACKTRACE
Expand Down Expand Up @@ -51,17 +72,11 @@ static void backtrace_test_saved(void)
static int backtrace_regression_test(void)
{
printk("====[ backtrace testing ]===========\n");
printk("Testing a backtrace from process context.\n");
printk("The following trace is a kernel self test and not a bug!\n");
dump_stack();

backtrace_test_normal();
backtrace_test_irq();
backtrace_test_saved();

init_timer(&backtrace_timer);
backtrace_timer.function = backtrace_test_timer;
mod_timer(&backtrace_timer, jiffies + 10);

msleep(10);
printk("====[ end of backtrace testing ]====\n");
return 0;
}
Expand Down

0 comments on commit f073065

Please sign in to comment.