10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# CDDL HEADER START
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# The contents of this file are subject to the terms of the
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# Common Development and Distribution License (the "License").
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# You may not use this file except in compliance with the License.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# See the License for the specific language governing permissions
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# and limitations under the License.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# When distributing Covered Code, include this CDDL HEADER in each
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# If applicable, add the following below this CDDL HEADER, with the
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# fields enclosed by brackets "[]" replaced with your own identifying
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# information: Portions Copyright [yyyy] [name of copyright owner]
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# CDDL HEADER END
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire# Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# Test ip:::{send,receive} of IPv4 UDP to a local address.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# This may fail due to:
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# 1. A change to the ip stack breaking expected probe behavior,
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# which is the reason we are testing.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# 2. No physical network interface is plumbed and up.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# 3. No other hosts on this subnet are reachable and listening on rpcbind.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# 4. An unlikely race causes the unlocked global send/receive
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# variables to be corrupted.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# This test sends a UDP message using ping and checks that at least the
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# following counts were traced:
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# 1 x ip:::send (UDP sent to ping's base UDP port)
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire# 1 x udp:::send (UDP sent to ping's base UDP port)
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# 1 x ip:::receive (UDP received)
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire# No udp:::receive event is expected as the response ping -U elicits is
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire# an ICMP PORT_UNREACHABLE response rather than a UDP packet, and locally
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire# the echo request UDP packet only reaches IP, so the udp:::receive probe
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire# is not triggered by it.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan$dtrace -c "/usr/sbin/ping -U $local" -qs /dev/stdin <<EOF | grep -v 'is alive'
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire ipsend = udpsend = ipreceive = 0;
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan/args[2]->ip_saddr == "$local" && args[2]->ip_daddr == "$local" &&
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan args[4]->ipv4_protocol == IPPROTO_UDP/
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire/args[2]->ip_saddr == "$local" && args[2]->ip_daddr == "$local"/
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanip:::receive
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan/args[2]->ip_saddr == "$local" && args[2]->ip_daddr == "$local" &&
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan args[4]->ipv4_protocol == IPPROTO_UDP/
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire ipreceive++;
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan printf("Minimum UDP events seen\n\n");
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire printf("ip:::send - %s\n", ipsend >= 1 ? "yes" : "no");
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire printf("ip:::receive - %s\n", ipreceive >= 1 ? "yes" : "no");
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire printf("udp:::send - %s\n", udpsend >= 1 ? "yes" : "no");