Internet-Draft | Protocol Numbers for SCHC | April 2023 |
Moskowitz, et al. | Expires 12 October 2023 | [Page] |
This document requests an Internet Protocol Number, an Ethertype, and UDP port assignment for SCHC. The Internet Protocol Number request is so that SCHC can be used for IP independent SCHC of other transports such as UDP and ESP. The Ethertype is to support generic use of native SCHC over any IEEE 802 technology for IP and non-IP protocols. The UDP port request is to support End-to-End SCHC through potentially blocking firewalls.¶
This Internet-Draft is submitted in full conformance with the provisions of BCP 78 and BCP 79.¶
Internet-Drafts are working documents of the Internet Engineering Task Force (IETF). Note that other groups may also distribute working documents as Internet-Drafts. The list of current Internet-Drafts is at https://datatracker.ietf.org/drafts/current/.¶
Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress."¶
This Internet-Draft will expire on 12 October 2023.¶
Copyright (c) 2023 IETF Trust and the persons identified as the document authors. All rights reserved.¶
This document is subject to BCP 78 and the IETF Trust's Legal Provisions Relating to IETF Documents (https://trustee.ietf.org/license-info) in effect on the date of publication of this document. Please review these documents carefully, as they describe your rights and restrictions with respect to this document. Code Components extracted from this document must include Revised BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Revised BSD License.¶
The Static Context Header Compression (SCHC) Architecture [schc-architecture] originally envisioned SCHC used at the Network layer to enable IPv6 over selected Low-Power Wide Area Networking (LPWAN) radio technologies, encompassing IP and Transport, by the network provider. Then SCHC would be used by the application; this would include any security envelope.¶
This approach brakes down when dealing with Diet ESP [diet-esp]. When Next Header is ESP, it is challenging for the ESP process to determine if an incoming ESP payload is regular ESP [RFC4303] or a diet ESP payload. Careful allocation of the incoming SPI [ikev2-diet-esp] can mitigate this and have an implicit SCHC header, but it is not sound protocol design. If the Next Header in the IP header were SCHC, not ESP, a clear segregation of incoming traffic is directly supportable.¶
Additionally, SCHC can then be the Next Header within the ESP header with 'regular' SCHC rules for processing this content. This approach will greatly simplify [diet-esp].¶
DTLS 1.3 [RFC9147] adds further complications. DTLS 1.3 headers themselves are typically already very compressed and SCHC would not provide much value. But the UDP header in front of DTLS would benefit of a separate compression from the IP Header compression. Where it is possible with ESP's SPI to mitigate inbound packet processing challenges implicit SCHC would generate, DTLS header does not safely even provide this and a SCHC IP number is necessary to separate traffic.¶
New IETF work has started with the SCHC WH that is chartered to:¶
provide specifications for the application of SCHC over underlying layers, where underlying layers include but are not limited to UDP tunnels, IP, PPP, and Ethernet, as well as the use of SCHC by upper-layer protocols.¶
To achieve its charter, the SCHC working group needs the allocations that are requested in this document.¶
These issues carry over to IP Header compression if SCHC were available as an Ethertype (for 802 networking) and if SCHC were available as a TCP/UDP port number (for firewall traversal challenges). At each layer, SCHC solves a problem that protocol designers, using constrained networks, currently have to design around.¶
A mobile node, or network, may use different links over a period of time. In some cases the node has the multiple interfaces and, in theory, could tune the compression to each interface. In other cases, it is the whole network that is mobile and individual nodes have no "knowledge" of which link with what characteristics is actively handling the traffic. In either case, the node administrator is aware that some links are constrained and use of SCHC compression is highly recommended.¶
One example is an UA that uses different links over the duration of an operation (i.e. flight).¶
The UA could use SCHC compression only on the UHF link, but this may complicate the implementation.¶
A more complex example is an Unmanned Cargo Aircraft that has multiple avionics systems, all Ethernet connected to an onboard router that has the multiple interfaces. Here the nodes each manage their own secure path to their ground-based server, but have no knowledge of which link is in use to intelligently use compression.¶
In the case of a classical LPWAN link such as LoRa [RFC9011], the use of SCHC to compress the transported protocol, as well as the SCHC session (called instance) to use, are implicit. The MAC-Layer endpoints are preconfigured so there can be only one session, and there can be only SCHC. When extended to Ethernet and more powerful endpoint, this model is way too restrictive, and it is necessary to signal both the use of SCHC and the SCHC session to be used. While the SCHC WG is charterd to produce the latter, the Ethertype defined in this document will be used to signal SCHC as the upper* layer protocol.¶
As an example that will leverage this, Aircraft-to-anything (A2X) [drip-a2x-adhoc-session] and Aircraft-to-Ground [drip-efficient-a2g-comm] protocols are specific cases that can benefit from SCHC as an Ethertype. These can use IEEE 802 wireless technology and lessen spectrum contention in high traffic or long-range situations by minimizing the datagram size via SCHC.¶
In the above uses, SCHC compresses the IPv6 header completely (all 40 bytes), leaving only destination address (32 bytes, source address calcuated from content), or only 8 bytes (needs both addresses) at the cost of the 1-byte SCHC RuleID. The 2-byte payload length may be needed in some cases (as in Section 4).¶
Since the whole point of SCHC is to reduce payload size, SCHC directly over an 802 technology cannot be addressed via the Ethernet Protocol Assignment under the IANA OUI. A distinct Ethertype is needed by SCHC to actually reduce payload overhead.¶
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.¶
SCHC as the IP payload SHOULD be indicated in the IPv4 "Protocol" field or the IPv6 "Next Header" field with a value of TBD1 (recommended: 145) as shown below:¶
Decimal | Keyword | Protocol | IPv6 Extension Header | Reference |
---|---|---|---|---|
TBD1 (145) | SCHC | Static Context Header Compression | This RFC |
The SCHC compressed header with payload is shown below. The size of the SCHC RuleID is variable as described in [RFC8724]. An implementation should have a table of source IP address and RuleID size. The addresses should be represented in prefix format to allow for groups of addresses having the same RuleID size.¶
The RuleID may be statically configured per [RFC8724], or may be negotiated within a protocol as in IKE [ikev2-diet-esp].¶
The use of SCHC as an Ethertype is similar to that as in Section 3, above. Immediately after the SCHC Ethertype is the RuleID as in Figure 1. If the rules for the RuleID does not provide the datagram length, the datagram length MUST be explicit in the Compression Residue, as the 802 header may not provide the needed length information to properly process the datagram.¶
This document requests IANA to make the following change to the "Assigned Internet Protocol Numbers" [IANA-IPN] registry:¶
Decimal | Keyword | Protocol | IPv6 Extension Header | Reference |
---|---|---|---|---|
TBD1 (145) | SCHC | Static Context Header Compression | This RFC |
IANA is requested using the process in Section 5.5 of [intarea-rfc7042bis], to request the Ethertype for SCHC.¶
A registry of SCHC RuleIDs for SCHC as an Ethertype may be needed. More discussion is needed to resolve this. For example, split a 1-byte RuleID in half. The top half of 1-14 assigned to different domains of use, like for aviation. A vaule of 15 designates that a 2-byte RuleID is used.¶
Discussions with Pascal Thubert, lpwan co-chair, helped develop this approach of using SCHC E2E below the current Transport Layers.¶