diff options
| author | Samuel Holland <samuel@sholland.org> | 2019-06-29 18:19:04 -0500 | 
|---|---|---|
| committer | Rich Felker <dalias@aerifal.cx> | 2019-07-10 17:06:00 -0400 | 
| commit | e0eee3ceefd550724058ffbdf878e9eb06e18f18 (patch) | |
| tree | 4c646a29132f7e8025b2755fa4d5956e08fcacdb /src | |
| parent | a730639273fd5040ea3528a9fc7b8590f46a6702 (diff) | |
| download | musl-e0eee3ceefd550724058ffbdf878e9eb06e18f18.tar.gz | |
fix restrict violations in internal use of several functions
The old/new parameters to pthread_sigmask, sigprocmask, and setitimer
are marked restrict, so passing the same address to both is
prohibited. Modify callers of these functions to use a separate object
for each argument.
Diffstat (limited to 'src')
| -rw-r--r-- | src/aio/lio_listio.c | 6 | ||||
| -rw-r--r-- | src/signal/sigset.c | 8 | ||||
| -rw-r--r-- | src/unistd/ualarm.c | 6 | 
3 files changed, 10 insertions, 10 deletions
diff --git a/src/aio/lio_listio.c b/src/aio/lio_listio.c index 7b6a03d3..0799c15d 100644 --- a/src/aio/lio_listio.c +++ b/src/aio/lio_listio.c @@ -113,7 +113,7 @@ int lio_listio(int mode, struct aiocb *restrict const *restrict cbs, int cnt, st  	if (st) {  		pthread_attr_t a; -		sigset_t set; +		sigset_t set, set_old;  		pthread_t td;  		if (sev->sigev_notify == SIGEV_THREAD) { @@ -128,13 +128,13 @@ int lio_listio(int mode, struct aiocb *restrict const *restrict cbs, int cnt, st  		}  		pthread_attr_setdetachstate(&a, PTHREAD_CREATE_DETACHED);  		sigfillset(&set); -		pthread_sigmask(SIG_BLOCK, &set, &set); +		pthread_sigmask(SIG_BLOCK, &set, &set_old);  		if (pthread_create(&td, &a, wait_thread, st)) {  			free(st);  			errno = EAGAIN;  			return -1;  		} -		pthread_sigmask(SIG_SETMASK, &set, 0); +		pthread_sigmask(SIG_SETMASK, &set_old, 0);  	}  	return 0; diff --git a/src/signal/sigset.c b/src/signal/sigset.c index 0d7b4564..f3e8c407 100644 --- a/src/signal/sigset.c +++ b/src/signal/sigset.c @@ -3,7 +3,7 @@  void (*sigset(int sig, void (*handler)(int)))(int)  {  	struct sigaction sa, sa_old; -	sigset_t mask; +	sigset_t mask, mask_old;  	sigemptyset(&mask);  	if (sigaddset(&mask, sig) < 0) @@ -12,7 +12,7 @@ void (*sigset(int sig, void (*handler)(int)))(int)  	if (handler == SIG_HOLD) {  		if (sigaction(sig, 0, &sa_old) < 0)  			return SIG_ERR; -		if (sigprocmask(SIG_BLOCK, &mask, &mask) < 0) +		if (sigprocmask(SIG_BLOCK, &mask, &mask_old) < 0)  			return SIG_ERR;  	} else {  		sa.sa_handler = handler; @@ -20,8 +20,8 @@ void (*sigset(int sig, void (*handler)(int)))(int)  		sigemptyset(&sa.sa_mask);  		if (sigaction(sig, &sa, &sa_old) < 0)  			return SIG_ERR; -		if (sigprocmask(SIG_UNBLOCK, &mask, &mask) < 0) +		if (sigprocmask(SIG_UNBLOCK, &mask, &mask_old) < 0)  			return SIG_ERR;  	} -	return sigismember(&mask, sig) ? SIG_HOLD : sa_old.sa_handler; +	return sigismember(&mask_old, sig) ? SIG_HOLD : sa_old.sa_handler;  } diff --git a/src/unistd/ualarm.c b/src/unistd/ualarm.c index 855504bc..2985855c 100644 --- a/src/unistd/ualarm.c +++ b/src/unistd/ualarm.c @@ -7,7 +7,7 @@ unsigned ualarm(unsigned value, unsigned interval)  	struct itimerval it = {  		.it_interval.tv_usec = interval,  		.it_value.tv_usec = value -	}; -	setitimer(ITIMER_REAL, &it, &it); -	return it.it_value.tv_sec*1000000 + it.it_value.tv_usec; +	}, it_old; +	setitimer(ITIMER_REAL, &it, &it_old); +	return it_old.it_value.tv_sec*1000000 + it_old.it_value.tv_usec;  }  | 
