diff options
author | Franck Bui-Huu <fbuihuu@gmail.com> | 2007-02-05 09:24:21 -0500 |
---|---|---|
committer | Ralf Baechle <ralf@linux-mips.org> | 2007-02-10 17:38:45 -0500 |
commit | c0b9bae9d18980afa1797fb7b75adb4fbc837b66 (patch) | |
tree | 0782ec6c56261422c7186d7cfca68aebfdb36194 /arch/mips/kernel/signal32.c | |
parent | c3fc4ab36d495f50ccc89986fe32eeabc2549fa1 (diff) |
[MIPS] signal: clean up sigframe structure
This patch makes 'struct sigframe' declaration avalaible for all signals
code. It allows signal32 to not have its own declaration.
This patch also removes all ICACHE_REFILLS_WORKAROUND_WAR tests in
structure declaration and hopefully make them more readable.
Signed-off-by: Franck Bui-Huu <fbuihuu@gmail.com>
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
Diffstat (limited to 'arch/mips/kernel/signal32.c')
-rw-r--r-- | arch/mips/kernel/signal32.c | 49 |
1 files changed, 21 insertions, 28 deletions
diff --git a/arch/mips/kernel/signal32.c b/arch/mips/kernel/signal32.c index c86a5ddff050..e0a855331826 100644 --- a/arch/mips/kernel/signal32.c +++ b/arch/mips/kernel/signal32.c | |||
@@ -139,6 +139,27 @@ struct ucontext32 { | |||
139 | sigset_t32 uc_sigmask; /* mask last for extensibility */ | 139 | sigset_t32 uc_sigmask; /* mask last for extensibility */ |
140 | }; | 140 | }; |
141 | 141 | ||
142 | #if ICACHE_REFILLS_WORKAROUND_WAR == 0 | ||
143 | |||
144 | struct rt_sigframe32 { | ||
145 | u32 rs_ass[4]; /* argument save space for o32 */ | ||
146 | u32 rs_code[2]; /* signal trampoline */ | ||
147 | compat_siginfo_t rs_info; | ||
148 | struct ucontext32 rs_uc; | ||
149 | }; | ||
150 | |||
151 | #else /* ICACHE_REFILLS_WORKAROUND_WAR */ | ||
152 | |||
153 | struct rt_sigframe32 { | ||
154 | u32 rs_ass[4]; /* argument save space for o32 */ | ||
155 | u32 rs_pad[2]; | ||
156 | compat_siginfo_t rs_info; | ||
157 | struct ucontext32 rs_uc; | ||
158 | u32 rs_code[8] __attribute__((aligned(32))); /* signal trampoline */ | ||
159 | }; | ||
160 | |||
161 | #endif /* !ICACHE_REFILLS_WORKAROUND_WAR */ | ||
162 | |||
142 | extern void __put_sigset_unknown_nsig(void); | 163 | extern void __put_sigset_unknown_nsig(void); |
143 | extern void __get_sigset_unknown_nsig(void); | 164 | extern void __get_sigset_unknown_nsig(void); |
144 | 165 | ||
@@ -383,34 +404,6 @@ static int restore_sigcontext32(struct pt_regs *regs, struct sigcontext32 __user | |||
383 | return err; | 404 | return err; |
384 | } | 405 | } |
385 | 406 | ||
386 | struct sigframe { | ||
387 | u32 sf_ass[4]; /* argument save space for o32 */ | ||
388 | #if ICACHE_REFILLS_WORKAROUND_WAR | ||
389 | u32 sf_pad[2]; | ||
390 | #else | ||
391 | u32 sf_code[2]; /* signal trampoline */ | ||
392 | #endif | ||
393 | struct sigcontext32 sf_sc; | ||
394 | sigset_t sf_mask; | ||
395 | #if ICACHE_REFILLS_WORKAROUND_WAR | ||
396 | u32 sf_code[8] ____cacheline_aligned; /* signal trampoline */ | ||
397 | #endif | ||
398 | }; | ||
399 | |||
400 | struct rt_sigframe32 { | ||
401 | u32 rs_ass[4]; /* argument save space for o32 */ | ||
402 | #if ICACHE_REFILLS_WORKAROUND_WAR | ||
403 | u32 rs_pad[2]; | ||
404 | #else | ||
405 | u32 rs_code[2]; /* signal trampoline */ | ||
406 | #endif | ||
407 | compat_siginfo_t rs_info; | ||
408 | struct ucontext32 rs_uc; | ||
409 | #if ICACHE_REFILLS_WORKAROUND_WAR | ||
410 | u32 rs_code[8] __attribute__((aligned(32))); /* signal trampoline */ | ||
411 | #endif | ||
412 | }; | ||
413 | |||
414 | int copy_siginfo_to_user32(compat_siginfo_t __user *to, siginfo_t *from) | 407 | int copy_siginfo_to_user32(compat_siginfo_t __user *to, siginfo_t *from) |
415 | { | 408 | { |
416 | int err; | 409 | int err; |