rfc2043
Network Working Group                                           A. Fuqua
Request for Comments: 2043                                           IBM
Category: Standards Track                                   October 1996
                  The PPP SNA Control Protocol (SNACP)
Status of this Memo
   This document specifies an Internet standards track protocol for the
   Internet community, and requests discussion and suggestions for
   improvements.  Please refer to the current edition of the "Internet
   Official Protocol Standards" (STD 1) for the standardization state
   and status of this protocol.  Distribution of this memo is unlimited.
Abstract
   The Point-to-Point Protocol (PPP) [1] provides a standard method for
   transporting multi-protocol datagrams over point-to-point links.  PPP
   defines an extensible Link Control Protocol, and proposes a family of
   Network Control Protocols for establishing and configuring different
   network-layer protocols.
   This document defines the Network Control Protocols for establishing
   and configuring Systems Network Architecture (SNA) over PPP and SNA
   over LLC 802.2 over PPP.
Table of Contents
   1.     Introduction ..........................................    2
      1.1       Specification of Requirements ...................    2
      1.2       Terminology .....................................    3
   2.     A PPP Network Control Protocol for SNA ................    4
   3.     Sending SNA PIUs and NLPs. ............................    5
      3.1       Sending SNA XID or FID2 PIUs over LLC ...........    5
      3.2       Sending HPR Network Layer Packets (NLPs) ........    5
      3.3       Other Considerations ............................    6
   SECURITY CONSIDERATIONS ......................................    6
   REFERENCES ...................................................    6
   ACKNOWLEDGEMENTS... ..........................................    7
   CHAIR'S ADDRESS ..............................................    7
   AUTHOR'S ADDRESS .............................................    7
Fuqua                       Standards Track                     [Page 1]
RFC 2043                       PPP SNACP                    October 1996
1.  Introduction
   PPP has three main components:
   1. A method for encapsulating multi-protocol datagrams.
   2. A Link Control Protocol (LCP) for establishing, configuring,
      and testing the data-link connection.
   3. A family of Network Control Protocols for establishing and
      configuring different network-layer protocols.
   In order to establish communications over a point-to-point link, each
   end of the PPP link must first send LCP packets to configure and test
   the data link.  After the link has been established and optional
   facilities have been negotiated as needed by the LCP, PPP must send
   SNACP packets to choose and configure the SNA network-layer protocol.
   Once SNACP has reached the Opened state, SNA datagrams can be sent
   over the link.
   The link will remain configured for communications until explicit LCP
   or SNACP packets close the link down, or until some external event
   occurs (an inactivity timer expires or network administrator
   intervention).
1.1.  Specification of Requirements
   In this document, several words are used to signify the requirements
   of the specification.  These words are often capitalized.
   MUST      This word, or the adjective "required", means that the
             definition is an absolute requirement of the specification.
   MUST NOT  This phrase means that the definition is an absolute
             prohibition of the specification.
   SHOULD    This word, or the adjective "recommended", means that there
             may exist valid reasons in particular circumstances to
             ignore this item, but the full implications must be
             understood and carefully weighed before choosing a
             different course.
   MAY       This word, or the adjective "optional", means that this
             item is one of an allowed set of alternatives.  An
             implementation which does not include this option MUST be
             prepared to interoperate with another implementation which
             does include the option.
Fuqua                       Standards Track                     [Page 2]
RFC 2043                       PPP SNACP                    October 1996
1.2.  Terminology
   This document frequently uses the following terms:
   datagram  The unit of transmission in the network layer (such as IP).
             A datagram may be encapsulated in one or more packets
             passed to the data link layer.
   frame     The unit of transmission at the data link layer.  A frame
             may include a header and/or a trailer, along with some
             number of units of data.
   packet    The basic unit of encapsulation, which is passed across the
             interface between the network layer and the data link
             layer.  A packet is usually mapped to a frame; the
             exceptions are when data link layer fragmentation is being
             performed, or when multiple packets are incorporated into a
             single frame.
   peer      The other end of the point-to-point link.
   silently discard
             This means the implementation discards the packet without
             further processing.  The implementation SHOULD provide the
             capability of logging the error, including the contents of
             the silently discarded packet, and SHOULD record the event
             in a statistics counter.
   PIU       Path information unit.  A message unit consisting of a
             transmission header (TH) alone, or a TH followed by a basic
             information unit (BIU) or a BIU segment.  PIU is analogous
             to datagram.
   TH        Transmission header.  Control information, optionally
             followed by a basic information unit (BIU) or a BIU
             segment, that is created and used by path control to route
             message units and to control their flow within the network.
   BIU       Basic information unit.  In SNA, the unit of data and
             control information passed between half-sessions.  It
             consists of a request/response header (RH) followed by a
             request/response unit (RU).
   message unit
             In SNA, the unit of data processed by any layer; for
             example, a basic information unit (BIU), a path information
             unit (PIU), or a request/response unit (RU).
Fuqua                       Standards Track                     [Page 3]
RFC 2043                       PPP SNACP                    October 1996
   NLP       Network Layer Packet.  In High Performance Routing (HPR),
             the message unit used to carry data over the route.
             Network Layer Packet is analogous to datagram.
2.  A PPP Network Control Protocol for SNA
   The SNA Control Protocol (SNACP) is responsible for configuring,
   enabling, and disabling SNA on both ends of the point-to-point link.
   SNACP uses the same packet exchange mechanism as the Link Control
   Protocol (LCP). SNACP packets may not be exchanged until PPP has
   reached the Network-Layer Protocol phase.  SNACP packets received
   before this phase is reached should be silently discarded.
   Note that there are actually two SNA Network Control Protocols; one
   for SNA over LLC 802.2 and another for SNA without LLC 802.2.  These
   SNA NCPs are negotiated separately and independently of each other.
   The SNA Control Protocol is exactly the same as the Link Control
   Protocol [1] with the following exceptions:
   Frame Modifications
      The packet may utilize any modifications to the basic frame format
      which have been negotiated during the Link Establishment phase.
   Data Link Layer Protocol Field
      Exactly one SNACP packet is encapsulated in the PPP Information
      field, where the PPP Protocol field indicates type hex 804B (SNA
      over LLC 802.2) or hex 804D (SNA).
   Code field
      Only Codes 1 through 7 (Configure-Request, Configure-Ack,
      Configure-Nak, Configure-Reject, Terminate-Request, Terminate-Ack
      and Code-Reject) are used.  Other Codes should be treated as
      unrecognized and should result in Code-Rejects.
   Timeouts
      SNACP packets may not be exchanged until PPP has reached the
      Network-Layer Protocol phase. An implementation should be prepared
      to wait for Authentication and Link Quality Determination to
      finish before timing out waiting for a Configure-Ack or other
      response.  It is suggested that an implementation give up only
      after user intervention or a configurable amount of time.
Fuqua                       Standards Track                     [Page 4]
RFC 2043                       PPP SNACP                    October 1996
   Configuration Option Types
      There are no Configuration Options for SNA or for SNA over LLC
      802.2.
3.  Sending SNA PIUs and NLPs.
   Before any SNA packets may be communicated, PPP must reach the
   Network-Layer Protocol phase, and the appropriate SNA Control
   Protocol must reach the Opened state.
   The maximum length of a SNA packet transmitted over a PPP link is the
   same as the maximum length of the Information field of a PPP
   encapsulated packet.
   The format of the PPP Information field itself is the same as that
   defined in [1].  Detailed information on SNA and APPN can be found in
   [3], [4], [5], [6], and [7].
3.1.  Sending SNA XID or FID2 PIUs over LLC
   Exactly one SNA XID or FID2 PIU over LLC 802.2 is encapsulated in the
   PPP Information field, where the PPP Protocol field indicates type
   hex 004B (SNA over LLC 802.2).
   A summary of this frame structure, beginning with the PPP Protocol
   field, is shown below. The fields are transmitted from left to right.
                -- LLC portion (PPP Information Field) -------------
               |                                                    |
   -+----------+----------+----------+----------+-------------------+-
    | Protocol | DSAP     | SSAP     | Control  | LLC Information   |
    | 0x004B   | Address  | Address  | Field    | Field             |
   -+----------+----------+----------+----------+-------------------+-
   The LLC information field contains the XID or FID2 PIU. LLC(2) is
   included in this format for link-level error recovery.  Error
   recovery is done by the routers at each end of the PPP link.
3.2.  Sending HPR Network Layer Packets (NLPs)
   Exactly one HPR Network Layer Packet (NLP) is encapsulated in the PPP
   Information field, where the PPP Protocol field indicates type hex
   004D (SNA).
Fuqua                       Standards Track                     [Page 5]
RFC 2043                       PPP SNACP                    October 1996
   A summary of this frame structure, beginning with the PPP Protocol
   field, is shown below. The fields are transmitted from left to right.
                -- HPR Network Layer Packet (NLP) --
                  |   (PPP Information Field)          |
      -+----------+--------+--------+------------------+-
       | Protocol | NHDR   | THDR   | data             |
       | 0x004D   |        |        |                  |
      -+----------+--------+--------+------------------+-
3.3.  Other Considerations
   It is architecturally possible to transport HPR NLPs over LLC over
   PPP using PPP Protocol field type hex 004B (SNA over LLC 802.2) if
   the optional HPR link-level error recover tower is included in the
   implementation.
Security Considerations
   Security issues are not discussed in this memo.
References
   [1]   Simpson, W., "The Point-to-Point Protocol (PPP)", STD 51,
         RFC 1661, Daydreamer, July 1994.
   [2]   Reynolds, J., and J. Postel, "Assigned Numbers", STD 2, RFC
         1700, USC/Information Sciences Institute, October 1994.
   [3]   "SNA Formats", GA27-3136, IBM.
   [4]   "SNA APPN Architecture Reference", SC30-3422, IBM.
   [5]   "APPN Architecture and Product Implementations Tutorial",
          GG24-3669-02, IBM.
   [6]   APPN Implementers Workshop homepage,
         http://www.raleigh.ibm.com/app/aiwhome.htm
   [7]   "APPN High Performance Routing (HPR) Architecture",
         ftp://networking.raleigh.ibm.com/pub/standards/aiw/appn/hpr
   IBM documents are orderable through 1-800-879-2755.
Fuqua                       Standards Track                     [Page 6]
RFC 2043                       PPP SNACP                    October 1996
Acknowledgements
   Some of the text in this document is taken from previous documents
   produced by the Point-to-Point Protocol Working Group of the Internet
   Engineering Task Force (IETF).
   Some of the text in this document is taken from miscellaneous IBM
   documents.
   Many people provided suggestions and portions of text for this
   document.  Special thanks to Allen Carriker, Marcia Peters, and Scott
   G. Wasson.
Chair's Address
   The working group can be contacted via the current chair:
   Karl F. Fox
   Ascend Communications
   3518 Riverside Dr., Suite 101
   Columbus, Ohio  4322
   EMail: karl@ascend.com
Author's Address
   Questions about this memo can also be directed to:
   Andrew M. Fuqua
   International Business Machines Corporation
   P. O. Box 12195
   Research Triangle Park, NC  27709
   EMail: fuqua@vnet.ibm.com
Fuqua                       Standards Track                     [Page 7]
ERRATA