mirror of
https://sourceware.org/git/glibc.git
synced 2025-09-02 16:01:20 +03:00
Update.
2005-01-20 Ulrich Drepper <drepper@redhat.com> * posix/execl.c: Do not allocate potentially large buffers on the stack. * posix/execle.c: Likewise. * posix/execlp.c: Likewise. * posix/execlp.c: Likewise. (script_execute): Removed. (allocate_scripts_argv): New function. Called at most once to allocate memory, not every time a script is run. Adjust caller. * sysdeps/generic/wordexp.c (exec_comm): Add a few TEMP_FAILURE_RETRY. Reorganize code to avoid multiple calls to exec_comm_child. (exec_comm_child): Can now be inlined. * posix/Makefile: Add -fomit-frame-pointer for a few more files. * stdlib/Makefile: Likewise.
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
/* Copyright (C) 1991,92,94,97,98,99,2002 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 1991,92,94,97,98,99,2002,2005 Free Software Foundation, Inc.
|
||||
This file is part of the GNU C Library.
|
||||
|
||||
The GNU C Library is free software; you can redistribute it and/or
|
||||
@@ -16,10 +16,10 @@
|
||||
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
||||
02111-1307 USA. */
|
||||
|
||||
#include <alloca.h>
|
||||
#include <unistd.h>
|
||||
#include <stdarg.h>
|
||||
#include <stddef.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#include <stackinfo.h>
|
||||
@@ -33,46 +33,44 @@
|
||||
int
|
||||
execl (const char *path, const char *arg, ...)
|
||||
{
|
||||
size_t argv_max = 1024;
|
||||
const char **argv = alloca (argv_max * sizeof (const char *));
|
||||
unsigned int i;
|
||||
#define INITIAL_ARGV_MAX 1024
|
||||
size_t argv_max = INITIAL_ARGV_MAX;
|
||||
const char *initial_argv[INITIAL_ARGV_MAX];
|
||||
const char **argv = initial_argv;
|
||||
va_list args;
|
||||
|
||||
argv[0] = arg;
|
||||
|
||||
va_start (args, arg);
|
||||
i = 0;
|
||||
unsigned int i = 0;
|
||||
while (argv[i++] != NULL)
|
||||
{
|
||||
if (i == argv_max)
|
||||
{
|
||||
const char **nptr = alloca ((argv_max *= 2) * sizeof (const char *));
|
||||
|
||||
#ifndef _STACK_GROWS_UP
|
||||
if ((char *) nptr + argv_max == (char *) argv)
|
||||
argv_max *= 2;
|
||||
const char **nptr = realloc (argv == initial_argv ? NULL : argv,
|
||||
argv_max * sizeof (const char *));
|
||||
if (nptr == NULL)
|
||||
{
|
||||
/* Stack grows down. */
|
||||
argv = (const char **) memcpy (nptr, argv,
|
||||
i * sizeof (const char *));
|
||||
argv_max += i;
|
||||
if (argv != initial_argv)
|
||||
free (argv);
|
||||
return -1;
|
||||
}
|
||||
else
|
||||
#endif
|
||||
#ifndef _STACK_GROWS_DOWN
|
||||
if ((char *) argv + i == (char *) nptr)
|
||||
/* Stack grows up. */
|
||||
argv_max += i;
|
||||
else
|
||||
#endif
|
||||
/* We have a hole in the stack. */
|
||||
argv = (const char **) memcpy (nptr, argv,
|
||||
i * sizeof (const char *));
|
||||
if (argv == initial_argv)
|
||||
/* We have to copy the already filled-in data ourselves. */
|
||||
memcpy (nptr, argv, i * sizeof (const char *));
|
||||
|
||||
argv = nptr;
|
||||
}
|
||||
|
||||
argv[i] = va_arg (args, const char *);
|
||||
}
|
||||
va_end (args);
|
||||
|
||||
return __execve (path, (char *const *) argv, __environ);
|
||||
int ret = __execve (path, (char *const *) argv, __environ);
|
||||
if (argv != initial_argv)
|
||||
free (argv);
|
||||
|
||||
return ret;
|
||||
}
|
||||
libc_hidden_def (execl)
|
||||
|
Reference in New Issue
Block a user