110 lines
		
	
	
	
		
			2.3 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			110 lines
		
	
	
	
		
			2.3 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _ASM_X86_SIGNAL_H
 | |
| #define _ASM_X86_SIGNAL_H
 | |
| 
 | |
| #ifndef __ASSEMBLY__
 | |
| #include <linux/linkage.h>
 | |
| 
 | |
| /* Most things should be clean enough to redefine this at will, if care
 | |
|    is taken to make libc match.  */
 | |
| 
 | |
| #define _NSIG		64
 | |
| 
 | |
| #ifdef __i386__
 | |
| # define _NSIG_BPW	32
 | |
| #else
 | |
| # define _NSIG_BPW	64
 | |
| #endif
 | |
| 
 | |
| #define _NSIG_WORDS	(_NSIG / _NSIG_BPW)
 | |
| 
 | |
| typedef unsigned long old_sigset_t;		/* at least 32 bits */
 | |
| 
 | |
| typedef struct {
 | |
| 	unsigned long sig[_NSIG_WORDS];
 | |
| } sigset_t;
 | |
| 
 | |
| #ifndef CONFIG_COMPAT
 | |
| typedef sigset_t compat_sigset_t;
 | |
| #endif
 | |
| 
 | |
| #endif /* __ASSEMBLY__ */
 | |
| #include <uapi/asm/signal.h>
 | |
| #ifndef __ASSEMBLY__
 | |
| extern void do_notify_resume(struct pt_regs *, void *, __u32);
 | |
| 
 | |
| #define __ARCH_HAS_SA_RESTORER
 | |
| 
 | |
| #include <asm/sigcontext.h>
 | |
| 
 | |
| #ifdef __i386__
 | |
| 
 | |
| #define __HAVE_ARCH_SIG_BITOPS
 | |
| 
 | |
| #define sigaddset(set,sig)		    \
 | |
| 	(__builtin_constant_p(sig)	    \
 | |
| 	 ? __const_sigaddset((set), (sig))  \
 | |
| 	 : __gen_sigaddset((set), (sig)))
 | |
| 
 | |
| static inline void __gen_sigaddset(sigset_t *set, int _sig)
 | |
| {
 | |
| 	asm("btsl %1,%0" : "+m"(*set) : "Ir"(_sig - 1) : "cc");
 | |
| }
 | |
| 
 | |
| static inline void __const_sigaddset(sigset_t *set, int _sig)
 | |
| {
 | |
| 	unsigned long sig = _sig - 1;
 | |
| 	set->sig[sig / _NSIG_BPW] |= 1 << (sig % _NSIG_BPW);
 | |
| }
 | |
| 
 | |
| #define sigdelset(set, sig)		    \
 | |
| 	(__builtin_constant_p(sig)	    \
 | |
| 	 ? __const_sigdelset((set), (sig))  \
 | |
| 	 : __gen_sigdelset((set), (sig)))
 | |
| 
 | |
| 
 | |
| static inline void __gen_sigdelset(sigset_t *set, int _sig)
 | |
| {
 | |
| 	asm("btrl %1,%0" : "+m"(*set) : "Ir"(_sig - 1) : "cc");
 | |
| }
 | |
| 
 | |
| static inline void __const_sigdelset(sigset_t *set, int _sig)
 | |
| {
 | |
| 	unsigned long sig = _sig - 1;
 | |
| 	set->sig[sig / _NSIG_BPW] &= ~(1 << (sig % _NSIG_BPW));
 | |
| }
 | |
| 
 | |
| static inline int __const_sigismember(sigset_t *set, int _sig)
 | |
| {
 | |
| 	unsigned long sig = _sig - 1;
 | |
| 	return 1 & (set->sig[sig / _NSIG_BPW] >> (sig % _NSIG_BPW));
 | |
| }
 | |
| 
 | |
| static inline int __gen_sigismember(sigset_t *set, int _sig)
 | |
| {
 | |
| 	int ret;
 | |
| 	asm("btl %2,%1\n\tsbbl %0,%0"
 | |
| 	    : "=r"(ret) : "m"(*set), "Ir"(_sig-1) : "cc");
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| #define sigismember(set, sig)			\
 | |
| 	(__builtin_constant_p(sig)		\
 | |
| 	 ? __const_sigismember((set), (sig))	\
 | |
| 	 : __gen_sigismember((set), (sig)))
 | |
| 
 | |
| static inline int sigfindinword(unsigned long word)
 | |
| {
 | |
| 	asm("bsfl %1,%0" : "=r"(word) : "rm"(word) : "cc");
 | |
| 	return word;
 | |
| }
 | |
| 
 | |
| struct pt_regs;
 | |
| 
 | |
| #else /* __i386__ */
 | |
| 
 | |
| #undef __HAVE_ARCH_SIG_BITOPS
 | |
| 
 | |
| #endif /* !__i386__ */
 | |
| 
 | |
| #endif /* __ASSEMBLY__ */
 | |
| #endif /* _ASM_X86_SIGNAL_H */
 | 
