Print this page
4474 DTrace Userland CTF Support
4475 DTrace userland Keyword
4476 DTrace tests should be better citizens
4479 pid provider types
4480 dof emulation missing checks
Reviewed by: Bryan Cantrill <bryan@joyent.com>
Split |
Close |
Expand all |
Collapse all |
--- old/usr/src/cmd/dtrace/test/tst/common/usdt/tst.reap.ksh
+++ new/usr/src/cmd/dtrace/test/tst/common/usdt/tst.reap.ksh
1 1 #
2 2 # CDDL HEADER START
3 3 #
4 4 # The contents of this file are subject to the terms of the
5 5 # Common Development and Distribution License (the "License").
6 6 # You may not use this file except in compliance with the License.
7 7 #
8 8 # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 9 # or http://www.opensolaris.org/os/licensing.
10 10 # See the License for the specific language governing permissions
11 11 # and limitations under the License.
12 12 #
13 13 # When distributing Covered Code, include this CDDL HEADER in each
14 14 # file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 15 # If applicable, add the following below this CDDL HEADER, with the
16 16 # fields enclosed by brackets "[]" replaced with your own identifying
17 17 # information: Portions Copyright [yyyy] [name of copyright owner]
18 18 #
19 19 # CDDL HEADER END
20 20 #
21 21
22 22 #
23 23 # Copyright (c) 2011, Joyent, Inc. All rights reserved.
24 24 #
25 25
26 26 if [ $# != 1 ]; then
27 27 echo expected one argument: '<'dtrace-path'>'
28 28 exit 2
29 29 fi
30 30
31 31 dtrace=$1
32 32 DIR=/var/tmp/dtest.$$
33 33
34 34 mkdir $DIR
35 35 cd $DIR
36 36
37 37 cat > test.c <<EOF
38 38 #include <unistd.h>
39 39 #include <sys/sdt.h>
40 40
41 41 int
42 42 main(int argc, char **argv)
43 43 {
↓ open down ↓ |
43 lines elided |
↑ open up ↑ |
44 44 DTRACE_PROBE(test_prov, probe1);
45 45 }
46 46 EOF
47 47
48 48 cat > prov.d <<EOF
49 49 provider test_prov {
50 50 probe probe1();
51 51 };
52 52 EOF
53 53
54 -gcc -c test.c
54 +gcc -m32 -c test.c
55 55 if [ $? -ne 0 ]; then
56 56 print -u2 "failed to compile test.c"
57 57 exit 1
58 58 fi
59 59 $dtrace -G -32 -s prov.d test.o
60 60 if [ $? -ne 0 ]; then
61 61 print -u2 "failed to create DOF"
62 62 exit 1
63 63 fi
64 -gcc -o test test.o prov.o
64 +
65 +gcc -m32 -o test test.o prov.o
65 66 if [ $? -ne 0 ]; then
66 67 print -u2 "failed to link final executable"
67 68 exit 1
68 69 fi
69 70
70 71 script()
71 72 {
72 73 $dtrace -Zwqs /dev/stdin <<EOF
73 74 test_prov*:::
74 75 {
75 76 probeid = id;
76 77 }
77 78
78 79 tick-1sec
79 80 /probeid == 0/
80 81 {
81 82 printf("launching test\n");
82 83 system("./test");
83 84 }
84 85
85 86 tick-1sec
86 87 /probeid != 0/
87 88 {
88 89 printf("attempting re-enabling\n");
89 90 system("dtrace -e -x errtags -i %d", probeid);
90 91 attempts++;
91 92 }
92 93
93 94 tick-1sec
94 95 /attempts > 10/
95 96 {
96 97 exit(0);
97 98 }
98 99 EOF
99 100 }
100 101
101 102 script 2>&1 | tee test.out
102 103
103 104 #
104 105 # It should be true that our probe was reaped over the course of the enabling,
105 106 # causing the embedded DTrace invocation to fail on an invalid probe (that is,
106 107 # D_PDESC_INVAL) instead of an inability to grab the underlying process
107 108 # (D_PROC_GRAB).
108 109 #
109 110 grep D_PDESC_INVAL test.out 2> /dev/null 1>&2
110 111 status=$?
111 112
112 113 cd /
113 114 /usr/bin/rm -rf $DIR
114 115
115 116 exit $status
↓ open down ↓ |
41 lines elided |
↑ open up ↑ |
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX