1. Field of the Invention
The present invention is directed generally to communication systems and, more particularly, to method an apparatus for delivery of isochronous datagram delivery in a contention-based data communication system.
2. Description of the Related Art
Packet data communication systems are well known in the art. An example of a packet-based communication system is the Internet. A data message is broken into multiple data packets and transmitted on the communication system along with delivery address data and packet numbering data. The multiple data packets, which may be referred to as datagrams, may be transmitted over one or more communication pathways to the destination indicated by the destination address associated with each datagram. The datagrams are reassembled and delivered to the destination address.
Certain applications, such as email, are generally not time-sensitive. These applications will tolerate high-latency. That is, delays in transmission of the individual datagrams does not adversely affect the overall quality of service (QoS).
Other applications, such as voice over Internet protocol (VoIP) or streaming media require low-latency. That is, such applications are sensitive to delays in transmission of individual packets and the overall QoS may be adversely affected by delays. Transmission of low-latency traffic, such as VoIP over a multiple-access media, such as Ethernet, involve prioritization of the traffic by the sending node prior to injection onto the multiple-access media. The concept is to place the VoIP traffic ahead of other traffic within the sending node. These techniques typically do not guarantee that high priority, low-latency traffic will successfully access the transmission channel.
In another example, Echelon has developed a predictive P-persistent carrier sense multiple access (CSMA) that achieves low-latency via an access priority scheme. Other examples have been proposed in the literature.
In a wireless network application, a separate radio frequency (RF) channel is often used to send VoIP data as a completely separate data link path. This approach essentially eliminates contention for the RF channel.
A common alternative method is to provide sufficient capacity overhead such that low-latency traffic can flow sufficiently quickly within the confines of the existing media access control (MAC) protocol. While such applications achieve the desired low-latency and QoS, the overall system architecture results in low efficiency with respect to overall channel utilization.
Therefore, it can be appreciated that there is a significant need for a system and method for delivery of low-latency data over a contention-based data link. The present invention provides this, and other advantages, as will be apparent from the following detailed description and accompanying figures.
As will be discussed in greater detail herein, techniques disclosed herein can be used to provide transmission capabilities for low-latency applications, which are sometimes referred to as real time protocol (RTP) datagrams. The term “isochronous datagram delivery,” as used herein, refers to the transmission of data at substantially uniform time intervals. For the sake of convenience, the data may be described as datagrams or data packets. Those skilled in the art will appreciate that standards, such as the international standards organization open systems interconnection (ISO/OSI) model, define multiple communication layers wherein the data or datagrams may be part of data frames transmitted in a data link layer. The lower portion of the data link layer is generally referred to as the media access control (MAC). Specific implementation of the MAC, and the data link layer in general, can be readily accomplished by those skilled in the art applying the teachings contained herein.
The term “contention-based data link,” as used herein, refers to a communication link in which multiple users contend for access. The Ethernet is one example of a contention-based network. Wireless communication systems provide another example of contention-based networks. As will be apparent to one skilled in the art, the techniques described herein are applicable to wireless or wired contention-based networks.
The present invention is embodied in a system 100, which is illustrated in
The wireless communication network 102 also includes a plurality of customer premise equipment (CPE) 108-112, which communicate with the base station via wireless communication links 114-118, respectively. The communication links 114-118 are illustrated in
In the simplified embodiment of the wireless communication network 102 illustrated in
In low-latency applications, such as VoIP, multi-media, streaming media, and the like, one computing device is sending data to another computing device. In the example illustration of
The transmitter 142 and receiver 144 are coupled to an antenna 148. The antenna on the sending station (e.g., the CPE 108 of
An example of wireless operation using an OFDM NLOS CPE with internal premises antenna is provided in U.S. application Ser. No. 09/694,766, filed Oct. 23, 2000, and entitled FIXED OFDM WIRELESS MAN UTILIZING CPE HAVING INTERNAL ANTENNA. That application, which is assigned to the assignee of the present invention, is incorporated herein by reference in its entirety.
In a typical embodiment, the sending station 140 also includes a central processing unit (CPU) 150 and memory 152. The CPU 150 may be satisfactorily implemented by a conventional microprocessor, microcontroller, digital signal processor, programmable gate array, or the like. The present invention is not limited by the specific implementation of the CPU 150. Similarly, the memory 152 may include one or more conventional data storage components, such as random access memory, read-only memory, flash memory, or the like, and may include a combination of these elements. In general, the CPU 150 executes instructions stored in the memory 152.
The sending station 140 may also include a number of different I/O devices 154, such as a keyboard, display, cursor control device, mass storage device(s) and the like. For the sake of brevity, these various components, whose operation is well understood, are referred to as the I/O devices 154. The various components of the sending station 140 are coupled together by a bus system 156. The bus system 156 may comprise an address bus, data bas, control bus, power bus, and the like. For the sake of convenience, the various busses are illustrated in
In operation, the sending station 140 has a data file to be transmitted to a receiving station. As is known in the art, the data file is generally packetized for transmission over the contention-based data link. The packetized data, sometimes referred to as a datagram, includes a data portion and a header portion. As those skilled in the art will understand, the header portion may include source address, destination address, error correction data, priority data, and the like. The specific implementation of packets used in the present invention can be readily determined by those skilled in the art utilizing the present teachings.
Using VoIP application as an example, voice input from a user may be supplied to the sending station 140 via a microphone or pre-stored in a mass storage device, which is one of the I/O devices 154. The voice data is temporarily stored in the memory 152 and processed by the CPU 150 into datagrams, as described above. The datagrams are then placed in an output queue 160 to await transmission to the receiving station.
The sending station 140 also includes a poll rate indicator processor 162. Although illustrated as a separate block in the functional block diagram of
As will be described in greater detail below, the poll rate indicator processor 162 determines a polling rate data value to indicate the rate at which the receiving station should poll the sending station 140 for data. The polling rate data value is sent to the receiving station to thereby permit the receiving station to adjust the polling rate (i.e., the rate at which the receiving station polls the sending station for a datagram). In an exemplary embodiment, the poll rate indicator processor 162 monitors the number of datagrams in the output queue 160. Ideally, the output queue 160 will contain only a single datagram if the polling rate is properly adjusted. If the output queue 160 contains more than one datagram, the poll rate indicator processor 162 may alter the polling rate data transmitted to the receiving station to indicate that the receiving station should increase its polling rate. Conversely, if no datagrams are present in the output queue 160, the poll rate indicator processor 162 may adjust the polling rate data value sent to the receiving station to allow the receiving station to decrease its polling rate. The operation of the polling rate indicator processor 162 is described in greater detail below.
The sending station 140 also has a next poll expected (NPE) variable 164 to indicate when the next poll is expected from the receiving station. The NPE interval variable 164 is used internally within the sending station 140 as part of the sending algorithm. The poll rate indicator processor 162 adjusts this variable based on the number of datagrams in the output queue 160.
In addition to the components described above, the receiving station 170 includes a scheduler 172. The scheduler 172 receives the polling rate data generated by the polling rate indicator processor 162 (see
The operation of the system 100 may now be described in greater detail. The process will be described using the wireless system of
The desired low latency is accomplished by the use of an explicit reservation on the data channel by the receiving station 170 (see
The data link protocol comprises two data elements in addition to conventional datagram information. This includes a “preempt” signal sent from the receiving station 170 to the sending station 140. In addition, the data link protocol comprises a “next poll interval” returned by the sending station 140 to the receiving station 170 along with the isochronous datagram.
When the last of the RTP datagrams has been transmitted from the sending station 140 to the receiving station 170, the sending station transmits a call termination 184. This indicates to the receiving station that the preemption has ended and that additional polls to the sending station 140 are unnecessary. Those skilled in the art will appreciate that both the sending station 140 and the receiving station 170 may also include time-out protocols. For example, if the sending station 140 does not receive a poll 180 for some predetermined period of time, the sending station may terminate the process and/or attempt a new call setup 178 to the receiving station 170. Similarly, the receiving station 170 may include a time-out protocol where it terminates the polling process if it does not receive a response to a poll 180 within some predetermined period of time.
The isochronous session protocol of
Similarly, the example protocol illustrated in
The sending station 140 initiates the isochronous session by sending the call set up request 178 to the receiving station 170. The receiving station 170 then sends a poll signal to poll the sending station 140 for isochronous data. Although the poll signal is explicitly addressed to the isochronous sending station (i.e., the sending station 140 of
When the receiving station 170 processes the incoming RTP datagram, the NPI data value is used to determine when the next poll must be generated. For example, the sending station may have need for a high throughput rate and requires the same time slot in each data frame. In that case, the preemption of the previous sending station would continue indefinitely. In another example, the application may require the sending station to send datagrams by way of example, every 4 frames. During the intervening 3 frames, the receiving station 170 effectively removes the preempt signal and allows the previously reserved station to resume transmission of its data or a third sending station to transmit data. The use of the preempt signal permits the interposition of isochronous polls transparently within a reservation-Aloha protocol.
If the polling rate is too slow, the datagrams will begin to build up within the sending station. In response to the receipt of an additional datagram, sending station 140 changes states from the WaitForPoll state 186 to an ExtraData state 190. This indicates that the receiving station 170 is polling too slowly. In response to a poll from the receiving station 170, the sending station 140 transitions from the ExtraData state 190 to the WaitForData state 188. As will be described in greater detail below, the sending station 170 also sends data to the receiving station 170 indicating that the polling rate should increase. This forces the receiving station back to flipping between the WaitForPoll state 186 and the WaitForData state 188.
In the event that the receiving station 170 is polling too frequently, a poll may arrive before a datagram is available for transmission. If the sending station 140 is in the WaitForData state 188 (as the result of a previously received poll) and an additional poll is received, the sending station 140 transitions to an ExtraPolls state 192. This indicates that the polling rate is too fast. The availability of a datagram causes a state transition from the ExtraPolls state 192 to the WaitForPoll state 186. In addition, the datagram may include instructions to the receiving station 170 to decrease the polling rate. Thus, the state diagram illustrated in
With respect to
The overall operation of an exemplary embodiment of the system 100 is illustrated in the flow chart of
In step 208, the sending station 140 sends RTP datagram that includes both data and an NPI data value in response to the poll in step 206. In decision 210, the system 100 that determines whether the RTP transmission indicates a request to terminate the isochronous session. If the sending station 140 has requested an end to the isochronous session, the result of decision 210 is YES. In that event, the system 100 terminates the isochronous session and ends the process at 212. If the interrupted (i.e., non-RTP) sending station still has data awaiting transmission, the suspended transmission is transparently resumed without requiring any additional call setup processing for resumption of the suspended transmission.
If the isochronous session is not ending, the result of decision 210 is NO. In that event, the receiving station 170 adjusts the polling rate in step 214 and, in decision 216, determines whether it is the correct time for the next poll to the RTP sending station 140. As previously discussed, the sending station 140 transmits the NPI data value to the receiving station 170 to indicate how frequently polls should occur. While the RTP datagram transfer rate may be sufficiently high such that data is transmitted from the sending station 140 every data frame, a more typical implementation may require transmission of one or more RTP datagrams every few data frames. In the intervening data frames, other stations are free to utilize that time slot for transmission of their own data. This includes the suspended transmission from the non-RTP sending station.
If it is the time for a poll to the RTP datagram sending station 140, the result of decision 216 is YES. In that event, the system returns to step 204 where the receiving station 170 transmits a poll to the RTP sending station 140.
If it is not the time for the next poll to the RTP sending station 140, the result of decision 216 is NO. In that event, the non-RTP sending station may resume the suspended transmission in step 218. As noted above, other stations may also utilize the reserved time slot in intervening data frames if the suspended transmission has ended. That is, any sending station may utilize the time slot until it is time for the receiving station 170 to transmit a poll to the RTP sending station 140. Thus, the reserved slots for a lower priority sending stations are preempted for use by a higher priority sending station transmitting a RTP datagrams. During the operation of the isochronous session, the polling rate is dynamically adjusted such that the transmission rate substantially equals the receive rate. Upon completion of the RTP datagram transmission, the suspended lower priority transmission may resume if there are one or more data frames available before the next poll to the sending station 140. This process permits transparent operation of the RTP datagram transmission and minimizes channel access time by preempting the already reserved slot. In addition, the computationally efficient polling rate adjustment algorhithm allows for efficient transmission of the datagram.
The operation of the system 100 to dynamically adjust the polling rate is illustrated in a flow chart of
If there are less than three datagrams in the output queue 160 (see
If the output queue 160 (see
If the output queue 160 does not have less than one datagram, the result of decision 252 is NO. In that event, or following the change in the NPE variable 164 in step 246, 250, or 254, the sending station 140 transmits the polling rate data value NPI to the receiving station (e.g., the receiving station 170 of
The sending station 140 transmits the NPI data value to the receiving station 170 as part of the RTP datagram. In one embodiment, the NPI data value may be set equal to the NPE variable 164. Alternatively, the sending station 140 may send a data value other than the NPE variable 164. For example, the NPE variable 164 may increase as a result of a backup of RTP datagrams in the output queue 160. However, rather than force a rapid change in the polling rate by the receiving station 170, the sending station 140 may send a different data value, other than the NPE variable 164, so as to adjust the polling rate in the receiving station 170 more gradually than might otherwise be indicated by the NPE variable. The NPI value sent from the sending station 140 to the receiving station 170 may be greater than or less than the NPE variable 164 depending upon implementation details.
The next poll interval variable adjustment process described above is one exemplary embodiment. Where the NPE variable 164 is adjusted to try and keep the number of datagrams in the queue 160 at a level of one datagram. Those skilled in the art will appreciate that different thresholds may be utilized in implementing the sending station 140. That is, an implementation may desire to have two datagrams in the output queue 160 to optimize data processing by the sending station 140. Similarly, a threshold of more than three RTP datagrams may be required in the queue 160 prior to a large increase in the next poll expected variable 164. The present invention is clearly not limited by the specific number of RTP datagrams in the output queue 160 for the various thresholds described above.
As previously noted, the polling interval data transmitted from the sending station 140 to the receiving station 170 indicates the delay time until the next polling request by the receiving station. This value can be provided in a variety of different units based on the particular implementation. For example, the polling interval data may be time dependent units, such as slot times, symbol times, frame times or the like. Alternatively, the polling interval may simply be in time units, such as fractional seconds. In an exemplary embodiment, the NPI value transmitted from the sending station 140 to the receiving station 170 indicates a number of delay frames until the next poll. For example, if the NPI is 5, then the scheduler 174 (see
The process has been described above for a wireless communication system implementation. However, those skilled in the art will appreciate that a wire line implementation may also be advantageously implemented in accordance with the present teachings. That is, a wire line, such as an Ethernet, also operates over a contention-based datalink. In this implementation, illustrated in
In the embodiment described above, a single isochronous session was set up between the sending station (e.g., the sending station 140 of
In an alternative embodiment, illustrated in
The foregoing described embodiments depict different components contained within, or connected with, different other components. It is to be understood that such depicted architectures are merely exemplary, and that in fact many other architectures can be implemented which achieve the same functionality. In a conceptual sense, any arrangement of components to achieve the same functionality is effectively “associated” such that the desired functionality is achieved. Hence, any two components herein combined to achieve a particular functionality can be seen as “associated with” each other such that the desired functionality is achieved, irrespective of architectures or intermedial components. Likewise, any two components so associated can also be viewed as being “operably connected”, or “operably coupled”, to each other to achieve the desired functionality.
While particular embodiments of the present invention have been shown and described, it will be obvious to those skilled in the art that, based upon the teachings herein, changes and modifications may be made without departing from this invention and its broader aspects and, therefore, the appended claims are to encompass within their scope all such changes and modifications as are within the true spirit and scope of this invention. Furthermore, it is to be understood that the invention is solely defined by the appended claims. It will be understood by those within the art that, in general, terms used herein, and especially in the appended claims (e.g., bodies of the appended claims) are generally intended as “open” terms (e.g., the term “including” should be interpreted as “including but not limited to,” the term “having” should be interpreted as “having at least,” the term “includes” should be interpreted as “includes but is not limited to,” etc.). It will be further understood by those within the art that if a specific number of an introduced claim recitation is intended, such an intent will be explicitly recited in the claim, and in the absence of such recitation no such intent is present. For example, as an aid to understanding, the following appended claims may contain usage of the introductory phrases “at least one” and “one or more” to introduce claim recitations. However, the use of such phrases should not be construed to imply that the introduction of a claim recitation by the indefinite articles “a” or “an” limits any particular claim containing such introduced claim recitation to inventions containing only one such recitation, even when the same claim includes the introductory phrases “one or more” or “at least one” and indefinite articles such as “a” or “an” (e.g., “a” and/or “an” should typically be interpreted to mean “at least one” or “one or more”); the same holds true for the use of definite articles used to introduce claim recitations. In addition, even if a specific number of an introduced claim recitation is explicitly recited, those skilled in the art will recognize that such recitation should typically be interpreted to mean at least the recited number (e.g., the bare recitation of “two recitations,” without other modifiers, typically means at least two recitations, or two or more recitations).
Number | Name | Date | Kind |
---|---|---|---|
5574934 | Mirashrafi et al. | Nov 1996 | A |
5742847 | Knoll et al. | Apr 1998 | A |
6161138 | Gross et al. | Dec 2000 | A |
6259689 | Wethington et al. | Jul 2001 | B1 |
6625204 | Abramson et al. | Sep 2003 | B1 |
6633564 | Steer et al. | Oct 2003 | B1 |
6640248 | Jorgensen | Oct 2003 | B1 |
20010043573 | Kelly | Nov 2001 | A1 |
20010043574 | Nguyen et al. | Nov 2001 | A1 |
20010043575 | Kelly | Nov 2001 | A1 |
20010045908 | Kelly et al. | Nov 2001 | A1 |
20010048669 | Kelly et al. | Dec 2001 | A1 |
20010048671 | Kelly et al. | Dec 2001 | A1 |
20010049670 | Kelly et al. | Dec 2001 | A1 |
20020000931 | Petronic et al. | Jan 2002 | A1 |
20020004369 | Kelly et al. | Jan 2002 | A1 |
20020009058 | Kelly et al. | Jan 2002 | A1 |
20020015424 | Preston et al. | Feb 2002 | A1 |
20020051435 | Giallorenzi | May 2002 | A1 |
20020051438 | Ertel et al. | May 2002 | A1 |
20020051462 | Ertel et al. | May 2002 | A1 |
20020055351 | Elsey et al. | May 2002 | A1 |
20020067759 | Ertel et al. | Jun 2002 | A1 |
20020071384 | Hall et al. | Jun 2002 | A1 |
20020071479 | Giallorenzi | Jun 2002 | A1 |
20020093924 | Preston et al. | Jul 2002 | A1 |
20020093990 | Preston et al. | Jul 2002 | A1 |
20020097703 | Nieczyporowicz | Jul 2002 | A1 |
20020097706 | Preston et al. | Jul 2002 | A1 |
20020099854 | Jorgensen | Jul 2002 | A1 |
20020126850 | Hall et al. | Sep 2002 | A1 |
20020131375 | Vogel et al. | Sep 2002 | A1 |
20020136168 | Struhsaker et al. | Sep 2002 | A1 |
20020136169 | Struhsaker et al. | Sep 2002 | A1 |
20020136170 | Struhsaker | Sep 2002 | A1 |
20020141355 | Struhsaker et al. | Oct 2002 | A1 |
20020141587 | Ertel et al. | Oct 2002 | A1 |
20020146060 | Ertel et al. | Oct 2002 | A1 |
20020158797 | Kelly et al. | Oct 2002 | A1 |
20020172180 | Hall | Nov 2002 | A1 |
20020172193 | Preston et al. | Nov 2002 | A1 |
20020181446 | Preston et al. | Dec 2002 | A1 |
20030050015 | Kelly et al. | Mar 2003 | A1 |
20030058810 | Petronic | Mar 2003 | A1 |
20030067903 | Jorgensen | Apr 2003 | A1 |
20030088366 | Branlund | May 2003 | A1 |
20030112878 | Kloper | Jun 2003 | A1 |
20030161284 | Chen | Aug 2003 | A1 |
20030186694 | Sayers | Oct 2003 | A1 |
20030223750 | Farmer | Dec 2003 | A1 |
20040033780 | Kelly | Feb 2004 | A1 |
20070058581 | Benveniste | Mar 2007 | A1 |
Number | Date | Country | |
---|---|---|---|
20050195828 A1 | Sep 2005 | US |
Number | Date | Country | |
---|---|---|---|
60550722 | Mar 2004 | US |