#!/usr/bin/perl
#
# $Name: V6LC_P2_1_4_3 $
#
# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006
# 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: mcastOne.seq,v 1.5 2005/04/11 09:05:56 akisada Exp $
#
######################################################################
BEGIN {
$V6evalTool::TestVersion = '$Name: V6LC_P2_1_4_3 $';
}
use V6evalTool;
use CommonPMTU;
use lib '../';
use AdvancedFunctionality;
if (!$AdvancedFunctionality::TRANSMITTING_EREQ) {
exit($V6evalTool::exitSkip);
}
$pktdesc{'echo_request_mc1500'} = 'Recv multicast Echo Request (Packet size is 1500)';
$pktdesc{'echo_request_mc1400'} = 'Recv multicast Echo Request (Packet size is 1400)';
$pktdesc{'PktTooBig'} = 'Send Packet Too Big message';
$pktdesc{'PktTooBig_others'} = 'Send Packet Too Big message';
$endStatus = $V6evalTool::exitPass;
$IF = 'Link0';
$NUTdev = $V6evalTool::NutDef{'Link0_device'};
#fake data
$packet_len = 0;
$hoplimit = 0;
$ping_cs = 0;
$ping_id = 0;
$ping_sn = 0;
$frag_m = 0;
$frag_id = 0;
$ping_pl = 0;
#decrease value of MTU
$MTU_decrea = 50;
vCapture($IF);
#======================================================================
if (setup11($IF) != $CommonPMTU::Success) {
$ret = cleanup($IF);
if ($ret == $CommonPMTU::Success) {
exit($V6evalTool::exitFail);
} else {
exit($V6evalTool::exitFatal);
}
}
#======================================================================
#----- test
$max_mtu = 1500;
#-----------------------------------------NUT send 1st Echo Request
#----- create fragment pkt.def
$MTU_value = $max_mtu; #MTU value, fixed
$PKT_size = 1500; #this size is IPv6 pakcet size.,1280,1400,1500 etc
$frag_start = 48; #1280 or 48 #should be 48
$data_size_1st = $frag_start - 40 - 8;
$data_size_2nd = ($PKT_size - 40) - $data_size_1st;
#define packet format
$header_ether = '_hether_nut2mc';
$ip_src = 'NUT_GL0_ADDR';
$ip_dst = 'GL_MCAST_ADDR';
$def_file = 'pkt_frag.def'; #fragment define file
#write def file
if(writefragdef_req($def_file, $MTU_value, $PKT_size,$data_size_1st,$data_size_2nd, $header_ether, $ip_src, $ip_dst ) != $CommonPMTU::Success) {
exit($V6evalTool::exitFatal);
}
vCPP("-DFRAG_DEF");
vLogHTML('NUT send 1st Echo Request to Multicast Destination
');
vClear($IF);
vRemote('ping6.rmt', "size=1452 addr=FF1E::1:2 if=$NUTdev");
%ret = nd_vRecv_EN($IF, $CommonPMTU::wait_reply, 0, 0, 'echo_request_mc1500',@CommonPMTU::req_fragment_1st_name);
if ($ret{'status'} == 0) {
$packet_len = 0;
if($ret{'recvFrame'} eq 'echo_request_mc1500'){
vLogHTML('OK
');
$packet_flag ='echo_request';
$packet_len = $ret{"Frame_Ether.Packet_IPv6.Hdr_IPv6.PayloadLength"} + 40;
$hoplimit = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.HopLimit'});
$ping_cs = sprintf('0x%04x', $ret{'Frame_Ether.Packet_IPv6.ICMPv6_EchoRequest.Checksum'});
$ping_id = sprintf('0x%04x', $ret{'Frame_Ether.Packet_IPv6.ICMPv6_EchoRequest.Identifier'});
$ping_sn = sprintf('0x%04x', $ret{'Frame_Ether.Packet_IPv6.ICMPv6_EchoRequest.SequenceNumber'});
$ping_pl = $ret{'Frame_Ether.Packet_IPv6.ICMPv6_EchoRequest.Payload.data'};
}
else{
vLogHTML('OK. recive 1st fragment.
');
$pkt_name = $ret{'recvFrame'};
$pkt_name =~ /^echo_request(\d+)_1st_(\d+)$/;
$size_2nd_frag = $1-$2-40;
$name_2nd_frag = "echo_request$1"."_2nd_$size_2nd_frag";
#get ipv6 packet length
$packet_len = $ret{"Frame_Ether.Packet_IPv6.Hdr_IPv6.PayloadLength"} + 40;
$hoplimit = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.HopLimit'});
$frag_id = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.Identification'});
$frag_m = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.MFlag'});
$ping_pl = $ret{'Frame_Ether.Packet_IPv6.Payload.data'};
%ret = nd_vRecv_EN($IF, $CommonPMTU::wait_reply, 0, 0, "$name_2nd_frag");
if ($ret{'status'} == 0) {
vLogHTML('OK. recive 2nd fragment.
');
#get ipv6 packet length
$packet_len_2nd = $ret{"Frame_Ether.Packet_IPv6.Hdr_IPv6.PayloadLength"} + 40;
if($packet_len < $packet_len_2nd){
$packet_len = $packet_len_2nd;
$hoplimit = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.HopLimit'});
$frag_id = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.Identification'});
$frag_m = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.MFlag'});
$ping_pl = $ret{'Frame_Ether.Packet_IPv6.Payload.data'};
}
}
else {
vLogHTML('NG. can\'t recive 2nd fragment.
');
$endStatus = $V6evalTool::exitFail;
}
}
}else {
vLogHTML('Cannot receive Echo Request
');
vLogHTML('NG
');
$endStatus = $V6evalTool::exitFail;
}
unlink($def_file);
#create payload def file
open(FH, "> payload_data.def") or die("cannot create def file");
print FH "Payload payloadRef {\n";
print FH "\tdata = {";
for ($j = 0; $j < length($ping_pl); $j += 2) {
print FH '0x', substr($ping_pl, $j, 2);
print FH ', ' if ($j < length($ping_pl) - 2);
print FH "\n\t\t" if ($j % 16 == 14);
}
print FH "};\n";
print FH "}\n";
close(FH);
#send Packet Too Big message
if($packet_len > 1280){
if($packet_len >= 1450){
vCPP("-DPAYLOAD_DATA -DHLIM=$hoplimit -DMPING_CS=$ping_cs -DMPING_ID=$ping_id -DMPING_SEQ=$ping_sn -DFRAG_ID=$frag_id -DFRAG_M=$frag_m -DPTB_MTU=1450");
if($packet_flag eq 'echo_request'){
vSend($IF, 'PktTooBig');
}else{
vSend($IF, 'PktTooBig_others');
}
$max_mtu = 1450;
}
else{
vCPP("-DPAYLOAD_DATA -DHLIM=$hoplimit -DMPING_CS=$ping_cs -DMPING_ID=$ping_id -DMPING_SEQ=$ping_sn -DFRAG_ID=$frag_id -DFRAG_M=$frag_m -DPTB_MTU=$packet_len");
if($packet_flag eq 'echo_request'){
vSend($IF, 'PktTooBig');
}else{
vSend($IF, 'PktTooBig_others');
}
$max_mtu = $packet_len;
}
}else{
$max_mtu = 1280;
vLogHTML('Cannot send Packet Too Big message
');
}
#unlink("payload_data.def");
#------------------------------------NUT send 2nd Echo Request
if($max_mtu > 1280){
#----- create fragment pkt.def
$MTU_value = $max_mtu; #MTU value, fixed
$PKT_size = 1500; #this size is IPv6 pakcet size.,1280,1400,1500 etc
$frag_start = 48; #1280 or 48 #should be 48
$data_size_1st = $frag_start - 40 - 8;
$data_size_2nd = ($PKT_size - 40) - $data_size_1st;
#define packet format
$header_ether = '_hether_nut2mc';
$ip_src = 'NUT_GL0_ADDR';
$ip_dst = 'GL_MCAST_ADDR';
$def_file = 'pkt_frag.def'; #fragment define file
#write def file
if(writefragdef_req($def_file, $MTU_value, $PKT_size,$data_size_1st,$data_size_2nd, $header_ether, $ip_src, $ip_dst ) != $CommonPMTU::Success) {
exit($V6evalTool::exitFatal);
}
vCPP("-DFRAG_DEF");
vLogHTML('NUT send 2nd Echo Request to Multicast Destination
');
vClear($IF);
vRemote('ping6.rmt', "size=1452 addr=FF1E::1:2 if=$NUTdev");
%ret = nd_vRecv_EN($IF, $CommonPMTU::wait_reply, 0, 0, @CommonPMTU::req_fragment_1st_name);
if ($ret{'status'} == 0) {
vLogHTML('OK. recive 1st fragment.
');
$pkt_name = $ret{'recvFrame'};
$pkt_name =~ /^echo_request(\d+)_1st_(\d+)$/;
$size_2nd_frag = $1-$2-40;
$name_2nd_frag = "echo_request$1"."_2nd_$size_2nd_frag";
#get ipv6 packet length
$packet_len = $ret{"Frame_Ether.Packet_IPv6.Hdr_IPv6.PayloadLength"} + 40;
$hoplimit = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.HopLimit'});
$frag_id = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.Identification'});
$frag_m = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.MFlag'});
$ping_pl = $ret{'Frame_Ether.Packet_IPv6.Payload.data'};
%ret = nd_vRecv_EN($IF, $CommonPMTU::wait_reply, 0, 0, "$name_2nd_frag");
if ($ret{'status'} == 0) {
vLogHTML('OK. recive 2nd fragment.
');
#get ipv6 packet length
$packet_len_2nd = $ret{"Frame_Ether.Packet_IPv6.Hdr_IPv6.PayloadLength"} + 40;
if($packet_len < $packet_len_2nd){
$packet_len = $packet_len_2nd;
$hoplimit = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.HopLimit'});
$frag_id = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.Identification'});
$frag_m = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.MFlag'});
$ping_pl = $ret{'Frame_Ether.Packet_IPv6.Payload.data'};
}
}
else {
vLogHTML('NG. can\'t recive 2nd fragment.
');
$endStatus = $V6evalTool::exitFail;
}
}else {
vLogHTML('Cannot receive Echo Request
');
vLogHTML('NG
');
$endStatus = $V6evalTool::exitFail;
}
unlink($def_file);
#create payload def file
open(FH, "> payload_data.def") or die("cannot create def file");
print FH "Payload payloadRef {\n";
print FH "\tdata = {";
for ($j = 0; $j < length($ping_pl); $j += 2) {
print FH '0x', substr($ping_pl, $j, 2);
print FH ', ' if ($j < length($ping_pl) - 2);
print FH "\n\t\t" if ($j % 16 == 14);
}
print FH "};\n";
print FH "}\n";
close(FH);
#send Packet Too Big message
if($packet_len > 1280){
if($packet_len >= 1400){
vCPP("-DPAYLOAD_DATA -DHLIM=$hoplimit -DMPING_CS=$ping_cs -DMPING_ID=$ping_id -DMPING_SEQ=$ping_sn -DFRAG_ID=$frag_id -DFRAG_M=$frag_m -DPTB_MTU=1400");
vSend($IF, 'PktTooBig_others');
$max_mtu = 1400;
}
else{
$packet_len = $packet_len - $MTU_decrea;
vCPP("-DPAYLOAD_DATA -DHLIM=$hoplimit -DMPING_CS=$ping_cs -DMPING_ID=$ping_id -DMPING_SEQ=$ping_sn -DFRAG_ID=$frag_id -DFRAG_M=$frag_m -DPTB_MTU=$packet_len");
vSend($IF, 'PktTooBig_others');
$max_mtu = $packet_len;
}
}else{
$max_mtu = 1280;
vLogHTML('Cannot send Packet Too Big message
');
}
#unlink("payload_data.def");
}else{
vLogHTML('NUT does not send 2nd Echo Request to Multicast Destination
');
}
#------------------------------------------NUT send 3rd echo Requset
if($max_mtu > 1280){
#----- create fragment pkt.def
$MTU_value = $max_mtu; #MTU value, fixed
$PKT_size = 1500; #this size is IPv6 pakcet size.,1280,1400,1500 etc
$frag_start = 48; #1280 or 48 #should be 48
$data_size_1st = $frag_start - 40 - 8;
$data_size_2nd = ($PKT_size - 40) - $data_size_1st;
#define packet format
$header_ether = '_hether_nut2mc';
$ip_src = 'NUT_GL0_ADDR';
$ip_dst = 'GL_MCAST_ADDR';
$def_file = 'pkt_frag.def'; #fragment define file
#write def file
if(writefragdef_req($def_file, $MTU_value, $PKT_size,$data_size_1st,$data_size_2nd, $header_ether, $ip_src, $ip_dst ) != $CommonPMTU::Success) {
exit($V6evalTool::exitFatal);
}
vCPP("-DFRAG_DEF");
vLogHTML('NUT send 3rd Echo Request to Multicast Destination
');
vClear($IF);
vRemote('ping6.rmt', "size=1452 addr=FF1E::1:2 if=$NUTdev");
%ret = nd_vRecv_EN($IF, $CommonPMTU::wait_reply, 0, 0, @CommonPMTU::req_fragment_1st_name);
if ($ret{'status'} == 0) {
vLogHTML('OK. recive 1st fragment.
');
$pkt_name = $ret{'recvFrame'};
$pkt_name =~ /^echo_request(\d+)_1st_(\d+)$/;
$size_2nd_frag = $1-$2-40;
$name_2nd_frag = "echo_request$1"."_2nd_$size_2nd_frag";
%ret = nd_vRecv_EN($IF, $CommonPMTU::wait_reply, 0, 0, "$name_2nd_frag");
if ($ret{'status'} == 0) {
vLogHTML('OK. recive 2nd fragment.
');
}
else {
vLogHTML('NG. can\'t recive 2nd fragment.
');
$endStatus = $V6evalTool::exitFail;
}
}else {
vLogHTML('Cannot receive Echo Request
');
vLogHTML('NG
');
$endStatus = $V6evalTool::exitFail;
}
unlink($def_file);
}else{
vLogHTML('NUT does not send 3rd Echo Request to Multicast Destination
');
}
#-----------------------------------------NUT send 4th Echo Request
#----- create fragment pkt.def
$MTU_value = $max_mtu; #MTU value, fixed
$PKT_size = 1400; #this size is IPv6 pakcet size.,1280,1400,1500 etc
$frag_start = 48; #1280 or 48 #should be 48
$data_size_1st = $frag_start - 40 - 8;
$data_size_2nd = ($PKT_size - 40) - $data_size_1st;
#define packet format
$header_ether = '_hether_nut2mc';
$ip_src = 'NUT_GL0_ADDR';
$ip_dst = 'GL_MCAST_ADDR';
$def_file = 'pkt_frag.def'; #fragment define file
#write def file
if(writefragdef_req($def_file, $MTU_value, $PKT_size,$data_size_1st,$data_size_2nd, $header_ether, $ip_src, $ip_dst ) != $CommonPMTU::Success) {
exit($V6evalTool::exitFatal);
}
vCPP("-DFRAG_DEF");
vLogHTML('NUT send 4th Echo Request to Multicast Destination
');
vClear($IF);
vRemote('ping6.rmt', "size=1352 addr=FF1E::1:2 if=$NUTdev");
%ret = nd_vRecv_EN($IF, $CommonPMTU::wait_reply, 0, 0, 'echo_request_mc1400',@CommonPMTU::req_fragment_1st_name);
if ($ret{'status'} == 0) {
$packet_len = 0;
if($ret{'recvFrame'} eq 'echo_request_mc1400'){
vLogHTML('OK
');
$packet_flag ='echo_request';
$packet_len = $ret{"Frame_Ether.Packet_IPv6.Hdr_IPv6.PayloadLength"} + 40;
$hoplimit = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.HopLimit'});
$ping_cs = sprintf('0x%04x', $ret{'Frame_Ether.Packet_IPv6.ICMPv6_EchoRequest.Checksum'});
$ping_id = sprintf('0x%04x', $ret{'Frame_Ether.Packet_IPv6.ICMPv6_EchoRequest.Identifier'});
$ping_sn = sprintf('0x%04x', $ret{'Frame_Ether.Packet_IPv6.ICMPv6_EchoRequest.SequenceNumber'});
$ping_pl = $ret{'Frame_Ether.Packet_IPv6.ICMPv6_EchoRequest.Payload.data'};
}
else{
vLogHTML('OK. recive 1st fragment.
');
$pkt_name = $ret{'recvFrame'};
$pkt_name =~ /^echo_request(\d+)_1st_(\d+)$/;
$size_2nd_frag = $1-$2-40;
$name_2nd_frag = "echo_request$1"."_2nd_$size_2nd_frag";
#get ipv6 packet length
$packet_len = $ret{"Frame_Ether.Packet_IPv6.Hdr_IPv6.PayloadLength"} + 40;
$hoplimit = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.HopLimit'});
$frag_id = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.Identification'});
$frag_m = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.MFlag'});
$ping_pl = $ret{'Frame_Ether.Packet_IPv6.Payload.data'};
%ret = nd_vRecv_EN($IF, $CommonPMTU::wait_reply, 0, 0, "$name_2nd_frag");
if ($ret{'status'} == 0) {
vLogHTML('OK. recive 2nd fragment.
');
#get ipv6 packet length
$packet_len_2nd = $ret{"Frame_Ether.Packet_IPv6.Hdr_IPv6.PayloadLength"} + 40;
if($packet_len < $packet_len_2nd){
$packet_len = $packet_len_2nd;
$hoplimit = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.HopLimit'});
$frag_id = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.Identification'});
$frag_m = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.MFlag'});
$ping_pl = $ret{'Frame_Ether.Packet_IPv6.Payload.data'};
}
}
else {
vLogHTML('NG. can\'t recive 2nd fragment.
');
$endStatus = $V6evalTool::exitFail;
}
}
}else {
vLogHTML('Cannot receive Echo Request
');
vLogHTML('NG
');
$endStatus = $V6evalTool::exitFail;
}
unlink($def_file);
#create payload def file
open(FH, "> payload_data.def") or die("cannot create def file");
print FH "Payload payloadRef {\n";
print FH "\tdata = {";
for ($j = 0; $j < length($ping_pl); $j += 2) {
print FH '0x', substr($ping_pl, $j, 2);
print FH ', ' if ($j < length($ping_pl) - 2);
print FH "\n\t\t" if ($j % 16 == 14);
}
print FH "};\n";
print FH "}\n";
close(FH);
#send Packet Too Big message
if($packet_len > 1280){
if($packet_len >= 1300){
vCPP("-DPAYLOAD_DATA -DHLIM=$hoplimit -DMPING_CS=$ping_cs -DMPING_ID=$ping_id -DMPING_SEQ=$ping_sn -DFRAG_ID=$frag_id -DFRAG_M=$frag_m -DPTB_MTU=1300");
if($packet_flag eq 'echo_request'){
vSend($IF, 'PktTooBig');
}else{
vSend($IF, 'PktTooBig_others');
}
$max_mtu = 1300;
}
else{
$packet_len = $packet_len - $MTU_decrea;
vCPP("-DPAYLOAD_DATA -DHLIM=$hoplimit -DMPING_CS=$ping_cs -DMPING_ID=$ping_id -DMPING_SEQ=$ping_sn -DFRAG_ID=$frag_id -DFRAG_M=$frag_m -DPTB_MTU=$packet_len");
if($packet_flag eq 'echo_request'){
vSend($IF, 'PktTooBig');
}else{
vSend($IF, 'PktTooBig_others');
}
$max_mtu = $packet_len;
}
}else{
$max_mtu = 1280;
vLogHTML('Cannot send Packet Too Big message
');
}
#unlink("payload_data.def");
#------------------------------------NUT send 5th Echo Request
if($max_mtu > 1280){
#----- create fragment pkt.def
$MTU_value = $max_mtu; #MTU value, fixed
$PKT_size = 1400; #this size is IPv6 pakcet size.,1280,1400,1500 etc
$frag_start = 48; #1280 or 48 #should be 48
$data_size_1st = $frag_start - 40 - 8;
$data_size_2nd = ($PKT_size - 40) - $data_size_1st;
#define packet format
$header_ether = '_hether_nut2mc';
$ip_src = 'NUT_GL0_ADDR';
$ip_dst = 'GL_MCAST_ADDR';
$def_file = 'pkt_frag.def'; #fragment define file
#write def file
if(writefragdef_req($def_file, $MTU_value, $PKT_size,$data_size_1st,$data_size_2nd, $header_ether, $ip_src, $ip_dst ) != $CommonPMTU::Success) {
exit($V6evalTool::exitFatal);
}
vCPP("-DFRAG_DEF");
vLogHTML('NUT send 5th Echo Request to Multicast Destination
');
vClear($IF);
vRemote('ping6.rmt', "size=1352 addr=FF1E::1:2 if=$NUTdev");
%ret = nd_vRecv_EN($IF, $CommonPMTU::wait_reply, 0, 0, @CommonPMTU::req_fragment_1st_name);
if ($ret{'status'} == 0) {
vLogHTML('OK. recive 1st fragment.
');
$pkt_name = $ret{'recvFrame'};
$pkt_name =~ /^echo_request(\d+)_1st_(\d+)$/;
$size_2nd_frag = $1-$2-40;
$name_2nd_frag = "echo_request$1"."_2nd_$size_2nd_frag";
#get ipv6 packet length
$packet_len = $ret{"Frame_Ether.Packet_IPv6.Hdr_IPv6.PayloadLength"} + 40;
$hoplimit = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.HopLimit'});
$frag_id = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.Identification'});
$frag_m = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.MFlag'});
$ping_pl = $ret{'Frame_Ether.Packet_IPv6.Payload.data'};
%ret = nd_vRecv_EN($IF, $CommonPMTU::wait_reply, 0, 0, "$name_2nd_frag");
if ($ret{'status'} == 0) {
vLogHTML('OK. recive 2nd fragment.
');
#get ipv6 packet length
$packet_len_2nd = $ret{"Frame_Ether.Packet_IPv6.Hdr_IPv6.PayloadLength"} + 40;
if($packet_len < $packet_len_2nd){
$packet_len = $packet_len_2nd;
$hoplimit = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.HopLimit'});
$frag_id = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.Identification'});
$frag_m = sprintf('0x%02x', $ret{'Frame_Ether.Packet_IPv6.Hdr_Fragment.MFlag'});
$ping_pl = $ret{'Frame_Ether.Packet_IPv6.Payload.data'};
}
}
else {
vLogHTML('NG. can\'t recive 2nd fragment.
');
$endStatus = $V6evalTool::exitFail;
}
}else {
vLogHTML('Cannot receive Echo Request
');
vLogHTML('NG
');
$endStatus = $V6evalTool::exitFail;
}
unlink($def_file);
#create payload def file
open(FH, "> payload_data.def") or die("cannot create def file");
print FH "Payload payloadRef {\n";
print FH "\tdata = {";
for ($j = 0; $j < length($ping_pl); $j += 2) {
print FH '0x', substr($ping_pl, $j, 2);
print FH ', ' if ($j < length($ping_pl) - 2);
print FH "\n\t\t" if ($j % 16 == 14);
}
print FH "};\n";
print FH "}\n";
close(FH);
}else{
vLogHTML('NUT does not send 5th Echo Request to Multicast Destination
');
}
#send Packet Too Big message
vCPP("-DPAYLOAD_DATA -DHLIM=$hoplimit -DMPING_CS=$ping_cs -DMPING_ID=$ping_id -DMPING_SEQ=$ping_sn -DFRAG_ID=$frag_id -DFRAG_M=$frag_m -DPTB_MTU=1350");
vSend($IF, 'PktTooBig_others');
unlink("payload_data.def");
#------------------------------------------NUT send 6th Echo Request
#----- create fragment pkt.def
$MTU_value = $max_mtu; #MTU value, fixed
$PKT_size = 1400; #this size is IPv6 pakcet size.,1280,1400,1500 etc
$frag_start = 48; #1280 or 48 #should be 48
$data_size_1st = $frag_start - 40 - 8;
$data_size_2nd = ($PKT_size - 40) - $data_size_1st;
#define packet format
$header_ether = '_hether_nut2mc';
$ip_src = 'NUT_GL0_ADDR';
$ip_dst = 'GL_MCAST_ADDR';
$def_file = 'pkt_frag.def'; #fragment define file
#write def file
if(writefragdef_req($def_file, $MTU_value, $PKT_size,$data_size_1st,$data_size_2nd, $header_ether, $ip_src, $ip_dst ) != $CommonPMTU::Success) {
exit($V6evalTool::exitFatal);
}
vCPP("-DFRAG_DEF");
vLogHTML('NUT send 6th Echo Request to Multicast Destination
');
vClear($IF);
vRemote('ping6.rmt', "size=1352 addr=FF1E::1:2 if=$NUTdev");
%ret = nd_vRecv_EN($IF, $CommonPMTU::wait_reply, 0, 0, @CommonPMTU::req_fragment_1st_name);
if ($ret{'status'} == 0) {
vLogHTML('OK. recive 1st fragment.
');
$pkt_name = $ret{'recvFrame'};
$pkt_name =~ /^echo_request(\d+)_1st_(\d+)$/;
$size_2nd_frag = $1-$2-40;
$name_2nd_frag = "echo_request$1"."_2nd_$size_2nd_frag";
%ret = nd_vRecv_EN($IF, $CommonPMTU::wait_reply, 0, 0, "$name_2nd_frag");
if ($ret{'status'} == 0) {
vLogHTML('OK. recive 2nd fragment.
');
}
else {
vLogHTML('NG. can\'t recive 2nd fragment.
');
$endStatus = $V6evalTool::exitFail;
}
}else {
vLogHTML('Cannot receive Echo Request
');
vLogHTML('NG
');
$endStatus = $V6evalTool::exitFail;
}
unlink($def_file);
#----- end test
$ret = cleanup($IF);
vStop($IF);
if ($ret == $CommonPMTU::Success) {
exit($endStatus);
} else {
exit($V6evalTool::exitFatal);
}
######################################################################
__END__
=head1 NAME
mcastOne - Verify that a node properly chooses the PMTU for multicast
destinations when receiveng PTB messages from more than one router.
=head1 TARGET
Host and Router
=head1 SYNOPSIS
=begin html
mcastOne.seq [-tooloption ...] -pkt mcastOne.def
-tooloption : v6eval tool option
=end html
=head1 INITIALIZATION
If the NUT is a host, send a Router Advertisment.
If the NUT is a router, configure a default route with TN as the next hop.
And make state of Neighbor Cashe Entry for TN's addresses reachable.
=head1 TEST PROCEDURE
TR1 NUT
| |
|<--------------------------|
| 1.Echo Request |
| (1500 octets) |
| |
|-------------------------->|
| 2.Packet Too Big |
| (MTU is 1450) |
| |
|<--------------------------|
| 3.Fragmented Echo Request |
| (1st + 2nd = 1500) |
| |
|-------------------------->|
| 4.Packet Too Big |
| (MTU is 1400) |
| |
|<--------------------------|
| 5.Fragmented Echo Request |
| (1st + 2nd = 1500) |
| |
|<--------------------------|
| 6.Echo Request |
| (1400 octets) |
| |
|-------------------------->|
| 7.Packet Too Big |
| (MTU is 1300) |
| |
|<--------------------------|
| 8.Fragmented Echo Reply |
| (1st + 2nd = 1400) |
| |
|-------------------------->|
| 9.Packet Too Big |
| (MTU is 1350) |
| |
|<--------------------------|
| 10.Fragmented Echo Reply |
| (1st + 2nd = 1400) |
| |
v v
1. Receive Echo Request <=end html =head1 SEE ALSO perldoc V6evalTool =cutRFC 1981 - Path MTU Discovery for IPv6