The transport of multiple channels of isochronous constant-rate data is increasingly popular given the advent of personal computing devices used for communications. Wireless devices for transporting such data are also increasingly popular. Isochronous constant-rate data, such as real-time and/or streaming audio and/or video data, tend to require low transport latencies while also being tolerant of some loss. Various technologies for transporting multiple channels of such data are becoming more common. For example, three persons may concurrently listen to music streamed from a personal computer (“PC”) to wireless headsets, the wireless link between each headset and the PC comprising an isochronous, constant-rate data channel. One example technology for transporting such data is Bluetooth.
The scheduling of multiple isochronous constant-rate data streams can be a difficult problem. Due to the time-dependent nature of such data, data from multiple streams or channels must be interlaced and delivered to an underlying transport mechanism at regular intervals or time slots. Problems can occur if data from one of the channels is delayed or missing at the time of scheduling. In such a case, a decision must be made as to whether or not to wait for data that is not available at the time of scheduling but that may be ready in time for actual transport. If a scheduler waits too long for the delayed data, it risks delaying other channels which may have data ready to be sent. If it skips the delayed data and continues on to the next data channel, the scheduler may skip data that would otherwise have been ready by the time the channel was scheduled (the arrival of the associated time slot) for actual transport. Such difficulties can lead to unacceptable multi-channel operation.
The following presents a simplified summary of the disclosure in order to provide a basic understanding to the reader. This summary is not an extensive overview of the disclosure and it does not identify key/critical elements of the invention or delineate the scope of the invention. Its sole purpose is to present some concepts disclosed herein in a simplified form as a prelude to the more detailed description that is presented later.
The present examples provide technologies for scheduling the dispatch of multi-channel isochronous constant-rate data, such as real-time and/or streaming audio data, video data, or the like. The technologies include systems and methods that provide for the independent dispatch of such data from each of multiple channels such that data delays in one channel have no adverse affect on the dispatch of data from another channel.
Many of the attendant features will be more readily appreciated as the same become better understood by reference to the following detailed description considered in connection with the accompanying drawings.
The present description will be better understood from the following detailed description considered in connection with the accompanying drawings, wherein:
Like reference numerals are used to designate like parts in the accompanying drawings.
The detailed description provided below in connection with the accompanying drawings is intended as a description of the present examples and is not intended to represent the only forms in which the present examples may be constructed or utilized. The description sets forth at least some of the functions of the examples and/or the sequence of steps for constructing and operating examples. However, the same or equivalent functions and sequences may be accomplished by different examples.
Although the present examples are described and illustrated herein as being implemented in a computing environment, the environment described is provided as an example and not a limitation. As those skilled in the art will appreciate, the present examples are suitable for application in a variety of different types of computing environments or the like.
Block 110 includes example channel controller 116 and three example channels, channels 1, 2 and 3. Users of system 100, such as software applications, programs, systems, or the like (“users” or “user applications”), typically interact with system 100 via protocol or application interface (“API”) 114. Users are typically able to allocate or establish one or more channels via channel controller 116 using API 114.
Users of system 100 typically transport channel data over allocated channels using channel interfaces, such as example interfaces 111-113. Such channel interfaces may be part of API 114. System 100 generally supports multiple users, each user allocating one or more channels. In one example, system 100 may establish between one and three SCO channels.
Example channels 1-3 typically provide a constant-rate transport with data transmission intervals locked to timing signals provide by example clock 180. Data is generally transported via a channel in fixed size packets at fixed intervals, typically as specified when the channel is established. Clock 180 provides signals that establish a fixed interval or constant rate of transmission. For example, at each constant-rate interval indicated by clock 180, data in transport buffer 120 at the location of read pointer 124 is read and transmitted and read pointer 124 is advanced to the next frame of transport buffer 120. Thus, read pointer 124 is locked to clock 180, advancing through the frames of transport buffer 120, sequentially indicating the frames of data to be read from the buffer, the data being transmitted in lock-step with constant-rate timing signals from clock 180.
For data being sent from system 100, example scheduler 130 typically provides data from the established channels to transport 140. This typically occurs by breaking data into fixed-size packets that correspond to frames, such as example frame 126, in transport buffer 120 and dispatching the packets or writing them into the buffer.
Transport buffer 120 is typically partitioned to provide a series of frames in a repeating sequential fashion for each established channel, with a corresponding write pointer for each channel, such as example write pointers 122. For example, each fixed-size packet from channel 1 is typically dispatched or written to transport buffer 120 at the location of the write pointer for channel 1. If only a single channel is allocated, then transport buffer 120 is dedicated entirely to data packets from channel 1. Alternatively, if two channels are allocated, then buffer frames alternate for data packets from channel 1 and channel 2, the corresponding write pointers pointing to the next available frame location in buffer 120 for each channel. A similar example with three channels is shown in
Transport 140 typically reads any data in transport buffer 120, the reading generally taking place in lock-step with constant-rate timing signals from clock 180. The location of reads is controlled by read pointer 124 which generally moves forward in the buffer, as indicated by timing indicator 128, according to clock 180 timing signals. Generally, once read pointer 124 advances past a frame, that frame is no longer available for writing by scheduler 130.
Transport 140 provides data packets that have been read from transport buffer 120 to example radio 150 for transmission. Radio 150 subsequently transmits the frames to their destination. Destinations, such as indicated by cloud 170, are typically other computing environments including an instance of system 100.
Example channel schedulers 231-233 are typically established in conjunction with the allocation of a corresponding channel. For example, when a user application allocates a single channel, say channel 1, a corresponding channel scheduler is also established, channel 1 scheduler 231. Alternatively, if two channels are allocated via one or more users then two channel schedulers are established (such as channel 1-2 schedulers 231 and 232). If three channels are allocated then three channel schedulers are established (such as channel 1-3 schedulers 231-233), and so forth.
Each channel scheduler typically schedules the writing of data packets from a corresponding channel into appropriate frames or time slots in transport buffer 120. Each channel scheduler writes the next available data packet into the frame in the buffer indicated by a corresponding write pointer. Data packets are typically made available after a user writes them to a channel, such as channels 1, 2, and 3. For example, channel 1 scheduler 231 writes the next available data packet from channel 1 into frame 221 pointed to by write pointer 1 (as indicated by the dotted arrow between 231 and 221), after which the pointer is advance to the next frame of transport buffer 120 reserved for data packets from channel 1. Note the number from 1 to 3 printed in each frame of example transport buffer 120 in
The dashed arrow drawn between channel 3 scheduler 233 and frame 223 indicates control over the channel 3 write arrow by channel 3 scheduler 233. A similar dashed arrow is shown between channel 1 scheduler 231 and frame 221, and between channel 2 scheduler 232 and frame 222. In practice, control of write pointers may be maintained via elements of scheduler 230 and/or in conjunction with transport 140.
Read monitor 234 is typically an element or function of scheduler 230 that monitors the position of read pointer 124, as indicated by the dashed arrow between read pointer 124 and read monitor 234. Read pointer 124 is typically advanced one frame by transport 140 as each data packet is read from transport buffer 120 and transmitted over the physical media, such as radio 150. Read monitor 234 generally compares the position of each of the write pointers 122 to the position of read pointer 124. If a data packet to be written at a write pointer buffer location doesn't become available until after the read pointer advances past the write pointer, then scheduler 230 generally discards the late data packet. For example, if read pointer 124 advances to frame 222 before a data packet becomes available for channel 1 scheduler 231 to write into frame 221, then channel 1 scheduler 231 discards the late data packet and advances the channel 1 write pointer to the next channel 1 frame location in transport buffer 120, or the frame following frame 223. Alternatively, channel 1 scheduler 231 may write the data packet into frame 221 even though read pointer 224 has already advanced past the channel 1 write pointer as the data packet is thus written too late to be read. Generally, each channel scheduler operates similarly to yet independently from any others. By establishing such independent channel schedulers for each allocated channel, isochronous constant-rate data from each channel may be independently dispatched such that data availability delays from one channel do not adversely impact data being sent from other channels.
In one example, channels 110 correspond to Bluetooth SCO streams and transport buffer 120 corresponds to a universal serial bus (“USB”) frame buffer associated with a Bluetooth USB interface. In this example, the data packets of a particular SCO stream always arrive in order, but data packets between SCO streams may arrive out of order. For example, channel 1 may make available two packets, then channel 3 one packet, followed by channel 2 three packets, etc. Scheduler 230 dispatches data packets from multiple SCO streams, even when the packets arrive out of order between streams, to the USB interface such that they are transmitted via the USB bus in proper order. Any packet arrive too late to be dispatched and transmitted in proper order is typically dropped.
Block 310 indicates receiving an indication that a new channel has been allocated. The channel allocation process, which is separate from method 300, typically includes the following: For each newly allocated channel, the transport buffer is further subdivided such that each sequence of frames includes a frame for the new channel. A write pointer is also established for the new channel that points to the next available frame for the channel. Frames are typically sized to represent a specific duration of time. In one example, the frames in a system with three channels accept 9 millisecond (“ms”) chunks of data. In another example, the frames in a system with two channels accept 6 millisecond (“ms”) chunks of data. Once an indication is received, method 300 typically continues at block 320.
Block 320 indicates establishing a channel scheduler for the newly allocated channel. The channel scheduler monitors the new channel for data available to be transported. Each such channel scheduler operates independently of other channel schedulers. That is, no channel scheduler is blocked from dispatching data from its channel due to delays in data arrival or the like on other channels. Once a channel scheduler is established, method 300 typically continues at block 330.
Block 330 indicates the channel scheduler determining if data is available in the channel for dispatch. When a user of the system, typically the user that allocated the new channel, writes data to the channel, then data is available for dispatch. If data is available, method 300 typically continues at block 340.
Block 340 indicates determining if the read pointer has advanced beyond the new channel's write pointer. This typically occurs if there is a delay in channel data availability beyond the time that the frame is to be transmitted. If the read pointer had advanced beyond the new channel's write pointer, then method 300 typically continues at block 360. Otherwise method 300 typically continues at block 350.
Block 350 indicates dispatching data from the new channel. Generally the channel scheduler will read a packet of data from the new channel and write the data packet into the frame of the transport buffer pointed to by the write pointer for the new channel. Data packets are generally read from the channel in first-in, first-out (“FIFO”) order. After a data packet has been dispatched, method 300 typically continues at block 330.
Block 360 indicates discarding data from the new channel. Generally the channel scheduler will discard a packet of data from the new channel, the data packet discarded being the one that would have been dispatched (see block 350) had it not been delayed beyond the channel's frame transmission time. In an alternative example, the data packet is dispatched as indicated by block 350, but the packet is never transmitted because the transport read pointer is already beyond the frame of the late data packet. After the data packet is discarded, method 300 typically continues at block 330.
Computing environment 400 typically includes a general-purpose computing system in the form of a computing device 401 coupled to various components, such as peripheral devices 402, 403, 404 and the like. System 400 may couple to various other components, such as input devices 403, including voice recognition, touch pads, buttons, keyboards and/or pointing devices, such as a mouse or trackball, via one or more input/output (“I/O”) interfaces 412. The components of computing device 401 may include one or more processors (including central processing units (“CPU”), graphics processing units (“GPU”), microprocessors (“pP”), and the like) 407, system memory 409, and a system bus 408 that typically couples the various components. Processor 407 typically processes or executes various computer-executable instructions to control the operation of computing device 401 and to communicate with other electronic and/or computing devices, systems or environment (not shown) via various communications connections such as a network connection 414 or the like. System bus 408 represents any number of several types of bus structures, including a memory bus or memory controller, a peripheral bus, a serial bus, an accelerated graphics port, a processor or local bus using any of a variety of bus architectures, and the like.
System memory 409 may include computer readable media in the form of volatile memory, such as random access memory (“RAM”), and/or non-volatile memory, such as read only memory (“ROM”) or flash memory (“FLASH”). A basic input/output system (“BIOS”) may be stored in non-volatile or the like. System memory 409 typically stores data, computer-executable instructions and/or program modules comprising computer-executable instructions that are immediately accessible to and/or presently operated on by one or more of the processors 407.
Mass storage devices 404 and 410 may be coupled to computing device 401 or incorporated into computing device 401 via coupling to the system bus. Such mass storage devices 404 and 410 may include non-volatile RAM, a magnetic disk drive which reads from and/or writes to a removable, non-volatile magnetic disk (e.g., a “floppy disk”) 405, and/or an optical disk drive that reads from and/or writes to a non-volatile optical disk such as a CD ROM, DVD ROM 406. Alternatively, a mass storage device, such as hard disk 410, may include non-removable storage medium. Other mass storage devices may include memory cards, memory sticks, tape storage devices, and the like.
Any number of computer programs, files, data structures, and the like may be stored in mass storage 410, other storage devices 404, 405, 406 and system memory 409 (typically limited by available space) including, by way of example and not limitation, operating systems, application programs, data files, directory structures, computer-executable instructions, and the like.
Output components or devices, such as display device 402, may be coupled to computing device 401, typically via an interface such as a display adapter 411. Output device 402 may be a liquid crystal display (“LCD”). Other example output devices may include printers, audio outputs, voice outputs, cathode ray tube (“CRT”) displays, tactile devices or other sensory output mechanisms, or the like. Output devices may enable computing device 401 to interact with human operators or other machines, systems, computing environments, or the like. A user may interface with computing environment 400 via any number of different I/O devices 403 such as a touch pad, buttons, keyboard, mouse, joystick, game pad, data port, and the like. These and other I/O devices may be coupled to processor 407 via I/O interfaces 412 which may be coupled to system bus 408, and/or may be coupled by other interfaces and bus structures, such as a parallel port, game port, universal serial bus (“USB”), fire wire, infrared (“IR”) port, and the like.
Computing device 401 may operate in a networked environment via communications connections to one or more remote computing devices through one or more cellular networks, wireless networks, local area networks (“LAN”), wide area networks (“WAN”), storage area networks (“SAN”), the Internet, radio links, optical links and the like. Computing device 401 may be coupled to a network via network adapter 413 or the like, or, alternatively, via a modem, digital subscriber line (“DSL”) link, integrated services digital network (“ISDN”) link, Internet link, wireless link, or the like.
Communications connection 414, such as a network connection, typically provides a coupling to communications media, such as a network. Communications media typically provide computer-readable and computer-executable instructions, data structures, files, program modules and other data using a modulated data signal, such as a carrier wave or other transport mechanism. The term “modulated data signal” typically means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communications media may include wired media, such as a wired network or direct-wired connection or the like, and wireless media, such as acoustic, radio frequency, infrared, or other wireless communications mechanisms.
Power source 490, such as a battery or a power supply, typically provides power for portions or all of computing environment 400. In the case of the computing environment 400 being a mobile device or portable device or the like, power source 490 may be a battery. Alternatively, in the case computing environment 400 is a desktop computer or server or the like, power source 490 may be a power supply designed to connect to an alternating current (“AC”) source, such as via a wall outlet.
Some mobile devices may not include many of the components described in connection with
Those skilled in the art will realize that storage devices utilized to provide computer-readable and computer-executable instructions and data can be distributed over a network. For example, a remote computer or storage device may store computer-readable and computer-executable instructions in the form of software applications and data. A local computer may access the remote computer or storage device via the network and download part or all of a software application or data and may execute any computer-executable instructions. Alternatively, the local computer may download pieces of the software or data as needed, or distributively process the software by executing some of the instructions at the local computer and some at remote computers and/or devices.
Those skilled in the art will also realize that, by utilizing conventional techniques, all or portions of the software's computer-executable instructions may be carried out by a dedicated electronic circuit such as a digital signal processor (“DSP”), programmable logic array (“PLA”), discrete circuits, and the like. The term “electronic apparatus” may include computing devices or consumer electronic devices comprising any software, firmware or the like, or electronic devices or circuits comprising no software, firmware or the like.
The term “firmware” typically refers to executable instructions, code, data, applications, programs, or the like maintained in an electronic device such as a ROM. The term “software” generally refers to executable instructions, code, data, applications, programs, or the like maintained in or on any form of computer-readable media. The term “computer-readable media” typically refers to system memory, storage devices and their associated media, and the like.
In view of the many possible embodiments to which the principles of the present invention and the forgoing examples may be applied, it should be recognized that the examples described herein are meant to be illustrative only and should not be taken as limiting the scope of the present invention. Therefore, the invention as described herein contemplates all such embodiments as may come within the scope of the following claims and any equivalents thereto.