aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/ubicom32/files/arch/ubicom32/include/asm/stacktrace.h
blob: f278ac7b5c9d34969a263b2a9020b444c4911d08 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/*
 * arch/ubicom32/include/asm/stacktrace.h
 *   Stacktrace functions for the Ubicom32 architecture.
 *
 * (C) Copyright 2009, Ubicom, Inc.
 *
 * This file is part of the Ubicom32 Linux Kernel Port.
 *
 * The Ubicom32 Linux Kernel Port is free software: you can redistribute
 * it and/or modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation, either version 2 of the
 * License, or (at your option) any later version.
 *
 * The Ubicom32 Linux Kernel Port is distributed in the hope that it
 * will be useful, but WITHOUT ANY WARRANTY; without even the implied
 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See
 * the GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with the Ubicom32 Linux Kernel Port.  If not,
 * see <http://www.gnu.org/licenses/>.
 *
 * Ubicom32 implementation derived from (with many thanks):
 *   arch/m68knommu
 *   arch/blackfin
 *   arch/parisc
 */
#ifndef _ASM_UBICOM32_STACKTRACE_H
#define _ASM_UBICOM32_STACKTRACE_H

#define between(a, b, c)	(( \
			((unsigned long) a) >= ((unsigned long) b)) && \
			(((unsigned long)a) <= ((unsigned long)c)))

/*
 * These symbols are filled in by the linker.
 */
extern unsigned long _stext;
extern unsigned long _etext;

/* OCM text goes from __ocm_text_run_begin to __data_begin */
extern unsigned long __ocm_text_run_begin;
extern unsigned long __data_begin;

/* Account for OCM case - see stacktrace.c maybe combine(also trap.c) */
/*
 * ubicom32_is_kernel()
 *
 * 	Check to see if the given address belongs to the kernel.
 * NOMMU does not permit any other means.
 */
static inline int ubicom32_is_kernel(unsigned long addr)
{
	int is_kernel = between(addr, &_stext, &_etext) || \
			between(addr, &__ocm_text_run_begin, &__data_begin);

#ifdef CONFIG_MODULES
	if (!is_kernel)
		is_kernel = is_module_address(addr);
#endif
	return is_kernel;
}

extern unsigned long stacktrace_iterate(
				unsigned long **trace,
				unsigned long stext, unsigned long etext,
				unsigned long ocm_stext, unsigned long ocm_etext,
				unsigned long sstack, unsigned long estack);
#ifdef CONFIG_STACKTRACE
void stacktrace_save_entries(struct task_struct *tsk, struct stack_trace *trace, unsigned long sp);
#endif
#endif /* _ASM_UBICOM32_STACKTRACE_H */