usr/src/lib/libc/port/gen/waitpid.c
author Jon Tibble <meths@btinternet.com>
Thu, 09 Dec 2010 22:32:39 +0100
changeset 13255 4afa820d78b9
parent 6812 febeba71273d
permissions -rw-r--r--
298 SPARC build fails in smt_pause.o 478 Build needs fixing for pkgdepend flag day Reviewed by: [email protected] Reviewed by: [email protected] Reviewed by: [email protected] Approved by: [email protected]
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     1
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     2
 * CDDL HEADER START
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     3
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     4
 * The contents of this file are subject to the terms of the
5891
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
     5
 * Common Development and Distribution License (the "License").
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
     6
 * You may not use this file except in compliance with the License.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     7
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     8
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     9
 * or http://www.opensolaris.org/os/licensing.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    10
 * See the License for the specific language governing permissions
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    11
 * and limitations under the License.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    12
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    13
 * When distributing Covered Code, include this CDDL HEADER in each
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    14
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    15
 * If applicable, add the following below this CDDL HEADER, with the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    16
 * fields enclosed by brackets "[]" replaced with your own identifying
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    17
 * information: Portions Copyright [yyyy] [name of copyright owner]
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    18
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    19
 * CDDL HEADER END
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    20
 */
5891
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    21
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    22
/*
5891
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    23
 * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    24
 * Use is subject to license terms.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    25
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    26
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    27
/*	Copyright (c) 1988 AT&T	*/
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    28
/*	  All Rights Reserved  	*/
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    29
6812
febeba71273d PSARC 2008/309 expunge synonyms.h
raf
parents: 5891
diff changeset
    30
#pragma ident	"%Z%%M%	%I%	%E% SMI"
febeba71273d PSARC 2008/309 expunge synonyms.h
raf
parents: 5891
diff changeset
    31
5891
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    32
/*
6812
febeba71273d PSARC 2008/309 expunge synonyms.h
raf
parents: 5891
diff changeset
    33
 * All of the wait*() functions are cancellation points.
5891
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    34
 */
6812
febeba71273d PSARC 2008/309 expunge synonyms.h
raf
parents: 5891
diff changeset
    35
#pragma weak _waitpid = waitpid
febeba71273d PSARC 2008/309 expunge synonyms.h
raf
parents: 5891
diff changeset
    36
#pragma weak _wait = wait
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    37
6812
febeba71273d PSARC 2008/309 expunge synonyms.h
raf
parents: 5891
diff changeset
    38
#include "lint.h"
5891
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    39
#include <unistd.h>
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    40
#include <string.h>
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    41
#include <errno.h>
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    42
#include <wait.h>
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    43
#include <sys/types.h>
5891
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    44
#include <sys/siginfo.h>
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    45
#include <sys/times.h>
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    46
#include <sys/resource.h>
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    47
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    48
/*
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    49
 * Convert the siginfo_t code and status fields to an old style wait status.
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    50
 */
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    51
static int
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    52
wstat(int code, int status)
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    53
{
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    54
	int stat = (status & 0377);
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    55
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    56
	switch (code) {
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    57
	case CLD_EXITED:
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    58
		stat <<= 8;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    59
		break;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    60
	case CLD_DUMPED:
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    61
		stat |= WCOREFLG;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    62
		break;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    63
	case CLD_KILLED:
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    64
		break;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    65
	case CLD_TRAPPED:
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    66
	case CLD_STOPPED:
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    67
		stat <<= 8;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    68
		stat |= WSTOPFLG;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    69
		break;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    70
	case CLD_CONTINUED:
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    71
		stat = WCONTFLG;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    72
		break;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    73
	}
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    74
	return (stat);
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    75
}
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    76
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    77
pid_t
5891
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
    78
waitpid(pid_t pid, int *stat_loc, int options)
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    79
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    80
	idtype_t idtype;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    81
	id_t id;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    82
	siginfo_t info;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    83
	int error;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    84
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    85
	if (pid > 0) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    86
		idtype = P_PID;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    87
		id = pid;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    88
	} else if (pid < -1) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    89
		idtype = P_PGID;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    90
		id = -pid;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    91
	} else if (pid == -1) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    92
		idtype = P_ALL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    93
		id = 0;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    94
	} else {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    95
		idtype = P_PGID;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    96
		id = getpgid(0);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    97
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    98
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    99
	options |= (WEXITED|WTRAPPED);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   100
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   101
	if ((error = waitid(idtype, id, &info, options)) < 0)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   102
		return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   103
5891
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   104
	if (stat_loc)
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   105
		*stat_loc = wstat(info.si_code, info.si_status);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   106
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   107
	return (info.si_pid);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   108
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   109
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   110
pid_t
5891
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   111
wait(int *stat_loc)
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   112
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   113
	return (waitpid(-1, stat_loc, 0));
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   114
}
5891
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   115
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   116
pid_t
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   117
wait4(pid_t pid, int *stat_loc, int options, struct rusage *rp)
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   118
{
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   119
	struct tms	before_tms;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   120
	struct tms	after_tms;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   121
	siginfo_t	info;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   122
	int		error;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   123
	int		noptions;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   124
	idtype_t	idtype;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   125
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   126
	if (rp)
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   127
		(void) memset(rp, 0, sizeof (struct rusage));
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   128
	(void) memset(&info, 0, sizeof (siginfo_t));
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   129
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   130
	if (times(&before_tms) == (clock_t)-1)
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   131
		return (-1);		/* errno is set by times() */
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   132
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   133
	/*
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   134
	 * SunOS's wait4() previously supported only WNOHANG &
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   135
	 * WUNTRACED.  XPG4v2 mandates that wait3() (which calls
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   136
	 * wait4()) also support WCONTINUED.
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   137
	 */
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   138
	if (options & ~(WNOHANG|WUNTRACED|WCONTINUED)) {
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   139
		errno = EINVAL;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   140
		return (-1);
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   141
	}
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   142
	noptions = options | WEXITED | WTRAPPED;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   143
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   144
	/*
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   145
	 * Emulate undocumented 4.x semantics for 1186845
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   146
	 */
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   147
	if (pid < 0) {
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   148
		pid = -pid;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   149
		idtype = P_PGID;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   150
	} else if (pid == 0) {
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   151
		idtype = P_ALL;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   152
	} else {
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   153
		idtype = P_PID;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   154
	}
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   155
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   156
	error = waitid(idtype, pid, &info, noptions);
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   157
	if (error == 0) {
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   158
		clock_t diffu;	/* difference in usertime (ticks) */
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   159
		clock_t diffs;	/* difference in systemtime (ticks) */
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   160
		clock_t hz;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   161
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   162
		if ((options & WNOHANG) && info.si_pid == 0)
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   163
			return (0);	/* no child found */
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   164
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   165
		if (rp) {
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   166
			if (times(&after_tms) == (clock_t)-1)
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   167
				return (-1);	/* errno set by times() */
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   168
			/*
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   169
			 * The system/user time is an approximation only !!!
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   170
			 */
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   171
			diffu = after_tms.tms_cutime - before_tms.tms_cutime;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   172
			diffs = after_tms.tms_cstime - before_tms.tms_cstime;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   173
			hz = CLK_TCK;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   174
			rp->ru_utime.tv_sec = diffu / hz;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   175
			rp->ru_utime.tv_usec = (diffu % hz) * (1000000 / hz);
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   176
			rp->ru_stime.tv_sec = diffs / hz;
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   177
			rp->ru_stime.tv_usec = (diffs % hz) * (1000000 / hz);
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   178
		}
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   179
		if (stat_loc)
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   180
			*stat_loc = wstat(info.si_code, info.si_status);
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   181
		return (info.si_pid);
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   182
	} else {
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   183
		return (-1);		/* error number is set by waitid() */
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   184
	}
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   185
}
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   186
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   187
pid_t
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   188
wait3(int *stat_loc, int options, struct rusage *rp)
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   189
{
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   190
	return (wait4(0, stat_loc, options, rp));
0d5c6468bb04 6598890 cancellation code abuses synonyms
raf
parents: 0
diff changeset
   191
}