Disclosed embodiments relate generally to the field of Bluetooth devices in Bluetooth network communications, more specifically to data forwarding between such Bluetooth devices.
Bluetooth (BT) is an example ad-hoc networking technology. BT technology is a wireless communication standard generally used when transferring information between two or more wireless devices that are near to one another when speed is not a consideration, including telephones, printers, modems and headsets. BT is well suited for low-bandwidth applications including transferring sound data with telephones (e.g., with a BT headset) or byte data with hand-held computers (transferring files), or keyboards and mice. The BT Special Interest Group (SIG) specification may be used for these BT communications.
One use for BT is for scatternets which include a plurality of independent and unsynchronized piconets, where piconets are a basic unit of BT networking. In a piconet, there is a master device and one or more slave devices, where the devices each generally include a host processor (or ‘application processor’) and a controller (or ‘firmware (FW) processor’). The master device determines the channel and phase for the slave device(s). A scatternet is a type of adhoc computer network comprising two or more piconets. In a scatternet, a slave device can communicate with more than one piconet. In connection with operation of a scatternet, the BT master devices may relay the identity of mobile slave devices that are within their individual piconets to its host processor for purposes of tracking the location of a mobile slave device, or the location of a person carrying a mobile slave device.
As shown in
Upon reception of the data, the BT devices other than the first BT device 101 shown as BT devices 102 and 103 in
This Summary is provided to introduce a brief selection of disclosed concepts in a simplified form that are further described below in the Detailed Description including the drawings provided. This Summary is not intended to limit the claimed subject matter's scope.
Disclosed embodiments recognize for BT applications where each BT device includes a host processor and a BT controller coupled together by a HCI, conventional data forwarding for BT devices wakes up the host processor for looping with respect to its BT controller for every packet received including resending the data back to its BT controller, which wastes battery power, and also increases latency. For BT applications (e.g., scatternet applications) it is desirable to send data to the next BT device in the chain without involving the host processor, at least not looping through the host processor. This reduces the system power consumption dramatically in the Advanced Audio Distribution Profile (A2DP) use case.
All known BT-based communication systems involve the host processor of the BT devices participating in data forwarding by looping the data through the host processor before being forwarded to the next BT device in the chain including parsing, acting on, and resending the data to the BT controller. Advantages of disclosed data forwarding include enabling data such as A2DP data to be transferred from one BT device to several other BT devices without waking up the host, or at least not looping through its host processor.
A new mechanism generally in the FW layer of the BT device allows the user to forward Asynchronous Connection-Less (ACL) data without the host processor involvement in at least resending the data received back to its BT controller, which minimizes data latency and device power consumption. A disclosed set of new HCI commands between the host processor and BT controller enables a user to define the network topology to configure each BT device in the chain from which one of the BT devices the BT device receives data from, and to which one of the BT devices the BT device forwards the received data to. Disclosed HCI also optionally configures for each BT device whether to send the received data to its host processor or not, and if sent to its host processor, whether to add a time stamp to each packet or not (e.g., in order to time synchronize between the respective BT devices in the chain).
Reference will now be made to the accompanying drawings, which are not necessarily drawn to scale, wherein:
Example embodiments are described with reference to the drawings, wherein like reference numerals are used to designate similar or equivalent elements. Illustrated ordering of acts or events should not be considered as limiting, as some acts or events may occur in different order and/or concurrently with other acts or events. Furthermore, some illustrated acts or events may not be required to implement a methodology in accordance with this disclosure.
Also, the terms “coupled to” or “couples with” (and the like) as used herein without further qualification are intended to describe either an indirect or direct electrical connection. Thus, if a first device “couples” to a second device, that connection can be through a direct electrical connection where there are only parasitics in the pathway, or through an indirect electrical connection via intervening items including other devices and connections. For indirect coupling, the intervening item generally does not modify the information of a signal but may adjust its current level, voltage level, and/or power level.
Step 201 comprises providing BT devices at respective nodes in a BT network, where the BT devices (see the BT device shown in
The BT controller includes a processor coupled to a memory and to a transceiver, and a RF driver for driving the transceiver that is adapted to be coupled to an antenna. The HCI firmware includes disclosed HCI command code which allows a user to define a topology of the BT network, including configuring each BT device in a current chain including from which one of the BT devices it receives data from to which one of BT devices it should forward data to. Step 202 comprises configuring the BT network comprising configuring each BT device in a current chain from which of the BT devices it receives data including at least one packet from, and to which one of the BT devices it forwards the data to. Step 203 comprises communicating the data across the BT network with the BT devices forwarding the data between the BT devices without the device's host processor's involvement in at least resending the data back to its BT controller.
Upon reception of the data, the BT devices other than the first BT device 301 shown as BT devices 302 and 303 in
The BT device 400 comprises a host processor 425a and a BT controller 425b that communicate with one another over the HCI 430. The host processor 425a includes a memory 432 that stores disclosed HCI FW including disclosed HCI command code which allows a user to define a topology of the BT network, including configuring each BT device in a current chain including from which one of the BT devices it receives data including at least one packet from, and to which one of the BT devices it should forward the data to. The BT controller 425b includes a processor 423, a memory 422 including software source code 422a for parsing, understanding and acting on commands received from the host processor 425a for implementing disclosed ACL data forwarding for the BT device 400. BT device 400 also includes a transceiver 424 including a RF driver 424a that is adapted to be coupled to an antenna 418 which is generally off chip. The processors can comprise a digital signal processor (DSP) or microcontroller. The processors collectively implement a BT protocol stack for BT operations (see
The transceiver 424 is also shown including hardware comprising digital logic 424b that can be used as an alternative to software 422a for implementing disclosed ACL forwarding. As known in the art the transceiver 424 includes a transmitter and a receiver. The transmitter generally comprises a media access control (MAC) module, an encoder, a modulator, an Inverse Fast Fourier Transform (IFFT) unit, a digital to analog conversion (DAC)/filter module, and a RF/antenna module. The receiver generally comprises a RF/antenna unit, an analog to digital conversion (ADC)/filter unit, a FFT unit, a demodulator, a decoder, and a MAC module.
The memory 422 is more generally configured to store information including data, instructions, or both. The memory 422 may be any storage medium accessible by the processor 423, such as a read only memory (ROM), a random access memory (RAM), a register, cache memory, or magnetic media device such as internal hard disks and removable disks. A phase lock loop (PLL) 432 is also provided for purposes including mixing and frequency synthesis.
The processor 423 is coupled to the memory 422 and to the transceiver 424. In some implementations, the transceiver 424 comprises baseband units (not shown in
The BT controller 425b is shown including link manager protocol (LMP) 426, a baseband section and a RF section that are part of the transceiver 424 shown in
Disclosed embodiments are further illustrated by the following specific Examples, which should not be construed as limiting the scope or content of this Disclosure in any way.
Those skilled in the art to which this disclosure relates will appreciate that many other embodiments and variations of embodiments are possible within the scope of the claimed invention, and further additions, deletions, substitutions and modifications may be made to the described embodiments without departing from the scope of this disclosure. For example, although BT communications are generally described herein using ACL, disclosed BT communications may also utilize other link types, such as a Synchronous Connection Oriented (SCO) link which comprises a set of reserved timeslots on an existing ACL transport.
This application is a continuation of U.S. patent application Ser. No. 16/102,033, filed on Aug. 13, 2018, which is a continuation and claims priority to U.S. patent application Ser. No. 15/696,902, filed Sep. 6, 2017 (Now U.S. Pat. No. 10,051,450), both of which is incorporated herein by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
7082461 | Sharma | Jul 2006 | B2 |
7529237 | Ami | May 2009 | B2 |
7546099 | Trost et al. | Jun 2009 | B2 |
8126982 | Nidd | Feb 2012 | B2 |
8190716 | Zhodzishsky | May 2012 | B2 |
8275316 | Ding | Sep 2012 | B2 |
8583169 | Walley | Nov 2013 | B2 |
8761671 | Singer et al. | Jun 2014 | B2 |
9258671 | Tsaur | Feb 2016 | B2 |
9306872 | Donaldson | Apr 2016 | B2 |
9426835 | Van De Laar | Aug 2016 | B2 |
9433033 | Luft | Aug 2016 | B2 |
20010002908 | Rune et al. | Jun 2001 | A1 |
20020120750 | Nidd | Aug 2002 | A1 |
20020151275 | Trost et al. | Oct 2002 | A1 |
20030021262 | Ma | Jan 2003 | A1 |
20030104826 | Deng | Jun 2003 | A1 |
20030235202 | Van Der Zee | Dec 2003 | A1 |
20060146777 | Ami | Jul 2006 | A1 |
20100273417 | Tian | Oct 2010 | A1 |
20110161529 | Chen | Jun 2011 | A1 |
20130089080 | Singer | Apr 2013 | A1 |
20130090063 | Singer et al. | Apr 2013 | A1 |
Number | Date | Country |
---|---|---|
105681189 | Jun 2016 | CN |
105959921 | Sep 2016 | CN |
2017051173 | Mar 2017 | WO |
WO20170514173 | Mar 2017 | WO |
Entry |
---|
Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration; dated Dec. 27, 2018; 7 pages. |
Supplementary European Search Report; EP 18 85 4755; App. No./ Patent No. 188854755.8-1213/3679763 PCT/US2018049748; dated Aug. 9, 2020. |
Co-pending Chinese Patent Application No. 2018800569485 Office Action dated Dec. 5, 2022, 17 pgs. |
Co-pending Chinese Patent Application No. 2018800569485 Search Report dated Dec. 5, 2022, 2 pgs. |
Number | Date | Country | |
---|---|---|---|
20210029525 A1 | Jan 2021 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16102033 | Aug 2018 | US |
Child | 17068621 | US | |
Parent | 15696902 | Sep 2017 | US |
Child | 16102033 | US |