OpenCores
URL https://opencores.org/ocsvn/or1k_soc_on_altera_embedded_dev_kit/or1k_soc_on_altera_embedded_dev_kit/trunk

Subversion Repositories or1k_soc_on_altera_embedded_dev_kit

[/] [or1k_soc_on_altera_embedded_dev_kit/] [trunk/] [linux-2.6/] [linux-2.6.24/] [arch/] [sh/] [kernel/] [stacktrace.c] - Blame information for rev 7

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 3 xianfeng
/*
2
 * arch/sh/kernel/stacktrace.c
3
 *
4
 * Stack trace management functions
5
 *
6
 *  Copyright (C) 2006  Paul Mundt
7
 *
8
 * This file is subject to the terms and conditions of the GNU General Public
9
 * License.  See the file "COPYING" in the main directory of this archive
10
 * for more details.
11
 */
12
#include <linux/sched.h>
13
#include <linux/stacktrace.h>
14
#include <linux/thread_info.h>
15
#include <asm/ptrace.h>
16
 
17
/*
18
 * Save stack-backtrace addresses into a stack_trace buffer.
19
 */
20
void save_stack_trace(struct stack_trace *trace)
21
{
22
        unsigned long *sp = (unsigned long *)current_stack_pointer;
23
 
24
        while (!kstack_end(sp)) {
25
                unsigned long addr = *sp++;
26
 
27
                if (__kernel_text_address(addr)) {
28
                        if (trace->skip > 0)
29
                                trace->skip--;
30
                        else
31
                                trace->entries[trace->nr_entries++] = addr;
32
                        if (trace->nr_entries >= trace->max_entries)
33
                                break;
34
                }
35
        }
36
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.