Release 4.11 arch/x86/include/asm/signal.h
#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;
/* non-uapi in-kernel SA_FLAGS for those indicates ABI for a signal frame */
#define SA_IA32_ABI 0x02000000u
#define SA_X32_ABI 0x01000000u
#ifndef CONFIG_COMPAT
typedef sigset_t compat_sigset_t;
#endif
#endif /* __ASSEMBLY__ */
#include <uapi/asm/signal.h>
#ifndef __ASSEMBLY__
extern void do_signal(struct pt_regs *regs);
#define __ARCH_HAS_SA_RESTORER
#include <uapi/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");
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Thomas Gleixner | 13 | 86.67% | 1 | 50.00% |
Joe Perches | 2 | 13.33% | 1 | 50.00% |
Total | 15 | 100.00% | 2 | 100.00% |
static inline void __const_sigaddset(sigset_t *set, int _sig)
{
unsigned long sig = _sig - 1;
set->sig[sig / _NSIG_BPW] |= 1 << (sig % _NSIG_BPW);
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Thomas Gleixner | 38 | 97.44% | 1 | 50.00% |
Joe Perches | 1 | 2.56% | 1 | 50.00% |
Total | 39 | 100.00% | 2 | 100.00% |
#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");
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Thomas Gleixner | 13 | 86.67% | 1 | 50.00% |
Joe Perches | 2 | 13.33% | 1 | 50.00% |
Total | 15 | 100.00% | 2 | 100.00% |
static inline void __const_sigdelset(sigset_t *set, int _sig)
{
unsigned long sig = _sig - 1;
set->sig[sig / _NSIG_BPW] &= ~(1 << (sig % _NSIG_BPW));
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Thomas Gleixner | 41 | 97.62% | 1 | 50.00% |
Joe Perches | 1 | 2.38% | 1 | 50.00% |
Total | 42 | 100.00% | 2 | 100.00% |
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));
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Thomas Gleixner | 41 | 97.62% | 1 | 50.00% |
Joe Perches | 1 | 2.38% | 1 | 50.00% |
Total | 42 | 100.00% | 2 | 100.00% |
static inline int __gen_sigismember(sigset_t *set, int _sig)
{
unsigned char ret;
asm("btl %2,%1\n\tsetc %0"
: "=qm"(ret) : "m"(*set), "Ir"(_sig-1) : "cc");
return ret;
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Thomas Gleixner | 18 | 81.82% | 1 | 33.33% |
H. Peter Anvin | 3 | 13.64% | 1 | 33.33% |
Joe Perches | 1 | 4.55% | 1 | 33.33% |
Total | 22 | 100.00% | 3 | 100.00% |
#define sigismember(set, sig) \
(__builtin_constant_p(sig) \
? __const_sigismember((set), (sig)) \
: __gen_sigismember((set), (sig)))
struct pt_regs;
#else /* __i386__ */
#undef __HAVE_ARCH_SIG_BITOPS
#endif /* !__i386__ */
#endif /* __ASSEMBLY__ */
#endif /* _ASM_X86_SIGNAL_H */
Overall Contributors
Person | Tokens | Prop | Commits | CommitProp |
Thomas Gleixner | 273 | 83.49% | 2 | 14.29% |
Joe Perches | 10 | 3.06% | 1 | 7.14% |
Dmitry Safonov | 9 | 2.75% | 1 | 7.14% |
Suresh B. Siddha | 9 | 2.75% | 1 | 7.14% |
Andrew Lutomirski | 8 | 2.45% | 1 | 7.14% |
H. Peter Anvin | 6 | 1.83% | 2 | 14.29% |
Al Viro | 3 | 0.92% | 1 | 7.14% |
Roland McGrath | 3 | 0.92% | 1 | 7.14% |
Herton Ronaldo Krzesinski | 2 | 0.61% | 1 | 7.14% |
Jaswinder Singh Rajput | 2 | 0.61% | 1 | 7.14% |
Ingo Molnar | 1 | 0.31% | 1 | 7.14% |
David Howells | 1 | 0.31% | 1 | 7.14% |
Total | 327 | 100.00% | 14 | 100.00% |
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.