Blame view
kernel/backtracetest.c
2.08 KB
6dab27784 x86: add a simple... |
1 2 3 4 5 6 7 8 9 10 11 |
/* * Simple stack backtrace regression test module * * (C) Copyright 2008 Intel Corporation * Author: Arjan van de Ven <arjan@linux.intel.com> * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; version 2 * of the License. */ |
4e6a0535d backtrace: replac... |
12 |
#include <linux/completion.h> |
ad118c54a stacktrace: add s... |
13 |
#include <linux/delay.h> |
4e6a0535d backtrace: replac... |
14 |
#include <linux/interrupt.h> |
6dab27784 x86: add a simple... |
15 16 |
#include <linux/module.h> #include <linux/sched.h> |
ad118c54a stacktrace: add s... |
17 |
#include <linux/stacktrace.h> |
6dab27784 x86: add a simple... |
18 |
|
4e6a0535d backtrace: replac... |
19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
static void backtrace_test_normal(void) { printk("Testing a backtrace from process context. "); printk("The following trace is a kernel self test and not a bug! "); 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); |
6dab27784 x86: add a simple... |
38 |
|
4e6a0535d backtrace: replac... |
39 |
static void backtrace_test_irq(void) |
6dab27784 x86: add a simple... |
40 41 42 43 44 |
{ printk("Testing a backtrace from irq context. "); printk("The following trace is a kernel self test and not a bug! "); |
4e6a0535d backtrace: replac... |
45 46 47 48 |
init_completion(&backtrace_work); tasklet_schedule(&backtrace_tasklet); wait_for_completion(&backtrace_work); |
6dab27784 x86: add a simple... |
49 |
} |
ad118c54a stacktrace: add s... |
50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 |
#ifdef CONFIG_STACKTRACE static void backtrace_test_saved(void) { struct stack_trace trace; unsigned long entries[8]; printk("Testing a saved backtrace. "); printk("The following trace is a kernel self test and not a bug! "); trace.nr_entries = 0; trace.max_entries = ARRAY_SIZE(entries); trace.entries = entries; trace.skip = 0; save_stack_trace(&trace); print_stack_trace(&trace, 0); } #else static void backtrace_test_saved(void) { printk("Saved backtrace test skipped. "); } #endif |
6dab27784 x86: add a simple... |
77 78 79 80 |
static int backtrace_regression_test(void) { printk("====[ backtrace testing ]=========== "); |
6dab27784 x86: add a simple... |
81 |
|
4e6a0535d backtrace: replac... |
82 83 |
backtrace_test_normal(); backtrace_test_irq(); |
ad118c54a stacktrace: add s... |
84 |
backtrace_test_saved(); |
6dab27784 x86: add a simple... |
85 86 87 88 89 90 91 92 93 94 95 96 97 |
printk("====[ end of backtrace testing ]==== "); return 0; } static void exitf(void) { } module_init(backtrace_regression_test); module_exit(exitf); MODULE_LICENSE("GPL"); MODULE_AUTHOR("Arjan van de Ven <arjan@linux.intel.com>"); |