diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-08-01 17:59:11 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-08-01 17:59:11 -0400 |
commit | 2b12a4c524812fb3f6ee590a02e65b95c8c32229 (patch) | |
tree | 6d319a371c56798d2d5c3ad21801eba142a1c77e /arch/ia64/include/asm/siginfo.h | |
parent | 4744b43431e8613f920c5cba88346756f53c5165 (diff) | |
parent | 7f30491ccd28627742e37899453ae20e3da8e18f (diff) |
Merge branch 'release' of git://git.kernel.org/pub/scm/linux/kernel/git/aegl/linux-2.6
* 'release' of git://git.kernel.org/pub/scm/linux/kernel/git/aegl/linux-2.6:
[IA64] Move include/asm-ia64 to arch/ia64/include/asm
Diffstat (limited to 'arch/ia64/include/asm/siginfo.h')
-rw-r--r-- | arch/ia64/include/asm/siginfo.h | 139 |
1 files changed, 139 insertions, 0 deletions
diff --git a/arch/ia64/include/asm/siginfo.h b/arch/ia64/include/asm/siginfo.h new file mode 100644 index 000000000000..9294e4b0c8bc --- /dev/null +++ b/arch/ia64/include/asm/siginfo.h | |||
@@ -0,0 +1,139 @@ | |||
1 | #ifndef _ASM_IA64_SIGINFO_H | ||
2 | #define _ASM_IA64_SIGINFO_H | ||
3 | |||
4 | /* | ||
5 | * Based on <asm-i386/siginfo.h>. | ||
6 | * | ||
7 | * Modified 1998-2002 | ||
8 | * David Mosberger-Tang <davidm@hpl.hp.com>, Hewlett-Packard Co | ||
9 | */ | ||
10 | |||
11 | #define __ARCH_SI_PREAMBLE_SIZE (4 * sizeof(int)) | ||
12 | |||
13 | #define HAVE_ARCH_SIGINFO_T | ||
14 | #define HAVE_ARCH_COPY_SIGINFO | ||
15 | #define HAVE_ARCH_COPY_SIGINFO_TO_USER | ||
16 | |||
17 | #include <asm-generic/siginfo.h> | ||
18 | |||
19 | typedef struct siginfo { | ||
20 | int si_signo; | ||
21 | int si_errno; | ||
22 | int si_code; | ||
23 | int __pad0; | ||
24 | |||
25 | union { | ||
26 | int _pad[SI_PAD_SIZE]; | ||
27 | |||
28 | /* kill() */ | ||
29 | struct { | ||
30 | pid_t _pid; /* sender's pid */ | ||
31 | uid_t _uid; /* sender's uid */ | ||
32 | } _kill; | ||
33 | |||
34 | /* POSIX.1b timers */ | ||
35 | struct { | ||
36 | timer_t _tid; /* timer id */ | ||
37 | int _overrun; /* overrun count */ | ||
38 | char _pad[sizeof(__ARCH_SI_UID_T) - sizeof(int)]; | ||
39 | sigval_t _sigval; /* must overlay ._rt._sigval! */ | ||
40 | int _sys_private; /* not to be passed to user */ | ||
41 | } _timer; | ||
42 | |||
43 | /* POSIX.1b signals */ | ||
44 | struct { | ||
45 | pid_t _pid; /* sender's pid */ | ||
46 | uid_t _uid; /* sender's uid */ | ||
47 | sigval_t _sigval; | ||
48 | } _rt; | ||
49 | |||
50 | /* SIGCHLD */ | ||
51 | struct { | ||
52 | pid_t _pid; /* which child */ | ||
53 | uid_t _uid; /* sender's uid */ | ||
54 | int _status; /* exit code */ | ||
55 | clock_t _utime; | ||
56 | clock_t _stime; | ||
57 | } _sigchld; | ||
58 | |||
59 | /* SIGILL, SIGFPE, SIGSEGV, SIGBUS */ | ||
60 | struct { | ||
61 | void __user *_addr; /* faulting insn/memory ref. */ | ||
62 | int _imm; /* immediate value for "break" */ | ||
63 | unsigned int _flags; /* see below */ | ||
64 | unsigned long _isr; /* isr */ | ||
65 | } _sigfault; | ||
66 | |||
67 | /* SIGPOLL */ | ||
68 | struct { | ||
69 | long _band; /* POLL_IN, POLL_OUT, POLL_MSG (XPG requires a "long") */ | ||
70 | int _fd; | ||
71 | } _sigpoll; | ||
72 | } _sifields; | ||
73 | } siginfo_t; | ||
74 | |||
75 | #define si_imm _sifields._sigfault._imm /* as per UNIX SysV ABI spec */ | ||
76 | #define si_flags _sifields._sigfault._flags | ||
77 | /* | ||
78 | * si_isr is valid for SIGILL, SIGFPE, SIGSEGV, SIGBUS, and SIGTRAP provided that | ||
79 | * si_code is non-zero and __ISR_VALID is set in si_flags. | ||
80 | */ | ||
81 | #define si_isr _sifields._sigfault._isr | ||
82 | |||
83 | /* | ||
84 | * Flag values for si_flags: | ||
85 | */ | ||
86 | #define __ISR_VALID_BIT 0 | ||
87 | #define __ISR_VALID (1 << __ISR_VALID_BIT) | ||
88 | |||
89 | /* | ||
90 | * SIGILL si_codes | ||
91 | */ | ||
92 | #define ILL_BADIADDR (__SI_FAULT|9) /* unimplemented instruction address */ | ||
93 | #define __ILL_BREAK (__SI_FAULT|10) /* illegal break */ | ||
94 | #define __ILL_BNDMOD (__SI_FAULT|11) /* bundle-update (modification) in progress */ | ||
95 | #undef NSIGILL | ||
96 | #define NSIGILL 11 | ||
97 | |||
98 | /* | ||
99 | * SIGFPE si_codes | ||
100 | */ | ||
101 | #define __FPE_DECOVF (__SI_FAULT|9) /* decimal overflow */ | ||
102 | #define __FPE_DECDIV (__SI_FAULT|10) /* decimal division by zero */ | ||
103 | #define __FPE_DECERR (__SI_FAULT|11) /* packed decimal error */ | ||
104 | #define __FPE_INVASC (__SI_FAULT|12) /* invalid ASCII digit */ | ||
105 | #define __FPE_INVDEC (__SI_FAULT|13) /* invalid decimal digit */ | ||
106 | #undef NSIGFPE | ||
107 | #define NSIGFPE 13 | ||
108 | |||
109 | /* | ||
110 | * SIGSEGV si_codes | ||
111 | */ | ||
112 | #define __SEGV_PSTKOVF (__SI_FAULT|3) /* paragraph stack overflow */ | ||
113 | #undef NSIGSEGV | ||
114 | #define NSIGSEGV 3 | ||
115 | |||
116 | /* | ||
117 | * SIGTRAP si_codes | ||
118 | */ | ||
119 | #define TRAP_BRANCH (__SI_FAULT|3) /* process taken branch trap */ | ||
120 | #define TRAP_HWBKPT (__SI_FAULT|4) /* hardware breakpoint or watchpoint */ | ||
121 | #undef NSIGTRAP | ||
122 | #define NSIGTRAP 4 | ||
123 | |||
124 | #ifdef __KERNEL__ | ||
125 | #include <linux/string.h> | ||
126 | |||
127 | static inline void | ||
128 | copy_siginfo (siginfo_t *to, siginfo_t *from) | ||
129 | { | ||
130 | if (from->si_code < 0) | ||
131 | memcpy(to, from, sizeof(siginfo_t)); | ||
132 | else | ||
133 | /* _sigchld is currently the largest know union member */ | ||
134 | memcpy(to, from, 4*sizeof(int) + sizeof(from->_sifields._sigchld)); | ||
135 | } | ||
136 | |||
137 | #endif /* __KERNEL__ */ | ||
138 | |||
139 | #endif /* _ASM_IA64_SIGINFO_H */ | ||