/* * kernel/stacktrace.c * * Stack trace management functions * * Copyright (C) 2006 Red Hat, Inc., Ingo Molnar <mingo@redhat.com> */ #include <linux/sched.h> #include <linux/kernel.h> #include <linux/export.h> #include <linux/kallsyms.h> #include <linux/stacktrace.h> void print_stack_trace(struct stack_trace *trace, int spaces) { int i; if (WARN_ON(!trace->entries)) return; for (i = 0; i < trace->nr_entries; i++) { printk("%*c", 1 + spaces, ' '); print_ip_sym(trace->entries[i]); } } EXPORT_SYMBOL_GPL(print_stack_trace); int snprint_stack_trace(char *buf, size_t size, struct stack_trace *trace, int spaces) { int i; unsigned long ip; int generated; int total = 0; if (WARN_ON(!trace->entries)) return 0; for (i = 0; i < trace->nr_entries; i++) { ip = trace->entries[i]; generated = snprintf(buf, size, "%*c[<%p>] %pS\n", 1 + spaces, ' ', (void *) ip, (void *) ip); total += generated; /* Assume that generated isn't a negative number */ if (generated >= size) { buf += size; size = 0; } else { buf += generated; size -= generated; } } return total; } EXPORT_SYMBOL_GPL(snprint_stack_trace); /* * Architectures that do not implement save_stack_trace_tsk or * save_stack_trace_regs get this weak alias and a once-per-bootup warning * (whenever this facility is utilized - for example by procfs): */ __weak void save_stack_trace_tsk(struct task_struct *tsk, struct stack_trace *trace) { WARN_ONCE(1, KERN_INFO "save_stack_trace_tsk() not implemented yet.\n"); } __weak void save_stack_trace_regs(struct pt_regs *regs, struct stack_trace *trace) { WARN_ONCE(1, KERN_INFO "save_stack_trace_regs() not implemented yet.\n"); } og/drivers/usb/serial/omninet.c'>log</a><a href='/cgit.cgi/linux/net-next.git/tree/drivers/usb/serial/omninet.c?id=93c7018ec16bb83399dd4db61c361a6d6aba0d5a'>tree</a><a href='/cgit.cgi/linux/net-next.git/commit/drivers/usb/serial/omninet.c?id=93c7018ec16bb83399dd4db61c361a6d6aba0d5a'>commit</a><a href='/cgit.cgi/linux/net-next.git/diff/drivers/usb/serial/omninet.c?id=93c7018ec16bb83399dd4db61c361a6d6aba0d5a'>diff</a></td><td class='form'><form class='right' method='get' action='/cgit.cgi/linux/net-next.git/log/drivers/usb/serial/omninet.c'> <input type='hidden' name='id' value='93c7018ec16bb83399dd4db61c361a6d6aba0d5a'/><select name='qt'> <option value='grep'>log msg</option> <option value='author'>author</option> <option value='committer'>committer</option> <option value='range'>range</option> </select> <input class='txt' type='search' size='10' name='q' value=''/> <input type='submit' value='search'/> </form> </td></tr></table> <div class='path'>path: <a href='/cgit.cgi/linux/net-next.git/log/?id=93c7018ec16bb83399dd4db61c361a6d6aba0d5a'>root</a>/<a href='/cgit.cgi/linux/net-next.git/log/drivers?id=93c7018ec16bb83399dd4db61c361a6d6aba0d5a'>drivers</a>/<a href='/cgit.cgi/linux/net-next.git/log/drivers/usb?id=93c7018ec16bb83399dd4db61c361a6d6aba0d5a'>usb</a>/<a href='/cgit.cgi/linux/net-next.git/log/drivers/usb/serial?id=93c7018ec16bb83399dd4db61c361a6d6aba0d5a'>serial</a>/<a href='/cgit.cgi/linux/net-next.git/log/drivers/usb/serial/omninet.c?id=93c7018ec16bb83399dd4db61c361a6d6aba0d5a'>omninet.c</a></div><div class='content'><table class='list nowrap'><tr class='nohover'><th class='left'>Age</th><th class='left'>Commit message (<a href='/cgit.cgi/linux/net-next.git/log/drivers/usb/serial/omninet.c?id=93c7018ec16bb83399dd4db61c361a6d6aba0d5a&showmsg=1'>Expand</a>)</th><th class='left'>Author</th><th class='left'>Files</th><th class='left'>Lines</th></tr>