#!/usr/bin/perl
#
# $Copyright$
#
# $TAHI: ct/icmp/Time_Exc_Link-Local.seq,v 1.3 2003/10/15 08:06:31 masaxmasa Exp $
#----------------------------------------------------------------------
BEGIN { $V6evalTool::TestVersion = '$Name: $'; }
use V6evalTool;
use icmp;
$IF = Link0;
#----------------------------------------------------------------------
# Initialization
#----------------------------------------------------------------------
vLogHTML("Initialization
");
vCapture($IF);
$ret = mkNCE_Link();
if ($ret != 0) {
vLog("*** NUT can not be initialized !! ***");
exit($V6evalTool::exitFail);
}
else {
vLog("TN created the entry of TN's link-local address to Neighbor cache of NUT.");
};
#----------------------------------------------------------------------
# Check fragment reassembly.
#----------------------------------------------------------------------
%pktdesc = (
echo_request_1st_link_local => 'Send 1st Fragmented Echo Request (Link-local address)',
echo_request_2nd_link_local => 'Send 2nd Fragmented Echo Request (Link-local address)',
echo_reply_link_local_1024 => 'Receive Echo Reply (Link-local address)',
echo_request_1st => 'Send 1st Fragmented Echo Request (Link-local address)',
time_exceeded => 'Receive Time Exceeded (fragment reassembly)',
ns_local => 'Receive Neighbor Solicitation',
ns_local_sll => 'Receive Neighbor Solicitation',
na_local => 'Send Neighbor Advertisement'
);
vLogHTML('Begin check fragment reassembly');
vSend($IF, echo_request_1st_link_local);
vSend($IF, echo_request_2nd_link_local);
#%ret = vRecv($IF, 5, 0, 0, echo_reply_link_local_1024);
%ret = icmp_vRecv($IF, 5, 0, 0, echo_reply_link_local_1024);
if ($ret{status} == 0 && $ret{recvFrame} eq 'echo_reply_link_local_1024') {
vLogHTML('OK
');
}
else {
vLogHTML('Not replied.');
goto error;
};
vLogHTML('End check
');
#----------------------------------------------------------------------
# Test
#----------------------------------------------------------------------
vLogHTML("Test
");
vSend($IF, echo_request_1st);
#%ret = vRecv($IF, 65, 0, 0, time_exceeded, ns_local, ns_local_sll);
%ret = icmp_vRecv($IF, 65, 0, 0, time_exceeded);
if ($ret{status} != 0) {
vLog("TN can not receive ICMPv6 error message from NUT");
goto error;
}
elsif ($ret{recvFrame} eq 'time_exceeded') {
vLog("TN can receive ICMPv6 Time Exceeded message from NUT");
vLog("OK");
exit($V6evalTool::exitPass);
}
elsif ($ret{recvFrame} eq 'ns_local' || $ret{recvFrame} eq 'ns_local_sll') {
vSend($IF, na_local);
%ret = vRecv($IF, 65, 0, 0, time_exceeded);
if ($ret{recvFrame} eq 'time_exceeded') {
vLog("TN can receive ICMPv6 Time Exceeded message from NUT");
vLog("OK");
exit($V6evalTool::exitPass);
}
else {
vLog("TN can not receive ICMPv6 error message from NUT");
goto error;
}
}
else {
vLog("TN receive unexpected packets from NUT");
goto error;
};
error:
vLog("FAIL");
exit($V6evalTool::exitFail);
#----------------------------------------------------------------------
__END__
=head1 NAME
Time_Exc_Link-Local.seq - check Time Exceeded 1 (link local address)
=head1 TARGET
Host/Router
=head1 SYNOPSIS
Time_Exc_Link-Local.seq [-tooloption ...] -p Time_Exc_Link-Local.def
=head1 INITIALIZATION
Before starting test, check NUT's fragment reassembly function.
When test starts, states of Neighbor Cache Entry for TN's
addresses are reachable.
=head1 TEST PROCEDURE
This test verifies that NUT sends valid ICMPv6 Time Exceeded (code 1)
in response to a packet which can not be reassemble.
And this test verifies that the message processing rule ,
(a) If the message is a response to a message sent to one of the
node's unicast addresses, the Source Address of the reply must
be that same address.
TN NUT
---------------------------
1.
=== fragmented (1st) packet ===>
src address : TN link local address
dst address : NUT link local address
2.
<< JUDGMENT >>
<=== ICMPv6 Time Exceeded ===
src address : NUT link local address
dst address : TN link local address
Code is 1
=head1 JUDGMENT
<< PASS >>
NUT send ICMPv6 Time Exceeded.
<< FAIL >>
NUT do not send ICMPv6 Time Exceeded.
=head1 REFERENCE
RFC2463
3.3 Time Exceeded Message
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Type | Code | Checksum |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Unused |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| As much of invoking packet |
+ as will fit without the ICMPv6 packet +
| exceeding the minimum IPv6 MTU [IPv6] |
IPv6 Fields:
=begin html
Destination Address
Copied from the Source Address field of the invoking
packet.
=end html
ICMPv6 Fields:
=begin html
Type 3=end html =begin html
Code 0 - hop limit exceeded in transit=end html Unused This field is unused for all code values. It must be initialized to zero by the sender and ignored by the receiver. Description If a router receives a packet with a Hop Limit of zero, or a router decrements a packet's Hop Limit to zero, it MUST discard the packet and send an ICMPv6 Time Exceeded message with Code 0 to the source of the packet. This indicates either a routing loop or too small an initial Hop Limit value. The rules for selecting the Source Address of this message are defined in section 2.2. =head1 SEE ALSO perldoc V6evalTool =cut
1 - fragment reassembly time exceeded