2 .\" Copyright (c) 2004 Sun Microsystems, Inc. All Rights Reserved
3 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License"). You may not use this file except in compliance with the License.
4 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing. See the License for the specific language governing permissions and limitations under the License.
5 .\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE. If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
6 .TH TNFCTL_PROBE_APPLY 3TNF "Mar 1, 2004"
8 tnfctl_probe_apply, tnfctl_probe_apply_ids \- iterate over probes
12 \fBcc\fR [ \fIflag\fR ... ] \fIfile\fR ... \fB-ltnfctl\fR [ \fIlibrary\fR ... ]
13 #include <tnf/tnfctl.h>
15 \fBtnfctl_errcode_t\fR \fBtnfctl_probe_apply\fR(\fBtnfctl_handle_t *\fR\fIhndl\fR,
16 \fBtnfctl_probe_op_t\fR \fIprobe_op\fR, \fBvoid *\fR\fIclientdata\fR);
21 \fBtnfctl_errcode_t\fR \fBtnfctl_probe_apply_ids\fR(\fBtnfctl_handle_t *\fR\fIhndl\fR,
22 \fBulong_t\fR \fIprobe_count\fR, \fBulong_t *\fR\fIprobe_ids\fR,
23 \fBtnfctl_probe_op_t\fR \fIprobe_op\fR, \fBvoid *\fR\fIclientdata\fR);
29 \fBtnfctl_probe_apply()\fR is used to iterate over the probes controlled by
30 \fIhndl.\fR For every probe, the \fIprobe_op\fR function is called:
34 typedef tnfctl_errcode_t (*tnfctl_probe_op_t)(
35 tnfctl_handle_t *hndl,
36 tnfctl_probe_t *probe_hndl,
43 Several predefined functions are available for use as \fIprobe_op\fR. These
44 functions are described in \fBtnfctl_probe_state_get\fR(3TNF).
47 The \fIclientdata\fR supplied in \fBtnfctl_probe_apply()\fR is passed in as the
48 last argument of \fIprobe_op\fR. The \fIprobe_hndl\fR in the probe operation
49 function can be used to query or change the state of the probe. See
50 \fBtnfctl_probe_state_get\fR(3TNF). The \fIprobe_op\fR function should return
51 \fBTNFCTL_ERR_NONE\fR upon success. It can also return an error code, which
52 will cause \fBtnfctl_probe_apply()\fR to stop processing the rest of the probes
53 and return with the same error code. Note that there are five (5) error codes
54 reserved that the client can use for its own semantics. See \fBERRORS\fR.
57 The lifetime of \fIprobe_hndl\fR is the same as the lifetime of \fIhndl\fR. It
58 is good until \fIhndl\fR is closed by \fBtnfctl_close\fR(3TNF). Do not confuse
59 a \fIprobe_hndl\fR with \fIhndl\fR. The \fIprobe_hndl\fR refers to a particular
60 probe, while \fIhndl\fR refers to a process or the kernel. If \fIprobe_hndl\fR
61 is used in another \fBlibtnfctl\fR(3TNF) interface, and it references a probe
62 in a library that has been dynamically closed (see \fBdlclose\fR(3C)), then
63 the error code \fBTNFCTL_ERR_INVALIDPROBE\fR will be returned by that
67 \fBtnfctl_probe_apply_ids()\fR is very similar to \fBtnfctl_probe_apply()\fR.
68 The difference is that \fIprobe_op\fR is called only for probes that match a
69 probe id specified in the array of integers referenced by \fIprobe_ids\fR. The
70 number of probe ids in the array should be specified in \fIprobe_count\fR. Use
71 \fBtnfctl_probe_state_get()\fR to get the \fIprobe_id\fR that corresponds to
72 the \fIprobe_handl\fR.
76 \fBtnfctl_probe_apply()\fR and \fBtnfctl_probe_apply_ids()\fR return
77 \fBTNFCTL_ERR_NONE\fR upon success.
81 The following errors apply to both \fBtnfctl_probe_apply()\fR and
82 \fBtnfctl_probe_apply_ids()\fR:
86 \fB\fBTNFCTL_ERR_INTERNAL\fR\fR
89 An internal error occurred.
95 \fB\fBTNFCTL_ERR_USR1\fR\fR
98 Error code reserved for user.
104 \fB\fBTNFCTL_ERR_USR2\fR\fR
107 Error code reserved for user.
113 \fB\fBTNFCTL_ERR_USR3\fR\fR
116 Error code reserved for user.
122 \fB\fBTNFCTL_ERR_USR4\fR\fR
125 Error code reserved for user.
131 \fB\fBTNFCTL_ERR_USR5\fR\fR
134 Error code reserved for user.
139 \fBtnfctl_probe_apply()\fR and \fBtnfctl_probe_apply_ids()\fR also return any
140 error returned by the callback function \fIprobe_op\fR.
143 The following errors apply only to \fBtnfctl_probe_apply_ids()\fR:
147 \fB\fBTNFCTL_ERR_INVALIDPROBE\fR\fR
150 The probe handle is no longer valid. For example, the probe is in a library
151 that has been closed by \fBdlclose\fR(3C).
156 \fBExample 1 \fREnabling Probes
159 To enable all probes:
164 tnfctl_probe_apply(hndl, tnfctl_probe_enable, NULL);
169 \fBExample 2 \fRDisabling Probes
172 To disable the probes that match a certain pattern in the probe attribute
178 /* To disable all probes that contain the string "vm" */
179 tnfctl_probe_apply(hndl, select_disable, "vm");
180 static tnfctl_errcode_t
181 select_disable(tnfctl_handle_t *hndl, tnfctl_probe_t *probe_hndl,
184 char *pattern = client_data;
185 tnfctl_probe_state_t probe_state;
186 tnfctl_probe_state_get(hndl, probe_hndl, &probe_state);
187 if (strstr(probe_state.attr_string, pattern)) {
188 tnfctl_probe_disable(hndl, probe_hndl, NULL);
196 Note that these examples do not have any error handling code.
201 See \fBattributes\fR(5) for descriptions of the following attributes:
209 ATTRIBUTE TYPE ATTRIBUTE VALUE
217 \fBprex\fR(1), \fBTNF_PROBE\fR(3TNF), \fBdlclose\fR(3C), \fBdlopen\fR(3C),
218 \fBlibtnfctl\fR(3TNF), \fBtnfctl_close\fR(3TNF),
219 \fBtnfctl_probe_state_get\fR(3TNF), \fBtracing\fR(3TNF),
220 \fBtnf_kernel_probes\fR(4), \fBattributes\fR(5)
223 \fILinker and Libraries Guide\fR