diff options
author | Jeff Johnston <jjohnstn@redhat.com> | 2002-05-31 20:18:59 +0000 |
---|---|---|
committer | Jeff Johnston <jjohnstn@redhat.com> | 2002-05-31 20:18:59 +0000 |
commit | ea55e3f7f3a213d4e3b5bdf966eecaf0aa1b7112 (patch) | |
tree | 5688b01e763ee509bc9e0dc1c8b43eb2dfa55261 /newlib/libc/sys/linux/sigset.c | |
parent | 89d7acf37a914c31834776879591c3301fb36c9b (diff) | |
download | cygnal-ea55e3f7f3a213d4e3b5bdf966eecaf0aa1b7112.tar.gz cygnal-ea55e3f7f3a213d4e3b5bdf966eecaf0aa1b7112.tar.bz2 cygnal-ea55e3f7f3a213d4e3b5bdf966eecaf0aa1b7112.zip |
2002-05-31 Jeff Johnston <jjohnstn@redhat.com>
* libc/sys/linux/Makefile.am: Add sig.c and sigaction.c. Also
make siglist.inc dependent on sig.c instead of signal.c.
* libc/sys/linux/Makefile.in: Regenerated.
* libc/sys/linux/sig.c: Rename from signal.c and change code to
use NSIG instead of _NSIG.
* libc/sys/linux/sigaction.c: New file.
* libc/sys/linux/signal.c: Changed to be linux signal() function
so as to override regular newlib default signal.c.
* libc/sys/linux/linuxthreads/config.h: Add __ASSUME_REALTIME_SIGNALS
definition.
* libc/sys/linux/linuxthreads/testrtsig.h: New file.
* libc/sys/linux/machine/i386/Makefile.am: Remove sigset.c.
* libc/sys/linux/machine/i386/Makefile.in: Regenerated.
* libc/sys/linux/machine/i386/sigset.c: Moved to linux main directory.
* libc/sys/linux/sigset.c: Moved from machine/i386 directory.
* libc/sys/linux/sys/signal.h: Redefine NSIG to _NSIG and override
default linux sigset_t typedef by defining it equal to __sigset_t.
* libc/unix/sigset.c: Add check so code isn't compiled on systems
with a sigset_t that isn't implemented with a single int.
Diffstat (limited to 'newlib/libc/sys/linux/sigset.c')
-rw-r--r-- | newlib/libc/sys/linux/sigset.c | 98 |
1 files changed, 98 insertions, 0 deletions
diff --git a/newlib/libc/sys/linux/sigset.c b/newlib/libc/sys/linux/sigset.c new file mode 100644 index 000000000..b6f2d79e5 --- /dev/null +++ b/newlib/libc/sys/linux/sigset.c @@ -0,0 +1,98 @@ +/* sigset.c - signal set manipulation functions */ + +/* Copyright 2002, Red Hat Inc. */ + +/* Note: these are currently grouped together in one file so that + it will override the default version in the libc/unix + directory which has grouped all functions in one file. */ + +/* sigaddset function */ + +#include <signal.h> +#include <bits/sigset.h> +#include <errno.h> +#include <string.h> +#include <machine/weakalias.h> + +int +sigaddset (sigset_t *set, const int signo) +{ + int index, mask; + __sigset_t *st = (__sigset_t *)set; + + if (signo > NSIG) + { + errno = EINVAL; + return -1; + } + + index = (signo - 1) / (8 * sizeof(long)); + mask = 1 << ((signo - 1) % (8 * sizeof(long))); + + st->__val[index] |= mask; + return 0; +} + +/* sigdelset function */ + +int +sigdelset (sigset_t *set, const int signo) +{ + int index, mask; + __sigset_t *st = (__sigset_t *)set; + + if (signo > NSIG) + { + errno = EINVAL; + return -1; + } + + index = (signo - 1) / (8 * sizeof(long)); + mask = 1 << ((signo - 1) % (8 * sizeof(long))); + + st->__val[index] &= ~mask; + return 0; +} + +/* sigemptyset function */ + +int +sigemptyset (sigset_t *set) +{ + int size = NSIG / 8; + __sigset_t *st = (__sigset_t *)set; + memset (st->__val, 0, size); + return 0; +} + +/* sigfillset function */ + +int +sigfillset (sigset_t *set) +{ + int size = NSIG / 8; + __sigset_t *st = (__sigset_t *)set; + memset (st->__val, 0xff, size); + return 0; +} + +/* sigismember function */ + +int +sigismember (const sigset_t *set, int signo) +{ + int index, mask; + __sigset_t *st = (__sigset_t *)set; + + if (signo > NSIG) + { + errno = EINVAL; + return -1; + } + + index = (signo - 1) / (8 * sizeof(long)); + mask = 1 << ((signo - 1) % (8 * sizeof(long))); + + return (st->__val[index] & mask) != 0; +} + |