Network Working Group W. Simpson Request for Comments: 2153 DayDreamer Updates: RFCs 1661, 1962 May 1997 Category: Informational PPP Vendor Extensions Status of this Memo This document provides information for the Internet community. It does not specify an Internet standard of any kind. 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 (LCP) for establishing, configuring, and testing the data-link connection; and a family of Network Control Protocols (NCPs) for establishing and configuring different network-layer protocols. This document defines a general mechanism for proprietary vendor extensions. Simpson Informational [Page i] RFC 2153 PPP vendor extensions May 1997 Table of Contents 1. Control Packets ....................................... 1 1.1 Vendor Specific Packet .......................... 1 2. Configuration Options ................................. 3 2.1 Vendor-Specific Option .......................... 3 3. Organizationally Unique Identifiers ................... 4 SECURITY CONSIDERATIONS ...................................... 5 REFERENCES ................................................... 5 CONTACTS ..................................................... 6 Simpson Informational [Page ii] RFC 2153 PPP vendor extensions May 1997 1. Control Packets The Packet format and basic facilities are already defined for LCP [1] and related NCPs. Up-to-date values of the LCP Code field are specified in the most recent "Assigned Numbers" [2]. This document concerns the following values: 0 Vendor Specific 1.1. Vendor Specific Packet Description Some implementors might not need nor want to publish their proprietary algorithms and attributes. This mechanism is available to specify these without encumbering the IANA with proprietary number requests. Vendor Specific packets MAY be sent at any time, including before LCP has reached the Opened state. The sender transmits a LCP or NCP packet with the Code field set to 0 (Vendor Specific), the Identifier field set, the local Magic-Number (if any) inserted, the OUI and Kind fields set, and the Value(s) field filled with any desired data, but not exceeding the default MRU minus twelve. Receipt of a Vendor Specific packet causes the RXR or RUC event. The response to the Vendor Specific packet is vender specific. Receipt of a Code-Reject for the packet SHOULD generate the RXJ+ (permitted) event. Rationale: This is defined as general feature of all PPP Control Protocols, to avoid future conflicts in vendor secretly self-assigned Code numbers. A summary of the Vendor Specific packet format is shown below. The fields are transmitted from left to right. Simpson Informational [Page 1] RFC 2153 PPP vendor extensions May 1997 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Code | Identifier | Length | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Magic-Number | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | OUI | Kind | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Value(s) ... +-+-+-+-+-+-+-+-+ Code 0 for Vendor Specific Identifier The Identifier field MUST be changed for each Vendor Specific packet sent. Length >= 12 When the Length is twelve, no Value(s) field is present. Magic-Number The Magic-Number field is four octets and aids in detecting links that are in the looped-back condition. Until the Magic-Number Configuration Option has been successfully negotiated, the Magic- Number MUST be transmitted as zero. See the Magic-Number Configuration Option for further explanation. OUI three octets. The vendor's Organizationally Unique Identifier. The bits within the octet are in canonical order, and the most significant octet is transmitted first. Kind one octet. Indicates a sub-type for the OUI. There is no standardization for this field. Each OUI implements its own values. The Kind field may be extended by the vendor to include zero or more octets of the Value(s) field. Simpson Informational [Page 2] RFC 2153 PPP vendor extensions May 1997 Value(s) Zero or more octets. The details are implementation specific. 2. Configuration Options The Configuration Option format and basic options are already defined for LCP [1]. Up-to-date values of the LCP Option Type field are specified in the most recent "Assigned Numbers" [2]. This document concerns the following values: 0 Vendor-Specific 2.1. Vendor-Specific Option Description Some implementors might not need nor want to publish their proprietary algorithms and attributes. This mechanism is available to specify these without encumbering the IANA with proprietary number requests. Before accepting this option, the implementation must verify that the Organizationally Unique Identifier and Kind specify a known mechanism, and that any vendor specific negotiation values are fully understood. Rationale: This is defined as general feature of all PPP Control Protocols, to avoid future conflicts in vendor secretly self-assigned Type numbers. A summary of the Vendor-Specific Configuration Option format is shown below. The fields are transmitted from left to right. +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Type | Length | OUI +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ ... | Kind | Value(s) ... +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+- Simpson Informational [Page 3] RFC 2153 PPP vendor extensions May 1997 Type 0 Length >= 6 When the Length is six, no Value(s) field is present. OUI three octets. The vendor's Organizationally Unique Identifier. The bits within the octet are in canonical order, and the most significant octet is transmitted first. Kind one octet. Indicates a sub-type for the OUI. There is no standardization for this field. Each OUI implements its own values. The Kind field may be extended by the vendor to include zero or more octets of the Value(s) field. Value(s) Zero or more octets. The details are implementation specific. 3. Organizationally Unique Identifiers The three-octet Organizationally Unique Identifier (OUI) identifies an organization that administers the meaning of the message. This OUI is based on IEEE 802 vendor assignments. IEEE contact details for assignment of an OUI are given in [RFC- 1700]. Vendors that desire to use their IEEE 802 OUI for PPP Vendor Extensions should also register the OUI with IANA. In the alternative, a vendor that does not otherwise need an IEEE assigned OUI can request a PPP specific OUI from IANA. This OUI shall be assigned from the 'CF0000' series. This has both the "locally-assigned" and "broadcast/multicast" bits set to 1; that is, the least significant two bits of the most significant octet are both set to 1. Appearance in memory, bits transmitted right-to-left within octets, Simpson Informational [Page 4] RFC 2153 PPP vendor extensions May 1997 octets transmitted left-to-right: +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |1 1 0 0 1 1 1 1|x x x x x x x x|x x x x x x x x| +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | | | Multicast Local Rationale: This is defined for vendors that are not able to use IEEE assignments, such as software-only vendors. It is not clear how the IEEE assigns blocks. In some instances, the "locally-assigned" bit is known to have been used. However, multicast has no meaning in PPP. Therefore, an IEEE assigned OUI would have the multicast bit cleared to 0. The 'CF0000' series was arbitrarily chosen to match the PPP NLPID 'CF', as a matter of mnemonic convenience. Security Considerations Security issues are not discussed in this document. References [1] Simpson, W., Editor, "The Point-to-Point Protocol (PPP)", STD 51, RFC 1661, DayDreamer, July 1994. [2] Reynolds, J.K., Postel, J.B., "Assigned Numbers", RFC-1700, July 1992. Simpson Informational [Page 5] RFC 2153 PPP vendor extensions May 1997 Contacts Comments about this document should be discussed on the ietf- ppp@merit.edu mailing list. This document was reviewed by the Point-to-Point Protocol Working Group of the Internet Engineering Task Force (IETF). The working group can be contacted via the current chair: Karl Fox Ascend Communications 655 Metro Place South, Suite 379 Dublin, Ohio 43017 karl@Ascend.com Questions about this document can also be directed to: William Allen Simpson DayDreamer Computer Systems Consulting Services 1384 Fontaine Madison Heights, Michigan 48071 wsimpson@UMich.edu wsimpson@GreenDragon.com (preferred) Simpson Informational [Page 6]