diff options
| author | Rich Felker <dalias@aerifal.cx> | 2015-12-15 23:20:36 -0500 | 
|---|---|---|
| committer | Rich Felker <dalias@aerifal.cx> | 2015-12-15 23:20:36 -0500 | 
| commit | 42216742cd69e52e70aeb1d14498a8145872de52 (patch) | |
| tree | d4cf6347d58e57d24bdd6d0931541a64d213e771 /src | |
| parent | 0d58bf2d6078dd486951cdeb24790043eb171081 (diff) | |
| download | musl-42216742cd69e52e70aeb1d14498a8145872de52.tar.gz | |
fix crash when signal number 0 is passed to sigaction
this error case was overlooked in the old range checking logic. new
check is moved out of __libc_sigaction to the public wrapper in order
to unify the error path and reduce code size.
Diffstat (limited to 'src')
| -rw-r--r-- | src/signal/sigaction.c | 6 | 
1 files changed, 1 insertions, 5 deletions
diff --git a/src/signal/sigaction.c b/src/signal/sigaction.c index ab23a6f2..6eca06f1 100644 --- a/src/signal/sigaction.c +++ b/src/signal/sigaction.c @@ -17,10 +17,6 @@ void __get_handler_set(sigset_t *set)  int __libc_sigaction(int sig, const struct sigaction *restrict sa, struct sigaction *restrict old)  {  	struct k_sigaction ksa, ksa_old; -	if (sig >= (unsigned)_NSIG) { -		errno = EINVAL; -		return -1; -	}  	if (sa) {  		if ((uintptr_t)sa->sa_handler > 1UL) {  			a_or_l(handler_set+(sig-1)/(8*sizeof(long)), @@ -57,7 +53,7 @@ int __libc_sigaction(int sig, const struct sigaction *restrict sa, struct sigact  int __sigaction(int sig, const struct sigaction *restrict sa, struct sigaction *restrict old)  { -	if (sig-32U < 3) { +	if (sig-32U < 3 || sig-1U >= _NSIG-1) {  		errno = EINVAL;  		return -1;  	}  | 
