Internet-Draft Zero Checksum for SCTP October 2023
Tüxen, et al. Expires 5 April 2024 [Page]
Workgroup:
Network Working Group
Internet-Draft:
draft-ietf-tsvwg-sctp-zero-checksum-04
Published:
Intended Status:
Standards Track
Expires:
Authors:
M. Tüxen
Münster Univ. of Appl. Sciences
V. Boivie
Google
F. Castelli
Google
R. Jesup
Mozilla

Zero Checksum for the Stream Control Transmission Protocol

Abstract

The Stream Control Transmission Protocol (SCTP) uses a 32-bit checksum in the common header of each packet to provide some level of data integrity. If another method used by SCTP provides already the same or a higher level of data integrity, computing this checksum does not provide any additional protection, but does require computing resources.

This document provides a simple extension to SCTP allowing to save these computing resources by using zero as the checksum in a backwards compatible way. It also defines how this feature can be used when SCTP packets are encapsulated in Datagram Transport Layer Security (DTLS) packets.

Status of This Memo

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 5 April 2024.

Table of Contents

1. Introduction

SCTP as specified in [RFC9260] uses a CRC32c to provide some level of data integrity. When using, for example, Datagram Transport Layer Security (DTLS) as the lower layer for SCTP as specified in [RFC8261], using the CRC32c does not provide any additional protection over the one already provided by DTLS. However, computing the CRC32c at the sender and receiver side does consume computational resources for no benefit. This is particularly important for end points that are computational-limited and use SCTP encapsulated in DTLS.

The extension described in this document allows an SCTP end point to declare that it accepts SCTP packets with a checksum of zero when using a specific alternate error detection method. This declaration happens during the setup of the SCTP association and allows end points supporting this extension to be interoperable with end points not supporting the extension described in this document. To provide this backwards compatibility, end points using this extension still need to implement the CRC32c checksum algorithm.

2. Conventions

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.

3. Alternate Error Detection Methods

SCTP uses a CRC32c to provide some level of data integrity. The CRC32c is computed based on the SCTP common header and the chunks contained in the packet. In particular, the computation of the CRC32c does not involve a pseudo header for IPv4 or IPv6 like the computation of the TCP or UDP checksum.

Zero is a valid result of the CRC32c algorithm. For example, the following figure depicts an SCTP packet containing a minimal INIT chunk with a correct CRC32c or zero.

 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|   Source Port Number = 5001   |Destination Port Number = 5001 |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                     Verification Tag = 0                      |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                         Checksum = 0                          |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|   Type = 1    |Chunk Flags = 0|       Chunk Length = 20       |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                   Initiate Tag = 0xFCB75CCA                   |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|       Advertised Receiver Window Credit (a_rwnd) = 1500       |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|Number of Outbound Streams = 1 | Number of Inbound Streams = 1 |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                        Initial TSN = 0                        |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 1: SCTP Packet with a correct CRC32c of zero

Using SCTP in combination with other mechanisms or protocol extensions might provide an equal or better level of data integrity protection than the one provided by using the CRC32c algorithm. Such alternate error detection methods have two requirements:

  1. An alternate error detection method MUST provide an equal or better level of data integrity than the one provided by using the CRC32c algorithm. This MAY only apply to packets satisfying some method specific constraints.

  2. An alternate error detection method MUST NOT interfere with middle boxes expecting correct CRC32c checksums.

One example fulfilling the first requirement is using DTLS as the lower layer of SCTP as specified in [RFC8261]. Another example is using SCTP Authentication as specified in [RFC4895]. Of course, this only applies to all SCTP packets having an AUTH chunk as its first chunk. The use of SCTP over UDP as specified in [RFC6951] is not fulfilling the first requirement. As using DTLS as the lower layer of SCTP as specified in [RFC8261] also fulfills the second requirement, it can be used as an alternate error detection method (see Section 6).

If an alternate error detection method is available, the computation of the CRC32c checksum consumes computational resources without providing any benefit. To avoid this, an SCTP end point could be willing to accept SCTP packets with an incorrect CRC32c checksum value of zero in addition to SCTP packets with correct CRC32c checksum values.

Because zero is a valid result of the CRC32c algorithm, a receiver of an SCTP packet containing a checksum value of zero cannot determine whether the sender included an incorrect CRC32c of zero to reduce the CPU cost or the result of the CRC32c computation was actually zero. However, if the receiver is willing to use an alternate error detection method, this ambiguity is irrelevant, since the receiver is fine with not using the CRC32c to protect incoming packets.

4. A New Chunk Parameter

The Zero Checksum Acceptable Chunk Parameter is defined by the following figure.

 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|   Type = 0x8001 (suggested)   |          Length = 8           |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|           Error Detection Method Identifier (EDMID)           |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Figure 2: Zero Checksum Acceptable Chunk Parameter
Type: 16 bits (unsigned integer)

This field holds the IANA defined parameter type for the "Zero Checksum Acceptable" chunk parameter. IANA is requested to assign the value 32769 (0x8001) (suggested) for this parameter type.

Length: 16 bits (unsigned integer)

This field holds the length in bytes of the chunk parameter; the value MUST be 8.

Error Detection Method Identifier (EDMID): 32 bits (unsigned integer)

An IANA registered value specifying the alternate error detection method the sender of this parameter is willing to use for received packets.

All transported integer numbers are in "network byte order" a.k.a., Big Endian.

The Zero Checksum Acceptable Chunk Parameter MAY appear in INIT and INIT ACK chunks and MUST NOT appear in any other chunk. The Parameter MUST NOT appear more than once in any chunk.

If an end point not supporting the extension described in this document receives this parameter in an INIT or INIT ACK chunk, it is REQUIRED to skip this parameter and continue to process further parameters in the chunk. This behavior is specified by [RFC9260] because the highest-order two bits of the Type are '10'.

5. Procedures

5.1. Declaration of Feature Support

An end point willing to accept SCTP packets with an incorrect checksum of zero MUST include the Zero Checksum Acceptable Chunk Parameter indicating the alternate error detection method it is willing to use in the INIT or INIT ACK chunk it sends.

An SCTP implementation MAY also require the upper layer to indicate that it is fine to use a specific alternate error detection method for accepting SCTP packets with an incorrect CRC32c value of zero.

5.2. Sender Side Considerations

An SCTP end point cannot just use an incorrect CRC32c checksum value of zero for all SCTP packets it sends. Therefore, the following restrictions apply:

  1. If an end point has not received an INIT or INIT ACK chunk containing a Zero Checksum Acceptable Chunk Parameter indicating an alternate error detection method it supports from its peer during the association setup, it MUST use a correct CRC32c checksum. In particular, when an end point

    a.

    sends a packet containing an INIT chunk, it MUST include a correct CRC32c checksum in the packet containing the INIT chunk.

    b.

    responds to an "Out of the Blue" (OOTB) SCTP packet, it MUST include a correct CRC32c checksum in the response packet.

  2. When an end point sends a packet containing a COOKIE ECHO chunk, it MUST include a correct CRC32c checksum in the packet containing the COOKIE ECHO chunk.

  3. When an end point supports the dynamic address reconfiguration specified in [RFC5061] and sends a packet containing an ASCONF chunk, it MUST include a correct CRC32c checksum in the packet containing the ASCONF chunk.

  4. Alternate error detection methods might have some additional conditions requiring that the sender MUST include a correct CRC32c checksum in the packet.

The first restriction allows backwards compatibility and the second and third restriction allow a simpler implementation of the extension defined in this document. The last restriction covers alternate error detection method specific constraints.

An SCTP end point MAY only send packets with an incorrect checksum of zero, if the upper layer allowed the use of the alternate error detection method that was announced by the peer.

If none of the above restrictions apply, an end point SHOULD use zero as the checksum when sending an SCTP packet.

5.3. Receiver Side Considerations

If an end point has sent the Zero Checksum Acceptable Chunk Parameter indicating the support of an alternate error detection method in an INIT or INIT ACK chunk, it MUST accept SCTP packets fulfilling the requirements of the announced alternate error detection method using an incorrect checksum value of zero in addition to SCTP packets containing the correct CRC32c checksum value for this association.

In addition to processing OOTB packets with a correct CRC32c checksum as specified in [RFC9260], an SCTP implementation MAY also process OOTB packets having an incorrect zero checksum. Doing so might result in faster SCTP association failure detection.

6. Error Detection via SCTP over DTLS

Using SCTP over DTLS as specified in [RFC8261] provides a stronger error detection method than using the CRC32c. Since middle boxes will not observe the unencrypted SCTP packet, there is no risk in interferring with using zero as an incorrect checksum. There are no additional error detection specific constraints on packets when using DTLS encapsulation.

IANA is requested to assign the Error Detection Method Identifier of 1 for this method.

7. Socket API Considerations

This section describes how the socket API defined in [RFC6458] needs to be extended to provide a way for the application to control the acceptance of a zero checksum.

Please note that this section is informational only.

A socket API implementation based on [RFC6458] is extended by supporting one new write-only IPPROTO_SCTP-level socket option.

7.1. Set Accepting a Zero Checksum (SCTP_ACCEPT_ZERO_CHECKSUM)

This IPPROTO_SCTP-level socket option with name SCTP_ACCEPT_ZERO_CHECKSUM can be used to control the acceptance of a zero checksum. It is a write-only socket option and applies only to future SCTP associations on the socket.

This option expects an unsigned integer. Possible values include:

SCTP_EDMID_NONE:

Disable the use of alternate error detection method. This means that all SCTP packets being sent have a correct CRC32c.

SCTP_EDMID_LOWER_LAYER_DTLS:

Use the alternate error detection method described in Section 6.

An implementation might only send packets with an incorrect checksum of zero, if the alternate error detection method announced by the peer is also enabled locally via this socket option.

The default for this socket option is that the use of alternate error detection methods is disabled.

8. IANA Considerations

[NOTE to RFC-Editor: "RFCXXXX" is to be replaced by the RFC number you assign this document.]

[NOTE to RFC-Editor: The suggested value for the parameter type is tentative and to be confirmed by IANA.]

This document (RFCXXXX) is the reference for the registration described in this section.

A new chunk parameter type has to be assigned by IANA. This requires an additional line in the "Chunk Parameter Types" registry for SCTP:

Table 1: New entry in "Chunk Parameter Types" registry
ID Value Chunk Parameter Type Reference
32769 (suggested) Zero Checksum Acceptable (0x8001 (suggested)) [RFCXXXX]

Furthermore, IANA is requested to establish a new "Error Detection Method" registry for SCTP. The assignment of new error detection methods is done through the RFC Required policy as defined in [RFC8126]. Documentation for a new error detection method MUST contain the following information:

  1. A name of an alternate error detection method.

  2. A reference to an RFC describing:

    (a)

    the alternate error detection method,

    (b)

    any method specific constraints referred to in the fourth exception in Section 5.2, and

    (c)

    why using the alternate error detection method does not interfere with middle boxes expecting correct CRC32c checksums.

IANA is requested to use the following as the initial contents of the registry:

Table 2: Initial Contents of the "Error Detection Method" registry
ID Value Error Detection Method Reference
0 Reserved [RFCXXXX]
1 SCTP over DTLS [RFCXXXX]
2 - 4294967295 Unassigned

9. Security Considerations

This document does not change the considerations given in [RFC9260].

10. References

10.1. Normative References

[RFC2119]
Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, DOI 10.17487/RFC2119, , <https://www.rfc-editor.org/info/rfc2119>.
[RFC5061]
Stewart, R., Xie, Q., Tuexen, M., Maruyama, S., and M. Kozuka, "Stream Control Transmission Protocol (SCTP) Dynamic Address Reconfiguration", RFC 5061, DOI 10.17487/RFC5061, , <https://www.rfc-editor.org/info/rfc5061>.
[RFC8126]
Cotton, M., Leiba, B., and T. Narten, "Guidelines for Writing an IANA Considerations Section in RFCs", BCP 26, RFC 8126, DOI 10.17487/RFC8126, , <https://www.rfc-editor.org/info/rfc8126>.
[RFC8174]
Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174, , <https://www.rfc-editor.org/info/rfc8174>.
[RFC8261]
Tuexen, M., Stewart, R., Jesup, R., and S. Loreto, "Datagram Transport Layer Security (DTLS) Encapsulation of SCTP Packets", RFC 8261, DOI 10.17487/RFC8261, , <https://www.rfc-editor.org/info/rfc8261>.
[RFC9260]
Stewart, R., Tüxen, M., and K. Nielsen, "Stream Control Transmission Protocol", RFC 9260, DOI 10.17487/RFC9260, , <https://www.rfc-editor.org/info/rfc9260>.

10.2. Informative References

[RFC4895]
Tuexen, M., Stewart, R., Lei, P., and E. Rescorla, "Authenticated Chunks for the Stream Control Transmission Protocol (SCTP)", RFC 4895, DOI 10.17487/RFC4895, , <https://www.rfc-editor.org/info/rfc4895>.
[RFC6458]
Stewart, R., Tuexen, M., Poon, K., Lei, P., and V. Yasevich, "Sockets API Extensions for the Stream Control Transmission Protocol (SCTP)", RFC 6458, DOI 10.17487/RFC6458, , <https://www.rfc-editor.org/info/rfc6458>.
[RFC6951]
Tuexen, M. and R. Stewart, "UDP Encapsulation of Stream Control Transmission Protocol (SCTP) Packets for End-Host to End-Host Communication", RFC 6951, DOI 10.17487/RFC6951, , <https://www.rfc-editor.org/info/rfc6951>.

Acknowledgments

The authors wish to thank Gorry Fairhurst, Mike Heard, Peter Lei, Nils Ohlmeier, Claudio Porfiri, and Magnus Westerlund for their invaluable comments.

Authors' Addresses

Michael Tüxen
Münster University of Applied Sciences
Stegerwaldstrasse 39
48565 Steinfurt
Germany
Victor Boivie
Google
Kungsbron 2
SE-11122 Stockholm
Sweden
Florent Castelli
Google
Kungsbron 2
SE-11122 Stockholm
Sweden
Randell Jesup
Mozilla Corporation
1835 Horse Shoe Trl
Malvern, PA 19355
United States of America