projects
/
musl
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
use vfork if possible in posix_spawn
[musl]
/
src
/
process
/
posix_spawn.c
diff --git
a/src/process/posix_spawn.c
b/src/process/posix_spawn.c
index
b1a9fbd
..
604756e
100644
(file)
--- a/
src/process/posix_spawn.c
+++ b/
src/process/posix_spawn.c
@@
-8,10
+8,13
@@
extern char **environ;
extern char **environ;
-int __posix_spawnx(pid_t *res, const char *path,
+pid_t __vfork(void);
+
+int __posix_spawnx(pid_t *restrict res, const char *restrict path,
int (*exec)(const char *, char *const *),
const posix_spawn_file_actions_t *fa,
int (*exec)(const char *, char *const *),
const posix_spawn_file_actions_t *fa,
- const posix_spawnattr_t *attr, char **argv, char **envp)
+ const posix_spawnattr_t *restrict attr,
+ char *const argv[restrict], char *const envp[restrict])
{
pid_t pid;
sigset_t oldmask;
{
pid_t pid;
sigset_t oldmask;
@@
-21,7
+24,7
@@
int __posix_spawnx(pid_t *res, const char *path,
if (!attr) attr = &dummy_attr;
sigprocmask(SIG_BLOCK, (void *)(uint64_t []){-1}, &oldmask);
if (!attr) attr = &dummy_attr;
sigprocmask(SIG_BLOCK, (void *)(uint64_t []){-1}, &oldmask);
- pid = __
syscall(SYS_fork
);
+ pid = __
vfork(
);
if (pid) {
sigprocmask(SIG_SETMASK, &oldmask, 0);
if (pid) {
sigprocmask(SIG_SETMASK, &oldmask, 0);
@@
-81,16
+84,17
@@
int __posix_spawnx(pid_t *res, const char *path,
sigprocmask(SIG_SETMASK, (attr->__flags & POSIX_SPAWN_SETSIGMASK)
? &attr->__mask : &oldmask, 0);
sigprocmask(SIG_SETMASK, (attr->__flags & POSIX_SPAWN_SETSIGMASK)
? &attr->__mask : &oldmask, 0);
- if (envp) environ = envp;
+ if (envp) environ =
(char **)
envp;
exec(path, argv);
_exit(127);
return 0;
}
exec(path, argv);
_exit(127);
return 0;
}
-int posix_spawn(pid_t *res
, const char *
path,
+int posix_spawn(pid_t *res
trict res, const char *restrict
path,
const posix_spawn_file_actions_t *fa,
const posix_spawn_file_actions_t *fa,
- const posix_spawnattr_t *attr, char **argv, char **envp)
+ const posix_spawnattr_t *restrict attr,
+ char *const argv[restrict], char *const envp[restrict])
{
return __posix_spawnx(res, path, execv, fa, attr, argv, envp);
}
{
return __posix_spawnx(res, path, execv, fa, attr, argv, envp);
}