ROHC

Robust Header Compression

Protocol
Introduced in Rel-5
A protocol that significantly reduces the header overhead of IP packets (e.g., IPv4, IPv6, UDP, RTP, TCP) over bandwidth-constrained wireless links. It operates by establishing a compression context between compressor and decompressor, sending full headers only initially, then transmitting small identifiers for subsequent packets. This improves spectral efficiency and reduces latency.

Description

Robust Header Compression (ROHC) is a standardized framework defined initially in IETF RFC 3095 and extensively profiled and adopted by 3GPP for cellular networks from Release 5 onwards. It is a lossless compression protocol designed to compress the headers of IP-based traffic streams (flows) before transmission over the radio interface. The protocol is implemented in the Packet Data Convergence Protocol (PDCP) layer in 3GPP stacks (UTRAN, E-UTRAN, NG-RAN). ROHC identifies fields in protocol headers that are constant, predictable (like sequentially incrementing sequence numbers), or inferable from other layers, and suppresses their transmission after initial synchronization.

The architecture involves a compressor (in the transmitting node, e.g., UE or gNB) and a decompressor (in the receiving node). They maintain synchronized compression contexts, which are sets of information about the header fields of the packet flow. ROHC operates in several states (modes) to trade off efficiency for robustness: Initialization and Refresh (IR) state, where full headers are sent to establish context; First Order (FO) state, where dynamic fields are compressed using patterns; and Second Order (SO) state, where only a small Context Identifier (CID) and cyclic redundancy check (CRC) are sent for very high compression. The protocol uses multiple feedback channels (acknowledged, unacknowledged, and bidirectional optimistic modes) to handle errors and ensure context synchronization even over lossy radio links.

How it works for a typical VoIP (RTP/UDP/IP) packet: The first packet is sent with a full header (IR packet). The decompressor learns the static fields (IP addresses, ports) and the changing pattern of dynamic fields (RTP sequence number, timestamp). For the next packet, the compressor sends a compressed header containing a small CID and encoded differences (deltas) for the dynamic fields. In the most efficient state, it may send only a 1-byte header with a CRC. If the decompressor detects an error via CRC or sequence number gap, it can request a context update via feedback or wait for a periodic refresh. ROHC defines specific profiles for different protocol stacks (e.g., Profile 0x0001 for RTP/UDP/IP, Profile 0x0002 for UDP/IP, Profile 0x0006 for TCP/IP). 3GPP specifications detail how ROHC is integrated into the PDCP layer, including context management during handover and bearer setup.

Purpose & Motivation

ROHC was created to solve the severe inefficiency of transmitting full IP headers over low-bandwidth, high-latency, and error-prone wireless links. In the early 2000s, as 3G networks began carrying IP traffic, it became apparent that the overhead of IPv4 (20 bytes) or IPv6 (40 bytes), plus UDP (8 bytes) and RTP (12 bytes), could be larger than the voice payload itself for VoIP. This wasted scarce radio spectrum and increased packet delay. Pre-ROHC solutions were less robust to packet loss and had limited compression efficiency.

The motivation for standardizing ROHC within 3GPP was to enable efficient support of real-time services like Voice over IP (VoIP) and video streaming over cellular networks. It directly addresses the problem of low spectral efficiency for small-packet, delay-sensitive traffic. By reducing header sizes from 40-60 bytes to as little as 1-4 bytes, ROHC can double or triple the effective capacity for voice calls. Its robustness to packet loss—a key design goal—ensures reliable decompression even when radio link conditions degrade, preventing context desynchronization which would cause catastrophic failure. Its adoption from Release 5 (HSDPA) through to 5G NR demonstrates its enduring value in conserving radio resources and reducing latency, which is critical for network capacity and user experience.

Key Features

  • Framework for compressing IP, UDP, RTP, ESP, and TCP headers
  • Operates with multiple compression states (IR, FO, SO) for efficiency/robustness trade-off
  • Uses compression contexts synchronized between compressor and decompressor
  • Supports multiple robustness modes (Unidirectional, Bidirectional Optimistic, Bidirectional Reliable)
  • Defines specific profiles for different protocol stack combinations
  • Integrated into the 3GPP PDCP layer for operation over Uu and radio interfaces

Evolution Across Releases

Rel-5 Initial

Initial adoption for UTRAN (HSPA). Specified as part of the PDCP layer in TS 25.323. Introduced support for compressing RTP/UDP/IP headers to enable efficient VoIP over HSDPA. Established the basic procedures for context establishment, refresh, and handover handling within the UMTS architecture.

Enhanced integration for LTE (E-UTRAN). Defined in TS 36.323 for LTE PDCP. Introduced support for additional profiles and improved handling for the evolved architecture. ROHC became a mandatory feature for VoIP support in LTE, with optimizations for the new radio interface and bearer types.

Further enhancements for 5G NR. Specified in TS 38.323 for NR PDCP. Continued support for established ROHC profiles and integration with the new NR service data adaptation protocol (SDAP) and QoS flow framework. Ensured robustness and efficiency for NR's diverse use cases, including enhanced Mobile Broadband (eMBB) and Ultra-Reliable Low Latency Communications (URLLC).

Study and specification related to Integrated Access and Backhaul (IAB). TS 38.174 includes considerations for ROHC operation over multi-hop IAB links, ensuring header compression efficiency is maintained in relay-based deployments.

Ongoing maintenance and potential enhancements in the context of 5G-Advanced. Work may include optimizations for new traffic patterns or further integration with network slicing management, ensuring ROHC remains effective for evolving service requirements.

Defining Specifications

SpecificationTitle
TS 21.905 3GPP TS 21.905
TS 23.280 3GPP TS 23.280
TS 23.479 3GPP TS 23.479
TS 23.792 3GPP TS 23.792
TS 24.301 3GPP TS 24.301
TS 24.379 3GPP TS 24.379
TS 24.380 3GPP TS 24.380
TS 25.323 3GPP TS 25.323
TS 25.331 3GPP TS 25.331
TS 25.912 3GPP TS 25.912
TS 25.993 3GPP TS 25.993
TS 26.517 3GPP TS 26.517
TS 26.935 3GPP TS 26.935
TS 26.936 3GPP TS 26.936
TS 26.937 3GPP TS 26.937
TS 29.116 3GPP TS 29.116
TS 29.468 3GPP TS 29.468
TS 36.300 3GPP TR 36.300
TS 36.302 3GPP TR 36.302
TS 36.306 3GPP TR 36.306
TS 36.323 3GPP TR 36.323
TS 36.331 3GPP TR 36.331
TS 36.509 3GPP TR 36.509
TS 38.323 3GPP TR 38.323
TS 38.331 3GPP TR 38.331
TS 43.051 3GPP TR 43.051
TS 43.129 3GPP TR 43.129
TS 44.060 3GPP TR 44.060
TS 44.065 3GPP TR 44.065