Bluetooth supports both synchronous and asynchronous services. For these services, conventional Bluetooth devices provide two different types of physical links: namely Synchronous Connection Oriented (SCO) links and Asynchronous Connectionless Links (ACLs). These two types of links are capable of handling many different device types and usage. Currently, SCO and ACL links do not have the necessary capabilities to handle many types of real-time, high bit rate communications, such as media data.
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 example enables data packets of variable size to be used on Bluetooth communication links over Universal Serial Bus (USB). A host device is configured to identify a target device with Bluetooth capabilities. The host device may determine a USB alternate setting for Bluetooth communication having data packets of variable sizes and establish a Bluetooth connection link with the target device having the determined USB alternate setting. Data packets are provided to the target device with variable sizes up to a maximum size associated with the alternate setting. In one implementation, the USB alternate setting is a new setting that is added to an existing Bluetooth SIG specification.
Many of the attendant features will be more readily appreciated as the same becomes 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 read in light of 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 appended drawings is intended as a description of the present examples and is not intended to represent the only forms in which the present example may be constructed or utilized. The description sets forth the functions of the example and the sequence of steps for constructing and operating the example. 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 system for transmitting variable-size data packets with Bluetooth enhanced synchronous oriented links over USB, the system 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 systems for transmitting variable-sized data packets using Bluetooth.
Host 103 may establish connections with Bluetooth capable devices through Bluetooth module 107. As shown in
In operation, Bluetooth module 107 is configured to communicate with target devices 131-133 to set the type of the connection link before data packets associated with that link are sent. In particular, Bluetooth module 107 is configure to specify the properties of the data packets transmitted over the communication link. In one example implementation, a USB alternate setting in accordance with a Bluetooth SIG specification is used to specify the data packet properties for Bluetooth links over USB. A new USB alternate setting is incorporated in the specification and is associated with a maximum data packet size that can include time-bounded data with a high bit rate. Host and target devices 131-133 are configured to send data packets of any size up to the maximum size.
SCO link 203 is configured for communicating synchronized information. SCO link 203 is typically configured as a symmetric, point to point link between the host (e.g. master) and the slave (e.g. target device) in the piconet. SCO link 203 may be used where latency is more important than data integrity. Particularly, SCO link 203 is suitable for time-bounded information like voice communications. SCO data packets are time-bounded and are typically not retransmitted. A SCO link may be set up by a Link Manager (LM) command from the master to the slave. This message may contain timing parameters, which specify SCO timing interval and starting offset.
eSCO links 204 is also configured for communicating synchronized information. eSCO link 204 has a number of enhancements over SCO link 203. For example, eSCO link 204 provides some retransmission capabilities and, thus, can improve data transmission performance in noisy environments. eSCO link 204 also allows the devices to choose a custom audio codec. Furthermore, eSCO enables packet types that allow the two devices to communicate at a higher bandwidth. Available data packet types for Bluetooth links over USB are associated with USB alternate settings specified by a conventional Bluetooth SIG specification. eSCO settings are communicated between the master and slave Bluetooth devices so that the devices understand the process for creating and parsing data packets. In one example implementation, the actual alternative settings are implicit based on the type and number of SCO or eSCO links. For example if one SCO 8-bit, use Interface Number=1, Alternative Setting=1; if three SCO 16-bit, use Interface Number=1, Alternative Setting=5; if eSCO, use new proposed Alternative Setting. Conventional USB alternate settings and the associated data packet types as specified by the existing Bluetooth specification are typically sufficient for communicating data for SCO links over USB. However, these conventional alternative settings are not sufficient to provide eSCO data packets for eSCO links when eSCO data packets are different from the existing eSCO packets are allowed under the existing Bluetooth specification. Conventional USB alternate settings will be discussed in conjunction with
Data packets for various communication types are included in specification 300. In particular, specification 300 specifies the data packets for Host Controller Interface (HCI) commands and events. These data packets are mainly used by the host to send administrative data related to the connection to the target device and typically do not contain the substantive data that are to be communicated.
Specification 300 also specifies the properties of data packets communicated through an ACL. In specification 300, data packets for ACL have a maximum USB data packet size of either 32 bytes or 64 bytes. As described above, ACL is not suitable for time-bounded data.
For time-bounded data, example specification 300 supports several types of USB data packet types suitable for SCO links. Each type of time-bounded data packets is associated with a particular USB alternate setting. As shown in
The data packets specified by specification 300 are suitable for SCO links with relatively low bit rate voice communication. However, the described USB alternate settings typically do not provide data packets that are suitable for carrying information for eSCO links, which do not have packet size limitations of transfer rates or bit rates. Typically, data for eSCO links can include enhanced quality audio, music, video, and other media data.
Data packet type 500 also enables a Bluetooth device to use different data packet sizes, up to the maximum size. In this manner, the device can efficiently transmit data without being constrained by a fixed data packet size. It is to be appreciated that data packet type 500 in the example shown in
Returning to decision block 706, if extended SCO USB is not supported, process 700 goes to decision block 720 where a determination is made whether 64 Kbit/sec link is supported. If not, process 700 returns an error at block 730. If so, process 700 continues at block 722 where the USB packet size is computed. At block 724, the USB alternative setting is selected from the USB specification. The process then continues at block 712.
Depending on the exact configuration and type of computing device, memory 810 may be volatile (such as RAM), non-volatile (such as ROM, flash memory, etc.) or some combination of the two. Additionally, computing device 800 may also have additional features/functionality. For example, computing device 800 may include multiple CPU's. The described methods may be executed in any manner by any processing unit in computing device 800. For example, the described process may be executed by both multiple CPU's in parallel.
Computing device 800 may also include additional storage (removable and/or non-removable) including, but not limited to, magnetic or optical disks or tape. Such additional storage is illustrated in
Computing device 800 may also contain communications device(s) 840 that allow the device to communicate with other devices. Communications device(s) 840 is an example of communication media. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” 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, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. The term computer-readable media as used herein includes both computer storage media and communication media. The described methods may be encoded in any computer-readable media in any form, such as data, computer-executable instructions, and the like.
Computing device 800 may also have input device(s) 835 such as keyboard, mouse, pen, voice input device, touch input device, etc. Output device(s) 830 such as a display, speakers, printer, etc. may also be included. All these devices are well know in the art and need not be discussed at length.
Those skilled in the art will realize that storage devices utilized to store program instructions can be distributed across a network. For example a remote computer may store an example of the process described as software. A local or terminal computer may access the remote computer and download a part or all of the software to run the program. Alternatively the local computer may download pieces of the software as needed, or distributively process by executing some software instructions at the local terminal and some at the remote computer (or computer network). Those skilled in the art will also realize that by utilizing conventional techniques known to those skilled in the art that all, or a portion of the software instructions may be carried out by a dedicated circuit, such as a DSP, programmable logic array, or the like.