#!/usr/bin/perl
#
# $Name: V6LC_4_0_1 $
#
# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
# Yokogawa Electric 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: v6LC_1_3_2_D.seq,v 1.1 2006/04/26 01:54:11 akisada Exp $
#
########################################################################
BEGIN { $V6evalTool::TestVersion = '$Name: V6LC_4_0_1 $'; }
use V6evalTool;
use CommonSPEC;
$discard_te = $CommonSPEC::exceed_max;
$delay = $CommonSPEC::exceed_max;
# wait time for ICMP Time Exceeded (sec.)
$exceed_min = $CommonSPEC::exceed_min;
# wait time of ICMP Time Exceeded (sec.)
$pktdesc{'echo_request_1st'} = 'Send Echo Request (1st fragment)';
$pktdesc{'echo_reply'} = 'Recv Echo Reply';
$pktdesc{'time_exceeded_1st'} = 'Recv ICMPv6 Time Exceeded (1st fragment)';
$endStatus = $V6evalTool::exitPass;
#----- create Fragment ID
$id = time & 0x00000fff;
$fid = sprintf("0x0%07x", $id);
$rid = sprintf("0x0%03x", $id);
$sno = 0;
vCPP("-DFRAG_ID=$fid -DREQ_ID=$rid -DSEQ_NO=$sno");
################################################################
$IF = 'Link0';
vCapture($IF);
#======================================================================
if (setup11_v6LC_1_3_2($IF) != $CommonSPEC::Success) {
$ret = cleanup($IF);
if ($ret == $CommonSPEC::Success) {
exit($V6evalTool::exitFail);
} else {
exit($V6evalTool::exitFatal);
}
}
#======================================================================
#
# 7. TN1 transmits Fragment A.1
# with a source address of TN1's Link-local address
# and a destination address set to the NUT's Link-local address.
#
vSend($IF, 'echo_request_1st');
#
# 8. Observe the packets transmitted by the NUT.
#
($recv_time, %ret) = nr_vRecv_EN($IF, $delay, 'time_exceeded_1st');
if ($ret{'status'} == 0) {
# if ($recv_time > $exceed_min) {
vLogHTML('OK
');
# } else {
# vLogHTML("Exceed too fast ($recv_time sec.)
");
# vLogHTML('NG
');
# $endStatus = $V6evalTool::exitFail;
# }
} else {
vLogHTML('Cannot receive ICMP Time Exceeded message
');
vLogHTML('NG
');
vSleep($discard_te, "Discard Unexpected 'ICMP Time Exceeded' message ($discard_te sec)");
$endStatus = $V6evalTool::exitFail;
}
#----- end test
$ret = cleanup_v6LC_1_3_2_D($IF);
vStop($IF);
if ($ret == $CommonSPEC::Success) {
exit($endStatus);
} else {
exit($V6evalTool::exitFatal);
}
######################################################################
__END__
=head1 NAME
v6LC_1_3_2_D - Reassembly Time Exceeded (Time Exceeded (Link-local), Only First Fragment Received)
=head1 TARGET
Host and Router
=head1 SYNOPSIS
=begin html
v6LC_1_3_2_D.seq [-tooloption ...] -pkt v6LC_1_3_2_D.def
-tooloption : v6eval tool option
=end html
=head1 INITIALIZATION
Perform Common Test Setup 1.1
=head1 TEST PROCEDURE
Tester Target
| |
|-------------------------->|
| Echo Request (1st) |
| |
| |
| wait for 65 sec. |
| |
| |
|<--------------------------|
| Neighbor Solicitation |
| |
|-------------------------->|
| Neighbor Advertisement |
| |
|<--------------------------|
| ICMP Error |
| |
| |
v v
1. Send Echo Request (1st fragment)
2. Wait ICMP Error for 65 seconds
If NS received then send NA, and wait ICMP Error again
3. Receive ICMP Error
Echo Request Data (original) is:
IPv6 Header
Version = 6
Traffic Class = 0
FlowLabel = 0
PayloadLength = 88
NextHeader = 58 (ICMPv6)
SourceAddress = Tester Link-local Address
DestinationAddress = Target Link-local Address
ICMP Echo Request
Type = 128 (Echo Request)
Code = 0
Checksum = (auto)
Identifier = (auto)
SequenceNumber = 0
PayloadData = data repeat{0x1, 40}
data repeat{0x2, 40}
Echo Request Data (1st fragment) is:
IPv6 Header
Version = 6
Traffic Class = 0
FlowLabel = 0
PayloadLength = 40
NextHeader = 44 (Fragment Header)
SourceAddress = Tester Link-local Address
DestinationAddress = Target Link-local Address
Fragment Header
NextHeader = 58 (ICMPv6)
FragmentOffset = 0
MFlag = 1
Identification = 32bit (Automatic generation)
Payload
data = 32 octets from the head of ICMP Echo request
=head1 JUDGEMENT
PASS: receive ICMPv6 Time Exceeded message, 60 seconds after reception of 1st Fragment
IPv6 Header
Version = 6
Traffic Class = 0
FlowLabel = 0
PayloadLength = 88
NextHeader = 58 (ICMPv6)
SourceAddress = Target Link-local Address
Destination Address = Tester Link-local Address
ICMP Echo Reply
Type = 3 (Time Exceeded)
Code = 1 (Fragment reassembly time exceeded)
Checksum = (auto)
Reserved = 0
PayloadData = (Sent Packet (1st))
=cut
# =head1 REFERENCE
#
# RFC2460
#
# 4.5 Fragment Header
#
# The following error conditions may arise when reassembling fragmented
# packets:
#
# =begin html
# # If insufficient fragments are received to complete reassembly of a # packet within 60 seconds of the reception of the first-arriving # fragment of that packet, reassembly of that packet must be # abandoned and all the fragments that have been received for that # packet must be discarded. If the first fragment (i.e., the one # with a Fragment Offset of zero) has been received, an ICMP Time # Exceeded -- Fragment Reassembly Time Exceeded message should be # sent to the source of that fragment. ## # =end html # # If the length of a fragment, as derived from the fragment packet's # Payload Length field, is not a multiple of 8 octets and the M flag # of that fragment is 1, then that fragment must be discarded and an # ICMP Parameter Problem, Code 0, message should be sent to the # source of the fragment, pointing to the Payload Length field of # the fragment packet. # # If the length and offset of a fragment are such that the Payload # Length of the packet reassembled from that fragment would exceed # 65,535 octets, then that fragment must be discarded and an ICMP # Parameter Problem, Code 0, message should be sent to the source of # the fragment, pointing to the Fragment Offset field of the # fragment packet. # # The following conditions are not expected to occur, but are not # considered errors if they do: # # The number and content of the headers preceding the Fragment # header of different fragments of the same original packet may # differ. Whatever headers are present, preceding the Fragment # header in each fragment packet, are processed when the packets # arrive, prior to queueing the fragments for reassembly. Only # those headers in the Offset zero fragment packet are retained in # the reassembled packet. # # The Next Header values in the Fragment headers of different # fragments of the same original packet may differ. Only the value # from the Offset zero fragment packet is used for reassembly. # =pod =head1 REFERENCE =begin html
=end html =head1 SEE ALSO perldoc V6evalTool =cutRFC 2460 - IPv6 Specification