Man Linux: Main Page and Category List

NAME

       fexecve - execute program specified via file descriptor

SYNOPSIS

       #define _GNU_SOURCE
       #include <unistd.h>

       int fexecve(int fd, char *const argv[], char *const envp[]);

DESCRIPTION

       fexecve() performs the same task as execve(2), with the difference that
       the file to be executed is specified via a file descriptor, fd,  rather
       than  via a pathname.  The file descriptor fd must be opened read-only,
       and the caller must have permission to execute the file that it  refers
       to.

RETURN VALUE

       A  successful  call to fexecve() never returns.  On error, the function
       returns, with a result value of -1, and errno is set appropriately.

ERRORS

       Errors are as for execve(2), with the following additions:

       EINVAL fd is not a valid file descriptor, or argv is NULL, or  envp  is
              NULL.

       ENOSYS The /proc file system could not be accessed.

VERSIONS

       fexecve() is implemented since glibc 2.3.2.

CONFORMING TO

       POSIX.1-2008.   This  function is not specified in POSIX.1-2001, and is
       not widely available on other systems.

NOTES

       On Linux, fexecve() is implemented using the proc(5)  file  system,  so
       /proc needs to be mounted and available at the time of the call.

SEE ALSO

       execve(2)

COLOPHON

       This  page  is  part of release 3.24 of the Linux man-pages project.  A
       description of the project, and information about reporting  bugs,  can
       be found at http://www.kernel.org/doc/man-pages/.