1. Field of the Invention
Example embodiments of the present invention relate generally to improving efficiency of transmission over a backhaul of a wireless communications network.
2. Description of the Related Art
The interface 18 between the BTS 12 and the RNC 14 is often called the backhaul. In particular, the interface 18 typically includes multiple T1/E1 lines connected between the BTS 12 and the RNC 14 for carrying packet data (e.g., IP packet data) between the BTS 12 and the RNC 14. Packet data flowing from the BTS 12 to the RNC 14 is said to flow over the reverse link, and packet data flowing from the RNC 14 to the BTS 12 is said to flow over the forward link. Typically, the transmission of packet data between the BTS 12 and the RNC 14 follows the well-known Remote Method Invocation (RMI) protocol. The RMI protocol is a hierarchal protocol placed on top of the UDP/IP packets being sent between the BTS 12 and the RNC 14. Namely, each protocol generally consists of a payload and associated header, and the previous protocol becomes nested inside the subsequent protocol as at least part of the payload for the subsequent protocol. The nested protocols are often referred to as a stack.
Backhaul packet transport efficiency is expressed as a ratio of the user payload to the sum of the user payload and the overhead (e.g., headers for payloads according to each protocol) for transporting this payload. For large data packets, the full RMI/UDP/IP protocol stack results in relatively high efficiency. However, overhead of the full stack is not negligible and the backhaul transport efficiency drops dramatically when smaller packets are sent.
For example, Voice over IP (VOIP) and Push to Talk (PTT) applications are expected to dramatically increase the volume of small packets on both the forward and reverse links. As discussed above, T1 carriers are used for backhaul transport. Inefficient transport would result in a large cost increase as more T1s are needed to handle the increase backhaul load.
The present invention relates a method of managing header compression.
In one embodiment, the method includes determining, at a first network element, whether to turn on compression of a header for a packet transport protocol used for a communication flow between the first network element and a second network element. The determining is based on a type of the communication flow, and the packet transport protocol is a protocol for transport of packets between the first and second network elements. The method further includes sending a compression mode indictor to the second network element along with a context identifier. The compression mode indicator indicates the determination, and the context identifier for use in identifying the communication flow.
Another embodiment of the method includes receiving, from a first network element, at least a forward link compression mode indictor and a reverse link context identifier at a second network element. The forward link compression mode indicator indicates whether compression of a header for a packet transport protocol has been turned on for packets of a communication flow over a forward link. The packet transport protocol is a protocol for transport of packet between the first and second network elements. The reverse link is communication flowing from the second network element to the first network element. The reverse link context identifier is for use in identifying the communication flow on the reverse link. The forward link is communication flowing from the first network element to the second network element. The method further includes determining a forward link context identifier based on the forward link compression mode indicator, the forward link context identifier for use in identifying the communication flow on the forward link, and sending the forward link context identifier to the first network element.
The present invention further relates to a method of processing a packet data flow.
In one embodiment, the method includes determining whether compression of a header for a packet transport protocol between a first network element and a second network element has been turned on for a communication flow between the first network element and the second network element. A compressed header that includes a context identifier is generated if the determining step determines that compression has been turned on. The context identifier is for use in identifying the communication flow. Another embodiment includes receiving a packet according to a transport protocol for packet communication between a first network element and a second network element. Whether a header of the packet has been compressed is then determined. The header is decompressed based on a context identifier in the compressed header if the determining step determines the header has been compressed. The context identifier identifies a communication flow between the first network element and the second network element.
The present invention will become more fully understood from the detail 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:
Example embodiments will now be described more fully with reference to the accompanying drawings. However, example embodiments may be embodied in many different forms and should not be construed as being limited to the example embodiments set forth herein. Example embodiments are provided so that this disclosure will be thorough, and will fully convey the scope to those who are skilled in the art. In some example embodiments, well-known processes, well-known device structures, and well-known technologies are not described in detail to avoid the unclear interpretation of the example embodiments. Throughout the specification, like reference numerals in the drawings denote like elements.
It will be understood that when an element or layer is referred to as being “on”, “connected to” or “coupled to” another element or layer, it may be directly on, connected or coupled to the other element or layer, or intervening elements or layers may be present. In contrast, when an element is referred to as being “directly on,” “directly connected to” or “directly coupled to” another element or layer, there may be no intervening elements or layers present. As used herein, the term “and/or” includes any and all combinations of one or more of the associated listed items.
It will be understood that, although the terms first, second, third, etc. may be used herein to describe various elements, components, regions, layers and/or sections, these elements, components, regions, layers and/or sections should not be limited by these terms. These terms may be only used to distinguish one element, component, region, layer or section from another region, layer or section. Thus, a first element, component, region, layer or section discussed below could be termed a second element, component, region, layer or section without departing from the teachings of the example embodiments.
Spatially relative terms, such as “beneath”, “below”, “lower”, “above”, “upper” and the like, may be used herein for ease of description to describe one element or feature's relationship to another element(s) or feature(s) as illustrated in the figures. It will be understood that the spatially relative terms may be intended to encompass different orientations of the device in use or operation in addition to the orientation depicted in the figures. For example, if the device in the figures is turned over, elements described as “below” or “beneath” other elements or features would then be oriented “above” the other elements or features. Thus, the example term “below” can encompass both an orientation of above and below. The device may be otherwise oriented (rotated 90 degrees or at other orientations) and the spatially relative descriptors used herein interpreted accordingly.
The terminology used herein is for the purpose of describing particular example embodiments only and is not intended to be limiting. As used herein, the singular forms “a”, “an” and “the” may be intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
Unless otherwise defined, all terms (including technical and scientific terms) used herein have the same meaning as commonly understood by one of ordinary skill in the art. It will be further understood that terms, such as those defined in commonly used dictionaries, should be interpreted as having a meaning that is consistent with their meaning in the context of the relevant art and will not be interpreted in an idealized or overly formal sense unless expressly so defined herein.
The BTS 12′ is the same as the BTS 12 of
The conventional RMI header is 44 bytes long. The first 2 bytes conventionally contain the length field that indicates the total length of the RMI packet. However, many of the fields in the RMI header remain static. According to embodiments of the present invention, the static fields are stored at the BTS 12′ and/or RNC 14′ in association with a respective context identifier for the communication flow. The RMI header may then be compressed at the RNC 14′ or the BTS 12′, and then decompressed at the other of the BTS 12′ or the RNC 14′.
In compressing the RMI header, the RMI header may be compressed or reduced to 7 bytes. The first two bytes provide a compression mode indicator, compression level indicator and the context identifier. The compression mode indicator may be the most significant bit of the RMI header, and indicates whether the header is compressed or not. If the most significant bit is set, for example, to 1, this indicates compression. However, if the most significant bit is not set (e.g., is a 0), then this indicates no header compression, and the first two bytes represent the length of the RMI packet.
The second bit in the first two bytes of the RMI header indicates the compression level. The fields which will remain static during a communication flow may depend on factors regarding the state of the AT 10. For example, mobility is one of the factors regarding the state of the AT 10 that may influence compression. If the AT has moved from one cell to another, and is involved in a hand-off, there will be fewer static fields then if the AT 10 is being served by a single BTS 12′. As a result, there may be at least two different levels of compression desired based on the state of AT. In particular, when the AT 10 is not involved in a hand-off, the RMI header may be compressed down to 7 bytes. However, if the AT is involved in a hand-off, than the RMI header is compressed down to 9 bytes. Furthermore, instead of implementing this lesser compression on both the forward link and the reverse link, the lesser compression may be implemented on only one of the forward link and the reverse link. As briefly mentioned above, to indicate the level of compression, the second bit of the RMI header is used. In particular, if this second bit is not set, then full compression is indicated, and the RMI header will be compressed to the 7 byte header. However, if the second bit of the RMI header is set, then the RMI header will be compressed down to the 9 bytes. As will be appreciated, the context identifier of the forward link and reverse link may be reduced to less than 14 bits such that the compression level indicator may be increased to greater than 1 bit; and thus, indicate different levels of compression. It will further be appreciated, that the levels of compression may be predetermined and stored at the BTS 12′ and the RNC 14′ such that each of the BTS 12′ and RNC 14′ knows, a priori, the level of RMI header compression to perform based on the compression level indicator.
The remaining 14 bits in the first two bytes of the RMI header provide the context identifier. As will be described in detail below, the context identifier for a communication flow depends on whether the flow is over the forward link or reverse link. Namely, the reverse link context identifier identifies the communication flow over the reverse link and the forward link context identifier identifies the communication flow over the forward link. In decompressing the RMI header, the context identifier in the compressed RMI header is used to access the stored static fields for the communication flow, and these fields are used to reconstruct the full RMI header.
Next operation of the BTS 12′ and RNC 14′ will be described in detail below with respect to
Next in step S42, if the reverse link compression mode has been set to on, processing proceeds to step S44. In step S44, the RNC 14′ computes the reverse link context identifier based on the session identifier. As is well-known, each active flow has a session at the RNC 14′. Namely, information particular to the flow such as the protocol negation at the various layer, etc. is stored at the RNC and referred to as a session. Furthermore, an identifier is assigned to the session and referred to as the session identifier. The reverse link context identifier may be the same as, a portion of, or include a portion of the session identifier. Alternatively, the reverse link context identifier may be a permutation of the session identifier or derived based on a function using the session identifier.
If in step S42 the reverse link compression mode is not on, then in step S46 the RNC 14′ sets the reverse link context ID to null.
Returning to
In response to the allocate traffic channel request, the BTS 12′ allocates resources in the conventional or any well-known manner. The BTS 12′ also determines the forward link (FL) context identifier.
As discussed above, the context identifier, whether forward link or reverse link, is 14 bits long. In the forward link, the most significant 4 to 6 bits may be used as the flow identifier. For example, if 4 bits are used as the flow identifier, then 16 flows per AT are supported. The remaining 8 to 10 bits are the same as the 8 to 10 least significant bits as the traffic channel element ID.
Returning to step S52, if the forward link compression mode from the RNC 14′ is not indicated as being on, then in step S56 the forward link context is set to null.
Returning to
Having received the allocate traffic channel response, the RNC 14′ sends an open flow response to the AT 10, which is transferred to the AT 10 by the BTS 12′. At this point, communication flow takes place, and will be described in further detail below with respect to
Next, processing of the packet data on the reverse link will be described. As will be appreciated, the AT 10 sends packet data to the BTS 12′. The BTS 12′ then processes the packet data based on the reverse link compression mode and/or the compression level.
Next, in step S76, the BTS 12′ employs the compressor 20 to compress the RMI header in accordance with the compression level. For example, if the AT 10 is not involved in a hand-off, then the RMI header may be compressed down to 7 bytes. The last 5 bytes are the non-static fields of the conventional RMI header. The first 2 bytes consist of the compression indicator, the compression level indicator and the reverse link context ID. In particular, the first bit of the RMI header serves as the compression indicator, and is selectively set to indicate that compression has occurred. At least the second bit of the RMI header serves as the compression level indicator, and is selectively set to indicate full compression (no hand-off) or partial compression (hand-off). The reverse link context ID received from the RNC 14′ and stored at the BTS 12′ fills out the remaining bits. Then, in step S76 the packet is sent with the compressed header. It will be appreciated that conventionally, the length indicator of an uncompressed RMI header does not have the most significant bit set as a “1”; and hence, is easily used as the compression indicator. However, it will also be appreciated that other bit positions in the RMI header could be used for not only the compression indicator, but also the compression level indicator and the context identifier.
Returning to step S72, if the reverse link compression mode is not on, then in step S77, the BTS 12′ sends the packet data with an uncompressed RMI header in the conventional manner.
As shown, in step S80 a packet is received. Then, in step S82 the RNC 14′ determines whether or not the RMI header has been compressed. In particular, the RNC 14′ determines from the first bit of the RMI header whether or not the RMI header has been compressed. If the first bit is set, than the RNC 14′ determines that the RMI header has been compressed. If the first bit of the RMI header is not set, then the RNC 14′ determines that the RMI header has not been compressed.
Assuming the RMI header has been compressed, then in step S84, the RNC 14′ determines the compression level. The compression level is indicated by the second bit in the RMI header. In accordance with the example of
In step S86, the decompressor 22 of the RNC 14′ decompresses the RMI header in accordance with the determined compression level. Namely, the decompressor 22 uses the reverse link context identifier to identify the communication flow and access the stored static fields. A full RMI header is constructed using the accessed static fields. For example, if the AT 10 is not involved in a hand-off, then to the 7 byte compressed RMI header, the decompressor 22 adds the other 37 static bytes. However, if the AT 10 is involved in a hand-off and the lesser compression is used, then to the 9 byte compressed RMI header, the decompressor 22 adds the static bytes. The RNC 14′ then processes the decompressed packet in the conventional manner in step S88.
If in step S82 the RMI header is not compressed, then in step S87, the RNC 14′ processes the uncompressed packet in the conventional manner.
The forward link data packet processing is the same as discussed above with respect to
As will be appreciated in the above discussion, by compressing the conventional 44 byte RMI header down to 7 bytes, or in some cases 9 bytes, the transport efficiency between the BTS and RNC is significantly improved.
The invention being thus described, it will be obvious that the same may be varied in many ways. For example, while embodiments of the present invention were described with respect to an EVDO system, it will be appreciated that the present invention is not limited to this system. 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.