diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2018-01-09 01:36:58 +0100 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2018-01-09 01:37:34 +0100 |
commit | 311ba8dc4416467947eff2ab327854f124226309 (patch) | |
tree | ad9a00d6a87de80ddc241b60b2d52aad971fa10e /sysdeps/mach/hurd/execve.c | |
parent | d7ff3f11b64a28273285d341f795217bbf18ac9c (diff) |
hurd: Use the new file_exec_paths RPC
From: Emilio Pozuelo Monfort <pochu27@gmail.com>
From: Svante Signell <svante.signell@gmail.com>
Pass the file paths of executable to the exec server, both relative and
absolute, which exec needs to properly execute and avertise #!-scripts.
Previously, the exec server tried to guess the name from argv[0] but argv[0]
only contains the executable name by convention.
* hurd/hurdexec.c (_hurd_exec): Deprecate function.
(_hurd_exec_paths): New function.
* hurd/hurd.h (_hurd_exec): Deprecate function.
(_hurd_exec_paths): Declare function.
* hurd/Versions: Export _hurd_exec_paths.
* sysdeps/mach/hurd/execve.c: Include <stdlib.h> and <stdio.h>
(__execve): Use __getcwd to build absolute path, and use
_hurd_exec_paths instead of _hurd_exec.
* sysdeps/mach/hurd/spawni.c: Likewise.
* sysdeps/mach/hurd/fexecve.c: Use _hurd_exec_paths instead of
_hurd_exec.
Diffstat (limited to 'sysdeps/mach/hurd/execve.c')
-rw-r--r-- | sysdeps/mach/hurd/execve.c | 36 |
1 files changed, 34 insertions, 2 deletions
diff --git a/sysdeps/mach/hurd/execve.c b/sysdeps/mach/hurd/execve.c index 04d3bd0d3e..1c5b681d89 100644 --- a/sysdeps/mach/hurd/execve.c +++ b/sysdeps/mach/hurd/execve.c @@ -18,6 +18,8 @@ #include <unistd.h> #include <hurd.h> #include <fcntl.h> +#include <stdlib.h> +#include <stdio.h> /* Replace the current process, executing FILE_NAME with arguments ARGV and environment ENVP. ARGV and ENVP are terminated by NULL pointers. */ @@ -25,16 +27,46 @@ int __execve (const char *file_name, char *const argv[], char *const envp[]) { error_t err; - file_t file = __file_name_lookup (file_name, O_EXEC, 0); + char *concat_name = NULL; + const char *abs_path; + file_t file = __file_name_lookup (file_name, O_EXEC, 0); if (file == MACH_PORT_NULL) return -1; + if (file_name[0] == '/') + { + /* Already an absolute path */ + abs_path = file_name; + } + else + { + /* Relative path */ + char *cwd = __getcwd (NULL, 0); + if (cwd == NULL) + { + __mach_port_deallocate (__mach_task_self (), file); + return -1; + } + + int res = __asprintf (&concat_name, "%s/%s", cwd, file_name); + free (cwd); + if (res == -1) + { + __mach_port_deallocate (__mach_task_self (), file); + return -1; + } + + abs_path = concat_name; + } + /* Hopefully this will not return. */ - err = _hurd_exec (__mach_task_self (), file, argv, envp); + err = _hurd_exec_paths (__mach_task_self (), file, + file_name, abs_path, argv, envp); /* Oh well. Might as well be tidy. */ __mach_port_deallocate (__mach_task_self (), file); + free (concat_name); return __hurd_fail (err); } |