xref: /titanic_44/usr/src/cmd/dtrace/demo/ip/ipio.d (revision 10e6dadfe63181edabc58c8f42e3c56a1cd9ec95)
1*10e6dadfSbrendan /*
2*10e6dadfSbrendan  * CDDL HEADER START
3*10e6dadfSbrendan  *
4*10e6dadfSbrendan  * The contents of this file are subject to the terms of the
5*10e6dadfSbrendan  * Common Development and Distribution License (the "License").
6*10e6dadfSbrendan  * You may not use this file except in compliance with the License.
7*10e6dadfSbrendan  *
8*10e6dadfSbrendan  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9*10e6dadfSbrendan  * or http://www.opensolaris.org/os/licensing.
10*10e6dadfSbrendan  * See the License for the specific language governing permissions
11*10e6dadfSbrendan  * and limitations under the License.
12*10e6dadfSbrendan  *
13*10e6dadfSbrendan  * When distributing Covered Code, include this CDDL HEADER in each
14*10e6dadfSbrendan  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15*10e6dadfSbrendan  * If applicable, add the following below this CDDL HEADER, with the
16*10e6dadfSbrendan  * fields enclosed by brackets "[]" replaced with your own identifying
17*10e6dadfSbrendan  * information: Portions Copyright [yyyy] [name of copyright owner]
18*10e6dadfSbrendan  *
19*10e6dadfSbrendan  * CDDL HEADER END
20*10e6dadfSbrendan  */
21*10e6dadfSbrendan /*
22*10e6dadfSbrendan  * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
23*10e6dadfSbrendan  * Use is subject to license terms.
24*10e6dadfSbrendan  */
25*10e6dadfSbrendan 
26*10e6dadfSbrendan #pragma D option quiet
27*10e6dadfSbrendan #pragma D option switchrate=10hz
28*10e6dadfSbrendan 
29*10e6dadfSbrendan dtrace:::BEGIN
30*10e6dadfSbrendan {
31*10e6dadfSbrendan 	printf(" %3s %10s %15s    %15s %8s %6s\n", "CPU", "DELTA(us)",
32*10e6dadfSbrendan 	    "SOURCE", "DEST", "INT", "BYTES");
33*10e6dadfSbrendan 	last = timestamp;
34*10e6dadfSbrendan }
35*10e6dadfSbrendan 
36*10e6dadfSbrendan ip:::send
37*10e6dadfSbrendan {
38*10e6dadfSbrendan 	this->elapsed = (timestamp - last) / 1000;
39*10e6dadfSbrendan 	printf(" %3d %10d %15s -> %15s %8s %6d\n", cpu, this->elapsed,
40*10e6dadfSbrendan 	    args[2]->ip_saddr, args[2]->ip_daddr, args[3]->if_name,
41*10e6dadfSbrendan 	    args[2]->ip_plength);
42*10e6dadfSbrendan 	last = timestamp;
43*10e6dadfSbrendan }
44*10e6dadfSbrendan 
45*10e6dadfSbrendan ip:::receive
46*10e6dadfSbrendan {
47*10e6dadfSbrendan 	this->elapsed = (timestamp - last) / 1000;
48*10e6dadfSbrendan 	printf(" %3d %10d %15s <- %15s %8s %6d\n", cpu, this->elapsed,
49*10e6dadfSbrendan 	    args[2]->ip_daddr, args[2]->ip_saddr, args[3]->if_name,
50*10e6dadfSbrendan 	    args[2]->ip_plength);
51*10e6dadfSbrendan 	last = timestamp;
52*10e6dadfSbrendan }
53