10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#!/usr/bin/ksh
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# CDDL HEADER START
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
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#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# or http://www.opensolaris.org/os/licensing.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# See the License for the specific language governing permissions
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# and limitations under the License.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
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#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# CDDL HEADER END
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire# Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire# Test {udp,ip}:::{send,receive} of IPv4 UDP to a remote host.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# This may fail due to:
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
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#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# This test sends a UDP message using ping and checks that at least the
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# following counts were traced:
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
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#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanif (( $# != 1 )); then
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan print -u2 "expected one argument: <dtrace-path>"
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan exit 2
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanfi
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendandtrace=$1
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendangetaddr=./get.ipv4remote.pl
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanif [[ ! -x $getaddr ]]; then
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan print -u2 "could not find or execute sub program: $getaddr"
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan exit 3
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanfi
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan$getaddr | read source dest
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanif (( $? != 0 )); then
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan exit 4
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanfi
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan$dtrace -c "/usr/sbin/ping -U $dest" -qs /dev/stdin <<EOF | grep -v 'is alive'
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanBEGIN
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan{
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire ipsend = udpsend = 0;
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan}
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanip:::send
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan/args[2]->ip_saddr == "$source" && args[2]->ip_daddr == "$dest" &&
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan args[4]->ipv4_protocol == IPPROTO_UDP/
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan{
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire ipsend++;
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire}
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguireudp:::send
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire/args[2]->ip_saddr == "$source" && args[2]->ip_daddr == "$dest"/
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire{
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire udpsend++;
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan}
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanEND
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan{
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan printf("Minimum UDP events seen\n\n");
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire printf("ip:::send - %s\n", ipsend >= 1 ? "yes" : "no");
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire printf("udp:::send - %s\n", udpsend >= 1 ? "yes" : "no");
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan}
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanEOF