Network Working Group                                         Wayne McCoy
Request for Comments: 1007                                       June 1987
                         MILITARY SUPPLEMENT
                               TO THE
                       ISO TRANSPORT PROTOCOL
Status of this Memo
   This RFC is being distributed to members of the Internet community
   in order to solicit comments on the Draft Military Supplement.
   While this document may not be directly relevant to the research
   problems of the Internet, it may  be of some interest to a number
   of researchers and implementors. Distribution of this memor is
   unlimited.
1. SCOPE
1.1   Purpose.
   This document supplements the Transport Service and Protocol of the
   International Standards Organization (ISO), IS 8072 and IS 8073,
   respectively, and their formal descriptions by providing conventions,
   option selections and parameter values to be used when the protocol
   is operated within the scope of the applicability statement in
   Paragraph 1.3 below.  Paragraph 1.4, below, describes the ISO
   standards.  Full implementation detail is not provided in this
   document, but reference is made to a separate document, entitled
   "Implementation Guide for the ISO Transport Protocol", in which
   guidance for implementation is given.
1.2  Organization.
   Five sections comprise this supplement.  In Section 1, the role and
   purpose of the Transport Protocol are stated and the international
   standards upon which the protocol is based are described.  These
   documents, as well as others supporting  the international standards
   and this supplement are listed in  Section 2.  Other definitions not
   already included in the international standards and supporting
   documents are given in Section 3.  The international standards cover
   a very wide variety of network environments and situations.  There
   is, thus, a collection of options and parameters provided by the
   standards which must be determined for specific uses.  Section 4
   states the options and parameters relevant to those implementations
   to which this supplement applies, and defines usage conventions.
McCoy                                                           [Page 1]
RFC 1007                                                       June 1987
   Conventions for addressing and Transport connection reference
   number usage and recovery of the Transport connection from peer
   deactivation are covered in Section 5.
1.3   Application.
   The use of the Transport Protocol Class 4 and the Protocol for
   Providing the Connectionless-Mode Network Service (IS 8473) is
   mandatory foruse in all DOD packet-switched data networks where
   there is a potential for host-to-host connectivity across network
   or subnetwork boundaries.  The term "network" as used here shall
   include Local Area Networks but not integrated weapons systems.
   The use of the Transport Protocol Class 4 and IS 8473 is
   strongly encouraged, particularly  where a need for equipment
   interchangeability or survivability is perceived. Use of the
   Transport Protocol Class 4 and IS 8473 in weapons systems, where
   such usage does not diminish required performance, is also
   encouraged.
1.4   International Standards Organization Transport Protocol.
   The international standard upon which this supplement is based is
   described in four documents:
       a. IS 8072, the Transport Service Definition, which defines the
          service that Transport provides to a user, described in
          English text;
       b. WG4 N53, the Formal Description of the Transport Service, in
          which the Transport Service is described using a formal
          description language;
       c. IS 8073, the Transport Protocol, in which the protocol is
          specified in English text; and
       d. N123, the formal description of the Transport Protocol, in
          which the specification IS 8073 is written in a formal
          description language.
   The ISO protocol has five classes of service, named Class 0 through
   Class 4.  Only Classes 4 and 2 will apply to this supplement.  The
   formal description language, Estelle, DP 9074, provides for protocol
   descriptions in terms of communicating finite state automata. It
   contains a subset language which corresponds to the international
   standard Pascal.  The Class 4 protocol operation when supported by a
   connectionless network service is described in an addendum to IS
   8073, N3339(rev).
McCoy                                                           [Page 2]
RFC 1007                                                       June 1987
2.  REFERENCED DOCUMENTS
2.1  Issues of Documents.
   The following documents of the issue in effect on date of invitation
   for bids or request for proposal form a part of this supplement to
   the extent specified herein.
                 FED-STD-1037  - Federal Standard - 1037,
                   Glossary of Telecommunication Terms.
            Implementation Guide for the ISO Transport Protocol
2.2  Other Publications.
   The following documents form part of this standard to the extent
   specified herin.  Unless otherwise indicated, the issue in effect on
   the date of invitation for bids or request for proposal shall apply.
   IS 8072 - Information Processing Systems -
        Open Systems Interconnection - Transport Service Definition.
        Available from: ANSI ISO TC97/SC6 Secretariat 1430 Broadway
        New York, NY 10018 (212) 354-3343
   IS 8073 - Information Processing Systems -
        Open Systems Interconnection - Transport  Protocol
        Specification. Available from ANSI (SC6 Secretariat).
   N3339(rev) - Draft Proposed Addendum to IS 8073
        to Enable Class 4 Operation Over Connectionless Mode Network
        Service as Defined in ISO/ISO 8348/AD1.  Available from ANSI
        (SC6 Secretariat).
   DP 9074 - Estelle - A Formal Description
        Technique Based on an Extended State Transition Model.
        Available from ANSI (SC21 Secretariat), address as for SC6,
        above.
   WG4 N53 - Information Processing Systems -
        Open Systems Interconnection - Formal Description of IS 8072
        in Estelle. (Working draft, ISO TC 97/SC 6/WG 4)
   N123 - Information Processing Systems -
        Open Systems Interconnection - Formal Description of IS 8073
        in Estelle. (Working draft, ISO TC 97/SC 6)
   IS 8473 - Information Processing Systems -
        Data Communications - Protocol for Providing the
        Connectionless-mode Network Service. Available from ANSI
        (SC6 Secretariat).
McCoy                                                           [Page 3]
RFC 1007                                                       June 1987
3. DEFINITIONS
3.1   Definition of terms.
   The definition of terms used in this standard shall comply with
   FED-STD-1037, ISO IS 8072, IS 8073 and IS 8473.  Other terms and
   definitions unique to N3756, WG4 N53 and N3339(rev) appear in
   those documents.
3.2   Abbreviations and acronyms.
   The following abbreviations and acronyms are used in this
   supplement:
     a.  ISO.  The International Standards Organization;
     b.  OSI.  Open Systems Interconnection;
     c.  TS.  Transport service;
     d.  TSAP.  Transport service access point;
     e.  NSAP.  Network service access point;
     f.  TPDU.  Transport protocol data unit;
     g.  CR.  Connect request;
     h.  CC.  Connect confirm;
     i.  DR.  Disconnect request;
     j.  ER.  Error;
     k.  AK.  Acknowledgement;
     l.  IP.  Internetwork protocol;
     m.  LAN.  Local area network.
     n.  CONS. Connection oriented network service.
     o.  CLNS. Connectionless network service.
     (Other provisions of this Section are under consideration.)
McCoy                                                           [Page 4]
RFC 1007                                                       June 1987
4. GENERAL REQUIREMENTS
4.1   Conformance.
   Implementations to which this supplement applies shall satisfy the
   conformance requirements (Clause 14, of IS 8073 and N3339(rev), as
   adapted for this supplement) in the following statements.
     a.  A system claiming to implement the procedures specified
         in this standard shall comply with the requirements in
         b. - d., below.
     b.  The system shall implement:
         b.1  Class 2 or Class 0 or both, if operated over a connection
              oriented network service; or
         b.2  Class 4 if operated over a connectionless network service.
     c.  If the system implements Class 4, it shall also implement
         Class 2, if it is operated over a connection oriented network
         service.  Class 2 shall not be implemented if operation is
         exclusively over a connectionless network service.
     d.  For each class which the system claims to implement, the
         system shall be capable of:
         d.1  initiating CR TPDUs or responding to CR TPDUs with TPDUs
              or both;
         d.2  responding to any other TPDU and operating network
              service in accordance with procedures for the class;
         d.3  operating all the procedures for the class listed as
              mandatory in the Provisions of Options table below;
         d.4  operating those procedures for the class, listed as as
              optional in the Provisions of Options table, for which
              conformance is claimed; and
         d.5  handling all TPDUs of lengths up to the lesser value of:
              d.5.1  the maximum length for the class;
              d.5.2  the maximum for which conformance is claimed.
     e.  Claims of conformance shall state:
         e.1  whether or not operation over connectionless service is
              implemented;
         e.2  which class or classes of protocol are implemented, if
McCoy                                                           [Page 5]
RFC 1007                                                       June 1987
              operation over a connection oriented network is
              implemented;
         e.3  whether the system is capable of initiating or responding
              to CR TPDUs or both;
         e.4  which of the procedures listed in the Provisions of
              Options table are implemented;
         e.5  the maximum size of TPDU implemented; the value shall be
              chosen from the following list and all values in the list
              which are less than this maximum shall be implemented:
              128, 256, 512, 1024, 2048, 4096, or 8192 octets.
   Provision of options (adapted from IS 8073, Table 9)
    __________________________________________________________________
   |        PROCEDURE         |     CLASS 2        |     CLASS 4     |
   |__________________________|____________________|_________________|
   |                          |                    |                 |
   |TPDU with checksum        |not applicable      |mandatory        |
   |TPDU without checksum     |mandatory           |optional         |
   |__________________________|____________________|_________________|
   |                          |                    |                 |
   |Expedited data transfer   |mandatory           |mandatory        |
   |No expedited data transfer|mandatory           |mandatory        |
   |__________________________|____________________|_________________|
   |                          |                    |                 |
   |Flow control in Class 2   |mandatory           |not applicable   |
   |No flow control in Class 2|optional            |not applicable   |
   |__________________________|____________________|_________________|
   |                          |                    |                 |
   |Normal formats            |mandatory           |mandatory        |
   |Extended formats          |optional            |optional         |
   |__________________________|____________________|_________________|
   The explicit manner in which implementations, to which this
   supplement applies, shall satisfy these conformance statements is
   given in Paragraph 4.4.  The options are described in more detail in
   Paragraph 4.3.
4.2   Transport Service access parameters.
   Each of the services of transport has parameters that identify
   communicating peers, express options for operation of the transport
   connection, or transmit data from one peer user to the other.  The
   conventions for these parameters for usage in implementations to
   which this supplement applies are given below.
McCoy                                                           [Page 6]
RFC 1007                                                       June 1987
4.2.1   Connect Service.
   The Connect Service is summarized below (refer to IS 8072 for
   detailed discussion):
   __________________________________________________________________
   |             Primitives                        Parameters       |
   |________________________________________________________________|
   | T-CONNECT          request     |  Called Address,              |
   |                    indication  |  Calling Address,             |
   |                                |  Expedited Data Option,       |
   |                                |  Quality of Service,          |
   |                                |  TS User-Data                 |
   |________________________________|_______________________________|
   | T-CONNECT          response    |  Responding Address,          |
   |                    confirm     |  Quality of Service,          |
   |                                |  Expedited Data Option,       |
   |                                |  TS User-Data                 |
   |________________________________|_______________________________|
   Conventions for Called Address, Calling Address and Responding
   Address will appear in Paragraph 5.1.1.  Use of the Expedited
   Data Option is dependent on the nature of the transport user;
   this supplement does not define how transport users will decide
   on such usage.  The parameters that define Quality of Service are
   discussed in IS 8072.  However, the manner in which these
   parameters are to be applied in an implementation issue , and the
   mechanisms to be used to maintain the requested quality of sevice
   are not defined.  It is thus recommended that these parameters
   not be used in implementations until such time that usage
   definition exists. The amount of data passed in TS User-Data is
   constrained to 32 octets or less.  (This TS User-Data parameter
   shall not be used for any data that requires any security protection
   whatever.)  No implementation is required to be able to send such
   data received from its user, but each implementation shall be
   capable of passing data received from the remote peer user during
   connection establishment to its user.
4.2.2   Disconnect Service.
   __________________________________________________________________
   |             Primitives                        Parameters       |
   |________________________________________________________________|
   | T-DISCONNECT       request     |  TS User-Data                 |
   |________________________________|_______________________________|
   | T-DISCONNECT       indication  |  TS User-Data,                |
   |                                |  Disconnect reason            |
   |________________________________|_______________________________|
   The Disconnect Service is abrupt in the sense that data may be lost
McCoy                                                           [Page 7]
RFC 1007                                                       June 1987
   whenever the service is invoked.  Transport user processes should
   therefore ensure that all data intended to be received has in fact
   been received before issuing a T-DISCONNECT-request.  The data used
   in the TS User-Data parameter is constrained to be 64 octets or less
   in length.  (The TS User-Data parameter shall not be used for data
   that requires any security protection whatever.)  Disconnect reasons
   are discussed in IS 8073, and reasons other than those listed in IS
   8073 are permitted.
4.2.3   Data Transfer Service.
   __________________________________________________________________
   |             Primitives                      Parameters         |
   |________________________________________________________________|
   | T-DATA             request     |  TS User-Data                 |
   |                    indication  |                               |
   |________________________________|_______________________________|
   The length of the data that is carried by the TS User-Data parameter
   is not constrained by the ISO Standard, but interface considerations
   may impose practical limits.  This is discussed further in the
   Implementors guide, Part 3.1.  For the purposes of this supplement,
   the TS User-Data parameter in this service is considered to be
   protected and should be used for any data requiring security
   protection.
4.2.4   Expedited Data Service.
   __________________________________________________________________
   |               Primitives                   Parameters          |
   |________________________________________________________________|
   | T-EXPEDITED-DATA   request     |  TS User-Data                 |
   |                    indication  |                               |
   |________________________________|_______________________________|
   The TS User-Data parameter is constrained to be no longer than
   16 octets and shall not be used for data requiring any security
   protection whatever.  The T-EXPEDITED-DATA-request cannot be used
   whenever non-use of expedited data was called for in either the
   T-CONNECT-request or T-CONNECT-response primitive.
4.3   Options.
   The protocol described in IS 8073 and N3756 permits certain options
   which qualify or enhance the service to be provided.  Negotiated
   options are those which both communicating peer transport entities
   agree upon during connection establishment. Local options are those
   which apply to a particular implementation of transport that may
   be used to enhance performance, optimize resource utilization or
   improve resilience to network failures. The election of a local
   option is invisible to the remote peer entity.
McCoy                                                           [Page 8]
RFC 1007                                                       June 1987
4.3.1  Negotiated options.
   The options in IS 8073 that shall be negotiated between peer
   transport entities are given in the following list.  The elections
   of these options to be taken in  an implementation to which this
   supplement applies are defined in Paragraph 4.4.
     a.   a. Class of service--agreement as to one of five classes of
          transport service, depending on which classes are supported by
          the entities, the quality of the network service available and
          the degree of resilience to network errors and failure
          required by the peer transport users.
     b.   b. Use of extended formats--agreement to use or not use
          extended formats for sequence numbering and flow control
          credit; normal formats provide sequence numbers in the range 0
          - (2**7 - 1) and flow control credit in the range 0 - (2**15 -
          1); extended  formats provided sequence numbers in the range 0
          - (2**31 - 1)  and credit in the range 0 - (2**16 - 1).
     c.   Use of expedited data transfer--agreement to use or not to use
          expedited data transfer during normal data transfer
          procedures.
     d.   Maximum size of protocol data units to be exchanged--agreement
          to limit size of exchanged protocol data units, depending on
          buffer resources that the entities have and network quality of
          service; values negotiated are in the range 2**7 - 2**13
          octets (total length).
     e.   Use of checksum--agreement to use or not to use a 16-bit
          checksum on each protocol data unit exchange between the
          entities, depending on expected residual error rate in the
          network service used.
     f.   Protection parameters--agreement as to how protection will be
          defined and maintained on the transport connection; these
          parameters are defined by the communicants which elect to use
          them.
     g.   Use of flow control in Class 2--agreement to use or not to use
          flow control in Class 2 when Class 2 operation has been
          negotiated. Conformance to the ISO Standard requires that if
          Class 4 is supported over CONS, then Class 2 shall also be
          supported.
     h.   Service quality parameters--agreement as to the quality of
          service to be expected on the transport connection; the ISO
          Standard does not state how these parameters are to be used by
          the transport entities or their users.
McCoy                                                           [Page 9]
RFC 1007                                                       June 1987
4.3.2   Local options, Class 2.
   The options that an implementor may decide in a particular Class 2
   implementation are given in the following list.  Recommendations
   and requirements for these options for the purposes of this
   this supplement are given in Paragraph 4.5.1.
     a.   Multiplexing on network connection--for better usage of of
          network resources, an implementation may elect to share a
          network connection among two or more transport connections.
     b.   Acknowledgement strategy--an implementation is not required by
          IS 8073 to use any particular strategy for sending
          acknowledgements for received data:  each data transfer
          protocol data unit may be explicitly acknowledged (one-for-
          one) or may be implicitly acknowledged by a group
          acknowledgement (one-for-N).
     c.   Concatenation of protocol data units--when network service
          data units are large compared to the protocol data units to be
          sent, an implementation may elect to concatenate these
          protocol data units into a single network service data unit.
     d.   Lockup prevention timer--when the wait-before-closing state is
          entered, there is a possibility of deadlock if the peer
          transport entity never responds to the CR TPDU.  The standard
          provides for an optional timer to alleviate this situation.
4.3.3   Local options, Class 4.
   The options that an implementor may decide in a particular Class 4
   implementation are given in the list below.  Recommendations and
   requirements for use of these options in implementations to which
   this supplement applies are given in Paragraph 4.5.2.
     a.   Withdrawal of flow control credit--when supporting several
          connections of differing precedence or priority, resource
          management must be practiced so as to maintain the precedence
          or priority relationships.
     b.   Flow control confirmation--when flow control credit is
          reduced, extra delay may be encountered because
          acknowledgements carrying new flow control information are
          lost; this procedure aids in speeding up resynchronization of
          the flow control.
     c.   Subsequenced acknowledgements--when the flow control window
          has been closed this procedure alleviates ambiguity due to
          lost or out-of-order acknowledgements.
McCoy                                                          [Page 10]
RFC 1007                                                       June 1987
     d.   Splitting over network connection--when operating over a
          connection-oriented network service, a Class 4 implementation
          is permitted to use more than one network connection, for
          better performance and better resilience to network connection
          failure.
     e.   Acknowledgement strategy--an implementation is not required by
          the standard to use any particular strategy for sending
          acknowledgements for received data:  each data transfer
          protocol data unit may be explicitly acknowledged (one-for-
          one) or may be implicitly acknowledged by a group
          acknowledgement (one-for-N).
     f.   Wait-before-closing state--when a connect request has been
          sent to the peer and the user has requested a disconnection
          before the connect confirmation has been received, an
          implementation may elect to wait until the confirmation has
          arrived before sending the disconnection request to the peer,
          to ensure positive identification of the connection to be
          released.
     g.   Multiplexing on network connection--for better usage of
          network resources, an implementation may elect to share a
          network connection among two or more transport connections.
     h.   Concatenation of protocol data units--when network service
          data units are large compared to the protocol data units to be
          sent, an implementation may elect to concatenate these
          protocol data units into a single network service data unit.
     i.   Checksum algorithm--the Fletcher checksum algorithm provided
          in an annex to the standard is not part of the standard and is
          provided for information only.  The checksum algorithm used
          nature of network errors expected and need only satisfy the
          summation criterion given in the standard.
     j.   Send network RESET when bad checksum received--it may not be
          possible to know with certainty which of several transport
          connections multiplexed on a network connection is to receive
          a protocol data unit which carries a bad checksum.  A N-RESET
          or N-DISCONNECT may be sent on the network connection to all
          transport entities on the connection to indicate the error.
     k.   Protocol data unit retransmission policy--protocol data units
          for which no acknowledgement has been received may be
          retransmitted in case the originals were never received.
          Whether to retransmit only the oldest unacknowledged protocol
          data unit or all those that are outstanding has implications
          for buffer management in the sending entity and for
          utilization of the bandwidth in the network transmission
McCoy                                                          [Page 11]
RFC 1007                                                       June 1987
          medium.
4.4   Negotiations.
   Paragraph 4.2.1 lists those options that shall be negotiatied by
   communicating transport entities.  Below,  conventions are given for
   these options, in usage to which this  supplement applies.  These
   requirements reflect the conformance statement of IS 8073 and the
   needs of the DOD.
4.4.1   Options.
4.4.1.1   Class of service.
     a.   An implementation operating on CONS shall be capable of
          offering Class 2 and may optionally support Class 0.
     b.   An implementation shall not respond by a proposal of Class 0
          and shall not respond by a proposal of Class 2 if the connect
          request was received on a CLNS.
     c.   An implementation may offer Class 2 as an alternative class of
          operation in a connect request when operating over CONS. No
          alternative class may be offered if operation over a CLNS.
     d.   An implementation shall respond to a connect request that
          proposes Class 1 or 3 as primary choice with a disconnect
          request, reason code 128+2 (see p. 87 of IS 8073).
     e.   An implementation shall not propose Class 1 or Class 3 in
          response to a connect request carrying Class 1 or Class 3 as
          an alternative class of service.
     f.   An implementation which proposes Class 4 in a connect request
          need not accept a proposal for Class 2 from its peer if Class
          2 was not offered as an alternative in the connect request, or
          if operation is over a CLNS. Class 2 shall be accepted when
          proposed by the responding peer if it  was offered as an
          alternative in the connect request.
4.4.1.2   Extended formats.
     a.   An implementation shall always propose use of extended formats
          when either Class 4 or Class 2 is proposed in a connect
          request.
     b.   An implementation shall always accept the use of extended
          formats when so proposed in a received connect request.
McCoy                                                          [Page 12]
RFC 1007                                                       June 1987
4.4.1.3   Expedited data.
     a.   Use of expedited data is subject to negotiation by users of
          Transport Service.
     b.   Expedited data shall be supported in Class 2.
4.4.1.4   Maximum protocol data unit size.
   (The provisions of this paragraph are under consideration.)
4.4.1.5   Use of checksum.
   An implementation shall propose use of checksums consistent with the
   expected quality of service and security requirements.
     a.   Checksums should be used when operating with the IP on
          catenated networks.
     b.   Checksums should not be used if high performance is required,
          except when required by high error rates in the network
          service.
     c.   Checksums should always be used when any encryption is being
          used.
4.4.1.6   Protection parameters.
   Use of the security parameters is not defined in this supplement.
4.4.1.7   Use of flow control in Class 2.
     a.   An implementation shall always propose the use of flow control
          in Class 2 whenever Class 2 is proposed as either primary or
          alternative choice of service.
     b.   An implementation shall accept use of flow control in Class 2
          whenever negotiation to Class 2 occurs.
4.4.1.8  Service quality parameters.
     a.   Use of the service quality parameters in the CR and CC
          protocol data units is not defined except for the residual
          error rate parameter and the priority parameter.
     b.   Residual error rate (the use of this parameter is under
          consideration).
McCoy                                                          [Page 13]
RFC 1007                                                       June 1987
     c.   Priority (the use of this parameter is under consideration).
4.4.2   Parameters.
          This paragraph defines the values to be used in the CR and CC
          TPDUs.
4.4.2.1   Class 2 parameters.
4.4.2.1.1   Connect request (CR) protocol data unit.
4.4.2.1.1.1   Fixed part of header.
     a.   Connect request code: as in IS 8073.
     b.   Initial credit allocation: this field defines the number of
          TPDUs offered as initial credit by the connection initiator.
          Since the field is of length  4, the maximum credit that can
          be initially offered is limited to 15.  These TPDUs are
          constrained in length to the maximum size defined in the TPDU
          size field, listed below in Paragraph 4.4.2.1.1.2.
     c.   Destination reference: as in IS 8073.
     d.   Source reference: this reference shall be selected pursuant to
          the provisions of Paragraph 5.2.1.
     e.   Class and option: the class field shall take binary value
          0010; the option field shall take binary value 0010. (These
          values select Class 2, and the options of extended formats and
          flow control in Class 2.)
4.4.2.1.1.2   Variable part of header.
     a.   TSAP identifiers: the parameter values shall follow the
          conventions given in Paragraphs 5.1.1 and 5.1.2.
     b.   TPDU size: (The values to be used are under consideration.)
     c.   Version number: as in IS 8073.
     d.   Protection parameters: should not be used.
     e.   Checksum: shall not be used.
     f.   Additional options: this field shall take binary value 0001 if
          the initiating user has proposed the use of expedited data,
          and shall take value 0000 otherwise.
McCoy                                                          [Page 14]
RFC 1007                                                       June 1987
     g.   Alternative protocol classes: this field shall not be used
          unless Class 0 is to be proposed as an alternate class of
          operation.
     h.   Throughput: should not be used.
     i.   Residual error rate: should not be used.
     j.   Priority: (Use of this parameter is under consideration.)
     k.   Transit delay: should not be used.
4.4.2.1.1.3  User data.
   The CR TPDU shall not carry user data which has any requirement
   whatever for security protection.
4.4.2.1.2   Connect Confirm (CC) TPDU.
4.4.2.1.2.1   Fixed part of header.
     a.   Connect confirm code: as in IS 8073.
     b.   Initial credit allocation: same as Paragraph 4.4.2.1.1.1.
     c.   Destination reference: this reference shall be the "Source
          reference" number from the received CR TPDU.
     d.   Source reference: this reference shall be selected pursuant to
          the provisions of Paragraph 5.2.1.
     e.   Class and option: the class field shall take binary value 0010
          and the option field shall take binary value  0010 (selects
          Class 2 and options of extended formats and flow control in
          Class 2).
4.4.2.1.2.2   Variable part of header.
     a.   TSAP identifier(s): the parameter values shall follow the
          conventions given in Paragraphs 5.1.1 and 5.1.2.
     b.   b. TPDU size: (The values for this parameter are under
          consideration.)
     c.   Version number: as in  IS 8073.
     d.   Protection parameters: should not be used.
McCoy                                                          [Page 15]
RFC 1007                                                       June 1987
     e.   Checksum : shall not be used.
     f.   Additional options: This field shall take binary value 0001 if
          the responding transport entity has proposed the use of
          expedited data, and shall take binary value 0000 otherwise.
     g.   Alternative protocol classes: shall not be used.
     h.   Throughput: should not be used.
     i.   Residual error rate: should not be used.
     j.   Priority: (The use of this parameter is under consideration.)
     k.   Transit delay: should not be used.
4.4.2.1.2.3   User data.
     The CC TPDU shall not carry any data which has any requirement
     whatever for security protection.
4.4.2.2   Class 4 parameters.
4.4.2.2.1  Connect request (CR) TPDU.
4.4.2.2.1.1   Fixed part of header.
     a.   Connect request code: as in IS 8073.
     b.   Initial credit allocation: this field defines the number of
          TPDUs offered as initial credit by the connection initiator.
          Since the field is of length 4, the maximum credit that can be
          initially offered is limited to 15. These TPDUs are
          constrained in length to the maximum size defined in the TPDU
          size field, listed below in Paragraph 4.4.2.2.1.2.
     c.   Destination reference: as in  IS 8073.
     d.   Source reference: this reference shall be selected pursuant to
          the provisions of Paragaph 5.2.1.
     e.   Class and option: the class field shall take binary value
          0100; the option field shall take binary value 0010. (These
          values select Class 4, and the options  of extended formats
          and flow control in Class 2.  This latter option is ignored if
          the class negotiated is Class 2.)
McCoy                                                          [Page 16]
RFC 1007                                                       June 1987
4.4.2.2.1.2   Variable part of header.
     a.   TSAP identifiers: the parameter values shall follow the
          conventions given in Paragraphs 5.1.1 and 5.1.2.
     b.   PDU size: (The values for this parameter are under
          consideration.)
     c.   Version number: as in IS 8073.
     d.   Protection parameters: should not be used.
     e.   Checksum: if Class 4 has been selected, this parameter may be
          used.  If Class 2 (or Class) has been selected, this parameter
          shall not be used.
     f.   Additional options: this field shall take binary value 0001 if
          the initiating user has proposed the use of expedited data,
          and shall take binary value 0000 otherwise.
     g.   Alternative protocol classes: this field shall be used only if
          Class 2 (or Class 0) is to be proposed as an alternate class
          of operation, conformant to the conditions of Paragraph
          4.4.1.1.  If Class 2 is proposed, the field shall take binary
          value 00000010 (1 octet).
     h.   Acknowledge time:  should not be used.
     i.   Throughput: should not be used.
     j.   Residual error rate: (The use of this parameter is under
          consideration.)
     k.   Priority: (The use of this parameter is under consideration.)
     l.   Transit delay: should not be used.
4.4.2.2.1.3   User data.
     The CR TPDU shall not carry user data which has any requirement
     whatever for security protection.
4.4.2.2.2   Connect confirm (CC) TPDU.
4.4.2.2.2.1   Fixed part of header.
     a.   Connect confirm code: as in IS 8073.
     b.   Initial credit allocation: same as Paragraph 4.4.2.2.1.1.b.
McCoy                                                          [Page 17]
RFC 1007                                                       June 1987
     c.   Destination reference: this reference shall be the number in
          "Source reference" from the received CR TPDU.
     d.   Source reference: this reference shall be selected pursuant to
          the provisions of Paragraph 5.2.1.
     e.   Class and option: if Class 2 has been selected, then the class
          field shall take binary value 0010 and the option field shall
          take binary value 0010.  If Class 4 has been selected, then
          the class field shall take binary value 0100 and the option
          field shall take binary value 0010.
4.4.2.2.1.2  Variable part of header.
     a.   TSAP identifier(s): the parameters values shall follow the
          conventions given in Paragraphs 5.1.1 and 5.1.2.
     b.   TPDU size: (The values for this parameter are under
          consideration.)
     c.   Version number: as in IS 8073.
     d.   Protection parameters: should not be used.
     e.   Checksum: if Class 4 has been selected, this parameter may be
          used. If Class 2 (or Class 0) has been selected, this
          parameter shall not be used.
     f.   Additional options: if Class 4 or Class 2 has been selected,
          this field shall take binary value 0001 if the responding user
          has proposed use of expedited data and shall take binary value
          0000 otherwise.
     g.   Alternate protocol classes: shall not be used.
     h.   Acknowledgement time: should not be used.
     i.   Throughput: should not be used.
     j.   Residual error rate: (The use of this parameter is under
          consideration.)
     k.   Priority: (The use of this parameter is under consideration.)
     l.   Transit delay: should not be used.
4.4.2.2.1.3   User data.
   The CC TPDU shall not carry user data which has any requirement
   whatever for security protection.
McCoy                                                          [Page 18]
RFC 1007                                                       June 1987
4.5   Use of local options.
   The paragraphs that follow give policy and guidance in the election
   of local options.
4.5.1   Local options, Class 2.
4.5.1.1   Multiplexing.
   Any Class 2 connections may be multiplexed on the same network
   connection to the limits provided by the network service.
   Multiplexing Class 2 and Class 4 connections together on the same
   network connection is not recommended.
4.5.1.2   Acknowledgement strategy.
   (The provisions of this paragraph are under consideration.)
4.5.1.3   Concatenation.
   This permits placing certain TPDUs into a single network service
   data unit with a data-bearing TPDU.  It is useful for reducing
   the overhead of separate transmission of the individual TPDUs.
4.5.1.4   Lockup prevention timer.
   It is strongly recommended that this timer be used for all Class 2
   connections.  A description of the timer has been included in the
   transport formal description.  (This timer corresponds to the
   optional TS1 timer that IS 8073 recommends.)
4.5.1.5   Treatment of protocol errors.
   Protocol errors detected by a Class 2 transport connection shall
   result in that connection being terminated, without sending an ER
   TPDU.
4.5.1.6   Action on receipt of Error transport protocol data unit.
   The receipt of an ER TPDU for a Class 2 transport connection shall
   cause immediate termination of that transport connection.
4.5.2   Local options, Class 4.
4.5.2.1   Withdrawal of flow control credit.
   Because of the need to serve transport connections of various
   levels of operating priority, an implementation shall support
   the withdrawal of flow control credit from any Class 4 transport
   connection as a means of managing resource allocation among
   Class 4 connections.
McCoy                                                          [Page 19]
RFC 1007                                                       June 1987
4.5.2.2   Flow control confirmation.
   The requirement to support withdrawal of flow control credit
   strongly indicates the need to use flow control confirmation.
   An implementation should support and use the flow control
   confirmation procedures of IS 8073, consistent with quality of
   service and other requirements.
4.5.2.3   Subsequenced acknowledgements.
   The possibility of credit withdrawal strongly indicates the
   requirement for subsequence numbers on acknowledgements.  An
   implementation shall support and use subsequence numbers as
   defined in IS 8073.
4.5.2.4   Splitting over network connection.
   Implementations may use splitting as necessary or useful in the
   operating environment. (Splitting is defined only for operation
   over a CONS.
4.5.2.5   Acknowledgement strategy.
   (The provisions of this paragraph are under consideration.)
4.5.2.6   Wait-before-closing state.
   It is recommended that this state be used.  A lockup prevention
   timer, such as used in Class 2, is not necessary, since the CR
   TPDU retransmission timer serves this purpose.
4.5.2.7   Multiplexing on network connection.
   Multiplexing of Class 4 connections on a single network
   connection may be used as necessary or useful, within the limits
   permitted by the network service.  Class 4 connections should not
   be multiplexed onto network connections serving Class 2 transport
   connections.
4.5.2.8   Concatenation of protocol data units.
   Concatenation may be useful when operating over a CLNS that has
   large capacity service data units.  Concatenation on networks
   that areconnection-oriented may be useful if transport
   connections are being multiplexed.  A careful analysis of the
   treatment of the network service data unit in internetwork
   environments should be done to determine whether concatenation
   of TPDUs provides sufficient benefit to justify its usage in
   those circumstances.
McCoy                                                          [Page 20]
RFC 1007                                                       June 1987
4.5.2.9   Checksum algorithm.
   It is strongly recommended that the algorithm described in the
   Implementors Guide Part 7, be used rather than the algorithm
   given in the Annex to IS 8073.  The algorithm in  Part 7
   computes the same checksum as the one in IS 8073 but  has been
   optimized.  Guidance on the use and non-use of  checksum is
   given in the Implementors Guide, Part 7.
4.5.2.10   Send network RESET when bad checksum received.
   It is recommended that only an N-RESET be sent when encountering
   a TPDU with a bad checksum on a CONS.  An implementation shall
   not send an N-DISCONNECT-request in such situations, since the
   TPDU with the bad checksum may have come from some entity
   intending to interfere with communications.  When  operating
   Class 4 over a CLNS, no action shall be taken on the receipt of
   a TPDU with a bad checksum,  i.e., the TPDU shall be discarded.
4.5.2.11   Protocol data unit retransmission policy.
   (The provisions of this paragraph are under consideration.)
4.5.2.12   Treatment of protocol errors.
   In Class 4, a protocol error arising from a TPDU containing
   unrecognized parameters shall cause a DR TPDU to be sent to the
   sender, if the TPDU is otherwise valid.  All other erroneous TPDUs
   shall be discarded.
4.5.2.13   Action on receipt of Error transport protocol data unit.
   If an ER TPDU is received from a remote transport entity, an
   implementation to which this supplement applies shall release the
   transport connection with which the ER TPDU is associated, if such
   association can be made.  When association cannot be made, the ER
   TPDU shall be discarded.
5. SPECIAL REQUIREMENTS
5.1   Addressing conventions.
   (The provisions of Paragraph 5.1 and its subparagraphs are under
   consideration.)
5.1.1   Transport Service Access Point.
5.1.2   Connect-request/confirm protocol data units.
5.1.3   Network Service Access Point.
McCoy                                                          [Page 21]
RFC 1007                                                       June 1987
5.2   Convention for use of transport connection reference numbers.
   The ISO Transport Protocol provides for freezing reference numbers
   by means of a timer, so that re-use of a reference number does not
   cause ambiguity in communications. However, certain requirements
   are imposed on DOD implementations, so that this means of reference
   number control is inadequate alone. The ISO standard defines only
   those actions to be followed if a timer is used.  Other means of
   reference number control are not prohibited, providing that the
   minimum freeze time, as defined in IS 8073, is exceeded for each
   reference number used.
5.2.1   Specification of convention.
   An implementation adhering to the applications definitions in
   this supplement, Paragraph 1.3, shall not re-use a transport
   connection reference number until the set of available reference
   numbers has recycled to that point.  Expressed more formally,
   if all reference numbers are defined to be within the interval
   [1,N] and a reference number R in this interval is used, then
   R shall be prohibited from being selected again until all the
   numbers R+1,...,N,1,2,...,R-1 shall have been used.  The choice
   of N should be sufficiently large that the expected recycle period
   exceeds the minimum freeze time as specified in IS 8073.  This
   requirement is in addition to and does not supersede the freeze
   requirement of IS 8073.  A simple means of implementing this
   convention is given in Part 9.3 of the Implementors Guide.
5.3  Operation over connectionless network service.
   Implementations to which this supplement applies are required to
   operate over connectionless network services in addition to being
   able to operate over connection-oriented network services. The ISO
   standard specifies transport only for operation over a
   connection-oriented network.  However, the specification for Class
   4 has been written in such a way that use with connectionless
   network service is not precluded.  The formal description offers
   even more flexibility in this regard.  Consequently, operation over
   connectionless network services, whether a LAN or IP, is primarily
   an implementation issue for Class 4.  Operation of Class 2
   transportover a connectionless network service is not considered
   to be a reasonable  option because of the lack of sufficent error
   recovery in Class 2.   For the purposes of this supplement,
   operation of Class 2 on a  connectionless network service is
   not recommended. Operation of Class  4  over a connectionless
   network service is discussed further in parts 1.2.2.2,  3.4,
   and 6 of the accompanying Implementors Guide.
McCoy                                                          [Page 22]
RFC 1007                                                       June 1987
5.4   Recovery from peer deactivation.
   The ISO Standard does not provide for re-establishment of the
   transport connection  when one of the communicating peers is
   deactivated ("crashes").  However, the state tables for Class
   4 transport in Annex A to IS 8073  are flexible enough that
   simple adaptations in an implementation can yield some degree
   of crash recovery without change to the protocol.  These
   adaptations are discussed in Part 9.2 of the Implementors Guide.
McCoy                                                          [Page 23]