diff options
| author | Rich Felker <dalias@aerifal.cx> | 2014-05-26 21:26:46 -0400 | 
|---|---|---|
| committer | Rich Felker <dalias@aerifal.cx> | 2014-05-26 21:26:46 -0400 | 
| commit | 4ef04a27c7cf81db13316ceb6e840527977a7787 (patch) | |
| tree | 89d3f33b263ea8701bd612211d6e304681213f54 | |
| parent | 594c827a22124ae550b9a877b8188e0898dff8db (diff) | |
| download | musl-4ef04a27c7cf81db13316ceb6e840527977a7787.tar.gz | |
fix type of extended argument array to pselect6 syscall
this only matters on x32 (and perhaps future 32-on-64 abis for other
archs); otherwise the type is long anyway. the cast through uintptr_t
prevents nonsensical "sign extension" of pointers, and follows the
principle that uintptr_t is the canonical integer type to which
pointer conversion is safe.
| -rw-r--r-- | src/select/pselect.c | 3 | 
1 files changed, 2 insertions, 1 deletions
| diff --git a/src/select/pselect.c b/src/select/pselect.c index a19e153e..4e2d7b07 100644 --- a/src/select/pselect.c +++ b/src/select/pselect.c @@ -1,11 +1,12 @@  #include <sys/select.h>  #include <signal.h> +#include <stdint.h>  #include "syscall.h"  #include "libc.h"  int pselect(int n, fd_set *restrict rfds, fd_set *restrict wfds, fd_set *restrict efds, const struct timespec *restrict ts, const sigset_t *restrict mask)  { -	long data[2] = { (long)mask, _NSIG/8 }; +	syscall_arg_t data[2] = { (uintptr_t)mask, _NSIG/8 };  	struct timespec ts_tmp;  	if (ts) ts_tmp = *ts;  	return syscall_cp(SYS_pselect6, n, rfds, wfds, efds, ts ? &ts_tmp : 0, data); | 
