As the momentum for enabling voice over IP (VoIP) in 3G systems such as UMTS grows, operators will be concerned with maximizing the air interface capacity to maximize revenue. While VoIP simplifies core network design and adds new and valuable services compared to traditional circuit switch (CS) voice, VoIP also inherently adds additional overhead in the form of large headers.
Next, a user data protocol (UDP) and version 6 internet protocol (IPv6) layer 14 adds, according to UDP, another 8 bytes of header to indicate, for example, source/destination port numbers and a checksum (mandatory for IPv6); and then adds 40 bytes of header (e.g., routing information for each packet) according to IPv6.
Therefore the original 159 bit speech packet becomes 656 bits, which is an overhead of over 300%. Fortunately, it is not necessary to transmit the enormous header for each voice packet over the air interface all the time. 3GPP Release 5 mandates that the robust header compression (RoHC) specified in RFC 3095 be supported in the packet data convergence protocol (PDCP) layer 16 of UMTS. Namely, the PDCP layer 16 in the protocol stack for transmission will include a compressor 17 operating according to RoHC, while the PDCP layer in the protocol stack for reception will include a decompressor operating according to RoHC. As is known, the protocol stack for reception is opposite and complementary to the protocol stack for transmission, and is shown in
The principle behind header compression is that most of the fields in the RTP/UDP/IPv6 header are static; hence they can be sent once uncompressed at call setup from the compressor on the transmission side to the decompressor at the reception side. Once the decompressor has reliably acquired the static information, the compressor starts sending compressed headers carrying information regarding the dynamic parts of the RTP/UDP/IPv6 header. From the compressed header the decompressor is able to fully reconstruct the RTP/UDP/IPv6 header and pass it on to the peer application. In this way, the large RTP/UDP/IPv6 headers are not transmitted over the UMTS air interface for each voice packet, leading to tremendous savings in capacity.
As stated above, unfortunately, the 2 byte UDP checksum is uncompressible and sent in every voice packet over the air. While slightly larger headers are sent sometimes to update certain header fields, the vast majority of the time RoHC will operate with just 3 bytes of compressed header (1 byte R-0+2 bytes UDP checksum).
The output of the PDCP layer 16 is sent to the radio link control (RLC) layer 18. The RLC layer 18 may operate in a transparent mode or unacknowledged mode (UM). The unacknowledged mode is used in the packet switched (PS) domain of UMTS, and in this mode, an additional 1 byte of RLC UM header is added to the voice packet. This results in a total overhead of 4 bytes.
Subsequently, the medium access control (MAC)-d layer 20 performs transport format selection and routes the appropriate number of RLC packet data units (PDUs) from the RLC layer to the physical (PHY) layer 24. Unless logical channel multiplexing is used (not considered here), the MAC-d layer 20 does not add additional header overhead. In the case the high speed downlink packet access (HSDPA) channel is used in the downlink direction, packets flow from the MAC-d layer 20 to the MAC-hs layer 22, which performs user scheduling, rate selection, and hybrid automatic repeat request (HARQ). In case the enhanced dedicated channel (E-DCH) is used in the uplink direction, then packets flow from the MAC-d layer 20 to the MAC-e layer 22, which performs rate selection, multiple flow multiplexing, and HARQ. The MAC-hs/MAC-e layer 22 header size is variable, but typically adds approximately 20 bits of header when carrying a single MAC-d PDU. Finally, the physical (PHY) layer 24 adds its own error detection mechanism by attaching CRC bits, and transmits the data packet over the air.
Focusing just on the RoHC overhead of 3 bytes, this results in a 15% overhead in the size of each voice packet for an AMR 7.95 kbps vocoder, and a 20% overhead for AMR 5.9 kbps vocoder. Therefore even with RoHC, there is a significant penalty to pay when carrying voice over IP.
The present invention provides techniques to further reduce or compress the resulting RoHC header on the transmission side and decompress the header on the reception side.
In at least one embodiment, the one-byte RTP header that would remain after conventional RoHC is eliminated.
In at least other embodiments, the UDP checksum that would remain after conventional RoHC is eliminated.
In a further embodiment, both of these techniques are employed, which results in a zero-byte RoHC header, referred to as zero-byte header compression.
The present invention will become more fully understood from the detailed description given herein below and the accompanying drawings which are given by way of illustration only, wherein like reference numerals designate corresponding parts in the various drawings, and wherein:
Next, embodiments of the present invention will be described in detail. First, methods of compressing and decompressing the R-0 header portion of the compressed RoHC header will be described. Then, methods of compressing and decompressing the UDP checksum portion of the UDP header will be described.
Referring to
Accordingly, compression of the R-0 header on the uplink will first be described followed by compression of the R-0 header on the downlink.
Compression
In the uplink, packets are delivered to the RoHC compressor in the UE in order. Accordingly, the RLC UM sequence numbers will set forth the same packet order as the RTP sequence numbers. Accordingly, in this embodiment, the compressor 17 at the PDCP layer 16 is modified to eliminate the R-0 header, which includes the 2 bit packet identifier and the 6 least significant bits of the sequence number for the RTP packet.
Decompression
As discussed above, the protocol stack for reception is opposite and complementary to the protocol stack for transmission. This is shown in
Alternatively, given that the RTP sequence numbers are used to identify missing RTP packets, and hence it is the relative sequence numbers between packets that really matters and not the absolute sequence number, the RLC UM sequence number may be used directly for the purpose of generating an RTP sequence number to use in the reconstructed RTP header. For example, in one embodiment, the RTP sequence number could be reconstructed by using as its 6 least significant bits the 6 least significant bits of the RLC UM sequence number. As another example, no reconstruction takes place, and instead the RLC UM sequence numbers are supplied to the algorithm for detecting missing RTP packets or the algorithm for dealing with missing RTP packets (e.g., an algorithm that corrects for the missing RTP packets in some manner).
Compression
In a first embodiment for compression of the RoHC R-0 header in the downlink, the PDCP layer for transmission is modified to include a reordering buffer.
Decompression
Because the packets are in order, the RLC UM sequence numbers may used by the decompressor at the reception side in the same manner described above with respect to the uplink case.
Compression
In this second embodiment, the PDCP layer 16 may be modified to influence the determination of the RLC UM sequence number. More specifically, the PDCP layer 16 may send an indication to the RLC UM layer 18 indicating an out of order or missing RTP sequence number. Namely, the PDCP layer 16 may monitor the sequence of RTP sequence numbers and convey this sequence to the RLC UM layer 18. In this manner, out of order or missing RTP sequence numbers are communicated to the RLC UM layer 18. The RLC UM layer 18 may then generate RLC UM sequence numbers such that the sequence of RLC UM sequence numbers corresponds to the sequence of RTP sequence numbers. For example, the sequence of RLC UM sequence numbers will be out of order or missing in the same manner as the sequence of RTP sequence numbers. As such, the R-0 header may then be eliminated by the compressor 17 at the PDCP layer 16.
Decompression
On the reception side, the RoHC decompressor may properly regenerate the RTP sequence numbers or follow any of the other embodiments described above with respect to decompression on the uplink. Also, the RLC UM protocol may need to be amended to allow a mode which can deliver packets out of order to higher layers to avoid additional delay.
The UDP checksum is mandatory with IPv6, hence there is no option to disable the UDP checksum (as is possible in IPv4). The IETF has recognized that certain applications (such as voice and real-time video) can benefit by having damaged data delivered rather than having the packets discarded by the network. Hence, the IETF has introduced UDP-Lite, which provides a partial checksum for the UDP payload that allows only a specific portion of the payload, such as the UDP-Lite and IP headers, to be checked for errors. The UDP-Lite header is well-known and illustrated in
The advantage in having only the UDP-Lite and IP header covered by the checksum is that these fields are static as far as RoHC is concerned, and therefore, the UDP-Lite checksum is also static. Accordingly, these headers are initially sent uncompressed to the decompressor, and thereafter, the need to send the UDP checksum with every voice packet is eliminated. The IETF RFC 4019 defines the RoHC profile for UDP-Lite. For VoIP, it is not expected that the coverage field of the UDP-Lite header would change during the session, hence the entire UDP-Lite header becomes static and fully compressible.
Unfortunately, not all applications would necessarily choose to use UDP-Lite, nor is it guaranteed that UDP-Lite is available as a transport mechanism. In those cases, regular UDP may be used and the UDP checksum would not be static; forcing the transmission of the UDP checksum over the air interface with every voice packet. For this situation, two embodiments will be described below that avoid having to send the UDP checksum over the air interface.
Compression
According to this embodiment, on the transmission side, the compressor 17 may be modified to strip off the UDP checksum, and the data packet is sent without the UDP checksum. In another variation of this embodiment, the RoHC compressor 17 may be modified to first verify the checksum to make sure that the checksum does not fail before sending the packet. If the checksum fails the packet is dropped at the compressor 17. However, if the checksum is verified, then the checksum may be stripped off during compression.
Decompression
At the reception side, the decompressor may be modified to re-compute the checksum. The checksum is generated as specified in the UDP. Namely, the RoHC decompressor mimics the UDP layer and re-computes the checksum based on the received packet. The computed checksum is then inserted into the UDP header to fully reconstruct the UDP header.
Both the compression and decompression methodologies discussed above may be employed for the uplink and the downlink.
A second embodiment of the present invention enforces the use of UDP-Lite to avoid sending the UDP checksum over the air interface.
Compression
In this embodiment, the compressor 17 in the PDCP layer 16 may be modified to convert regular UDP to UDP-Lite. To convert UDP to UDP-Lite, the compressor 17 overwrites the 2-byte length field in the UDP header to form the 2-byte coverage field in UDP-Lite, changes the IP identifier in the IPv6 header to a value of indicating UDP-Lite (e.g., 136 in IPv6), re-computes a checksum based on a desired coverage, and replaces the UDP checksum with the re-computed checksum. The 2-byte length field in regular UDP now becomes a 2-byte coverage field for the checksum in UDP-Lite, and the RoHC compressor can specify that the coverage of the checksum is only the UDP-Lite and IP headers. As the checksum is now a static value (does not depend on dynamic information), it no longer needs to be sent over the air interface with every voice packet. Namely, the RoHC will eliminate the checksum along with the rest of the UDP-Lite header.
Decompression
At the reception side, if the application that will receive the packet (e.g., the peer application) supports UDP-Lite, then the decompressor may operate in the conventional manner. However, if the application that will receive the packet only supports UDP, then the decompressor may operate in a modified manner and convert UDP-Lite to UDP. Namely, the decompressor changes the IP identifier in the IPv6 header to indicate UDP, re-computes the UDP checksum to cover the entire packet, replaces the UDP-Lite checksum with the UDP checksum, and overwrites the 2-byte coverage field with the 2-byte length information required for the UDP header.
The compression and decompression methods may be employed on the uplink and the downlink. However, in another embodiment, support for UDP-Lite may be made mandatory in the UE (e.g., mobile phone, PDA, computer, etc.). Since the UE supports UDP-Lite from requirement, when transmitting, no conversion to UDP-Lite is required. And, when receiving, no conversion to UDP from UDP-Lite is required. Namely, the UE will be able to operate properly, not ever knowing that the original application was using regular UDP and not UDP-Lite.
As will be appreciated, the compression and decompression methods for eliminating the R-0 header and the UDP checksum may be employed together such that together with conventional RoHC, the RTP/UDP/IPv6 header is completely eliminated. For an AMR 7.95 kbps vocoder, the addition of the techniques according to the present invention result in an additional 15% reduction in overhead. For an AMR 5.9 kbps vocoder, the reduction in overhead is an additional 20%. This reduction in overhead can be used to allow for greater VoIP capacity over the UMTS air interface.
The invention being thus described, it will be obvious that the same may be varied in many ways. Such variations are not to be regarded as a departure from the invention, and all such modifications are intended to be included within the scope of the invention.
Number | Name | Date | Kind |
---|---|---|---|
6118784 | Tsuchiya et al. | Sep 2000 | A |
6999429 | Hannu et al. | Feb 2006 | B1 |
7009951 | Kalliokulju et al. | Mar 2006 | B2 |
7221657 | Bergenlid et al. | May 2007 | B2 |
20040033801 | Yi et al. | Feb 2004 | A1 |
20040095939 | Yang | May 2004 | A1 |
20050287957 | Lee et al. | Dec 2005 | A1 |
20060039358 | Kim | Feb 2006 | A1 |
20070041382 | Vayanos et al. | Feb 2007 | A1 |
Number | Date | Country | |
---|---|---|---|
20070047551 A1 | Mar 2007 | US |