cregit-Linux how code gets into the kernel

Release 4.7 arch/x86/kernel/stacktrace.c

Directory: arch/x86/kernel
/*
 * Stack trace management functions
 *
 *  Copyright (C) 2006-2009 Red Hat, Inc., Ingo Molnar <mingo@redhat.com>
 */
#include <linux/sched.h>
#include <linux/stacktrace.h>
#include <linux/module.h>
#include <linux/uaccess.h>
#include <asm/stacktrace.h>


static int save_stack_stack(void *data, char *name) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
ingo molnaringo molnar847.06%133.33%
andi kleenandi kleen847.06%133.33%
steven rostedtsteven rostedt15.88%133.33%
Total17100.00%3100.00%


static int __save_stack_address(void *data, unsigned long addr, bool reliable, bool nosched) { struct stack_trace *trace = data; #ifdef CONFIG_FRAME_POINTER if (!reliable) return 0; #endif if (nosched && in_sched_functions(addr)) return 0; if (trace->skip > 0) { trace->skip--; return 0; } if (trace->nr_entries < trace->max_entries) { trace->entries[trace->nr_entries++] = addr; return 0; } else { return -1; /* no more room, stop walking the stack */ } }

Contributors

PersonTokensPropCommitsCommitProp
andi kleenandi kleen3533.33%114.29%
alexei starovoitovalexei starovoitov2321.90%114.29%
ingo molnaringo molnar2120.00%114.29%
oleg nesterovoleg nesterov1918.10%228.57%
vegard nossumvegard nossum54.76%114.29%
arjan van de venarjan van de ven21.90%114.29%
Total105100.00%7100.00%


static int save_stack_address(void *data, unsigned long addr, int reliable) { return __save_stack_address(data, addr, reliable, false); }

Contributors

PersonTokensPropCommitsCommitProp
arjan van de venarjan van de ven1448.28%250.00%
oleg nesterovoleg nesterov1448.28%125.00%
alexei starovoitovalexei starovoitov13.45%125.00%
Total29100.00%4100.00%


static int save_stack_address_nosched(void *data, unsigned long addr, int reliable) { return __save_stack_address(data, addr, reliable, true); }

Contributors

PersonTokensPropCommitsCommitProp
oleg nesterovoleg nesterov2172.41%125.00%
arjan van de venarjan van de ven620.69%125.00%
alexei starovoitovalexei starovoitov13.45%125.00%
vegard nossumvegard nossum13.45%125.00%
Total29100.00%4100.00%

static const struct stacktrace_ops save_stack_ops = { .stack = save_stack_stack, .address = save_stack_address, .walk_stack = print_context_stack, }; static const struct stacktrace_ops save_stack_ops_nosched = { .stack = save_stack_stack, .address = save_stack_address_nosched, .walk_stack = print_context_stack, }; /* * Save stack-backtrace addresses into a stack_trace buffer. */
void save_stack_trace(struct stack_trace *trace) { dump_trace(current, NULL, NULL, 0, &save_stack_ops, trace); if (trace->nr_entries < trace->max_entries) trace->entries[trace->nr_entries++] = ULONG_MAX; }

Contributors

PersonTokensPropCommitsCommitProp
ingo molnaringo molnar3062.50%120.00%
catalin marinascatalin marinas1020.83%120.00%
andi kleenandi kleen510.42%120.00%
namhyung kimnamhyung kim24.17%120.00%
christoph hellwigchristoph hellwig12.08%120.00%
Total48100.00%5100.00%

EXPORT_SYMBOL_GPL(save_stack_trace);
void save_stack_trace_regs(struct pt_regs *regs, struct stack_trace *trace) { dump_trace(current, regs, NULL, 0, &save_stack_ops, trace); if (trace->nr_entries < trace->max_entries) trace->entries[trace->nr_entries++] = ULONG_MAX; }

Contributors

PersonTokensPropCommitsCommitProp
vegard nossumvegard nossum4381.13%125.00%
masami hiramatsumasami hiramatsu47.55%125.00%
soeren sandmann pedersen*soeren sandmann pedersen*47.55%125.00%
namhyung kimnamhyung kim23.77%125.00%
Total53100.00%4100.00%


void save_stack_trace_tsk(struct task_struct *tsk, struct stack_trace *trace) { dump_trace(tsk, NULL, NULL, 0, &save_stack_ops_nosched, trace); if (trace->nr_entries < trace->max_entries) trace->entries[trace->nr_entries++] = ULONG_MAX; }

Contributors

PersonTokensPropCommitsCommitProp
arjan van de venarjan van de ven5196.23%150.00%
namhyung kimnamhyung kim23.77%150.00%
Total53100.00%2100.00%

EXPORT_SYMBOL_GPL(save_stack_trace_tsk); /* Userspace stacktrace - based on kernel/trace/trace_sysprof.c */ struct stack_frame_user { const void __user *next_fp; unsigned long ret_addr; };
static int copy_stack_frame(const void __user *fp, struct stack_frame_user *frame) { int ret; if (!access_ok(VERIFY_READ, fp, sizeof(*frame))) return 0; ret = 1; pagefault_disable(); if (__copy_from_user_inatomic(frame, fp, sizeof(*frame))) ret = 0; pagefault_enable(); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
torok edwintorok edwin7098.59%150.00%
frederic weisbeckerfrederic weisbecker11.41%150.00%
Total71100.00%2100.00%


static inline void __save_stack_trace_user(struct stack_trace *trace) { const struct pt_regs *regs = task_pt_regs(current); const void __user *fp = (const void __user *)regs->bp; if (trace->nr_entries < trace->max_entries) trace->entries[trace->nr_entries++] = regs->ip; while (trace->nr_entries < trace->max_entries) { struct stack_frame_user frame; frame.next_fp = NULL; frame.ret_addr = 0; if (!copy_stack_frame(fp, &frame)) break; if ((unsigned long)fp < regs->sp) break; if (frame.ret_addr) { trace->entries[trace->nr_entries++] = frame.ret_addr; } if (fp == frame.next_fp) break; fp = frame.next_fp; } }

Contributors

PersonTokensPropCommitsCommitProp
torok edwintorok edwin15299.35%266.67%
frederic weisbeckerfrederic weisbecker10.65%133.33%
Total153100.00%3100.00%


void save_stack_trace_user(struct stack_trace *trace) { /* * Trace user stack if we are not a kernel thread */ if (current->mm) { __save_stack_trace_user(trace); } if (trace->nr_entries < trace->max_entries) trace->entries[trace->nr_entries++] = ULONG_MAX; }

Contributors

PersonTokensPropCommitsCommitProp
torok edwintorok edwin46100.00%2100.00%
Total46100.00%2100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
torok edwintorok edwin28641.27%28.33%
arjan van de venarjan van de ven9113.13%312.50%
ingo molnaringo molnar7811.26%312.50%
andi kleenandi kleen7010.10%28.33%
oleg nesterovoleg nesterov547.79%28.33%
vegard nossumvegard nossum497.07%28.33%
alexei starovoitovalexei starovoitov253.61%14.17%
frederic weisbeckerfrederic weisbecker131.88%28.33%
catalin marinascatalin marinas101.44%14.17%
namhyung kimnamhyung kim60.87%14.17%
soeren sandmann pedersen*soeren sandmann pedersen*40.58%14.17%
masami hiramatsumasami hiramatsu40.58%14.17%
steven rostedtsteven rostedt10.14%14.17%
jan beulichjan beulich10.14%14.17%
christoph hellwigchristoph hellwig10.14%14.17%
Total693100.00%24100.00%
Directory: arch/x86/kernel
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}