summaryrefslogtreecommitdiff
path: root/src/process/posix_spawn.c
AgeCommit message (Collapse)AuthorFilesLines
2012-10-15block uid/gid changes during posix_spawnRich Felker1-0/+10
usage of vfork creates a situation where a process of lower privilege may momentarily have write access to the memory of a process of higher privilege. consider the case of a multi-threaded suid program which is calling posix_spawn in one thread while another thread drops the elevated privileges then runs untrusted (relative to the elevated privilege) code as the original invoking user. this untrusted code can then potentially modify the data the child process will use before calling exec, for example changing the pathname or arguments that will be passed to exec. note that if vfork is implemented as fork, the lock will not be held until the child execs, but since memory is not shared it does not matter.
2012-09-14use vfork if possible in posix_spawnRich Felker1-1/+3
vfork is implemented as the fork syscall (with no atfork handlers run) on archs where it is not available, so this change does not introduce any change in behavior or regression for such archs.
2012-09-06use restrict everywhere it's required by c99 and/or posix 2008Rich Felker1-6/+6
to deal with the fact that the public headers may be used with pre-c99 compilers, __restrict is used in place of restrict, and defined appropriately for any supported compiler. we also avoid the form [restrict] since older versions of gcc rejected it due to a bug in the original c99 standard, and instead use the form *restrict.
2011-09-13fix various errors in function signatures/prototypes found by nszRich Felker1-3/+5
2011-05-29fix backwards posix_spawn file action orderRich Felker1-2/+3
2011-05-28add file actions support to posix_spawnRich Felker1-0/+28
2011-05-28posix_spawn: honor POSIX_SPAWN_SETSIGDEF flagRich Felker1-1/+3
2011-05-28initial implementation of posix_spawnRich Felker1-0/+65
file actions are not yet implemented, but everything else should be mostly complete and roughly correct.