The present application relates generally to wireless communications, and more specifically to systems, methods, and devices for fragmentation of packets in low-speed wireless networks.
In many communication systems, communications networks are used to exchange messages among several interacting spatially-separated devices. Networks may be classified according to geographic scope, which could be, for example, a metropolitan area, a local area, or a personal area. Such networks would be designated respectively as a wide area network (WAN), metropolitan area network (MAN), local area network (LAN), or personal area network (PAN). Networks also differ according to the switching/routing technique used to interconnect the various network nodes and devices (e.g. circuit switching vs. packet switching), the type of physical media employed for transmission (e.g. wired vs. wireless), and the set of communication protocols used (e.g. Internet protocol suite, SONET (Synchronous Optical Networking), Ethernet, etc.).
Wireless networks are often used when the network elements are mobile with dynamic connectivity, or if the network architecture is formed in an ad hoc, rather than fixed, topology. Wireless networks may use electromagnetic waves in the radio, microwave, infra-red, optical, etc. frequency bands. Wireless networks may facilitate improved user mobility and rapid field deployment as compared to fixed wired networks.
The devices in a wireless network may transmit and/or receive information. The information may include packets, which may be referred to as data units (e.g., MAC Service Data Units (MSDUs)). The packets may include overhead information (e.g., header information, packet properties, etc.) that helps in routing the packet through the network, identifying the data in the packet, and processing the packet. The packets may also include a payload that includes data such as user data, multimedia content, etc.
Certain wireless networks have relatively low data transmission rates and may be described as “low-speed” networks. Devices participating in those networks may be constrained to only transmit small packets within a given transmission opportunity window (TXOP). However, data packets, such as those used for Ethernet, are larger than those that can be transmitted in a single TXOP on a low-speed network and therefore such packets may be fragmented and sent piecemeal. Each of the data fragments may be sent in a packet or data frame (e.g., a MAC Protocol Data Unit (MPDU)). A block acknowledgment (ACK) may be sent to acknowledge up to 16 fragments of each of up to 64 data units using a fixed size bitmap (i.e., 64×16 bits or 128 bytes). There are setup and tear down phases associated with using block acknowledgments. During the setup phase, capability information such as buffer size and block acknowledgment policy are negotiated between the transmitter and the receiver. Once the setup phase is completed, the transmitter may send fragments without waiting for an acknowledgment (ACK) frame. Using the block ACK may be less efficient when acknowledging fragments of a few data units because of the large size of the block ACK's bitmap. The overhead associated with the setup and teardown phases of the block ACK may also reduce efficiency. Current fragmentation schemes in low-speed (and other) networks may have a receiver transmit an acknowledgment (ACK) after each fragment is received. Because of the increased rate of packet fragmentation in low-speed networks, the number of ACKs transmitted in such networks is proportionally increased. The increase in the number of ACKs lowers the efficiency of the data traffic on the network because a larger portion of each TXOP is dedicated to overhead (e.g. ACK transmittal and various frame spaces).
One aspect of the disclosure provides a method including determining, at a transmitter, whether the transmitter supports multi-fragment acknowledgment (MFA) based on a parameter of the transmitter. The method also includes transmitting a first frame to a receiver. A fragment block acknowledgement (BA) support sub-field of a sub-1 gigahertz (S11G) capabilities information field of a S1G capabilities element of the first frame has a first value in response to determining that the transmitter supports MFA. The fragment BA support sub-field has a second value in response to determining that the transmitter does not support MFA.
Another aspect is a method including determining, at a transmitter, whether the transmitter supports multi-fragment acknowledgment (MFA) based on a parameter of the transmitter. The method also includes determining, at the transmitter, whether a receiver supports MFA based on a value of a fragment block acknowledgment (BA) support field of a frame received from the receiver. The method further includes, in response to determining that the transmitter and the receiver support MFA, creating a plurality of data fragments from a single data unit and transmitting the plurality of data fragments to the receiver. A particular data fragment of the plurality of data fragments indicates an implicit block acknowledgment request. Each of a first plurality of data fragments of the plurality of data fragments indicates a block acknowledgment policy. Each of the first plurality of data fragments is transmitted to the receiver prior to transmission of the particular data fragment to the receiver.
Another aspect is a method including creating a plurality of data fragments from a single data unit and transmitting the plurality of data fragments to a receiver. A particular data fragment of the plurality of data fragments indicates an implicit block acknowledgment request. Each of a first plurality of data fragments of the plurality of data fragments indicates a block acknowledgment policy. Each of the first plurality of data fragments is transmitted to the receiver prior to transmission of the particular data fragment to the receiver.
Another aspect is a method including creating a plurality of data fragments from a single data unit and transmitting the plurality of data fragments to a receiver. The method also includes, after transmitting a particular data fragment of the plurality of data fragments to the receiver, receiving a multi-fragment acknowledgment (MFA) from the receiver. The MFA indicates receipt or non-receipt by the receiver of each of a first plurality of data fragments and of the particular data fragment. Each of the first plurality of data fragments is transmitted to the receiver prior to transmission of the particular data fragment to the receiver. The MFA includes a null data packet (NDP) media access control (MAC) frame type field, a block acknowledgment identifier field, a starting sequence control field, and a block acknowledgment bitmap.
Another aspect is a method including creating a plurality of data fragments from a single data unit and transmitting the plurality of data fragments to a receiver. A particular data fragment (e.g., last) of the plurality of data fragments indicates an implicit block acknowledgment request. Each of a first plurality of data fragments of the plurality of data fragments indicates a block acknowledgment policy. Each of the first plurality of data fragments is transmitted to the receiver prior to transmission of the particular data fragment to the receiver. The method also includes requesting an individual acknowledgment of each of the remaining data fragments of the plurality of data fragments.
Another aspect is a non-transitory computer-readable medium that stores instructions that, when executed by a processor, cause the processor to perform operations. The operations include creating a plurality of data fragments from a single data unit and transmitting the plurality of data fragments to a receiver. The operations also include, after transmitting a particular data fragment of the plurality of data fragments to the receiver, receiving a multi-fragment acknowledgment (MFA) from the receiver. The MFA indicates receipt or non-receipt by the receiver of each of a first plurality of data fragments of the plurality of data fragments and of the particular data fragment. Each of the first plurality of data fragments is transmitted to the receiver prior to transmission of the particular data fragment to the receiver. The MFA includes a null data packet (NDP) media access control (MAC) frame type field, a block acknowledgment identifier field, a starting sequence control field, and a block acknowledgment bitmap.
Another aspect is an apparatus including a processor and a memory. The memory stores instructions that are executable by the processor to perform operations. The operations include receiving a particular data fragment of a single data unit from a wireless device. The operations also include, in response to determining that the particular data fragment indicates an implicit block acknowledgment request, initiating transmission of an acknowledgment to the wireless device. The acknowledgment indicates that the particular data fragment was received from the wireless device. The acknowledgment indicates whether each of a first plurality of data fragments of the single data unit was received from the wireless device. Each of the first plurality of data fragments includes a particular fragment sequence number (FGSN) prior to a FGSN of the particular data fragment. The operations further include refraining from initiating transmission of the acknowledgment to the wireless device in response to determining that the data fragment does not indicate an implicit block acknowledgment request.
a illustrates a method for data fragmentation in a low-speed network.
b illustrates aspects of a fragmentation method using a multi-fragment acknowledgment.
a illustrates aspects of a method for using a last fragment of a sequence of fragments to elicit a multi-fragment acknowledgment (MFA).
b illustrates aspects of a method for using a particular fragment of a sequence of fragments to elicit a multi-fragment acknowledgment (MFA).
a illustrates a fragment ACK, as may be used by the method in
b illustrates aspects of a multi-fragment acknowledgment (MFA), as may be used by the methods in
c illustrates aspects of another multi-fragment acknowledgment (MFA), as may be used by the methods in
Various aspects of the novel systems, apparatuses, and methods are described with reference to the accompanying drawings. The teachings in this disclosure may, however, be embodied in many different forms and should not be construed as limited to any specific structure or function presented throughout this disclosure. Based on the teachings herein one skilled in the art should appreciate that the scope of the disclosure is intended to cover any aspect of the novel systems, apparatuses, and methods disclosed herein, whether implemented independently of or combined with any other aspect of the disclosure. For example, an apparatus may be implemented or a method may be practiced using any number of the aspects set forth herein.
Although particular aspects are described herein, many variations and permutations of these aspects fall within the scope of the disclosure. Although some benefits and advantages are mentioned, the scope of the disclosure is not intended to be limited to particular benefits, uses, or objectives. Rather, aspects of the disclosure are intended to be broadly applicable to different wireless technologies, system configurations, networks, and transmission protocols, some of which are illustrated by way of example in the figures and in the following description. The detailed description and drawings are merely illustrative of the disclosure rather than limiting, the scope of the disclosure being defined by the appended claims and equivalents thereof.
Popular wireless network technologies may include various types of wireless local area networks (WLANs). A WLAN may be used to interconnect nearby devices together, employing widely used networking protocols. The various aspects described herein may apply to any communication standard, such as WiFi or, more generally, any member of the IEEE 802.11 family of wireless protocols. For example, the various aspects described herein may be used as part of the IEEE 802.11ah protocol, which uses sub-1 GHz frequency bands.
Wireless signals in a sub-gigahertz band may be transmitted according to the 802.11ah protocol using orthogonal frequency-division multiplexing (OFDM), direct-sequence spread spectrum (DSSS) communications, a combination of OFDM and DSSS communications, or other schemes. Implementations of the 802.11ah protocol may be used for sensors, metering devices, and smart grid networks. Advantageously, aspects of certain devices implementing the 802.11ah protocol may consume less power than devices implementing other wireless protocols, and/or may be used to transmit wireless signals across a relatively long range, for example about one kilometer or longer.
In some implementations, a WLAN includes various devices that access the wireless network. For example, two types of devices are access points (“APs”) and clients (also referred to as stations, or “STAs”). In general, an AP serves as a hub or base station for the WLAN and a STA serves as a user of the WLAN. For example, a STA may be a laptop computer, a personal digital assistant (PDA), a mobile phone, etc. In an example, a STA connects to an AP via a WiFi (e.g., IEEE 802.11 protocol) compliant wireless link to obtain general connectivity to the Internet or to other wide area networks. In some implementations, a STA may also be used as an AP.
An access point (“AP”) may also include, be implemented as, or known as a NodeB, Radio Network Controller (“RNC”), eNodeB, Base Station Controller (“BSC”), Base Transceiver Station (“BTS”), Base Station (“BS”), Transceiver Function (“TF”), Radio Router, Radio Transceiver, or some other terminology.
A station “STA” may also include, be implemented as, or known as an access terminal (“AT”), a subscriber station, a subscriber unit, a mobile station, a remote station, a remote terminal, a user terminal, a user agent, a user device, user equipment, or some other terminology. In some implementations an access terminal may include a cellular telephone, a cordless telephone, a Session Initiation Protocol (“SIP”) phone, a wireless local loop (“WLL”) station, a personal digital assistant (“PDA”), a handheld device having wireless connection capability, or some other suitable processing device connected to a wireless modem. Accordingly, one or more aspects taught herein may be incorporated into a phone (e.g., a cellular phone or smartphone), a computer (e.g., a laptop), a portable communication device, a headset, a portable computing device (e.g., a personal data assistant), an entertainment device (e.g., a music or video device, or a satellite radio), a gaming device or system, a global positioning system device, or any other suitable device that is configured to communicate via a wireless medium. APs and stations may be referred to generally as transmitting or receiving nodes in a wireless communication network.
As described above, certain of the devices described herein may implement one or more of the 802.11 family of standards, including existing standards such as 802.11g and developing standards such as 802.11ah. Such devices, whether used as a STA or AP or other device, may be used for smart metering or in a smart grid network. Such devices may provide sensor applications or be used in home automation. The devices may instead or in addition be used in a healthcare context, for example for personal healthcare. They may also be used for surveillance, to enable extended-range Internet connectivity (e.g. for use with hotspots), or to implement machine-to-machine communications.
A variety of processes and methods may be used for transmissions in the wireless communication system 100 between the AP 104 and the STAs 106. For example, signals may be sent and received between the AP 104 and the STAs 106 in accordance with orthogonal frequency-division multiplexing (OFDM) or orthogonal frequency-division multiple access (OFDMA) techniques. If this is the case, the wireless communication system 100 may be referred to as an OFDM/OFDMA system. Alternatively, signals may be sent and received between the AP 104 and the STAs 106 in accordance with code division multiple access (CDMA) techniques. If this is the case, the wireless communication system 100 may be referred to as a CDMA system.
A communication link that facilitates transmission from the AP 104 to one or more of the STAs 106 may be referred to as a downlink (DL) 108, and a communication link that facilitates transmission from one or more of the STAs 106 to the AP 104 may be referred to as an uplink (UL) 110. Alternatively, a downlink 108 may be referred to as a forward link or a forward channel, and an uplink 110 may be referred to as a reverse link or a reverse channel.
As used herein, a “data unit” may be a MAC service data unit (MSDU). A “data frame” (alternatively referred to as a fragment or data fragment) may be a MAC protocol data unit (MPDU) that includes a portion or all of the MSDU. Thus, a single data unit may be partitioned into one or more data frames or fragments and the one or more data frames or fragments may collectively represent the single data unit.
The AP 104 may transmit fragments (e.g., data fragment 112) of a single data unit to one or more of the STAs 106 and receive a multi-fragment acknowledgment (e.g., MFA 114), which may also be referred to as a multi-frame acknowledgment when one frame is communicated per frame, from the one or more of the STAs 106, as described with reference to
The AP 104 may act as a base station and provide wireless communication coverage in a basic service area (BSA) 102. The AP 104 along with the STAs 106 associated with the AP 104 and that use the AP 104 for communication may be referred to as a basic service set (BSS). It should be noted that the wireless communication system 100 may not have a central AP 104, but rather may function as a peer-to-peer or ad-hoc network between the STAs 106. Accordingly, the functions of the AP 104 described herein may alternatively be performed by one or more of the STAs 106.
The wireless device 202 may include a processor 204 which controls operation of the wireless device 202. The processor 204 may also be referred to as a central processing unit (CPU). Memory 206, which may include both read-only memory (ROM) and random access memory (RAM), provides instructions and data to the processor 204. A portion of the memory 206 may also include non-volatile random access memory (NVRAM). The processor 204 typically performs logical and arithmetic operations based on program instructions stored within the memory 206. The instructions in the memory 206 may be executable to implement the methods described herein.
The processor 204 may include or be a component of a processing system implemented with one or more processors. The one or more processors may be implemented with any combination of general-purpose microprocessors, microcontrollers, digital signal processors (DSPs), field programmable gate array (FPGAs), programmable logic devices (PLDs), controllers, state machines, gated logic, discrete hardware components, dedicated hardware finite state machines, or any other suitable entities that can perform calculations or other manipulations of information.
The processing system may also include machine-readable media for storing software. Software shall be construed broadly to mean any type of instructions, whether referred to as software, firmware, middleware, microcode, hardware description language, or otherwise. Instructions may include code (e.g., in source code format, binary code format, executable code format, or any other suitable format of code). The instructions, when executed by the one or more processors, cause the processing system to perform the various functions described herein.
The wireless device 202 may also include a housing 208 that may include a transmitter 210 and a receiver 212 to enable transmission and reception of data between the wireless device 202 and a remote device. The transmitter 210 and receiver 212 may be combined into a transceiver 214. An antenna 216 may be attached to the housing 208 and electrically coupled to the transceiver 214. The wireless device 202 may also include (not shown) multiple transmitters, multiple receivers, multiple transceivers, and/or multiple antennas.
The wireless device 202 may also include a signal detector 218 that may be used in an effort to detect and quantify the level of signals received by the transceiver 214. The signal detector 218 may detect such signals as total energy, energy per subcarrier per symbol, power spectral density and other signals. The wireless device 202 may also include a digital signal processor (DSP) 220 for use in processing signals. The DSP 220 may be configured to generate a data frame for transmission. In some aspects, the data frame may include a physical layer data unit (PPDU). In some aspects, the PPDU is referred to as a packet.
The wireless device 202 may further include a user interface 222 in some aspects. The user interface 222 may include a keypad, a microphone, a speaker, and/or a display. The user interface 222 may include any element or component that conveys information to a user of the wireless device 202 and/or receives input from the user.
The various components of the wireless device 202 may be coupled together by a bus system 226. The bus system 226 may include a data bus, for example, as well as a power bus, a control signal bus, and a status signal bus in addition to the data bus. Those of skill in the art will appreciate the components of the wireless device 202 may be coupled together or accept or provide inputs to each other using some other mechanism.
Although a number of separate components are illustrated in
As described above, the wireless device 202 may include an AP 104 or a STA 106, and may be used to transmit and/or receive communications.
The wireless device 202a may include a modulator 302 configured to modulate bits for transmission. For example, the modulator 302 may determine a plurality of symbols from bits received from the processor 204 or the user interface 222, for example by mapping bits to a plurality of symbols according to a constellation. The bits may correspond to user data or to control information. In some aspects, the bits are received in codewords. In one aspect, the modulator 302 includes a QAM (quadrature amplitude modulation) modulator, for example a 16-QAM modulator or a 64-QAM modulator. In other aspects, the modulator 302 includes a binary phase-shift keying (BPSK) modulator or a quadrature phase-shift keying (QPSK) modulator.
The wireless device 202a may further include a transform module 304 configured to convert symbols or otherwise modulated bits from the modulator 302 into a time domain. In
In
The DSP 220 may be configured to generate a data frame for transmission. For example, the DSP 220 may be configured to generate fragments (e.g., the data fragment 112 of
In some aspects, the DSP 220 is configured to insert one or more training fields between a plurality of data symbols. The DSP 220 may determine a position or location of the one or more training fields in the data frame based on information received from the processor 204, and/or stored in the memory 206 or in a portion of the DSP 220.
The wireless device 202a may further include a digital to analog converter 306 configured to convert the output of the transform module 304 into an analog signal. For example, the time-domain output of the transform module 304 may be converted to a baseband OFDM signal by the digital to analog converter 306. The digital to analog converter 306 may be implemented in the processor 204 or in another element of the wireless device 202. In some aspects, the digital to analog converter 306 is implemented in the transceiver 214 or in a data transmit processor.
The analog signal may be wirelessly transmitted by the transmitter 210. The analog signal may be further processed before being transmitted by the transmitter 210, for example by being filtered or by being upconverted to an intermediate or carrier frequency. In the aspect illustrated in
The transmitter 210 is configured to transmit one or more packets or data frames via a wireless signal based on the analog signal. The data frames may be generated using the processor 204 and/or the DSP 220, for example using the modulator 302 and the transform module 304.
In some aspects, the transmitter 210 is configured to transmit the data frames over a bandwidth of approximately 2.5 MHz or 1.25 MHz, or lower. When using such bandwidths, transmission of the data frame may be performed over a relatively lengthy period of time. For example, a data frame composed of 500 bytes may be transmitted over a period of approximately 11 milliseconds. Such transmission is approximately sixteen times slower than comparable transmissions implemented pursuant to the 802.11ac standard over bandwidths of approximately 20 MHz.
The receiver 212 is configured to receive one or more packets or data frames via a wireless signal. Data frames that may be received and decoded or otherwise processed are described in additional detail with respect to
In some aspects, the receiver 212 is configured to receive the data frames using a bandwidth of approximately 2.5 MHz or 1.25 MHz, or lower. When using such bandwidths, the data frame may be received over a relatively lengthy period of time, for example approximately 11 milliseconds when the data frame is composed of 500 bytes. During this time, the channel over which the data frame is received may be changing. For example, conditions of the channel may change due to movement of the wireless device 202b or of a device transmitting the data frame, or due to weather or other environmental conditions such as the introduction of various obstacles. In such circumstances, information received near the end may not be correctly decoded if the wireless device 202b uses settings determined when reception of the data frame began. As described in additional detail below, however, the wireless device 202b may use the training fields interposed between the plurality of data symbols to form an updated estimate of the channel in order to properly decode one or more of the data symbols.
In the aspect illustrated in
The wireless device 202b may include an analog to digital converter 402 configured to convert the amplified wireless signal from the receiver 212 into a digital representation thereof. Further to being amplified, the wireless signal may be processed before being converted by the digital to analog converter 402, for example by being filtered or by being downconverted to an intermediate or baseband frequency. The analog to digital converter 402 may be implemented in the processor 204 or in another element of the wireless device 202. In some aspects, the analog to digital converter 402 is implemented in the transceiver 214 or in a data receive processor.
The wireless device 202b may further include a transform module 404 configured to convert the representation the wireless signal into a frequency spectrum. In
The wireless device 202b may further include a channel estimator and equalizer 405 configured to form an estimate of the channel over which the data frame is received, and to remove certain effects of the channel based on the channel estimate. For example, the channel estimator may be configured to approximate a function of the channel, and the channel equalizer may be configured to apply an inverse of that function to the data in the frequency spectrum.
In some aspects, the channel estimator and equalizer 405 uses information in one or more received training fields, such as a long training field (LTF) for example, to estimate the channel. The channel estimate may be formed based on one or more LTFs received at the beginning of the data frame. This channel estimate may thereafter be used to equalize data symbols that follow the one or more LTFs. After a certain period of time or after a certain number of data symbols, one or more additional LTFs may be received in the data frame. The channel estimate may be updated or a new estimate formed using the additional LTFs. This new or update channel estimate may be used to equalize data symbols that follow the additional LTFs. In some aspects, the new or updated channel estimate is used to re-equalize data symbols preceding the additional LTFs. Those having ordinary skill in the art will understand methods for forming a channel estimate.
The wireless device 202b may further include a demodulator 406 configured to demodulate the equalized data. For example, the demodulator 406 may determine a plurality of bits from symbols output by the transform module 404 and the channel estimator and equalizer 405, for example by reversing a mapping of bits to a symbol in a constellation. The bits may be processed or evaluated by the processor 204, or used to display or otherwise output information to the user interface 222. In this way, data and/or information may be decoded. In some aspects, the bits correspond to codewords. In one aspect, the demodulator 406 includes a QAM (quadrature amplitude modulation) demodulator, for example a 16-QAM demodulator or a 64-QAM demodulator. In other aspects, the demodulator 406 may be a binary phase-shift keying (BPSK) demodulator or a quadrature phase-shift keying (QPSK) demodulator.
In
The wireless signal received at the receiver 212 includes one or more data frames. Using the functions or components described above, the data frames or data symbols therein may be decoded evaluated or otherwise evaluated or processed. For example, the processor 204 and/or the DSP 220 may be used to decode data symbols in the data frames using the transform module 404, the channel estimator and equalizer 405, and the demodulator 406.
Data frames exchanged by the AP 104 and the STA 106 may include control information or data, as described above. At the physical (PHY) layer, these data frames may be referred to as physical layer protocol data units (PPDUs). In some aspects, a PPDU may be referred to as a packet or physical layer packet. Each PPDU may include a preamble and a payload. The preamble may include training fields and a SIG field. The payload may include a Media Access Control (MAC) header or data for other layers, and/or user data, for example. The payload may be transmitted using one or more data symbols. The systems, methods, and devices herein may utilize data frames with training fields that are also interposed between data symbols in the payload.
a illustrates a method for data fragmentation in a low-speed network. In
Generally, SIFS is a short time interval between a data frame and its acknowledgment. SIFS are used in, for example, 802.11 compliant networks. The value of the SIFS (usually measured in microseconds) may be fixed per physical layer (PHY) and may be calculated so that a transmitting node will be able to switch back to receive mode and be capable of decoding an incoming packet. For example, a SIFS may be set at 10 μs.
After SIFS 503, ACK 505 is received by the wireless device. The ACK acknowledges that the receiver received data fragment 501. Notably, the time spent transmitting data fragment 501 plus SIFS 503 and the time receiving ACK 505 takes up the entire transmit opportunity window (TXOP) 517. The TXOP may be set by a standard, such as 802.11, and may be measured in, for example, milliseconds. For example, a TXOP for a particular network may be 10 ms. Thus, the total amount of data that can be sent with a data fragment is limited by the need to include SIFS 503 and ACK 505 into the single TXOP window 517.
After ACK 505 is received, the wireless device waits a period of time defined by the Distributed Coordination Function Interframe Space (DIFS) plus a randomized backoff period. The Distributed Coordination Function (DCF) requires a node participating in a Carrier Sense Multiple Access (CSMA) network to first sense the medium and if the medium is busy then to defer from transmitting for a period of time. The period of deferral (the DIFS) is followed by a randomized backoff period i.e. an additional period of time in which the node wishing to transmit will not attempt to access the medium.
The backoff period is used to resolve contention between different nodes (e.g. wireless devices) trying to access a medium (e.g. a radio network) at the same time. The backoff period may also be referred to as a contention window. Backoff requires each node trying to access a medium to choose a random number in a range and wait for the chosen number of time slots before trying to access the medium, and to check whether a different node has accessed the medium before. The slot time is defined in such a way that a node will always be capable of determining if another node has accessed the medium at the beginning of the previous slot. In particular, the 802.11 standard uses an exponential backoff algorithm where each time a node chooses a slot and collides with another node, it will increase the maximum number of the range exponentially. If, on the other hand, a node wishing to transmit senses the medium as free for the entire DIFS period, then the node may transmit on the medium. In some networks, the DIFS may be calculated, for example, as the SIFS plus a certain number of additional time slots.
After the DIFS plus backoff period 507, the wireless device transmits data fragment 509 and then receives ACK 511 after a SIFS period (not shown). Finally, after another DIFS and random backoff period (not shown), the wireless device transmits data fragment 513 and then receives ACK 515 after a SIFS period (not shown). At this point, the entire data unit has been sent. Notably, during the three TXOPs it took to send the single data unit, there were three SIFS periods, two DIFS periods plus random backoffs and three ACKs, and during all of these periods, the wireless device was not able to transmit content data (i.e. non-overhead data).
b illustrates aspects of a fragmentation method using a multi-fragment acknowledgment (MFA). In one aspect, the method of
In the implementation of
A receiver may determine that the last fragment of a data unit has been sent (e.g. fragment 523 of
To distinguish successive blocks of fragments where the FGSN is repeated between successive blocks, an indication of order of the successive blocks of fragments (e.g. an indication of sequence order) may be added to the fragment headers. For example, an additional bit may be added to the fragment header to distinguish successive fragment blocks as “odd” or “even” blocks. Alternatively, a bit in the existing fragment header may be repurposed. For example, a bit in the “Power Management” or “More Data” field may be used (e.g., repurposed) to indicate each successive fragment as either an “odd” or “even” fragment. As shown in
Notably, in the example illustrated in
a illustrates aspects of a method 700 for using a “last” fragment to elicit a multi-fragment acknowledgment (MFA). For example, a wireless device may transmit a plurality of data fragments of a data frame. Each of the plurality of data fragments, except the last data fragment (e.g., a last data fragment 703), may indicate an acknowledgment policy of “block acknowledgment.” The last data fragment 703 may indicate an acknowledgment policy of “implicit block acknowledgment request.” For example, a data frame may be split into ten data fragments. The first 9 data fragments (e.g., data fragments 701) may indicate an acknowledgment policy of “block acknowledgment” and the last data fragment 703 may indicate an acknowledgment policy of “implicit block acknowledgment request.” For example, the wireless device may set one or more bits of the fragment header of each of the plurality of data fragments to a particular value indicating the particular acknowledgment policy. In a particular embodiment, the wireless device may set one or more bits (e.g., 2 bits, such as bit 5 and bit 6) of a quality of service (QoS) field of a data fragment to represent a particular value (e.g., “00”) indicating the particular acknowledgment policy (e.g., implicit block acknowledgment request). In this embodiment, the data fragment may include a QoS data frame. In a particular embodiment, the wireless device may set one or more bits of an acknowledgment policy field of a data fragment to represent a particular value (e.g., “0”) indicating the particular acknowledgment policy (e.g., implicit block acknowledgment request). In this embodiment, the data fragment may include a “short” frame, e.g., a frame having a protocol version field in a frame control field set to 1. A short frame may include the acknowledgment policy field in the frame control field.
A more fragment field of the data fragments 701 may be set to a first value indicating more fragments. A more fragment field of the last data fragment 703 may be set to a second value indicating no more fragments. For example, a “More Fragment” bit of a particular data fragment may be set to “1” to indicate more fragments or may be set to “0” to indicate that the plurality of data fragments does not include more fragments subsequent to the particular data fragment.
The data fragments 701 may include FGSNs representing values “0” to “8”. The last data fragment 703 may include a FGSN representing “9”. The data fragments 701 and the last data fragment 703 may indicate a FSN (e.g., “1”) of the single data unit.
In response to the last data fragment 703, a receiver may transmit a multi-fragment acknowledgment (MFA) 705. In a particular embodiment, the MFA frame may be a null data packet (NDP) block acknowledgment. For example, the receiver may transmit the MFA 705 in response to the last data fragment 703 that indicates an implicit block acknowledgment request, where the last data fragment 703 includes a more fragment field indicating a particular value, or both. The receiver may transmit the MFA 705 a SIFS time after receiving the last data fragment 703 without regard to the idle/busy state of the wireless medium. The MFA 705 may indicate (e.g., via a bitmap) receipt or non-receipt by the receiver of each of the data fragments 701 with a FGSN less than the FGSN of the last data fragment 703 and whether the receiver received the last data fragment 703 for which the transmitter solicits a response by setting the acknowledgment policy to implicit block acknowledgment request.
Thus, a last data fragment may be used by a transmitter to elicit a multi-fragment acknowledgment (MFA) by setting values of one or more fields of the last data fragment. In a particular embodiment, fragments other than a “last” data fragment may also be used to elicit a MFA.
For example,
The data fragments 711 may include FGSNs representing values “0” to “6”. The data fragment 713 may include a FGSN representing “7”, the data fragment 717 may include a FGSN representing “8”, and the data fragment 721 may include a FGSN representing “9”. The data fragments 711, 713, 717, and 721 may indicate a FSN (e.g., “1”) of the single data unit. The FGSNs of the data fragments may indicate an order of transmission. For example, data fragments may be transmitted to the receiver in order of the corresponding FGSNs.
The data fragment 713 may elicit a multi-fragment acknowledgment (MFA) 715 from the receiver. For example, the receiver may send the MFA 715 in response to determining that the data fragment 713 indicates an implicit block acknowledgment request policy. The MFA 715 may indicate whether the receiver received each of the data fragments 711 with a FGSN less than a FGSN of the data fragment 713 and whether the receiver received the first data fragment 713.
In a particular embodiment, the receiver may transmit the MFA indicating whether up to a particular fragment number (e.g., 7 or 15) of data fragments were received or not received by the receiver. In a particular embodiment, each of the remaining data fragments may indicate that an individual acknowledgment is requested. In a particular embodiment, the receiver may determine that an individual acknowledgment is to be sent based on a FGSN of a data fragment indicating that the data fragment is not included in the initial particular number (e.g., 8 or 16) of data fragments. The receiver may determine the order of transmission of the data fragments based on the sequence of FGSNs of the data fragments. For example, the data fragment 717 and the data fragment 721 may indicate an individual acknowledgment policy. The receiver may transmit a first individual acknowledgment 719 indicating that the data fragment 717 was received. The receiver may transmit a second individual acknowledgment 723 indicating that the data fragment 721 was received.
In a particular embodiment, the transmitter may determine a number of data fragments to include in the first plurality of data fragments based on a threshold number of data fragments. For example, the threshold number of data fragments may indicate a maximum number of data fragments that may be acknowledged using a MFA. In a particular embodiment, the threshold number of data fragments may be 8. For example, the threshold number of data fragments may be 8 when the MFA is transmitted over a bandwidth of approximately 1 megahertz (MHz). In another embodiment, the threshold number of data fragments may be 16. For example, the threshold number of data fragments may be 16 when the MFA is transmitted over a bandwidth of approximately 2 MHz or greater. A MFA transmitted over a bandwidth of approximately 1 MHz may have a smaller bitmap (e.g., a block acknowledgment bitmap) than a bitmap of a MFA transmitted over a bandwidth of approximately 2 MHz or greater. The first plurality of data fragments may include up to the threshold number of data fragments minus 1. For example, the first plurality of data fragments may include 7 data fragments when the MFA is transmitted over a bandwidth of approximately 1 MHz. As another example, the first plurality of data fragments may include 15 data fragments when the MFA is transmitted over a bandwidth of approximately 2 MHz or greater. The MFA may be used to acknowledge the first plurality of data fragments and the particular data fragment that elicited the MFA. Each of any remaining data fragments of the plurality of data fragments may indicate that an individual acknowledgment is requested.
Thus, a data fragment may be used by a transmitter to elicit a multi-fragment acknowledgment (MFA) indicating whether the receiver received data fragments transmitted prior to and including the data fragment. Subsequent data fragments may be acknowledged using individual acknowledgments when a block acknowledgment bitmap is too small to accommodate the receipt status of part of all fragments.
a illustrates a fragment ACK 800, as may be used by the method in
b illustrates aspects of a multi-fragment acknowledgment (MFA) 810, as may be used by the methods in
Additional modifications to MFAs may be made by, for example, moving the RA 803 into the FCS field 805. This would save six bytes of overhead, giving a total MFA length of eight bytes.
c illustrates aspects of another multi-fragment acknowledgment (MFA) 820, as may be used by the methods in
In a particular embodiment, the MFA (e.g., the MFA 810, the MFA 820) may include an ACK mode indication bit (not shown) to distinguish the MFA from a “conventional” block acknowledgment (ACK) that acknowledges multiple data frames. For example, the MFA may include an ACK mode field. The ACK mode field may have a first value (e.g., 0) to indicate that the packet is an MFA and a second value (e.g., 1) to indicate that the packet is a block ACK. As another example, distinguishing between the MFA and a block ACK may be a two-step process. In the first step, the ACK mode field may distinguish between a “conventional” ACK (i.e., part of a session in which an ACK is to be received in response to each MPDU prior to transmission of the next MPDU) and a “block-type” ACK. The ACK mode field may have a first value (e.g., a first reserved MCS value) to indicate that the packet is an ACK and a second value (e.g., a second reserved MCS value) to indicate that the packet is a “block-type” ACK. A “block-type” ACK may be a block ACK (i.e., part of a session in which multiple MPDUs that include data from multiple data units will be acknowledged using a single block ACK) or a MFA (i.e., a MFA that acknowledges multiple fragments of a single data unit that were sent in multiple MPDUs).
In the second step, the MFA may be distinguished from a block ACK based on the data fragment to which the packet is a response to. If the data fragment indicates that the data fragment requests a block ACK as a response and a fragment number (e.g., FGSN) associated with the data fragment is greater than 0, then the packet is to be interpreted as a MFA. On the other hand, if the fragment number is 0 (or has no fragment number) then the packet is to be interpreted as a block ACK.
An MFA may be solicited (e.g., the receiver may be signaled to send an MFA) based on different conditions. For example, if the last fragment of a data unit is received, as described above with respect to
From the perspective of the wireless device transmitting data, if an MFA is not received during a time period after the last fragment of a block or a data unit is transmitted, the wireless device may, for example, retransmit the last fragment to re-solicit the receiver to send an MFA.
Upon receipt of an MFA indicating errors in the transmission of one or more fragments (e.g., the MFA bitmap indicated errors), the indicated fragments may be retransmitted by the wireless device. The receiver may acknowledge the receipt of the retransmitted fragments by, for example, responding with an ACK (rather than a MFA) for each retransmitted fragment, or may instead use an MFA to acknowledge multiple retransmitted fragments, or may use an MFA to acknowledge one or more retransmitted fragments as well as new fragments. As described above with reference to
The MFA 900 may be entirely included in a physical layer (PHY) preamble of a packet. In a particular embodiment, the MFA 900 may be included in a signal (SIG) field of the (PHY) preamble. As shown, the MFA 900 includes a null data packet (NDP) media access control (MAC) frame type field 912, a block acknowledgment (ack) identifier (ID) field 914, the SSC field 818 as in MFA 820, and a block ack bitmap field 918. The MFA 900 may contain one or more additional fields.
The block ack ID field 914 may include an identifier of the MFA 900. In a particular embodiment, the block ack ID field 914 may represent a scrambler initialization value of a service field of a data fragment (e.g., the last data fragment 703 of
In a particular embodiment, the NDP MAC frame type field 912 may have a value of 4 and may have a length of 3 bits. In a particular embodiment, the SSC field 818 may have a length of 12 bits.
In a particular embodiment, the block ack ID field 914 may have a length of 2 bits, the block ack bitmap field 918 may have a length of 8 bits, and the MFA 900 may be transmitted over a bandwidth of approximately 1 megahertz (MHz). In another particular embodiment, the block ack ID field 914 may have a length of 6 bits, the block ack bitmap field 918 may have a length of 16 bits, and the MFA 900 may be transmitted over a bandwidth of approximately 2 megahertz (MHz) or greater.
Thus, devices receiving a frame including a fragment BA support field 1012 from the wireless device may determine whether the wireless device supports MFA prior to transmitting data fragments to the wireless device. Prior to using MFA, each device may verify whether another device supports MFA. For example, one device may be an access point (AP) and the other device may be a station (“STA”). A S1G capabilities element may be transmitted as part of a beacon, a probe request, a probe response, an association request, an association response, a management frame, etc.
If the fragment sent at step 1105 is not the last fragment, then the process flow 1100 returns to step 1105 and sends the next fragment of the data unit. If, on the other hand, at step 1107 the fragment sent at step 1105 is the last fragment, then the process flow 1100 moves to step 1109. At step 1109, the device receives an acknowledgment, and the process flow 1100 moves to step 1111. At step 1111, the device determines whether a fragment sequence number (FGSN) of the last fragment of the data unit is equal to zero (or another value that indicates fragmentation is not in use). If the FGSN of the last data fragment is equal to zero, then the process flow 1100 moves to step 1115 and the device interprets the acknowledgment as a block ACK (e.g., an uncompressed block ACK with a 128-byte bitmap that indicates receipt/non-receipt for up to 16 fragments for each of up to 64 data units). The process flow 1100 then moves to step 1119. At step 1119, the device determines whether each of a plurality of data fragments of a plurality of data units was received by the receiver based on the block ACK (e.g., whether each of up to 16 fragments for each of up to 64 data units was received).
If, on the other hand, at step 1111 the FGSN of the last data fragment is not equal to zero, then the process flow 1100 moves to step 1113 and the device interprets the acknowledgment as a multi-fragment acknowledgment (MFA) that indicates the status of each transmitted fragment. As described above, with reference to
If, on the other hand, the device determines that the data fragment is not the last data fragment of the block, then the process flow 1200 moves to step 1207. At step 1207, the device determines whether the data fragment is a last data fragment of the single data unit. As described above with reference to
The process flow 1300 then moves to step 1304 where the transmitter transmits a first frame to a receiver. A fragment block acknowledgment (BA) support sub-field of a sub-1 gigahertz (S1G) capabilities information field of a S1G capabilities element of the first frame has a first value in response to the transmitter determining that the transmitter supports MFA, as further described with reference to
The process flow 1300 then moves to step 1306 where the transmitter determines whether a receiver supports MFA based on a value of a fragment BA support field of a second frame received from the receiver. For example, the receiver may have previously transmitted the second frame including a fragment BA support sub-field indicating whether the receiver supports MFA.
The process flow 1300 then moves to step 1308 where the transmitter creates a plurality of data fragments from a single data unit. For example, in response to determining that the receiver and the transmitter support MFA, the transmitter may split a single data unit into a plurality of data fragments.
The process flow 1300 then moves to step 1310 where the transmitter generates a fragment sequence number (FGSN) for each of the plurality of data fragments, as further described with reference to
In response to determining that the data fragment is not the particular data fragment, the process flow 1400 moves to step 1404 where the transmitter determines whether the data fragment is included in a first plurality of data fragments. Each of the first plurality of data fragments is transmitted to the receiver prior to transmission of the particular data fragment to the receiver.
In response to determining that the data fragment is included in the first plurality of data fragments, the process flow 1400 moves to step 1406, where the transmitter sets the acknowledgment policy of the data fragment to block acknowledgment.
Alternatively, in response to determining that the data fragment is not included in the first plurality of data fragments at step 1404, the process flow 1400 moves to step 1410, where the transmitter sets the acknowledgment policy of the data fragment to individual acknowledgment.
In response to determining that the data fragment is the particular data fragment at step 1402, the process flow 1400 moves to step 1412 where the transmitter sets the acknowledgment policy of the data fragment to implicit block acknowledgment request, and to 1414, where the transmitter sets the more fragment field of the data fragment to a particular value (e.g., zero).
The process flow 1400 moves from 1408, 1410, and 1414 to step 1408 where the transmitter transmits the data fragment to the receiver. The process flow 1400 moves to step 1416 where the transmitter determines whether the data fragment is a last data fragment of the plurality of data fragments. In response to determining that the data fragment is not the last data fragment, the process flow 1400 returns to step 1402 to process a next data fragment. For example, the data fragment may be included in the first plurality of data fragments. As another example, the data fragment may be a non-last data fragment of the plurality of data fragments and there may be subsequent data fragments to be processed.
In response to determining that the MFA has been received during the threshold time period at step 1502, the process flow 1500 moves to step 1506 where the transmitter receives an acknowledgment from the receiver. For example, the transmitter may receive the MFA 705 in response to the particular data fragment being a last data fragment of the plurality of data fragments, as described with reference to
The process flow 1500 then moves to step 1510, where the transmitter determines that a value of a starting sequence control (SSC) field of the acknowledgment corresponds to a sequence number of the single data unit. The particular data fragment may have included the sequence number of the single data unit.
The process flow 1500 then moves to step 1512, where the transmitter interprets the acknowledgement as a multi-fragment acknowledgment (MFA) indicating whether the receiver received each of the first plurality of data fragments and the particular data fragment. For example, the transmitter may determine that the MFA is responsive to the particular data fragment in response to determining that the block acknowledgment identifier field of the acknowledgment corresponds to a scrambler initialization value of a service field of the particular data fragment, that the SSC field of the acknowledgment corresponds to a sequence number of the single data unit, or both.
The process flow 1500 then moves to step 1514, where the transmitter determines whether each of the first plurality of data fragments and the particular data fragment was received by the receiver based on the MFA. For example, each bit of a bitmap (e.g., the block ack bitmap 918) of the MFA may indicate whether a corresponding data fragment was received, as further described with reference to
In response to determining that at least one of the first plurality of data fragments has not been received, the process flow moves to step 1518 where the transmitter selectively retransmit one or more of the first plurality of data fragments based on the MFA. For example, if there was an error in the receiver receiving one or more of the plurality of data fragments, the transmitter may retransmit the one or more data fragments so that the single data unit may be successfully rebuilt by the receiver.
In response to determining that all of the first plurality of data fragments and the particular data fragment have been received at step 1516, the process flow moves to step 1520 where the transmitter initiates transmission of a next data unit. A fragment sequence number (FGSN) of a first data fragment of the next data unit may be a lowest FGSN value (e.g., “0”) that indicates a beginning of the next sequence of data fragments.
A process flow 1600 includes step 1602 where a receiver receives a particular data fragment of a single data unit from a wireless device. The process flow 1600 then moves to step 1604 where the receiver determines whether the data fragment indicates an implicit block acknowledgment request.
In response to determining that the data fragment indicates the implicit block acknowledgment request, the process flow 1600 moves to step 1606 where the receiver initiates transmission of an acknowledgment to a wireless device. The acknowledgment indicates that the particular data fragment was received from the wireless device. The acknowledgment indicates whether each of a first plurality of data fragments of the single data unit was received from the wireless device. Each of the first plurality of data fragments includes a particular fragment sequence number (FGSN) prior to a FGSN of the particular data fragment, as further described with reference to
Alternatively, in response to determining that the data fragment does not indicate the implicit block acknowledgment request at step 1604, the process flow 1600 moves to step 1608 where the receiver refrains from initiating transmission of the acknowledgment to the wireless device. For example, the receiver may not send a multi-fragment acknowledgment (MFA) in response to a data fragment that indicates an acknowledgment policy other than implicit block acknowledgment request.
The process flow 1600 then moves to step 1610 where the receiver determines whether the data fragment indicates that an individual acknowledgment is requested (e.g., indicates an individual acknowledgement policy). In response to determining that the data fragment indicates that an individual acknowledgment is requested, the process flow 1600 moves to step 1612 where the receiver initiates transmission of a second acknowledgment to the wireless device. The second acknowledgment indicates that the particular data fragment was received from the wireless device. Alternatively, in response to determining that the particular data fragment does not indicate that an individual acknowledgment is requested, the process flow 1600 returns to step 1602.
In one implementation, means for creating a plurality of data fragments from a single data unit includes the processor 1703 (e.g., programmed to determine a size of the MSDU, determine a number of data fragments by dividing the size of the MSDU by a packet payload size, and generate the determined number of data fragments). In one implementation, means for initiating transmission of the plurality of data fragments to a wireless device includes the processor 1703 (e.g., programmed to determine that the plurality of data fragments are ready to be transmitted and send a signal to the transmitter 1705 requesting transmission of the plurality of data fragments). In one implementation, means for receiving an acknowledgment after a particular data fragment of the plurality of data fragments is transmitted to the wireless devices includes the processor 1703 (e.g., programmed to receive the acknowledgment as a signal from the receiver 1701). The particular data fragment may indicate an implicit block acknowledgment request. In a particular embodiment, the acknowledgment policy field of any fragment may be set to implicit block acknowledgment request to elicit the acknowledgment. To illustrate, a data fragment with an acknowledgment policy field set to implicit block acknowledgment request may elicit the MFA. In a particular embodiment, the data fragment that elicits the MFA may be a last data fragment of the plurality of data fragments with a more fragment field set to a first value (e.g., “0” or false) indicating that there are no more fragments, as described with reference to
One or more of the disclosed embodiments may be implemented in a system or an apparatus that may include a communications device, a fixed location data unit, a mobile location data unit, a mobile phone, a cellular phone, a computer, a tablet, a portable computer, or a desktop computer. Additionally, the system or the apparatus may include a set top box, an entertainment unit, a navigation device, a personal digital assistant (PDA), a monitor, a computer monitor, a television, a tuner, a radio, a satellite radio, a music player, a digital music player, a portable music player, a video player, a digital video player, a digital video disc (DVD) player, a portable digital video player, any other device that stores or retrieves data or computer instructions, or a combination thereof. As another illustrative, non-limiting example, the system or the apparatus may include remote units, such as mobile phones, hand-held personal communication systems (PCS) units, portable data units such as personal data assistants, global positioning system (GPS) enabled devices, navigation devices, fixed location data units such as meter reading equipment, or any other device that stores or retrieves data or computer instructions, or any combination thereof. Although one or more of
It should be understood that any reference to an element herein using a designation such as “first,” “second,” and so forth does not generally limit the quantity or order of those elements. Rather, these designations may be used herein as a convenient method of distinguishing between two or more elements or instances of an element. Thus, a reference to first and second elements does not mean that only two elements may be employed or that the first element must precede the second element in some manner. Also, unless stated otherwise a set of elements may comprise one or more elements.
As used herein, the term “determining” encompasses a wide variety of actions. For example, “determining” may include calculating, computing, processing, deriving, investigating, looking up (e.g., looking up in a table, a database or another data structure), ascertaining and the like. Also, “determining” may include receiving (e.g., receiving information), accessing (e.g., accessing data in a memory) and the like. Also, “determining” may include resolving, selecting, choosing, establishing and the like. Further, a “channel width” as used herein may encompass or may also be referred to as a bandwidth in certain aspects.
As used herein, a phrase referring to “at least one of” a list of items refers to any combination of those items, including single members. As an example, “at least one of: a, b, or c” is intended to cover: a, b, c, a-b, a-c, b-c, and a-b-c.
Various illustrative components, blocks, configurations, modules, circuits, and steps have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or processor executable instructions depends upon the particular application and design constraints imposed on the overall system. Additionally, the various operations of methods described above may be performed by any suitable means capable of performing the operations, such as various hardware and/or software component(s), circuits, and/or module(s). Generally, any operations illustrated in the
Those of skill in the art would further appreciate that the various illustrative logical blocks, configurations, modules, circuits, and algorithm steps described in connection with the present disclosure may be implemented or performed with a general purpose processor, a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array signal (FPGA) or other programmable logic device (PLD), discrete gate or transistor logic, discrete hardware components (e.g., electronic hardware), computer software executed by a processor, or any combination thereof designed to perform the functions described herein. A general purpose processor may be a microprocessor, but in the alternative, the processor may be any commercially available processor, controller, microcontroller or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
In one or more aspects, the functions described may be implemented in hardware, software, firmware, or any combination thereof. If implemented in software, the functions may be stored as one or more instructions or code on a computer-readable medium. Computer-readable media includes computer-readable storage media and communication media including any medium that facilitates transfer of a computer program from one place to another. A storage media may be any available media that can be accessed by a computer. By way of example, and not limitation, such computer-readable storage media can include random access memory (RAM), read-only memory (ROM), programmable read-only memory (PROM), erasable PROM (EPROM), electrically erasable PROM (EEPROM), register(s), hard disk, a removable disk, a compact disc read-only memory (CD-ROM), other optical disk storage, magnetic disk storage, magnetic storage devices, or any other medium that can be used to store desired program code in the form of instructions or data structures and that can be accessed by a computer. In the alternative, the computer-readable media (e.g., a storage medium) may be integral to the processor. The processor and the storage medium may reside in an application-specific integrated circuit (ASIC). The ASIC may reside in a computing device or a user terminal In the alternative, the processor and the storage medium may reside as discrete components in a computing device or user terminal.
Also, any connection is properly termed a computer-readable medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technologies such as infrared, radio, and microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technologies such as infrared, radio, and microwave are included in the definition of medium. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and Blu-ray® disc (Blu-ray is a registered trademark of Sony Corp. of Tokyo, Japan) where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Thus, in some aspects computer readable medium may include a non-transitory computer readable medium (e.g., tangible media). In addition, in some aspects computer readable medium may include a transitory computer readable medium (e.g., a signal). Combinations of the above should also be included within the scope of computer-readable media.
The methods disclosed herein include one or more steps or actions for achieving the described method. The method steps and/or actions may be interchanged with one another without departing from the scope of the claims. In other words, unless a specific order of steps or actions is specified, the order and/or use of specific steps and/or actions may be modified without departing from the scope of the claims.
Thus, certain aspects may include a computer program product for performing the operations presented herein. For example, such a computer program product may include a computer-readable storage medium having instructions stored (and/or encoded) thereon, the instructions being executable by one or more processors to perform the operations described herein. For certain aspects, the computer program product may include packaging material.
Further, it should be appreciated that modules and/or other appropriate means for performing the methods and techniques described herein can be downloaded and/or otherwise obtained by a user terminal and/or base station as applicable. Alternatively, various methods described herein can be provided via storage means (e.g., RAM, ROM, a physical storage medium such as a compact disc (CD) or floppy disk, etc. Moreover, any other suitable technique for providing the methods and techniques described herein to a device can be utilized.
It is to be understood that the claims are not limited to the precise configuration and components illustrated above. The previous description of the disclosed embodiments is provided to enable a person skilled in the art to make or use the disclosed embodiments. While the foregoing is directed to aspects of the present disclosure, other and further aspects of the disclosure may be devised without departing from the basic scope thereof, and the scope is determined by the claims that follow. Various modifications, changes and variations may be made in the arrangement, operation, and details of the embodiments described herein without departing from the scope of the disclosure or the claims. Thus, the present disclosure is not intended to be limited to the embodiments herein but is to be accorded the widest scope possible consistent with the principles and novel features as defined by the following claims and equivalents thereof.
The present application is a continuation-in-part of commonly owned U.S. patent application Ser. No. 13/597,758 filed Aug. 29, 2012, which claims priority from commonly owned U.S. Provisional Patent Application 61/530,753 filed Sep. 2, 2011 and U.S. Provisional Patent Application 61/669,608 filed Jul. 9, 2012, the contents of each of which are expressly incorporated herein by reference in their entirety.
Number | Date | Country | |
---|---|---|---|
61669608 | Jul 2012 | US | |
61530753 | Sep 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13597758 | Aug 2012 | US |
Child | 14011680 | US |