From: Joseph C. Sible Date: Sun, 2 Sep 2018 17:42:26 +0000 (-0400) Subject: implement fexecve in terms of execveat when it exists X-Git-Tag: v1.1.21~168 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=e36f80cba6d5eefcc1ee664f16c2c72054b83134;p=oweals%2Fmusl.git implement fexecve in terms of execveat when it exists This lets fexecve work even when /proc isn't mounted. --- diff --git a/src/process/fexecve.c b/src/process/fexecve.c index 6507b429..8be3f760 100644 --- a/src/process/fexecve.c +++ b/src/process/fexecve.c @@ -1,10 +1,15 @@ +#define _GNU_SOURCE #include #include +#include +#include "syscall.h" void __procfdname(char *, unsigned); int fexecve(int fd, char *const argv[], char *const envp[]) { + int r = __syscall(SYS_execveat, fd, "", argv, envp, AT_EMPTY_PATH); + if (r != -ENOSYS) return __syscall_ret(r); char buf[15 + 3*sizeof(int)]; __procfdname(buf, fd); execve(buf, argv, envp);