1
2#ifndef __LINUX_STACKTRACE_H
3#define __LINUX_STACKTRACE_H
4
5#include <linux/types.h>
6#include <asm/errno.h>
7
8struct task_struct;
9struct pt_regs;
10
11#ifdef CONFIG_STACKTRACE
12void stack_trace_print(const unsigned long *trace, unsigned int nr_entries,
13 int spaces);
14int stack_trace_snprint(char *buf, size_t size, const unsigned long *entries,
15 unsigned int nr_entries, int spaces);
16unsigned int stack_trace_save(unsigned long *store, unsigned int size,
17 unsigned int skipnr);
18unsigned int stack_trace_save_tsk(struct task_struct *task,
19 unsigned long *store, unsigned int size,
20 unsigned int skipnr);
21unsigned int stack_trace_save_regs(struct pt_regs *regs, unsigned long *store,
22 unsigned int size, unsigned int skipnr);
23unsigned int stack_trace_save_user(unsigned long *store, unsigned int size);
24
25
26#ifdef CONFIG_ARCH_STACKWALK
27
28
29
30
31
32
33
34
35
36typedef bool (*stack_trace_consume_fn)(void *cookie, unsigned long addr);
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53void arch_stack_walk(stack_trace_consume_fn consume_entry, void *cookie,
54 struct task_struct *task, struct pt_regs *regs);
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73int arch_stack_walk_reliable(stack_trace_consume_fn consume_entry, void *cookie,
74 struct task_struct *task);
75
76void arch_stack_walk_user(stack_trace_consume_fn consume_entry, void *cookie,
77 const struct pt_regs *regs);
78
79#else
80struct stack_trace {
81 unsigned int nr_entries, max_entries;
82 unsigned long *entries;
83 unsigned int skip;
84};
85
86extern void save_stack_trace(struct stack_trace *trace);
87extern void save_stack_trace_regs(struct pt_regs *regs,
88 struct stack_trace *trace);
89extern void save_stack_trace_tsk(struct task_struct *tsk,
90 struct stack_trace *trace);
91extern int save_stack_trace_tsk_reliable(struct task_struct *tsk,
92 struct stack_trace *trace);
93extern void save_stack_trace_user(struct stack_trace *trace);
94#endif
95#endif
96
97#if defined(CONFIG_STACKTRACE) && defined(CONFIG_HAVE_RELIABLE_STACKTRACE)
98int stack_trace_save_tsk_reliable(struct task_struct *tsk, unsigned long *store,
99 unsigned int size);
100#else
101static inline int stack_trace_save_tsk_reliable(struct task_struct *tsk,
102 unsigned long *store,
103 unsigned int size)
104{
105 return -ENOSYS;
106}
107#endif
108
109#endif
110