#!/usr/bin/perl # # $Copyright_v6PC$ # # $Copyright$ # # $TAHI: ct/spec/FH_1stOnly.seq,v 1.26 2004/04/02 03:47:50 kenta Exp $ # ###################################################################### BEGIN { $V6evalTool::TestVersion = '$Name: $'; } use V6evalTool; %pktdesc = ( echo_request => 'Send Echo Request (Preparation)', echo_reply => 'Recv Echo Reply', ns => 'Recv Neighbor Solicitation', na => 'Send Neighbor Advertisement', echo_request_1st => 'Send Echo Request (1st fragment only)', time_exceeded_1st => 'Recv ICMP Error (Time Exceeded, fragment reassembly time exceeded)', unicast_ns => 'Recv Unicast Neighbor Solicitation', unicast_ns_wsll => 'Recv Unicast Neighbor Solicitation (without SLL)', ); %nd = ( 'ns' => 'Recv Neighbor Solicitation', 'unicast_ns' => 'Recv Unicast Neighbor Solicitation', 'unicast_ns_wsll'=> 'Recv Unicast Neighbor Solicitation (without SLL)', ); $loop_count = 65; $IF = Link0; vCapture($IF); #----- preparation vLogHTML('Begin Preparation'); vSend($IF, echo_request); %ret = vRecv($IF, 5, 0, 0, ns, echo_reply); if ($ret{status} != 0) { vLogHTML('NG'); exit $V6evalTool::exitFail; } if ($ret{recvFrame} eq 'ns') { vSend($IF, na); %ret = vRecv($IF, 5, 0, 0, echo_reply); if ($ret{status} != 0) { vLogHTML('NG'); exit $V6evalTool::exitFail; } } if ($ret{recvFrame} ne 'echo_reply') { vLogHTML('NG'); exit $V6evalTool::exitFail; } vLogHTML('End Preparation'); #----- main test vSend($IF, echo_request_1st); # timeout for($i=0; $i< $loop_count; $i ++){ %ret = vRecv($IF, 1, 0, 0, sort(keys(%nd)), time_exceeded_1st); if ($ret{status} == 0 && $ret{recvFrame} eq 'time_exceeded_1st') { last; } $count = $ret{'recvCount'}; while(($recv, $send) = each(%nd)){ if ($ret{recvFrame} eq $recv) { vSend($IF, na); $i --; $count --; last; } } if($count){ vLogHTML('NG'); exit $V6evalTool::exitFail; } } if ($ret{status} == 0 && $ret{recvFrame} eq 'time_exceeded_1st') { vLogHTML('OK'); exit $V6evalTool::exitPass; } if(!$count){ vLogHTML('OK
'); vLogHTML('the fragments that have been received for that packet was discarded'); exit $V6evalTool::exitPass; } vLogHTML('NG'); exit $V6evalTool::exitFail; ###################################################################### __END__ =head1 NAME FH_1stOnly - check Fragment Reassembly (1st fragment only) =head1 TARGET Host and Router =head1 SYNOPSIS =begin html
  FH_1stOnly.seq [-tooloption ...] -pkt Fragment.def
    -tooloption : v6eval tool option
=end html =head1 INITIALIZATION 1. Ping to Target (create Neighbor Cache Entries, if not exist) 2. Override Neighbor Cache Entries =head1 TEST PROCEDURE Tester Target | | |-------------------------->| | Echo Request (1st) | | | | | |(<------------------------)| | No Packet | | or | |<--------------------------| | ICMP Error | | | | | v v 1. Send Echo Request (1st fragment) 2. Wait ICMP Error (timeout = 60 sec) 3. No packets from Target or Received ICMP Error(should) Echo Request Data (original) is: IPv6 Header Version = 6 Traffic Class = 0 FlowLabel = 0 PayloadLength = 1032 NextHeader = 58 (ICMP) 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, 512} data repeat{0x2, 512} Echo Request Data (1st fragment) is: IPv6 Header Version = 6 Traffic Class = 0 FlowLabel = 0 PayloadLength = 528 NextHeader = 44 (Fragment Header) SourceAddress = Tester Link Local Address DestinationAddress = Target Link Local Address Fragment Header NextHeader = 58 (ICMP) FragmentOffset = 0 MFlag = 1 Identification = 32bit (Automatic generation) Payload data = 520 octets from the head of ICMP Echo request =head1 JUDGMENT PASS: No packet from Target or PASS: ICMP Error Received IPv6 Header Version = 6 Traffic Class = 0 FlowLabel = 0 PayloadLength = 16 NextHeader = 58 (ICMP) SourceAddress = Target Link Local Address Destination Address = Tester Link Local Address ICMP Error Type = 3 (Time Exceeded) Code = 1 (fragment reassembly time exceeded) Checksum = (auto) PayloadData = (As much of Echo Request as will fit without the ICMPv6 packet exceeding the minimum IPv6 MTU) =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

=head1 SEE ALSO

  perldoc V6evalTool

=cut