skalibs

Mirror/fork of https://skarnet.org/software/skalibs/
git clone https://ccx.te2000.cz/git/skalibs
Log | Files | Refs | README | LICENSE

commit dfca03df0761c526bba84af0baa37ac9dbb5b42d
parent 3d480e3f202fc895fc7d36bcf94c654765f647dd
Author: Laurent Bercot <ska-skaware@skarnet.org>
Date:   Fri, 28 Apr 2017 10:35:45 +0000

 Fix NSIG definition (max+1 instead of max)

Diffstat:
Msrc/include/skalibs/nsig.h | 2+-
Msrc/libstddjb/selfpipe_finish.c | 2+-
Msrc/libstddjb/selfpipe_trapset.c | 4++--
Msrc/libstddjb/sig_stack.c | 8++++----
4 files changed, 8 insertions(+), 8 deletions(-)

diff --git a/src/include/skalibs/nsig.h b/src/include/skalibs/nsig.h @@ -5,7 +5,7 @@ #include <skalibs/nonposix.h> #include <signal.h> -#define SKALIBS_NSIG 64 +#define SKALIBS_NSIG 65 #ifndef NSIG # define NSIG SKALIBS_NSIG diff --git a/src/libstddjb/selfpipe_finish.c b/src/libstddjb/selfpipe_finish.c @@ -25,7 +25,7 @@ void selfpipe_finish (void) void selfpipe_finish (void) { - sig_restoreto(&selfpipe_caught, NSIG) ; + sig_restoreto(&selfpipe_caught, NSIG-1) ; sigemptyset(&selfpipe_caught) ; fd_close(selfpipe[1]) ; fd_close(selfpipe[0]) ; diff --git a/src/libstddjb/selfpipe_trapset.c b/src/libstddjb/selfpipe_trapset.c @@ -37,7 +37,7 @@ int selfpipe_trapset (sigset_t const *set) { unsigned int i = 1 ; if (selfpipe_fd < 0) return (errno = EBADF, -1) ; - for (; i <= NSIG ; i++) + for (; i < NSIG ; i++) { int h = sigismember(set, i) ; if (h < 0) continue ; @@ -50,7 +50,7 @@ int selfpipe_trapset (sigset_t const *set) if (sig_restore(i) < 0) break ; } } - if (i <= NSIG) + if (i < NSIG) { int e = errno ; sig_restoreto(set, i) ; diff --git a/src/libstddjb/sig_stack.c b/src/libstddjb/sig_stack.c @@ -7,12 +7,12 @@ #include <skalibs/sig.h> #include <skalibs/nsig.h> -static struct skasigaction skasigstack[NSIG][SIGSTACKSIZE] ; -static unsigned int sigsp[NSIG] ; +static struct skasigaction skasigstack[NSIG-1][SIGSTACKSIZE] ; +static unsigned int sigsp[NSIG-1] ; int sig_pusha (int sig, struct skasigaction const *ssa) { - if ((sig <= 0) || (sig > NSIG)) return (errno = EINVAL, -1) ; + if ((sig <= 0) || (sig >= NSIG)) return (errno = EINVAL, -1) ; if (sigsp[sig-1] >= SIGSTACKSIZE) return (errno = ENOBUFS, -1) ; if (skasigaction(sig, ssa, &skasigstack[sig-1][sigsp[sig-1]]) == -1) return -1 ; @@ -21,7 +21,7 @@ int sig_pusha (int sig, struct skasigaction const *ssa) int sig_pop (int sig) { - if ((sig <= 0) || (sig > NSIG)) return (errno = EINVAL, -1) ; + if ((sig <= 0) || (sig >= NSIG)) return (errno = EINVAL, -1) ; if (!sigsp[sig-1]) return (errno = EFAULT, -1); if (skasigaction(sig, &skasigstack[sig-1][sigsp[sig-1]-1], 0) == -1) return -1 ;