cregit-Linux how code gets into the kernel

Release 4.10 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/export.h>
#include <linux/uaccess.h>
#include <asm/stacktrace.h>
#include <asm/unwind.h>


static int save_stack_address(struct stack_trace *trace, unsigned long addr, bool nosched) { if (nosched && in_sched_functions(addr)) return 0; if (trace->skip > 0) { trace->skip--; return 0; } if (trace->nr_entries >= trace->max_entries) return -1; trace->entries[trace->nr_entries++] = addr; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
andi kleenandi kleen2532.47%114.29%
ingo molnaringo molnar1823.38%114.29%
alexei starovoitovalexei starovoitov1114.29%114.29%
oleg nesterovoleg nesterov1114.29%114.29%
josh poimboeufjosh poimboeuf911.69%114.29%
vegard nossumvegard nossum22.60%114.29%
arjan van de venarjan van de ven11.30%114.29%
Total77100.00%7100.00%


static void __save_stack_trace(struct stack_trace *trace, struct task_struct *task, struct pt_regs *regs, bool nosched) { struct unwind_state state; unsigned long addr; if (regs) save_stack_address(trace, regs->ip, nosched); for (unwind_start(&state, task, regs, NULL); !unwind_done(&state); unwind_next_frame(&state)) { addr = unwind_get_return_address(&state); if (!addr || save_stack_address(trace, addr, nosched)) break; } if (trace->nr_entries < trace->max_entries) trace->entries[trace->nr_entries++] = ULONG_MAX; }

Contributors

PersonTokensPropCommitsCommitProp
josh poimboeufjosh poimboeuf7561.98%112.50%
ingo molnaringo molnar1613.22%112.50%
catalin marinascatalin marinas108.26%112.50%
arjan van de venarjan van de ven97.44%225.00%
oleg nesterovoleg nesterov75.79%112.50%
andi kleenandi kleen32.48%112.50%
namhyung kimnamhyung kim10.83%112.50%
Total121100.00%8100.00%

/* * Save stack-backtrace addresses into a stack_trace buffer. */
void save_stack_trace(struct stack_trace *trace) { __save_stack_trace(trace, current, NULL, false); }

Contributors

PersonTokensPropCommitsCommitProp
josh poimboeufjosh poimboeuf21100.00%1100.00%
Total21100.00%1100.00%

EXPORT_SYMBOL_GPL(save_stack_trace);
void save_stack_trace_regs(struct pt_regs *regs, struct stack_trace *trace) { __save_stack_trace(trace, current, regs, false); }

Contributors

PersonTokensPropCommitsCommitProp
vegard nossumvegard nossum1453.85%125.00%
josh poimboeufjosh poimboeuf415.38%125.00%
soeren sandmann pedersen*soeren sandmann pedersen*415.38%125.00%
masami hiramatsumasami hiramatsu415.38%125.00%
Total26100.00%4100.00%


void save_stack_trace_tsk(struct task_struct *tsk, struct stack_trace *trace) { if (!try_get_task_stack(tsk)) return; __save_stack_trace(trace, tsk, NULL, true); put_task_stack(tsk); }

Contributors

PersonTokensPropCommitsCommitProp
arjan van de venarjan van de ven2255.00%133.33%
andy lutomirskiandy lutomirski1435.00%133.33%
josh poimboeufjosh poimboeuf410.00%133.33%
Total40100.00%3100.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 edwin28647.59%29.52%
josh poimboeufjosh poimboeuf11719.47%14.76%
ingo molnaringo molnar538.82%314.29%
arjan van de venarjan van de ven325.32%314.29%
andi kleenandi kleen315.16%14.76%
oleg nesterovoleg nesterov183.00%14.76%
vegard nossumvegard nossum162.66%29.52%
andy lutomirskiandy lutomirski142.33%14.76%
alexei starovoitovalexei starovoitov111.83%14.76%
catalin marinascatalin marinas101.66%14.76%
soeren sandmann pedersen*soeren sandmann pedersen*40.67%14.76%
masami hiramatsumasami hiramatsu40.67%14.76%
frederic weisbeckerfrederic weisbecker30.50%14.76%
namhyung kimnamhyung kim10.17%14.76%
paul gortmakerpaul gortmaker10.17%14.76%
Total601100.00%21100.00%
Directory: arch/x86/kernel
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.