Contributors: 12
Author |
Tokens |
Token Proportion |
Commits |
Commit Proportion |
Ingo Molnar |
68 |
31.78% |
1 |
7.69% |
JoonSoo Kim |
36 |
16.82% |
1 |
7.69% |
Török Edwin |
31 |
14.49% |
2 |
15.38% |
Josh Poimboeuf |
27 |
12.62% |
1 |
7.69% |
Arjan van de Ven |
24 |
11.21% |
1 |
7.69% |
Vegard Nossum |
8 |
3.74% |
1 |
7.69% |
Soeren Sandmann Pedersen |
6 |
2.80% |
1 |
7.69% |
Masami Hiramatsu |
4 |
1.87% |
1 |
7.69% |
Andi Kleen |
4 |
1.87% |
1 |
7.69% |
Andrew Morton |
3 |
1.40% |
1 |
7.69% |
Johannes Berg |
2 |
0.93% |
1 |
7.69% |
Greg Kroah-Hartman |
1 |
0.47% |
1 |
7.69% |
Total |
214 |
|
13 |
|
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef __LINUX_STACKTRACE_H
#define __LINUX_STACKTRACE_H
#include <linux/types.h>
struct task_struct;
struct pt_regs;
#ifdef CONFIG_STACKTRACE
struct stack_trace {
unsigned int nr_entries, max_entries;
unsigned long *entries;
int skip; /* input argument: How many entries to skip */
};
extern void save_stack_trace(struct stack_trace *trace);
extern void save_stack_trace_regs(struct pt_regs *regs,
struct stack_trace *trace);
extern void save_stack_trace_tsk(struct task_struct *tsk,
struct stack_trace *trace);
extern int save_stack_trace_tsk_reliable(struct task_struct *tsk,
struct stack_trace *trace);
extern void print_stack_trace(struct stack_trace *trace, int spaces);
extern int snprint_stack_trace(char *buf, size_t size,
struct stack_trace *trace, int spaces);
#ifdef CONFIG_USER_STACKTRACE_SUPPORT
extern void save_stack_trace_user(struct stack_trace *trace);
#else
# define save_stack_trace_user(trace) do { } while (0)
#endif
#else /* !CONFIG_STACKTRACE */
# define save_stack_trace(trace) do { } while (0)
# define save_stack_trace_tsk(tsk, trace) do { } while (0)
# define save_stack_trace_user(trace) do { } while (0)
# define print_stack_trace(trace, spaces) do { } while (0)
# define snprint_stack_trace(buf, size, trace, spaces) do { } while (0)
# define save_stack_trace_tsk_reliable(tsk, trace) ({ -ENOSYS; })
#endif /* CONFIG_STACKTRACE */
#endif /* __LINUX_STACKTRACE_H */