4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
23 * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
27 /* Copyright (c) 1988 AT&T */
28 /* All Rights Reserved */
30 #pragma ident "%Z%%M% %I% %E% SMI"
33 * execle(file, arg1, arg2, ..., 0, envp)
36 #pragma weak _execle = execle
39 #include <sys/types.h>
47 execle(const char *file
, const char *arg0
, ...)
52 register char **environmentp
;
58 * count the number of arguments in the variable argument list
59 * and allocate an argument vector for them on the stack,
60 * adding space at the end for a terminating null pointer
64 while (va_arg(args
, char *) != NULL
) {
69 * save the environment pointer, which is at the end of the
70 * variable argument list
73 environmentp
= va_arg(args
, char **);
77 * load the arguments in the variable argument list
78 * into the argument vector, and add the terminating null pointer
82 /* workaround for bugid 1242839 */
83 argvec
= (char **)alloca((size_t)((nargs
+ 2) * sizeof (char *)));
85 *argp
++ = (char *)arg0
;
86 while ((nextarg
= va_arg(args
, char *)) != NULL
) {
96 err
= execve(file
, argvec
, environmentp
);