Embodiments of the present disclosure generally relate to the field of wireless communication systems, and more particularly, to payload header reduction classification for multiprotocol convergence sublayer.
In broadband mobile access technologies such as WiMAX (e.g., IEEE 802.16-2009) and Long-Term Evolution (LTE) (e.g., 3GPP Release 8), the media access control (MAC) layer defines an interface entity or classification sublayer to provide various transforming and/or mapping of external network data to the transport connections in the MAC layer. For example, WiMAX defines a service specific convergence sublayer (CS) to classify the higher layer protocol data unit (PDU) into the appropriate connection for delivery to the MAC peer. In LTE, the packet data convergence protocol (PDCP) sublayer performs similar functions by maintaining a traffic flow template (TFT) to map data packets to corresponding evolved packet system (EPS) bearers.
In IEEE 802.16m, a multiprotocol convergence sublayer has been defined to multiplex several protocols into the same traffic flow connection, such that data traffic from different upper-layer protocols can share the same quality-of-service (QoS) parameters and conserve the number of transport connections. However, there is no ability to multiplex/mix data traffic that requires different header compression or suppression schemes into the same traffic flow connection.
Embodiments will be readily understood by the following detailed description in conjunction with the accompanying drawings. To facilitate this description, like reference numerals designate like structural elements. Embodiments are illustrated by way of example and not by way of limitation in the figures of the accompanying drawings.
In the following detailed description, reference is made to the accompanying drawings which form a part hereof wherein like numerals designate like parts throughout, and in which is shown by way of illustration embodiments that may be practiced. It is to be understood that other embodiments may be utilized and structural or logical changes may be made without departing from the scope of the present disclosure. Therefore, the following detailed description is not to be taken in a limiting sense, and the scope of embodiments is defined by the appended claims and their equivalents.
Various operations may be described as multiple discrete actions or operations in turn, in a manner that is most helpful in understanding the claimed subject matter. However, the order of description should not be construed as to imply that these operations are necessarily order dependent. In particular, these operations may not be performed in the order of presentation. Operations described may be performed in a different order than the described embodiment. Various additional operations may be performed and/or described operations may be omitted in additional embodiments.
For the purposes of the present disclosure, the phrase “A and/or B” means (A), (B), or (A and B). For the purposes of the present disclosure, the phrase “A, B, and/or C” means (A), (B), (C), (A and B), (A and C), (B and C), or (A, B and C).
The description may use the phrases “in an embodiment,” or “in embodiments,” which may each refer to one or more of the same or different embodiments. Furthermore, the terms “comprising,” “including,” “having,” and the like, as used with respect to embodiments of the present disclosure, are synonymous.
The CS 104 may include classifiers 116 to receive, at a CS service access point (SAP) 120 that represents a CS-layer boundary, the data units as service data units (SDU). The classifiers 116 may determine a type of transmission protocol for each received SDU and provide classification processes through Internet protocol (IP) classifier 124 or Ethernet classifier 128.
The classifiers 116 may map incoming SDUs to appropriate service flow connections by referencing a variety of parameters in the SDU and comparing the parameters to predefined classification rules. The parameters may include source address, destination address, source port, destination port, etc. After mapping an SDU to an appropriate service flow connection, the classifier may append the SDU with a flow identifier (FID).
Comparing the parameters to the classification rules may also allow the classifiers 116 to determine whether a particular SDU is associated with a header reduction process. In various embodiments, the classifiers 116 will also append the SDU with a header-reduction indicator that indicates whether a header of the SDU is to be reduced and, if so, what type of reduction process is to be used. The header-reduction indicator may be used to route the SDU to a header reducer 132 or, in the event that the header will not be reduced, directly to an assembler 136.
The header reducer 132 may include a payload header suppression (PHS) suppressor 140 to implement a PHS process on headers of received SDUs. A PHS process may include the removal of header information in the SDU that may be known or otherwise discernable by the receiver or other network entities. For example, various addressing or control information may not change for a fixed communication link. Therefore, this redundant header information is not needed in all SDUs and may be removed. In various embodiments the PHS suppressor 140 may communicate with a complementary entity in a receiver to establish PHS rules for a particular communication session.
The header reducer 132 may also include a robust header compression (RoHC) compressor 144 to implement a RoHC process on headers of received SDUs. A RoHC process may involve the RoHC compressor 144, while in an initialization and refresh (IR) state, transmitting one or more packets with full headers to establish various static fields on both sides of a communication link. The RoHC compressor 144 may then transition into a first-order (FO) state in which static header fields are compressed and dynamic header fields are uncompressed. The RoHC compressor 144 may also transition to a second order (SO) state in which both the static and dynamic fields are compressed.
The assembler 136 may receive the SDUs, either from the header reducer 132 or directly from the classifiers 116, and may assemble a MAC PDU. Assembly of the MAC PDU may include appending, to a received data unit, a type identifier that may be used to identify a transmission protocol and/or an associated header-reduction process of the data unit. In some embodiments, the type identifier may be a value from 1-5 to indicate that an associated SDU has: (1) an IP transmission protocol with no header reduction; (2) an IP transmission protocol with an RoHC process; (3) an IP transmission protocol with a PHS process; (4) an Ethernet transmission protocol with no header reduction; or (5) an Ethernet transmission protocol with a PHS process. The assembly of the MAC PDU may also include other packet formation operations such as providing an encapsulating header with control and address (e.g., MAC address) information.
The assembler 136 may provide the MAC PDU to a MAC SAP 142 that may represent another CS-layer boundary.
In some embodiments, additional/alternative classification information may be communicated through dynamic service addition (DSA) and/or dynamic service change (DSC) messages, which may be communicated prior to the SDUs. For example, multiprotocol CS policy (MCP) bits, communicated in DSA/DSC messages, may provide information about header reduction for each classification rule so that the transmitter and receiver can synchronize and distinguish the appropriate header reduction processes for data traffic from different upper-layer protocols in the same service flow connection. The classification rules may be a set of criteria/parameters that function to group PDUs into different classes.
In some embodiments, the MCP bits may include two bits and may be defined as follows: if bit 0 is set to one for a classification rule, all PDUs of a service flow connection that match this classification rule shall not suppress payload headers; if bit 0 is set to zero for a classification rule, and both the receiver and transmitter support PHS, all PDUs of the service flow connection that match this classification rule shall be prefixed by a PHS index (PHSI) field; if bit 1 is set to one for a classification rule, all PDUs of the service flow connection that match this classification rule shall not compress payload headers using RoHC; and if bit 1 is set to zero for a classification rule, and both the receiver and transmitter support RoHC, all PDUs of the service flow connection that match this classification rule shall be compressed using RoHC.
Some embodiments may include an exclusion condition flag, e.g., a bit, which may be communicated through DSA/DSC messages. The exclusion condition flag may indicate whether header-reduction processes are defined on a per-classification-rule basis, by the MCP bits, or on a per-service-flow basis, by service flow level transmission policy bits.
At block 308, the operation may include identifying a transmission protocol of a particular data unit. In various embodiments, a data unit may have an IP transmission protocol or an Ethernet transmission protocol and may be arranged as an IP packet or Ethernet packet, respectively.
If it is determined, at block 308, the data unit has an Ethernet transmission protocol, the operation may advance to an Ethernet classification at block 312. The Ethernet classification may include accessing parameters of the received Ethernet packet and comparing the accessed parameters to predefined classification rules. The comparing may result in a determination of whether a header reduction process is to be used and, if so, what type. The comparing may also result in a determination of a service flow connection to which the packet is to be mapped. The Ethernet classification may include various identifiers, e.g., FID and/or header-reduction indicator, being appended to the data unit to facilitate routing of the data unit.
At block 316, it may be determined whether PHS processing is to be performed. In some embodiments, this may be determined based on a header-reduction indicator appended to the packet during the Ethernet classification at block 312. If PHS processing is to be performed, the operation may advance to PHS processing at block 320. PHS processing at block 320 may be similar to that described above with respect to the PHS suppressor 140. After PHS processing at block 320 the operation may advance to assembling MAC PDU at block 324.
If it is determined, at block 316, that PHS processing is not to be used, the operation may advance to appending Type ID at block 324. It may be that RoHC processing is not used for Ethernet packets. Therefore, it may not be necessary to do an additional determination as to whether RoHC processing is to be used after block 316.
If it is determined, at block 308, the data unit has an IP transmission protocol, the operation may advance to an IP classification at block 328. The IP classification may include accessing parameters of the received IP packet and comparing the accessed parameters to predefined classification rules. Similar to the Ethernet classification at block 312, the comparing may result in a determining of whether a header reduction process is to be used and, if so, what type, as well as a service flow connection to which the packet is to be mapped. The IP classification may include various identifiers, e.g., FID and/or header-reduction indicator, being appended to the data unit to facilitate routing of the data unit.
Following block 328, the operation may advance to block 332 at which point it may be determined whether PHS processing is to be performed on the packet. Similar to determination at block 316, the determination of block 332 may be based on a header-reduction indicator appended to the packet in accordance with some embodiments. If it is determined that PHS processing is to be performed, the operation may advance to PHS processing at block 320. However, if it is determined that PHS processing is not to be performed, the operation may proceed to block 336.
At block 336 it is determined whether RoHC processing is to be performed. Similar to determination at block 332, the determination at block 336 may be based on a header-reduction indicator appended to the packet in accordance with some embodiments. If it is determined that RoHC processing is to be performed, the operation may advance to RoHC processing at block 340. RoHC processing at block 340 may be performed in a manner similar to that described above with respect to the RoHC compressor 144. After RoHC processing at block 340 the operation may advance to assembling MAC PDU at block 324.
At block 324, a Type ID, which provides information related to the transmission protocol and/or header reduction process, may be appended to the SDU. In embodiments in which a header-reduction indicator was previously provided, for routing within components of the multiprotocol CS layer, the header-reduction indicator may be removed in favor of the Type ID. As described above, the Type ID may be one of five values in accordance with some embodiments.
Assembling MAC PDU at block 324 may further include creation and addition of an encapsulating header to facilitate communication of the data unit between network peers, e.g., MAC SAP 142 and a MAC SAP of a receiver. The MAC PDU, which may also include the FID, Type ID, and the SDU, as shown in
The CS 404 may include a decapsulator 416 to receive, at a MAC SAP 420, data units as PDUs. The decapsulator 416 may reference a Type ID of the individual data units to determine an associated transmission protocol and transmit the data unit to the appropriate one of either an IP reconstructor 424 or an Ethernet reconstructor 428 (collectively referred to as “reconstructors 432”). In some embodiments, the decapsulator 416 may remove the Type ID from a data unit and append a header-reduction indicator to facilitate routing through the CS 404. In other embodiments, the type ID may remain appended to the data units to facilitate subsequent routing through the CS 404 and removed at a later time.
The reconstructors 432 may reconstruct the data units as protocol packets according to respective transmission protocol stacks. The reconstruction may include various packet assembling, addressing, and controlling processes.
The reconstructors 432 may determine whether a header-reduction process was performed on the data unit by referencing the header-reduction indicator or Type ID. If a header-reduction process was performed, the reconstructors 432 may transmit the data unit to a header expander 436, else the reconstructors 432 may transmit the data unit directly to a CS SAP 440, which may provide the data unit, as an SDU, to a UL entity 444.
The header expander 436 may expand a header by a header-expansion process that complements a header-reduction process implemented by the header reducer 132. The header expander 436 may include a PHS de-suppressor 448 to perform a PHS process that complements the PHS process performed by PHS suppressor 140. The PHS de-suppressor 448 may expand a previously-suppressed header of a data unit according to PHS rules established through communications with the PHS suppressor 140.
The header expander 436 may also include a RoHC decompressor 452 to perform a RoHC process that complements the RoHC process performed by the RoHC compressor 144. The RoHC decompressor 452 may expand a previously-compressed header of a data unit according to parameters established with the RoHC compressor 144 during an initial setup, IR state, and/or FO state.
At block 508, the operation may include decapsulating a PDU. The decapsulating of the PDU may involve interpretation and removal of an encapsulating header from the PDU that was provided for successful communication of the data unit between network peers, e.g., MAC SAP 140 and MAC SAP 420.
At block 512, the operation may include identifying a transmission protocol of the data unit. The transmission protocol may be identified by referencing the Type ID appended to the data unit. If it is determined that the transmission protocol is an Ethernet protocol, the operation may advance to reconstructing an Ethernet packet at block 520. The Ethernet packet may be reconstructed through an Ethernet protocol stack.
Following reconstruction of an Ethernet packet, the operation may proceed to determining whether a PHS process had been performed on the Ethernet packet at block 524. The determining at block 524 may be accomplished by referencing a Type ID and/or header-reduction indicator. If it is determined, at block 524, that a PHS process had been performed on the Ethernet packet, the operation may advance to de-suppressing header at block 528. A header of the Ethernet packet may be de-suppressed according to pre-established PHS rules.
Following de-suppression of the header, the operation may advance to providing the packet to UL entity at block 532. The packet may be provided to the UL entity at a CS SAP. In some embodiments, a Type ID and/or header-reduction indicator may be removed at or prior to the providing of the packet to UL entity at block 532.
If, at block 524, it is determined that a PHS process had not been performed on the Ethernet packet, the operation may advance to block 532. As described above, it may be that RoHC processes are not performed on Ethernet packets; therefore, it may not be necessary to provide an additional determination, following a negative determination in block 524, as to whether a RoHC process was used.
If, at block 512, it is determined that the transmission protocol is an IP protocol, the operation may advance to reconstructing IP packet at block 520. The IP packet may be reconstructed through an IP protocol stack.
Following reconstruction of an IP packet at block 536, the operation may proceed to determining whether a PHS process had been performed on the IP packet at block 540. The determining at block 540 may be similar to determining at block 524.
If it is determined, at block 540, that a PHS process had been performed on the IP packet, the operation may advance to de-suppressing header at block 528.
If it is determined, at block 540, that a PHS process had not been performed on the IP packet, the operation may advance to determining whether a RoHC process had been performed on the IP packet at block 544. The determining at block 544 may be accomplished by referencing a Type ID and/or a header-reduction indicator. If it is determined that a RoHC process has not been performed at block 544, the operation may proceed to the providing of the packet to the UL entity at block 532.
If it is determined, at block 544, that a RoHC process had been used, the operation may advance to decompressing header at block 548. The decompression of the header may be performed according to predetermined compression parameters, e.g., parameters established with a RoHC compressor during an initial setup, an IR state, and/or an FO state.
In various embodiments, the transmitter 100 and receiver 400 may be configured to communicate according to a wireless broadband mobile access technology standard such as WiMAX (e.g., IEEE 802.16-2009) or Long-Term Evolution (LTE) (e.g., 3GPP Release 8).
The CS and its associated entities described herein may be implemented into a system using any suitable hardware and/or software to configure as desired.
System control logic 608 for one embodiment may include any suitable interface controllers to provide for any suitable interface to at least one of the processor(s) 604 and/or to any suitable device or component in communication with system control logic 608.
System control logic 608 for one embodiment may include one or more memory controller(s) to provide an interface to system memory 612. System memory 612 may be used to load and store data and/or instructions, for example, for system 600. System memory 612 for one embodiment may include any suitable volatile memory, such as suitable dynamic random access memory (DRAM), for example.
System control logic 608 for one embodiment may include one or more input/output (I/O) controller(s) to provide an interface to NVM/storage 616 and communications interface(s) 620.
NVM/storage 616 may be used to store data and/or instructions, for example. NVM/storage 616 may include any suitable non-volatile memory, such as flash memory, for example, and/or may include any suitable non-volatile storage device(s), such as one or more hard disk drive(s) (HDD(s)), one or more compact disk (CD) drive(s), and/or one or more digital versatile disk (DVD) drive(s) for example.
The NVM/storage 616 may include a storage resource physically part of a device on which the system 600 is installed or it may be accessible by, but not necessarily a part of, the device. For example, the NVM/storage 616 may be accessed over a network via the communications interface(s) 620.
System memory 612 and NVM/storage 616 may include, in particular, temporal and persistent copies of CS logic 624, respectively. The CS logic 624 may include instructions that when executed by at least one of the processor(s) 604 result in the system 600 performing CS operations described herein. In some embodiments, the CS logic 624 may additionally/alternatively be located in the system control logic 608.
Communications interface(s) 620 may provide an interface for system 600 to communicate over one or more network(s) and/or with any other suitable device. Communications interface(s) 620 may include any suitable hardware and/or firmware. Communications interface(s) 620 for one embodiment may include, for example, a network adapter, a wireless network adapter, a telephone modem, and/or a wireless modem. For wireless communications, communications interface(s) 620 for one embodiment may use one or more antennae.
For one embodiment, at least one of the processor(s) 604 may be packaged together with logic for one or more controller(s) of system control logic 608. For one embodiment, at least one of the processor(s) 604 may be packaged together with logic for one or more controllers of system control logic 608 to form a System in Package (SiP). For one embodiment, at least one of the processor(s) 604 may be integrated on the same die with logic for one or more controller(s) of system control logic 608. For one embodiment, at least one of the processor(s) 604 may be integrated on the same die with logic for one or more controller(s) of system control logic 608 to form a System on Chip (SoC).
In various embodiments, system 600 may have more or less components, and/or different architectures.
Although certain embodiments have been illustrated and described herein for purposes of description, a wide variety of alternate and/or equivalent embodiments or implementations calculated to achieve the same purposes may be substituted for the embodiments shown and described without departing from the scope of the present disclosure. This application is intended to cover any adaptations or variations of the embodiments discussed herein. Therefore, it is manifestly intended that embodiments described herein be limited only by the claims and the equivalents thereof.