#!/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: F_Reassembly_reverse.seq,v 1.4 2005/04/11 08:27:21 akisada Exp $
#
######################################################################
BEGIN {
$V6evalTool::TestVersion = '$Name: V6LC_4_0_1 $';
}
use V6evalTool;
use CommonSPEC;
$discard_te = $CommonSPEC::exceed_max;
$pktdesc{'echo_request_1st'} = 'Send Echo Request (1st fragment)';
$pktdesc{'echo_request_2nd'} = 'Send Echo Request (2nd fragment)';
$pktdesc{'echo_request_3rd'} = 'Send Echo Request (3rd fragment)';
$pktdesc{'echo_reply'} = 'Recv Echo Reply';
$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);
#----- test
vSend($IF, 'echo_request_3rd');
vSend($IF, 'echo_request_2nd');
vSend($IF, 'echo_request_1st');
%ret = nd_vRecv_EN($IF, $CommonSPEC::wait_reply, 0, 0, 'echo_reply');
if ($ret{'status'} == 0) {
vLogHTML('OK
');
} else {
vLogHTML('Cannot receive Echo Reply
');
vLogHTML('NG
');
vSleep($discard_te, "Discard Unexpected 'ICMP Time Exceeded' message ($discard_te sec)");
$endStatus = $V6evalTool::exitFail;
}
#----- end test
$ret = cleanup($IF);
vStop($IF);
if ($ret == $CommonSPEC::Success) {
exit($endStatus);
} else {
exit($V6evalTool::exitFatal);
}
######################################################################
__END__
=head1 NAME
F_Reassembly_reverse - Fragment Reassembly (All Fragments are Valid, reverse order)
=head1 TARGET
Host and Router
=head1 SYNOPSIS
=begin html
F_Reassembly_reverse.seq [-tooloption ...] -pkt F_Reassembly_reverse.def
-tooloption : v6eval tool option
=end html
=head1 INITIALIZATION
None
=head1 TEST PROCEDURE
Tester Target
| |
|-------------------------->|
| Echo Request (3rd) |
| |
|-------------------------->|
| Echo Request (2nd) |
| |
|-------------------------->|
| Echo Request (1st) |
| |
|<--------------------------|
| Neighbor Solicitation |
| |
|-------------------------->|
| Neighbor Advertisement |
| |
|<--------------------------|
| Echo Reply |
| |
| |
v v
1. Send Echo Request (3rd fragment)
2. Send Echo Request (2nd fragment)
3. Send Echo Request (1st fragment)
4. Wait Echo Reply or NS
5. If NS received then send NA, and wait Echo Reply again
6. Receive Echo Reply
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 (3rd fragment) is:
IPv6 Header
Version = 6
Traffic Class = 0
FlowLabel = 0
PayloadLength = 32
NextHeader = 44 (Fragment Header)
SourceAddress = Tester Link Local Address
DestinationAddress = Target Link Local Address
Fragment Header
NextHeader = 58 (ICMPv6)
FragmentOffset = 8
MFlag = 0
Identification = 32bit (Automatic generation)
Payload
data = 24 octets from the back of ICMP Echo request
Echo Request Data (2nd 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 = 4
MFlag = 1
Identification = 32bit (Automatic generation)
Payload
data = 32 octets from the head of ICMP Echo request
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: Echo Reply Received
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 = 129 (Echo Reply)
Code = 0
Checksum = (auto)
Identifier = (same as Echo Request)
SequenceNumber = (same as Echo Request)
PayloadData = (same as Echo Request)
=cut
# =head1 REFERENCE
#
# RFC2460
#
# 4.5 Fragment Header
#
# :
#
# At the destination, fragment packets are reassembled into their
# original, unfragmented form, as illustrated:
#
# reassembled original packet:
#
# +------------------+----------------------//------------------------+
# | Unfragmentable | 2-bit reserved fFragmentablealized to zero for |
# | Part | transmission; ignorePart |
# +------------------+----------------------//------------------------+
#
# The following rules govern reassembly:
#
# An original packet is reassembled only from fragment packets that
# have the same Source Address, Destination Address, and Fragment
# Identification.
#
# The Unfragmentable Part of the reassembled packet consists of all
# headers up to, but not including, the Fragment header of the first
# fragment packet (that is, the packet whose Fragment Offset is
# zero), with the following two changes:
#
# The Next Header field of the last header of the Unfragmentable
# Part is obtained from the Next Header field of the first
# fragment's Fragment header.
#
# The Payload Length of the reassembled packet is computed from
# the length of the Unfragmentable Part and the length and offset
# of the last fragment. For example, a formula for computing the
# Payload Length of the reassembled original packet is:
#
# PL.orig = PL.first - FL.first - 8 + (8 * FO.last) + FL.last
#
# where
# PL.orig = Payload Length field of reassembled packet.
# PL.first = Payload Length field of first fragment packet.
# FL.first = length of fragment following Fragment header of
# first fragment packet.
# FO.last = Fragment Offset field of Fragment header of
# last fragment packet.
# FL.last = length of fragment following Fragment header of
# last fragment packet.
#
# The Fragmentable Part of the reassembled packet is constructed
# from the fragments following the Fragment headers in each of the
# fragment packets. The length of each fragment is computed by
# subtracting from the packet's Payload Length the length of the
# headers between the IPv6 header and fragment itself; its relative
# position in Fragmentable Part is computed from its Fragment Offset
# value.
#
# The Fragment header is not present in the final, reassembled
# packet.
#
=pod
=head1 REFERENCE
=begin html
=end html =head1 SEE ALSO perldoc V6evalTool =cutRFC 2460 - IPv6 Specification