| #ifndef __ASM_COMPAT_SIGNAL_H | 
 | #define __ASM_COMPAT_SIGNAL_H | 
 |  | 
 | #include <linux/bug.h> | 
 | #include <linux/compat.h> | 
 | #include <linux/compiler.h> | 
 |  | 
 | #include <asm/signal.h> | 
 | #include <asm/siginfo.h> | 
 |  | 
 | #include <asm/uaccess.h> | 
 |  | 
 | #define SI_PAD_SIZE32   ((SI_MAX_SIZE/sizeof(int)) - 3) | 
 |  | 
 | typedef struct compat_siginfo { | 
 | 	int si_signo; | 
 | 	int si_code; | 
 | 	int si_errno; | 
 |  | 
 | 	union { | 
 | 		int _pad[SI_PAD_SIZE32]; | 
 |  | 
 | 		/* kill() */ | 
 | 		struct { | 
 | 			compat_pid_t _pid;	/* sender's pid */ | 
 | 			compat_uid_t _uid;	/* sender's uid */ | 
 | 		} _kill; | 
 |  | 
 | 		/* SIGCHLD */ | 
 | 		struct { | 
 | 			compat_pid_t _pid;	/* which child */ | 
 | 			compat_uid_t _uid;	/* sender's uid */ | 
 | 			int _status;		/* exit code */ | 
 | 			compat_clock_t _utime; | 
 | 			compat_clock_t _stime; | 
 | 		} _sigchld; | 
 |  | 
 | 		/* IRIX SIGCHLD */ | 
 | 		struct { | 
 | 			compat_pid_t _pid;	/* which child */ | 
 | 			compat_clock_t _utime; | 
 | 			int _status;		/* exit code */ | 
 | 			compat_clock_t _stime; | 
 | 		} _irix_sigchld; | 
 |  | 
 | 		/* SIGILL, SIGFPE, SIGSEGV, SIGBUS */ | 
 | 		struct { | 
 | 			s32 _addr; /* faulting insn/memory ref. */ | 
 | 		} _sigfault; | 
 |  | 
 | 		/* SIGPOLL, SIGXFSZ (To do ...)  */ | 
 | 		struct { | 
 | 			int _band;	/* POLL_IN, POLL_OUT, POLL_MSG */ | 
 | 			int _fd; | 
 | 		} _sigpoll; | 
 |  | 
 | 		/* POSIX.1b timers */ | 
 | 		struct { | 
 | 			timer_t _tid;		/* timer id */ | 
 | 			int _overrun;		/* overrun count */ | 
 | 			compat_sigval_t _sigval;/* same as below */ | 
 | 			int _sys_private;       /* not to be passed to user */ | 
 | 		} _timer; | 
 |  | 
 | 		/* POSIX.1b signals */ | 
 | 		struct { | 
 | 			compat_pid_t _pid;	/* sender's pid */ | 
 | 			compat_uid_t _uid;	/* sender's uid */ | 
 | 			compat_sigval_t _sigval; | 
 | 		} _rt; | 
 |  | 
 | 	} _sifields; | 
 | } compat_siginfo_t; | 
 |  | 
 | static inline int __copy_conv_sigset_to_user(compat_sigset_t __user *d, | 
 | 	const sigset_t *s) | 
 | { | 
 | 	int err; | 
 |  | 
 | 	BUG_ON(sizeof(*d) != sizeof(*s)); | 
 | 	BUG_ON(_NSIG_WORDS != 2); | 
 |  | 
 | 	err  = __put_user(s->sig[0],       &d->sig[0]); | 
 | 	err |= __put_user(s->sig[0] >> 32, &d->sig[1]); | 
 | 	err |= __put_user(s->sig[1],       &d->sig[2]); | 
 | 	err |= __put_user(s->sig[1] >> 32, &d->sig[3]); | 
 |  | 
 | 	return err; | 
 | } | 
 |  | 
 | static inline int __copy_conv_sigset_from_user(sigset_t *d, | 
 | 	const compat_sigset_t __user *s) | 
 | { | 
 | 	int err; | 
 | 	union sigset_u { | 
 | 		sigset_t	s; | 
 | 		compat_sigset_t c; | 
 | 	} *u = (union sigset_u *) d; | 
 |  | 
 | 	BUG_ON(sizeof(*d) != sizeof(*s)); | 
 | 	BUG_ON(_NSIG_WORDS != 2); | 
 |  | 
 | #ifdef CONFIG_CPU_BIG_ENDIAN | 
 | 	err  = __get_user(u->c.sig[1], &s->sig[0]); | 
 | 	err |= __get_user(u->c.sig[0], &s->sig[1]); | 
 | 	err |= __get_user(u->c.sig[3], &s->sig[2]); | 
 | 	err |= __get_user(u->c.sig[2], &s->sig[3]); | 
 | #endif | 
 | #ifdef CONFIG_CPU_LITTLE_ENDIAN | 
 | 	err  = __get_user(u->c.sig[0], &s->sig[0]); | 
 | 	err |= __get_user(u->c.sig[1], &s->sig[1]); | 
 | 	err |= __get_user(u->c.sig[2], &s->sig[2]); | 
 | 	err |= __get_user(u->c.sig[3], &s->sig[3]); | 
 | #endif | 
 |  | 
 | 	return err; | 
 | } | 
 |  | 
 | #endif /* __ASM_COMPAT_SIGNAL_H */ |