1 /*
2  * CDDL HEADER START
3  *
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.
7  *
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.
12  *
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]
18  *
19  * CDDL HEADER END
20  */
21 
22 /*
23  * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
24  * Use is subject to license terms.
25  */
26 
27 /*
28  * ASSERTION: Make sure nfsv3 provider probes are firing, and that the
29  * arguments are properly visible.
30  *
31  * SECTION: nfs3 provider
32  */
33 
34 #pragma D option destructive
35 #pragma D option quiet
36 
37 pid$1:a.out:waiting:entry
38 {
39 	this->value = (int *)alloca(sizeof (int));
40 	*this->value = 1;
41 	copyout(this->value, arg0, sizeof (int));
42 }
43 
44 nfsv3:::op-getattr-start
45 {
46 	printf("ci_local: %s\n", args[0]->ci_local);
47 	printf("ci_remote: %s\n", args[0]->ci_remote);
48 	printf("ci_protocol: %s\n", args[0]->ci_protocol);
49 
50 	printf("noi_xid: %d\n", args[1]->noi_xid);
51 	printf("noi_cred->cr_uid: %d\n", args[1]->noi_cred->cr_uid);
52 	printf("noi_curpath: %s\n", args[1]->noi_curpath);
53 
54 	printf("fh3_flags: %d\n", args[2]->object.fh3_flags);
55 }
56 
57 nfsv3:::op-getattr-done
58 {
59 	printf("ci_local: %s\n", args[0]->ci_local);
60 	printf("ci_remote: %s\n", args[0]->ci_remote);
61 	printf("ci_protocol: %s\n", args[0]->ci_protocol);
62 
63 	printf("noi_xid: %d\n", args[1]->noi_xid);
64 	printf("noi_cred->cr_uid: %d\n", args[1]->noi_cred->cr_uid);
65 	printf("noi_curpath: %s\n", args[1]->noi_curpath);
66 
67 	printf("status: %d\n", args[2]->status);
68 }
69 
70 nfsv3:::*-done
71 /seen[probename] == 0/
72 {
73 	++numberseen;
74 	seen[probename] = 1;
75 	printf("%d ops seen, latest op is %s\n", numberseen, probename);
76 }
77 
78 nfsv3:::*-done
79 /numberseen == 22/
80 {
81 	exit(0);
82 }
83 
84 tick-1s
85 /tick++ == 10/
86 {
87 	printf("%d nfsv3 ops seen; should be 22\n", numberseen);
88 	exit(1);
89 }
90