#!/usr/bin/perl
#
# Copyright (C) 1999,2000 Yokogawa Electric Corporation and
# YDC Corporation.
# All rights reserved.
#
# Redistribution and use of this software in source and binary
# forms, with or without modification, are permitted provided that
# the following conditions and disclaimer are agreed and accepted
# by the user:
#
# 1. Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
#
# 2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in
# the documentation and/or other materials provided with
# the distribution.
#
# 3. Neither the names of the copyrighters, the name of the project
# which is related to this software (hereinafter referred to as
# "project") nor the names of the contributors may be used to
# endorse or promote products derived from this software without
# specific prior written permission.
#
# 4. No merchantable use may be permitted without prior written
# notification to the copyrighters.
#
# 5. The copyrighters, the project and the contributors may prohibit
# the use of this software at any time.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHTERS, THE PROJECT AND
# CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING
# BUT NOT LIMITED THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
# FOR A PARTICULAR PURPOSE, ARE DISCLAIMED. IN NO EVENT SHALL THE
# COPYRIGHTERS, THE PROJECT OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
# INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
# STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
# IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
# POSSIBILITY OF SUCH DAMAGE.
#
# $Id: hostRecvRedirectInvalid.seq,v 1.1.1.1 2000/10/31 22:39:34 sekiya Exp $
########################################################################
BEGIN { $V6evalTool::TestVersion = '$Name: $ '; }
use V6evalTool;
use nd;
use hostRedirect;
ndOptions(@ARGV);
# The following generate debugging messages.
$nd::debug=$ndOpt_v|$ndOpt_vv;
# You can specifies debug optons to a remote control program.
# If you want to know more detail, please see the following:
# - V6evalTool.pm: perldoc V6evalTool
# - V6evalRemote.pm: perldoc V6evalRemote
$nd::remote_debug="-o1" if $ndOpt_vv;
$IF=Link0;
$exit_rtn=$V6evalTool::exitPass;
$idx=0;
$wait_delay=$nd::DELAY_FIRST_PROBE_TIME+1;
$wait_probe=$nd::RETRANS_TIMER * $nd::MAX_UNICAST_SOLICIT;
#
#
#
$type=$V6evalTool::NutDef{Type};
if($type eq router) {
vLogHTML("This test is for the host only
");
exit $V6evalTool::exitHostOnly;
}
$type=$V6evalTool::NutDef{Type};
if($type ne host) {
vLogHTML(ndErrmsg("ERROR: $V6evalTool::NutDef{Type}: ".
"Unknown target type
"));
exit $V6evalTool::exitFail;
}
# sub test definition:
# - sending pattern,
# - SLLA vs cached LLA
# - expected state
# - message
#
$idx_ptn=0;
$idx_lla=1;
$idx_exp=2;
$idx_msg=3;
$idx_inc_ip=4;
$idx_prb_ip=5;
$idx_rpy_ip=6;
$idx_ign_ip=7;
$idx_non_n=8;
$idx_rpy_n=9;
$idx_ign_n=10;
$idx_stl_sr=11;
$idx_ign_sr=12;
@null=();
#
@def_RDredirect_rone2nut_tll_invalid_globalsrc=
(
RDredirect_rone2nut_tll_invalid_globalsrc,
same,
NONCE,
'Redirect w/ TLL, src=global (INVALID)',
\@null, \@null, \@null, \@null,
\@null, \@null, \@null,
\@null, \@null
);
#
@def_RDredirect_rone2nut_tll_invalid_hoplimit=
(
RDredirect_rone2nut_tll_invalid_hoplimit,
same,
NONCE,
'Redirect w/ TLL, hop limit!=255 (INVALID)',
\@null, \@null, \@null, \@null,
\@null, \@null, \@null,
\@null, \@null
);
#
@def_RDredirect_rone2nut_tll_invalid_icmpcode=
(
RDredirect_rone2nut_tll_invalid_icmpcode,
same,
NONCE,
'Redirect w/ TLL, icmp code!=0 (INVALID)',
\@null, \@null, \@null, \@null,
\@null, \@null, \@null,
\@null, \@null
);
#
@def_RDredirect_rone2nut_tll_invalid_chksum=
(
RDredirect_rone2nut_tll_invalid_chksum,
same,
NONCE,
'Redirect w/ TLL, checksum!=valid (INVALID)',
\@null, \@null, \@null, \@null,
\@null, \@null, \@null,
\@null, \@null
);
#
@def_RDredirect_rone2nut_tll_invalid_icmpdst=
(
RDredirect_rone2nut_tll_invalid_icmpdst,
same,
NONCE,
'Redirect w/ TLL, icmp dst=multicast (INVALID)',
\@null, \@null, \@null, \@null,
\@null, \@null, \@null,
\@null, \@null
);
#
@def_RDredirect_rone2nut_tll_invalid_router=
(
RDredirect_rone2nut_tll_invalid_router,
same,
NONCE,
'Redirect w/ TLL, src!=valid router (INVALID)',
\@null, \@null, \@null, \@null,
\@null, \@null, \@null,
\@null, \@null
);
#
#
#
@defs=
(
\@def_RDredirect_rone2nut_tll_invalid_globalsrc,
\@def_RDredirect_rone2nut_tll_invalid_hoplimit,
\@def_RDredirect_rone2nut_tll_invalid_icmpcode,
\@def_RDredirect_rone2nut_tll_invalid_chksum,
\@def_RDredirect_rone2nut_tll_invalid_icmpdst,
\@def_RDredirect_rone2nut_tll_invalid_router,
);
#
#
#
vCapture($IF);
#
#
#
$idx=0;
foreach(@defs) {
$exp=@$_[$idx_exp];
$msg=@$_[$idx_msg];
vLogHTML("
TN NUT ----------------------=end html =head1 TEST PROCEDURE B
State: NONCE (for R1, TN)
==== unsolicited RA ===> src=R1's link-local dst=all-node M=0, O=0 RouterLifetime=600 ReachableTime=0 RetransTimer=0 w/ SLLA Prefix Option: L=1, A=1 ValidLifetime=2592000 PreferredLifetime=604800 Prefix=3ffe:501:ffff:100::/64
State: STALE (for R1), NONCE (for TN)
==== solicited NA ===> src=R1's link-local dst=NUT's link-local R=1, S=1, O=1 target=R1's link-local TLLA=R1's LLA
State: REACHABLE (for R1), NONCE (for TN)
Wait (3 sec) for DAD NS
TN NUT ----------------------=end html =head1 JUDGMENT =begin html
State: REACHABLE (for R1), NONCE (for TN)
==== invalid redirect ===> ICMP Target=TN's link-local
Judgment: Examining NUT's neighbor cache state is NONCE
1. Invalid redirect messages=end html =head1 TERMINATION Send RA with RouterLifetime=0 to clear the Default Router List. =head1 NOTE The test does not invoke any remote command. =head1 SEE ALSO perldoc V6evalTool perldoc V6evalRemote =cut
8.1. Validation of Redirect Messages
A host MUST silently discard any received Redirect message that does not satisfy all of the following validity checks:
- IP Source Address is a link-local address. Routers must use their link-local address as the source for Router Advertisement and Redirect messages so that hosts can uniquely identify routers.
- The IP Hop Limit field has a value of 255, i.e., the packet could not possibly have been forwarded by a router.
- If the message includes an IP Authentication Header, the message authenticates correctly.
- ICMP Checksum is valid.
- ICMP Code is 0.
- ICMP length (derived from the IP length) is 40 or more octets.
- The IP source address of the Redirect is the same as the current first-hop router for the specified ICMP Destination Address.
- The ICMP Destination Address field in the redirect message does not contain a multicast address.
- The ICMP Target Address is either a link-local address (when redirected to a router) or the same as the ICMP Destination Address (when redirected to the on-link destination).
- All included options have a length that is greater than zero.
================+================+=========+====+========+==========+===============+=========== IP |ICMP |NC state ----------------+----------------+---------+----+--------+----------+---------------+-----+----- Src |Dst |Hop Limit|Code|Chksum |Dst |Target |Now |New ================+================+=========+====+========+==========+===============+=========== *R1's global |NUT's link-local|255 |0 |valid |off-link |TN's link-local|NONCE|NONCE ----------------+----------------+---------+----+--------+----------+---------------+-----+---- R1's link-local |NUT's link-local|*!=255 |0 |valid |off-link |TN's link-local|NONCE|NONCE ----------------+----------------+---------+----+--------+----------+---------------+-----+----- R1's link-local |NUT's link-local|255 |*!=0|valid |off-link |TN's link-local|NONCE|NONCE ----------------+----------------+---------+----+--------+----------+---------------+-----+----- R1's link-local |NUT's link-local|255 |0 |*invalid|off-link |TN's link-local|NONCE|NONCE ----------------+----------------+---------+----+--------+----------+---------------+-----+----- R1's link-local |NUT's link-local|255 |0 |valid |*multicast|TN's link-local|NONCE|NONCE ----------------+----------------+---------+----+--------+----------+---------------+-----+----- *R2's link-local|NUT's link-local|255 |0 |valid |off-link |NT's link-local|NONCE|NONCE ----------------+----------------+---------+----+--------+----------+---------------+-----+----- R1's link-local |NUT's link-local|255 |0 |valid |*off-link |*TN's global |NONCE|NONCE ================+================+=========+====+========+==========+===============+===========