提交 d5304147 编写于 作者: R Rich Felker

block uid/gid changes during posix_spawn

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.
上级 42c36f95
...@@ -5,9 +5,16 @@ ...@@ -5,9 +5,16 @@
#include <fcntl.h> #include <fcntl.h>
#include "syscall.h" #include "syscall.h"
#include "fdop.h" #include "fdop.h"
#include "libc.h"
extern char **environ; extern char **environ;
static void dummy_0()
{
}
weak_alias(dummy_0, __acquire_ptc);
weak_alias(dummy_0, __release_ptc);
pid_t __vfork(void); pid_t __vfork(void);
int __posix_spawnx(pid_t *restrict res, const char *restrict path, int __posix_spawnx(pid_t *restrict res, const char *restrict path,
...@@ -24,7 +31,10 @@ int __posix_spawnx(pid_t *restrict res, const char *restrict path, ...@@ -24,7 +31,10 @@ int __posix_spawnx(pid_t *restrict res, const char *restrict path,
if (!attr) attr = &dummy_attr; if (!attr) attr = &dummy_attr;
sigprocmask(SIG_BLOCK, (void *)(uint64_t []){-1}, &oldmask); sigprocmask(SIG_BLOCK, (void *)(uint64_t []){-1}, &oldmask);
__acquire_ptc();
pid = __vfork(); pid = __vfork();
__release_ptc();
if (pid) { if (pid) {
sigprocmask(SIG_SETMASK, &oldmask, 0); sigprocmask(SIG_SETMASK, &oldmask, 0);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册