|
NAMEdtrace_udp —
a DTrace provider for tracing events related to the UDP
protocol
SYNOPSISudp:::receive (pktinfo_t
*, csinfo_t *,
ipinfo_t *,
udpsinfo_t *,
udpinfo_t *);
DESCRIPTIONThe DTraceudp provider allows users to trace events in
the udp(4)
protocol implementation. The udp:::send () probe fires
whenever the kernel prepares to transmit a UDP packet, and the
udp:::receive () probe fires whenever the kernel
receives a UDP packet, unless the UDP header is incomplete, the destination
port is 0, the length field is invalid, or the checksum is wrong. The
arguments to these probes can be used to obtain detailed information about the
IP and UDP headers of the corresponding packet.
ARGUMENTSThe pktinfo_t argument is currently unimplemented and is included for compatibility with other implementations of this provider. Its fields are:
The csinfo_t argument is currently unimplemented and is included for compatibility with other implementations of this provider. Its fields are:
The ipinfo_t argument contains IP fields common to both IPv4 and IPv6 packets. Its fields are:
The udpsinfo_t argument contains the state of the UDP connection associated with the packet. Its fields are:
The udpinfo_t argument is the raw UDP header of the packet, with all fields in host order. Its fields are:
FILES
EXAMPLESThe following script counts transmitted packets by destination port.udp:::send { @num[args[4]->udp_dport] = count(); } This script will print some details of each UDP packet as it is sent or received by the kernel: #pragma D option quiet #pragma D option switchrate=10Hz dtrace:::BEGIN { printf(" %10s %36s %-36s %6s\n", "DELTA(us)", "SOURCE", "DEST", "BYTES"); last = timestamp; } udp:::send { this->elapsed = (timestamp - last) / 1000; self->dest = strjoin(strjoin(args[2]->ip_daddr, ":"), lltostr(args[4]->udp_dport)); printf(" %10d %30s:%-5d -> %-36s %6d\n", this->elapsed, args[2]->ip_saddr, args[4]->udp_sport, self->dest, args[4]->udp_length); last = timestamp; } udp:::receive { this->elapsed = (timestamp - last) / 1000; self->dest = strjoin(strjoin(args[2]->ip_saddr, ":"), lltostr(args[4]->udp_sport)); printf(" %10d %30s:%-5d <- %-36s %6d\n", this->elapsed, args[2]->ip_daddr, args[4]->udp_dport, self->dest, args[4]->udp_length); last = timestamp; } COMPATIBILITYThis provider is compatible with theudp provider in
Solaris.
SEE ALSOdtrace(1), dtrace_ip(4), dtrace_sctp(4), dtrace_tcp(4), dtrace_udplite(4), udp(4), SDT(9)HISTORYTheudp provider first appeared in
FreeBSD 10.0.
AUTHORSThis manual page was written by Mark Johnston <markj@FreeBSD.org>.
Visit the GSP FreeBSD Man Page Interface. |