zoukankan      html  css  js  c++  java
  • IPv6_1_1_rfc2460_IPv6 Specification

    (Obsoletes RFC 1883, Updated by RFC 5095, RFC 5722, RFC 5871, RFC 6437, RFC 6564, RFC 6935, RFC 6946, RFC 7045, RFC 7112, Errata)

    1: semantics 语义

    2: 1 octet = 8bits = 1byte

    3:  padding 填充

    4: terminology 专门名词, 术语 

    5: encounter:  遇见

    6: algoritms  算法

    7: omit 省略, 遗漏

    一:Introduction

        1. Changes form IPv6 to IPv6.

            1) Expanded Addressing Capabilities

                32 bits to 128 bits to support

                a) more levels of addressing hiearchy

                b) a much greater number of address nodes

                c) simpler auto-configration of address nodes.

                d) add a "scope" field to multicast addresses.

                e) define a new type of addresses called "anycast address" to send a packet to anyone of a group of nodes.

            2) Header Format Simplication

               Drop or make optional  some IPv4 header field.

                a) Reduce the common-case processing cost of packet handling.

                b) limit the bandwidth cost of the IPv6 header.

            3) Improved Support for Extensions and Options

                Changes in the way IP header options

                a) more efficient forwarding.

                b) less stringent limits on the length of options. (选项长度放松)

                c) greater flexibility for introducing new options in the future.

      

            4) Flow Labeling Capability

                a) add a capability to enable the labeling of packets, for which the sender requests special handling,

                    such as non-default quality or "real-time" service.

            5) Authentication and Privacy Capabilities

                a) Extensions to support authentication data integraty (数据完整),

                   optional data confidentiality(数据机密性)

    二、 Terminology

            1: node - a device that implements IPv6.

            2: router - a node that forwards IPv6 packets not explicitly addressed to itself.

            3: host - any node that is not a router.

            4: upper layer - a protocol layer immediatly above IPv6, ICMP, TCP, UDP, OSPF, IPX, AppleTalk or IPv6 intself.

            5. link - a communication facility at the same link.

                        below IPv6.

                        Ethernets(bridged), PPP links, X.25, Frame, Relay.

            6. neighbors - nodes attached to the same link

            7. interface - a node's attachment to a link.

            8. packet - an IPv6 header plus payload.

            9. link MTU - the maximum transmission unit.

                              maximum packet size in octets.

            10. path MTU - the minimum link MTU of all the links in a path between a source node and a destination node.

    三、 IPv6 Header Format  (40 octets)

           8 parts

          a) Version, Traffic class, Flow Label(4, 8, 20)

          b) Payload, Next Header, Hop Limit(16, 8, 8)

          c) Source Address(128).

          d) Destination Address(128). 

        1: Version - 4 bits

        2: Traffic Class -8 bits

        3: Flow Label -20 bits

        4: Payload -16 bits     The rest of the packet following this IPv6 Header, in octets(including IPv6 Extension Headers.)

        5: Next Header -8 bits

        6: Hop limit -8 bits   The packet is discarded if Hop limit is decremented to zero.

        7. Source Address - 128 bits.

        8. Destination Address -128 bits.

    四、 IPv6 Extension Header

         Optional IPv6 internet-layer is encoded in separate headers that may be placed between the IPv6 header and the upper layer header in a packet.

          note by self: ICMP is the upper-layer, so extension header does not include ICMP.

        ?

        With one excepition(Hop by Hop), extension headers are not examined or processed by any node along a packets delivery path,

        until the packet reaches the node(or each set of nodes in the case of municast).

        Extension Headers must be processed strictly in the order they appear in the packet.

        Hop by hop option carries information that must be examined and processed by every node along a packets delivery path,

        including the source and destination nodes.

        If the next header field value is unrecognized, it should discard the packet and send an ICMP Parameter Problem message to the source, with

        an ICMP code value of 1 ("unrecognized Next Header type encountered"). and the ICMP Point field containing the offset of the unrecognized

        value within the original packet. The same action should be taken if a node encounters a Next Header field value of zero in any header other 

        IPv6.

        Each extension header is an integer multiple of 8 octets long, in order to retain 8-octet alignment for subsequent headers.

        Multi-octet fields within each extension header are aligned on their nature boundaries, fields of width n octets are placed at an integer

        of multiple of n octets form the start of the header, for n = 1, 2, 4, 8.

        A full implementation of IPv6 includes implementation of the following extension headers.

            1) Hop by Hop (IPv6 Next Header value of 0)

            2) Routing (Type 0, IPv6 Next Header value of 43)

            3) Fragment (IPv6 Next Header value of 44)

            4) Destination options(Ipv6 Next Header value of 60)

            5) Authentication

            6) Encapsulating Security Payload

        4.1 Extension Header Order

            When more than one extension header is used in the same packet, it is recommended in the following order.

            1) IPv6 Header

            2) Hop by hop.

            3) Destination Options    (note 1)

            4) Routing 

            5) Fragment

            6) Authentication (note 2)

            7) Encapsulating Security Payload (note 2)

            8) Destination Options (note 3)

            9) upper-layer header

            note 1: for options to be processed by the first Destination Options plus subsequent destinations listed in the Routing Header.

            note 2: Addtional recommendations regarding the relative order of the Authentication and Encapsulating security Payload 

                       headers are given in RFC-2406.

            note 3: for options to be processed only by the final destination of the packet.

        

            Each extension header should occur at most once , except for Destination Options occuring at most twice.

        

            If the uppler-layer header is another IPv6 header (in the case of IPv6 being tunneld  over or encapsulated in IPv6), it may be followed

            its own extsion headers, which are separtely subject to the same ordering recommendations.

            If and when other extension headers are defined, their ordering constraints relative to the above listed headers must be specified.

         

            IPv6 nodes must accept and attemp to process extension headers in any order and occuring any number of times in the same packet, 

            except for the Hop-by-Hop Options header which is restricted to appear immediately after an IPv6 header only. Nonetheless, it is strongly

             advised that souces of IPv6 packets adhere to the above recommended order until and unless subsequent specifications revise that

             recommendation. 

            note by self: 虽然协议规定了extension header 出现的次数和次序, 但是对nodes来说, 必须能处理一个packet中出现任何次序和次数的extension header.

                               或者出现了其他RFC修改上述order。

        4.2 Options

            Two of currently-defined extension headers -- Hop-by-Hop and the Destination options -- carry  a variable number of type-length-value(TLF)

            encoded "options", of the following format:

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ - - - - - - - - - - - - 

            |     Option Type      |    Opt Data Len     |    Option Data      

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ - - - - - - - - - - - - 

            Option Type: 8-bit identifier of the type of option.

            Opt Data Len: 8-bit unsighed integer. Lenth of the Option Data field of ths option, in octets.

            Option Data: Variable-length field. Option-Type-specific data.

            

            The sequence of options within a header must be processed strictly  in the order the appear in the header

            A receiver must not,  for example, scan through the header looking for a particular kind of option and process

            that option prior to processing all preceding ones.

            The Option Type identifiers are internally encoded such that their highest-order two bits specify the action that must be taken

             if processing IPv6 node does not recognize the Option Type.

                00 -  skip over this action and continue processing the header.

                01 - discard the packet.

                02 - discard the packet and regardless of whether or not the packets Destination Address was a multicast address, send 

                       an ICMP Parameter Problem, Code 2, message to the packet's Source Address, pointing to the unrecognized Option Type.

                11 - discard the packet and, only if the packet's Destination Address was not a mullticast address,  send an ICMP Parameter

                       Problem, Code 2,  message to the packet's Source Address, pointing to the unrecognized Option Type.

                

            The third-highest-order bit of the Option type specifies whether or not the Option Data of that option can change en-route to

            the packet's final destination. When  an Authentication header is present  in the packet, for any option whose data may

            change en-route, its entire Option Data field must be treated as zero-valued octets when computing or verifying the packet's

            authenticating value.

                  0 - Option Data does not change en-route.

                  1 - Option Data may change en-route.

           The three high-order bits described above are  to be treated as part of the Option Type, not independent of the Option Type.

            The same Option Type numbering space is used for both the Hop-by-Hop  Options header and the Destination Operations header.

            However, the specification of a paticular option may restrict its  use to only one of those two headers.

            Individual options may have specific alignment requirements, to ensure the multi-octet values within Option Data fields fall on 

            natural boundaries. The alignment  requirement of an option is specified using the notation xn+y,  meaning the Option Type

            must appear at an integer multiple of x octets from the start of the header, plus y octets. 

                2n : means any 2-octet offset from the start of the header,

                8n+2 : means any 8-octet offset from the start of the header, plus 2 octets.

            There are two padding  options which are used when nesscessary to align subsequent options and to pad out the containing header to 

            a multiple of 8 octets in length. These padding options must be recognized by all IPv6 implementaions:

            Pad1 option (alignment requirement: none)

            +-+-+-+-+-+-+-+-+

            |            0              |

            +-+-+-+-+-+-+-+-+

            Note ! the format of Pad1 option is a special case -- it does not  have length and value fields(Option Data len, Option Data).

            Pad1 option is used to insert one octet of padding into the Option area of a header.

            More than one octet of padding required, PadN Option described next:

            PadN option (alignment requirement: none)

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ - - - - - - - - - - - - 

            |             1             |    Opt Data Len     |    Option Data      

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ - - - - - - - - - - - - 

            PadN option is used to insert two or more octets of padding into the Options area of a header.

            For N octets of padding, the Opt Data Len field containing the Value N - 2, Option Data

            consists of N-2 zero-valued octets.

            Appendix B contains formatting guidelines for designing new options.

        4.3 Hop-by-Hop Options Header

             Following Format

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            |      Next Header     |    Hdr Ext  Len      |                                                         |

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+                                                        + 

            |                                                                                                                   |

            .                                                  Options                                                      .

            .                                                                                                                   .

            |                                                                                                                   |

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            Next Header -- 8 bit,  Uses the same value as the IPv4 Protocol Field(RFC 1700).

            Hdr Ext Len -- 8 bit usigned integer. Length of the Hop-by-Hop Options header in

                                  8-octet unit, not including the first 8 octets.

            Options --- Variable-length field, of length such that complete Hop-by-Hop Options

                             header is an integer multiple of 8 octets long. Contains one or more

                             TLV(type-length-value) encoded options, as described in section 4.2.

           The only  Hop-by-Hop options defined in this document are Pad1 and PadN options.

        4.4 Routing Header

              It is used by an IPv6 source to list one or more intermediate nodes to be "visited" on the

              way to a packet's destination, vary similar to IPv4's Loose Source and Record Route Option.         

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            |      Next Header     |    Hdr Ext  Len     |     Routing Type    |   Segments Left    |

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            |                                                                                                                   |

            .                                             type-specific data                                             .

            .                                                                                                                   .

            |                                                                                                                   |

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            5 Sections  

            1) Next Header  --  8-bit selector. Uses the same values as IPv4  Protocol Field(RFC1700).

            2) Hdr Ext Len -- 8 bit, Length of the Routing header in 8-octet units, not including the first 8 octets.

            3) Routing Type -- 8 bit identifier of a particular Routing Header variant.

            4) Segments Left --8 bit. Number of  route segments remaining-- number of explicitly listed

                                         intermediate nodes still to be visited before reaching the final destination.

            5) type-specific data -- Variable-length field, of format determined by the Routing Type, and of length

                                             such that  the complete Routing Header is an integer multiple of 8 octets long.

            

           If a node receives a packet with an unrecognized Routing Type value, the required behavior depends on the value of 

           Segments Left field as follows:

                1) Segments Left is zero, the node must ignore the Routing header and proceed to process the next header.

                2) Segments Left is non-zero, the node must dicard the packet and send an ICMP Parmeter Problem, Code 0,

                    message to the packet's Source Address, pointing to the unrecognized Routing Type.

            If, after processing a Routing Header, an intermediate node determines that the packet is to be forwarded onto

            a link whose link MTU is less than the packet, the node must discard the packet and send ICMP Too Big message

            to the packet's Source Address.

          

            Type 0 Rourting Header

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            |      Next Header     |    Hdr Ext  Len     | Routing Type = 0  |   Segments Left    |

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            |                                                   Reserved                                                  |

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            |                                                  Address[1]                                                |

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            .                                                                                                                   .

            .                                                                                                                   . 

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            |                                                  Address[n]                                                |

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            

           Hdr Ext Len: For Type 0 Router Header,  Hdr Ext Len is equal to two times the number of addresses in the header.

           Reserved: 32-bit field, initialized to zero.

           

           Multicast Address must not appear in a Routing header of Type 0, or in the IPv6 Destination field carring Routing

           Header of Type 0.

           

            Routing Header of Type 0 performs  the following algorithms:

            if (Segments Left = 0)

            {

                 proceed  to process the next header in the packet.

            }

             else if ( Hdr Ext Len is odd)

            {

                send an ICMP Prameter Promblem, Code 0, message to the source, poiting to the  Hdr Ex Len field, and dicard the packet.

            }

            else

            {

                compute n = Hdr Ext Len/2

                if ( Segments Left  > n)

                {

                    send an ICMP Parameter Problem, Code 0, message to the Source, pointing to the Segments Left field, dicard the packet.

                }

                else

                {

                    decrement Segments Left by 1;

                    compute i, the next address to be visited in the address vector,  i = n - (Segments Left)

                    if ( Address[i] or the IPv6 Destination is muticast)

                    {

                         discard the packet;

                     }

                     else

                     {

                          swap  the IPv6 Destination Address and Address[i];

                          if ( Hop limit <= 1)

                          {

                              send an ICMP Time Exceed -- Hop Limit Exceed to the source and dicard the message.

                          }

                          else

                          {

                               decrement the Hop Limit by 1;

                               resubmit the packet to the IPv6 module for transmission to the new destination.

                          }

                     }

                }

            }

        4.5  Fragment Header

            The Fragment Header is used by an IPv6 source to send a packet larger than would fit in the path MTU.

            (Note: unlike IPv4, fragmentation in IPv6 is performed only by source nodes, not by routers along a packets'

             delivery path)

             

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            |      Next Header     |         Reserved     |    Fragment Offset                   |Res |M|

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            |                                              Identification                                                  |

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            1) Reserved: initialized to zero, ignored on reception.

            2)Fragment Offset:  13 bit unsigned integer, the offset, in 8-octet units, of the data following this header,

                                           relative to the start of the Fragmentable Part of the original packet.

            3) Res: 2-bit Reserved field, initialized to zero.

            4) M Flag: 0 = last fragment, 1= more fragments;

            5) Identification: 32bits.

            In order to send a packet that is too large to fit the path MTU, a source node may divide the packet into

            fragments and send each fragment as  a separate packet, to be reassembled at the receiver.

            For every packet that is to be fragmented, the source node generates an Identification.

            Identification must be different than that of any other fragmented packet sent recently with

            the same Source and Destination Address.  If a Routing Header present, the Destination

            of concern is that of the final destination.

             Note: recently means the maximum likely lifetime of a packet. including transmit time from source

                     to destination and time spent awaiting reassembly with other fragments.

                     However, it is not required that a source node know the maximum packet life time. 

                     Rather, it is assumed that the requirement can be met by maintaining the

                     Identification value as a simple, 32-bit, "wrap-around" counter,

                     incremented each time a packet must  be fragmented.

                     It is an implementation choice whether to  maintain a single counter for the node

                     or multiple counters. e.g, one for each of the node's possible source addresses, or

                     one for each active(source address, destination address) combination.

            The  initial, large, unfragmented packet is referred to as the "original packet".

             It is considered to consist of two parts, as follow:

            +------------------+----------------------//-----------------------+

            |   Unfragmentable |                      Fragmentable                         |
            |           Part          |                           Part                                  |
            +----------------------+----------------------//-------------------------------+

                1) Unfragmentalble Part:  consists of the IPv6 header plus any extension headers that must

                    be processed by nodes en route to destination, that is, all headers up to and including

                    the Routing header if present, else Hop-by-Hop Options Header if present,

                    else no extension headers.  

                2) Fragmentable Part: consists of the rest of the packet.     

        

                +------------------+--------------+--------------+--//--+----------+
                |   Unfragmentable  |        first       |      second    |         |    last      |
                |           Part          |      fragment  |     fragment   | ....    | fragment |
                +------------------+--------------+--------------+--//--+----------+

               +------------------+----------+--------------+
                |  Unfragmentable | Fragment |         first      |
                |         Part           |  Header   |       fragment |
               +------------------+----------+--------------+

               +------------------+----------+--------------+
                |  Unfragmentable  | Fragment|      second     |
                |           Part          |   Header |     fragment   |
               +------------------+----------+--------------+
                                                o
                                                o
                                                o
               +------------------+--------+----------+
               |   Unfragmentable |Fragment|     last    |
               |            Part         | Header  | fragment |
               +------------------+--------+----------+

            Each fragment packet is composed of

             (1) The Unfragmentable Part of the orginal packet, with the Payload Length changed and

                   Next Header field changed to 44.

            (2)  Fragment Header containing

                    a) Next Header that identifies the first header of the Fragmentable Part of the Original Packet.

                    b) A Fragment Offset  containing the offset of the fragment, in 8-octet units.

                        (The fragment offset of the first is "0").

           The Fragment length chosen to fit path MTU

            At the destination,  the following rules goven reassembly:

            (1) An orginal packet is resassembled only from packets having the same

                 Source Address, Destination Address, Fragment Identification.

            (2) Unfragmentable Part:

                a) The Next Header of the last header of the Unfragmentable.

        4.6 Destination  Options Header

            The  Destination Options Header is used to carry optional information that need to be

            examined only by  a packet's destination node(s), following format(same with Hop-by-Hop):

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            |      Next Header     |    Hdr Ext  Len      |                                                         |

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+                                                        + 

            |                                                                                                                   |

            .                                                  Options                                                      .

            .                                                                                                                   .

            |                                                                                                                   |

            +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

            

            Hdr Ext Len -- 8 bit usigned integer. Length of the Hop-by-Hop Options header in

                                  8-octet unit, not including the first 8 octets.

            The only destination options defined in this document are Pad1 and PadN options

            specified in Section 4.2.

            Note: there are two possible ways to encode optional destination information in an

                     IPv6 packet:

                    1) an option in the Destinaion Options Header.

                    2) as a separate extension header(examples Fragment Header, Authentication Header).

                    Which approach can be used depends on what action is desired of a destinaion

                    node that does not understand the optional  information:

        4.7 No Next Header

             The value 59 in the  the Next Header field of an IPv6 header or any extension header indicates

             that there is nothing following that header.

             If the Payload Length field of the IPv6 header indicates the
             presence of octets past the end of a header whose Next Header field
             contains 59, those octets must be ignored, and passed on unchanged if
             the packet is forwarded.

        4.8 Packet Size Issues

              IPv6 requires that every link in the internet have an MTU of 1280

             octets or greater. On any link that cannot convey a 1280-octet
             packet in one piece, link-specific fragmentation and reassembly must
             be provided at a layer below IPv6.

            From each link to which a node is directly attached, the node must be

            able to accept packets as large as that link’s MTU.

       

            It is strongly recommended that IPv6 nodes implement Path MTU

           Discovery [RFC-1981], in order to discover and take advantage of path
           MTUs greater than 1280 octets.

           However, a minimal IPv6 implementation (e.g., in a boot ROM) may simply

          restrict itself to sending packets no larger than 1280 octets,

         and omit implementation of Path MTU Discovery.

        A node must be able to accept a fragmented packet that, after

        reassembly, is as large as 1500 octets.

  • 相关阅读:
    MongoDB的安装与简单使用
    [SCOI2008]天平
    [ZJOI2008]树的统计
    [HEOI2015]兔子与樱花
    [HAOI2006]l旅行
    [ZJOI2008]泡泡堂BNB
    [ZJOI2007]时态同步
    [SCOI2005]栅栏
    [SCOI2008]着色方案
    [SCOI2005]互不侵犯King
  • 原文地址:https://www.cnblogs.com/gavinwu/p/3872719.html
Copyright © 2011-2022 走看看