aboutsummaryrefslogtreecommitdiff
path: root/sysdeps/mach/hurd/execve.c
diff options
context:
space:
mode:
authorSamuel Thibault <samuel.thibault@ens-lyon.org>2021-05-17 23:47:47 +0000
committerSamuel Thibault <samuel.thibault@ens-lyon.org>2021-05-18 09:36:00 +0000
commit4d4bb451d5fc820225c20a3c44dfc958e837cef8 (patch)
tree8026568ce2549680e5653ae26395c2c941a8bb7e /sysdeps/mach/hurd/execve.c
parent2457175e8b5dfa0ca447ba87cb2a1e7d7e2ba4a7 (diff)
downloadglibc-4d4bb451d5fc820225c20a3c44dfc958e837cef8.tar.xz
glibc-4d4bb451d5fc820225c20a3c44dfc958e837cef8.zip
hurd: Add execveat
Diffstat (limited to 'sysdeps/mach/hurd/execve.c')
-rw-r--r--sysdeps/mach/hurd/execve.c44
1 files changed, 1 insertions, 43 deletions
diff --git a/sysdeps/mach/hurd/execve.c b/sysdeps/mach/hurd/execve.c
index 3e49fa570b..071f879fad 100644
--- a/sysdeps/mach/hurd/execve.c
+++ b/sysdeps/mach/hurd/execve.c
@@ -26,49 +26,7 @@
int
__execve (const char *file_name, char *const argv[], char *const envp[])
{
- error_t err;
- 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_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);
+ return __execveat (AT_FDCWD, file_name, argv, envp, 0);
}
weak_alias (__execve, execve)