aboutsummaryrefslogtreecommitdiffstats
path: root/include/asm-v850/user.h
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@ppc970.osdl.org>2005-04-16 18:20:36 -0400
committerLinus Torvalds <torvalds@ppc970.osdl.org>2005-04-16 18:20:36 -0400
commit1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 (patch)
tree0bba044c4ce775e45a88a51686b5d9f90697ea9d /include/asm-v850/user.h
Linux-2.6.12-rc2v2.6.12-rc2
Initial git repository build. I'm not bothering with the full history, even though we have it. We can create a separate "historical" git archive of that later if we want to, and in the meantime it's about 3.2GB when imported into git - space that would just make the early git days unnecessarily complicated, when we don't have a lot of good infrastructure for it. Let it rip!
Diffstat (limited to 'include/asm-v850/user.h')
-rw-r--r--include/asm-v850/user.h56
1 files changed, 56 insertions, 0 deletions
diff --git a/include/asm-v850/user.h b/include/asm-v850/user.h
new file mode 100644
index 000000000000..ccf4cea6dc9c
--- /dev/null
+++ b/include/asm-v850/user.h
@@ -0,0 +1,56 @@
1#ifndef __V850_USER_H__
2#define __V850_USER_H__
3
4/* Adapted from <asm-ppc/user.h>. */
5
6#ifdef __KERNEL__
7
8#include <linux/ptrace.h>
9#include <asm/page.h>
10
11/*
12 * Core file format: The core file is written in such a way that gdb
13 * can understand it and provide useful information to the user (under
14 * linux we use the `trad-core' bfd, NOT the osf-core). The file contents
15 * are as follows:
16 *
17 * upage: 1 page consisting of a user struct that tells gdb
18 * what is present in the file. Directly after this is a
19 * copy of the task_struct, which is currently not used by gdb,
20 * but it may come in handy at some point. All of the registers
21 * are stored as part of the upage. The upage should always be
22 * only one page long.
23 * data: The data segment follows next. We use current->end_text to
24 * current->brk to pick up all of the user variables, plus any memory
25 * that may have been sbrk'ed. No attempt is made to determine if a
26 * page is demand-zero or if a page is totally unused, we just cover
27 * the entire range. All of the addresses are rounded in such a way
28 * that an integral number of pages is written.
29 * stack: We need the stack information in order to get a meaningful
30 * backtrace. We need to write the data from usp to
31 * current->start_stack, so we round each of these in order to be able
32 * to write an integer number of pages.
33 */
34struct user {
35 struct pt_regs regs; /* entire machine state */
36 size_t u_tsize; /* text size (pages) */
37 size_t u_dsize; /* data size (pages) */
38 size_t u_ssize; /* stack size (pages) */
39 unsigned long start_code; /* text starting address */
40 unsigned long start_data; /* data starting address */
41 unsigned long start_stack; /* stack starting address */
42 long int signal; /* signal causing core dump */
43 struct regs * u_ar0; /* help gdb find registers */
44 unsigned long magic; /* identifies a core file */
45 char u_comm[32]; /* user command name */
46};
47
48#define NBPG PAGE_SIZE
49#define UPAGES 1
50#define HOST_TEXT_START_ADDR (u.start_code)
51#define HOST_DATA_START_ADDR (u.start_data)
52#define HOST_STACK_END_ADDR (u.start_stack + u.u_ssize * NBPG)
53
54#endif /* __KERNEL__ */
55
56#endif /* __V850_USER_H__ */