Move /var/svc/log to /var/log/svc
[unleashed/lotheac.git] / usr / src / cmd / dtrace / test / tst / common / pid / tst.fork.d
blobf1b119785c972b500807690fa7bf958e459124a9
1 /*
2 * CDDL HEADER START
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]
19 * CDDL HEADER END
23 * Copyright 2007 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
27 #pragma ident "%Z%%M% %I% %E% SMI"
30 * ASSERTION: make sure fork(2) is okay
32 * SECTION: pid provider
35 #pragma D option destructive
37 pid$1:a.out:waiting:entry
39 this->value = (int *)alloca(sizeof (int));
40 *this->value = 1;
41 copyout(this->value, arg0, sizeof (int));
44 proc:::create
45 /pid == $1/
47 child = args[0]->pr_pid;
48 trace(pid);
51 pid$1:a.out:go:
52 /pid == child/
54 trace("wrong pid");
55 exit(1);
58 proc:::exit
59 /pid == $1 || pid == child/
61 out++;
62 trace(pid);
65 proc:::exit
66 /out == 2/
68 exit(0);
72 BEGIN
75 * Let's just do this for 5 seconds.
77 timeout = timestamp + 5000000000;
80 profile:::tick-4
81 /timestamp > timeout/
83 trace("test timed out");
84 exit(1);