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 * execl(name, arg0, arg1, ..., argn, 0)
34 * environment automatically passed.
37 #pragma weak _execl = execl
43 #include <sys/types.h>
48 execl(const char *name
, const char *arg0
, ...)
53 extern char **_environ
;
59 * count the number of arguments in the variable argument list
60 * and allocate an argument vector for them on the stack,
61 * adding an extra element for a terminating null pointer
65 while (va_arg(args
, char *) != NULL
) {
71 * load the arguments in the variable argument list
72 * into the argument vector and add the terminating null pointer
77 /* workaround for bugid 1242839 */
78 argvec
= (char **)alloca((size_t)((nargs
+ 2) * sizeof (char *)));
80 *argp
++ = (char *)arg0
;
81 while ((nextarg
= va_arg(args
, char *)) != NULL
) {
91 err
= execve(name
, argvec
, _environ
);