BLUETOOTH low energy (BLE) is a wireless communication technology useful for various applications and devices, such as in healthcare, fitness, security, home entertainment, and communication devices. The BLE communication technology provides for lower power consumption of the communication devices in comparison to BLUETOOTH or other wireless communication technologies, while also maintaining a similar wireless communication range and coverage. The reduced power consumption of the communication devices may be provided by a simpler modulation scheme in comparison to the other wireless communication technologies. The BLE communication technology is based on a BLE communication standard supported by various operating systems (OS), including ANDROID, IOS, WINDOWS, MACOS, LINUX, and other OS to operate the communication devices.
In accordance with at least one example of the description, a method includes broadcasting advertising packets from a broadcaster BLUETOOTH device, where the advertising packets include one or more connection parameters for one or more links in a link cluster. The method also includes receiving, at the broadcaster BLUETOOTH device, a link cluster coordination request from a scanner BLUETOOTH device, where the link cluster coordination request includes one or more connection parameters for a link in the link cluster.
In accordance with at least one example of the description, a system includes a scanner BLUETOOTH device configured to scan for advertising packets from a broadcaster BLUETOOTH device, where the advertising packets include one or more connection parameters for one or more links in a link cluster. The scanner BLUETOOTH device is also configured to, responsive to receiving an advertising packet, transmit a link cluster coordination request from the scanner BLUETOOTH device to the broadcaster BLUETOOTH device, where the link cluster coordination request includes one or more connection parameters for a link in the link cluster.
In accordance with at least one example of the description, a method includes receiving a generic access protocol (GAP) connect request at a broadcaster BLUETOOTH device. The method also includes transmitting a GAP connect response from the broadcaster BLUETOOTH device to a scanner BLUETOOTH device. The method includes receiving an enable message from the scanner BLUETOOTH device at the broadcaster BLUETOOTH device to enable generic attribute (GATT) notifications. The method also includes, responsive to receiving the enable message, transmitting GATT notifications regarding connection parameters of one or more links in a link cluster from the broadcaster BLUETOOTH device to the scanner BLUETOOTH device. The method includes receiving a disable message from the scanner BLUETOOTH device at the broadcaster BLUETOOTH device to disable GATT notifications. The method also includes, responsive to receiving the disable message, disabling transmitting GATT notifications regarding one or more links in the link cluster from the broadcaster BLUETOOTH device to the scanner BLUETOOTH device.
The same reference numbers or other reference designators are used in the drawings to designate the same or similar (functionally and/or structurally) features.
The BLUETOOTH (BT) Low Energy (BLE) standard defines a standard hierarchy of components. The hierarchy includes a BLE controller and a BLE host. Some examples may include a BLE PHY (physical) layer and a radio frequency (RF) frontend. On top of the BLE controller and BLE host resides the BLE application. The BLE controller handles all tasks required for a connection to stay active. A unicast BLE connection consists of two devices. BLE devices communicate at constant intervals (i.e. connection events) on channels known as a BLE data channel set. During a connection event, a device called a central handles one or more connection events by transmitting and receiving a packet(s) to a device called a peripheral. According to the BLE communication standard in the Bluetooth Core Specification Verification 5.3, which is incorporated herein by reference, data transfers may be carried over links or data channel sets, which are connections established between communication devices to exchange data in the form of messages or packets. Each data channel within the channel set has a unique band between 2.4 gigahertz (GHz) and 2.4835 GHz and thus each of those channels has unique characteristics. A link between two devices is a superset of connection events, where a connection event is each instance of communication between the two devices.
The current BLUETOOTH standard can support multiple centrals and multiple peripherals operating simultaneously. A central can connect to multiple peripherals, without connection events overlapping, in one case. In another case, a peripheral can simultaneously, without connection events overlapping, connect to multiple centrals. Connections are established based on peripheral advertising and central scanning. If a connection is established, the peripheral advertising is renewed to enable the peripheral to establish an additional connection with another central.
The current BLE standard limits a central from establishing more than one link to a single peripheral. In examples herein, link clusters are described, which are collections of two or more links between two BLE devices. Link clusters include two or more links that have a dependency or coordination between the links. Link clusters may include a collection of links between any number of devices. Link cluster discovery, establishment, and termination procedures are described herein. These procedures may be based on over-the-air signal exchange or over host controller interface (HCI) signal exchange. In other examples herein, link cluster management and control procedures are described. Coordination procedures may be useful to set or update the connection parameters of a specific link or of several coupled links within the link cluster. Link cluster signaling exchanges may be conducted over one link in a link cluster. In one example, link cluster signaling may support link cluster power management, where a power level per channel within the channel set may be limited. Link clusters allow a BLE system as described herein to optimize power consumption of link cluster devices, reduce latency, and increase system level throughput in some examples.
The processing and communication system 100 includes hardware components for establishing a connection and transmitting and receiving data in accordance with the BLE communication standard. As shown in
The processor 101 is configured to read and execute computer-readable instructions. For example, the processor 101 is configured to invoke and execute instructions in a program stored in the memory 102, including instructions 106. Responsive to the processor 101 transmitting data, the processor 101 drives or controls the transceiver 103 to perform the transmitting. The processor 101 also drives or controls the transceiver 103 to perform receiving, responsive to the processor 101 receiving data. Therefore, the processor 101 may be considered as a control center for performing the transmitting or receiving of data and the transceiver 103 is an executor for performing the transmitting and receiving operations.
In some examples, the memory 102 is coupled to the processor 101 through the bus 105. In other examples, the memory 102 is integrated with the processor 101. The memory 102 is configured to store various software programs and/or multiple groups of instructions, including the instructions 106. The memory 102 may include one or more storage devices. For example, the memory 102 includes a high-speed random-access memory and/or may include a nonvolatile memory such as one or more disk storage devices, a flash memory, another nonvolatile solid-state storage device, or a pseudo-static random-access memory (PSRAM). The memory 102 may store an OS such as ANDROID, IOS, WINDOWS or LINUX. The memory 102 may further store a network communications program. The network communications program is useful for performing communications with one or more attached devices, one or more user devices, or one or more network devices. The memory 102 may further store a user interface program. The user interface program displays content of an application through a graphical interface and receives data or an operation performed by a user on the application via an input control such as a menu, a dialog box or a physical input device (not shown). The memory 102 is configured to store the instructions 106 for implementing the various methods and processes provided in accordance with the various examples of this description.
The transceiver 103 includes a transmitter and a receiver. The transceiver 103 is configured to transmit one or more signals that is provided by the processor 101. The transceiver 103 is also configured to receive one or more signals from other devices or equipment. In this example, the transceiver 103 may be considered a wireless transceiver. The antenna 104 may be configured to enable the exchanging of wireless communication signals between the transceiver 103 and a network or another system or device.
The processing and communication system 100 may also include another communication component such as a Global Positioning System (GPS) module, cellular module, a BLUETOOTH or BLE module, Zigbee module, Long Term Evolution (LTE), LTE-Machine Type Communication (LTE-M), Narrow Band LTE (NB-LTE), Sub-Gigahertz Communication (sub1G), Wi-SUN, IEEE 802.15.4, or a Wireless Fidelity (WI-FI) module. The processing and communication system 100 may also support another wireless communication signal such as a satellite signal or a short-wave signal. The processing and communication system 100 may also be provided with a wired network interface or a local area network (LAN) interface to support wired communication.
In various examples, the processing and communication system 100 may further include an input/output interface (not shown) for enabling communications between the processing and communication system 100 and one or more input/output devices (not shown). Examples of the input/output devices include an audio input/output device, a key input device, a display and the like. The input/output devices are configured to implement interaction between the processing and communication system 100 and a user or an external environment. The input/output device may further include a camera, a touchscreen, a sensor, and the like. The input/output device communicates with the processor 101 through a user interface.
The processing and communication system 100 shown in
The BLUETOOTH device 200 includes a BLUETOOTH application 206, a BLUETOOTH host 208, a BLUETOOTH host-controller interface 210, two BLUETOOTH controllers 212A and 212B, two BLUETOOTH PHY layers 214A and 214B, and two RF frontends 216A and 216B. BLUETOOTH device 200 may include two or more, separate PHY layers joined by a single interface to a single logical link control layer and a single media access control layer. BLUETOOTH PHY layer 214A and RF frontend 216A may be configured to form a first link with another device, and BLUETOOTH PHY layer 214B and RF frontend 216B may be configured to form a second link with that other device, where the first and second links are separate links. In some examples, each of RF frontends 216A and 216B may include one or more antennas and other transceiver circuitry for communicating with another device. Other examples may include a single controller 212 with multiple BLUETOOTH PHY layers 214, a single controller 212 with a single BLUETOOTH PHY layer 214 and multiple RF frontends 216, or a single controller 212 with a single BLUETOOTH PHY layer 214 and a single RF frontend 216.
In some examples, the BLUETOOTH device 200 of
The BLUETOOTH device 200 is configured to provide the BLUETOOTH controller 212 with link cluster channel operation parameters 224. Data 226 may include any data related to communication between devices, such as performance indicators related to a channel within the channel set (e.g., power consumption, average and peak throughput, modem characteristic, modulation coding scheme (MCS), packet level limitations, responsiveness, etc.). Example details of selecting and changing channels can be found in commonly assigned U.S. patent application Ser. No. 17/828,225, entitled “Frequency Change During Connection Event,” filed on May 31, 2022, which is incorporated herein by reference in its entirety.
In some examples, BLUETOOTH device 200 may use advertising procedures to share connection parameters for a link within a link cluster and coordinate connection events between two or more devices. The connection parameters may include limitations or capabilities of the BLUETOOTH device 200. The device that advertises may be referred to as a broadcaster in examples herein. Other devices 202 (such as a second BLUETOOTH device 202 and/or a third BLUETOOTH device 202) may receive these advertisements and negotiate a communication connection with BLUETOOTH device 200. The device that receives the advertisement may be referred to as a scanner herein. The communication connection may be one or more links within a link cluster. After the link is established, the broadcaster may be referred to as a peripheral device, and the scanner may be referred to as a central device. In some examples, other devices 202 may accept the advertised connection parameters for a link within the link cluster, or may alter the connection parameters and then negotiate a communication connection with BLUETOOTH device 200. By using advertising procedures, communication connections may be made faster or with lower power use than other procedures.
In examples herein, a BLUETOOTH device 200 may engage in discovery, establishment, management, and termination of links within link clusters. The connection parameters of one or more links within a link cluster may be selected, negotiated, and updated as described herein. One or more of the links within a link cluster may be terminated in some examples. The operation settings (channel set, modem characteristic, power management, power level, duration, anchor point, etc.) of one or more links within a link cluster may be modified as described herein. Signaling operations in some examples may set or update parameters of a link or multiple links in a link cluster, such as PHY (physical) parameters, channel map and channel selection, encryption parameters, modem characteristic, MCS, packet level limitations, connection event limitations, and power management limitations (e.g., transmit power limitations). Links within a link cluster have an awareness or level of coordination between one another to form the link cluster. Each device may manage and coordinate its own links to effectively manage these links as part of link cluster.
BLE network 300 is a multi-peripheral multi-central network in one example. In multi-central mode, more than one central may be connected to a single peripheral device. As an example, peripheral device 308 is connected to both central device 306 and central device 312. In multi-peripheral mode, more than one peripheral may be connected to a multi-central device. As an example, peripheral devices 308 and 310 are connected to central device 306. In BLE network 300, any of the devices may be connected to any other device using a link cluster of two or more links. In other words, any of the connections shown in
Network 400 may transmit data between device 402 and device 404 using any suitable technique. One technique is synchronous duplicate mode, where the same data is transmitted on link 406A and link 406B. In duplicate mode, the transmitter sends copies of each frame over multiple links. In other examples, more than two links may connect device 402 and device 404. In duplicate mode, a receiver may obtain a frame on a first link and then drop copies of the frame that are received on subsequent links. Duplicate mode increases robustness of the network. Another technique is joint mode. In joint mode, transmitted frames are sent over multiple available links, but copies of frames are not sent. Joint mode reduces transmission latency. Examples described herein may use either or both modes.
Examples herein provide for a system and method for link cluster discovery, establishing, and termination. Examples herein may include link cluster detection, discovery, establishment, and termination procedures that coordinate or leverage the link cluster coupled operation. The procedures are divided into three phases in some examples: discovery, establishing, and termination. First, the devices discover the relevant links or the link cluster in the discovery phase. In the second phase, the devices establish the connection via a link. In the third phase, the devices terminate the link or the link cluster. The methods described herein may be based on over the air packet exchange supported by HCI and generic attribute profile (GATT). The methods described herein may also include some procedures for notification, selection, and negotiation of the connection parameters of any of the links within the link cluster.
In another example, the BLE device may move from the standby state 510 to a SCAN state 520 and initiate a SCAN. If the SCAN successfully captures an ADV signal from another device, the BLE device can initialize (INIT) a connection 522 to a link cluster initialization state 524. The BLE device in the initialization state 524 may initialize a link cluster central 508 on the connected side 504. The BLE device then operates as a central device. In this state, BLE device may advertise at state 526, SCAN at state 528, or initialize another link cluster at 530 via connection 532. The BLE device may also terminate a connection via termination 534 and return to the standby state 510.
Peripheral device 602 (e.g., a broadcaster) may enter an advertising duration 606, which includes an advertising interval 608. The advertising state is described above with respect to
Central device 604 (e.g., a scanner) may be in a scan state that has a scan duration 616. The scan duration 616 has a scan interval 618, which includes a scan window 620. During the scan duration 616, central device 604 may receive the advertising packets 610, 612, and/or 614 for the link within the link cluster from peripheral device 602. Responsive to receiving an advertising packet 610, 612, or 614, central device 604 may send a link cluster join or coordination (e.g., scan) request 622 to peripheral device 602. With a link cluster join request, the central device 604 may request to establish a link with the peripheral device 602 using the connection parameters in the advertising packet or packets. With a link cluster coordination request, the central device 604 may transmit a change or propose a change to one or more connection parameters in the advertising packet or packets. Peripheral device 602 can then send a link cluster join or coordination (e.g., scan) response 624 to central device 604. The link cluster join or coordination response 624 may establish a link in a link cluster or negotiate a link in a link cluster between peripheral device 602 and central device 604 using the negotiated connection parameters. The negotiation and coordination process may include any number of steps or transmissions between the devices. Peripheral device 602 may then continue advertising by broadcasting another advertising packet or packets 626 for a link within a link cluster, including any connection parameters. Peripheral device 602 may also connect to other central devices in some examples. In some examples, the broadcaster device may offer a choice of connection parameters for a scanner device to choose from. As described above, the devices may coordinate channel sets, start and stop times of connection events, and connection parameters for the connection events, such as power and MCS.
Although
After the advertising event, packets may be transmitted on secondary channel 634. Packet 640 on secondary channel 634 is an auxiliary advertising indication with link cluster information. Packet 642 on secondary channel may be a scan (join/coordination/termination) request with link cluster information. Packet 642 may be transmitted from a scanner device to a broadcaster device. Packet 644 on secondary channel 634 is a scan response with link cluster information, which may be a join or coordination response. Packet 644 may be transmitted from the broadcaster device to a scanner device.
On primary channel 632, another advertising event may occur that includes advertising packets 638A, 638B, and 638C. After this advertising event, packets such as packets 640, 642, and 644 may be transmitted again on secondary channel 634.
After the advertising event, duplicated packets may be transmitted on both secondary channels 664A and 664B. The duplicated packet 670 on secondary channel 664A and packet 676 on secondary channel 664B are an auxiliary advertising indication with link cluster information. The duplicated packet 672 on secondary channel 664A and packet 678 on secondary channel 664B are a scan request with link cluster information, which may be a join or coordination request, or any of the other possible scanner responses, as described above with respect to
On primary channel 662, another advertising event may occur that includes advertising packets 668A, 668B, and 668C. After this advertising event, the scanner may transmit packets on the secondary channels 664A and 664B similar to the packets 670, 672, 674, 676, 678, and 680 previously transmitted on these channels.
Flow 700 may include a link cluster advertising packet 610 broadcast from peripheral device 602 (e.g., broadcaster) to central device 604 (e.g., scanner). Responsive to receiving the link cluster advertising packet or packets 601, central device 604 may transmit a link cluster connection indication 702 to establish one or more links within the link cluster. The link cluster may include link 1 704, link 2 706, and link N 708 between peripheral device 602 and central device 604. Peripheral device 602 and central device 604 may enter a connection state 710, where the devices communicate with one another using the links within the link cluster. Any of the links of the link cluster may also be terminated individually or collectively. Links 704, 706, and 708 may each have different channel sets or other different connection parameters as described herein. The communication on links 704, 706, and 708 may overlap in time because of the frequency separation.
In examples herein, BLE messages between devices may include coupled coordinated parameters. The coupled coordinated parameters are useful for notifying, selecting, and negotiating the connection parameters of a specific link or several coupled links within a link cluster. The BLE messages may be expanded to include this information. The procedures for coordinating the coupled parameters includes advertising the connection parameters, such as the number of supported links, the frequency or bandwidth of the links, physical (PHY) parameters of link(s) (e.g., rate, power, etc.), a channel map and channel selection, encryption parameters, modem characteristics, packet level limitations, packet duration limitations, connection event limitations, power management limitations MCS, duration, connection event starting point. etc. The procedures also include establishing the connection parameters. The procedures may include a channel map advertisement. For example, only certain channels may be enabled for advertisements rather than all advertising channels. The channel map advertisement may be useful for coordinating frequency, power, the duration of the connection interval, etc. The procedures may also include encryption establishment. Each link in a link cluster may have a unique key used for encryption. Credentials may also be established for the connecting devices. Supported features may be advertised as well. Also, the coupled coordinated parameters may include termination conditions.
In some examples the packet exchange is supported over the HCI interface and based on GATT level signaling. A host may manage a link cluster. Coordinated discovery, establishment, and termination flows are defined for controlling coupled links within a link cluster between a GATT client and a GATT server. The Generic Access Profile (GAP) controls connections and advertising in BLUETOOTH, and determines how two devices can interact with one another. GAP defines the central and peripheral roles for devices. GAP describes the advertising and scan response processes, as described above with respect to
GATT uses a server/client relationship. The GATT server holds the ATT lookup data and service and characteristic definitions, and the GATT client sends requests to this server. All transactions are started by the main device, the GATT client, which receives responses from the secondary device, the GATT server. In one example, the peripheral device is the GATT server and the central device is the GATT client. In other examples, the peripheral device may be the GATT client and the central device may be the GATT server, depending on which direction data is transferred between the devices.
In examples herein, GATT may be useful for controlling links within a link cluster between a GATT client and a GATT server. Process flows described herein support link cluster service discovery, GATT link cluster client requests and server responses, GATT indications or notifications from client to server, and data transfer between devices. In one example, the process iterates through all available link cluster services in a GATT database, and an event is generated for each link cluster service discovered. In some examples, server-initiated link cluster updates may be sent from the GATT server to the client without the client requesting the update. Notifications may include the identifier of the link cluster characteristic, the link cluster value, and/or connection parameters. GATT messaging may be performed at the application layer or at the link layer via HCI in some examples.
Central device 604 sends an enable notifications message 806 to peripheral device 602. The message 806 enables GATT notifications between the two devices. Peripheral device 602 may send GATT notifications 808A to 808N, where any number N of GATT notifications may be sent. The GATT notifications may include link cluster information. These GATT notifications 808A to 808N may be sent without the client (e.g., central device 604) requesting the notifications. As shown in
Central device 604 may send a disable notifications message 810 to peripheral device 602. Responsive to receiving the message 810, peripheral device 602 stops notifications and the throughput calculation. In some examples, central device 604 may then send a GAP disconnect request 812 to peripheral device 602. Responsive to receiving the GAP disconnect request, peripheral device 602 disconnects and may start advertising to other devices. Peripheral device 602 may also send a gap disconnected response 814 to central device 604, completing the GAP disconnect process.
Method 900 begins at 910, where a broadcaster BLUETOOTH device broadcasts advertising packets, and where the advertising packets include one or more connection parameters for one or more links in a link cluster. The broadcast of an advertising packet is described above with respect to
Method 900 continues at 920, where the broadcaster BLUETOOTH device receives a link cluster coordination request from a scanner BLUETOOTH device. The link cluster coordination request includes one or more connection parameters for a link in the link cluster. The connection parameters may include channel sets, a connection event starting point (anchor point), connection duration, power level, MCS, connection interval anchor time, or any other connection parameters. The scanner BLUETOOTH device may accept the connection parameters for the link, or may propose other connection parameters in some examples. In other examples, the scanner BLUETOOTH device may send a join request accepting the connection parameters.
Method 900 continues at 930, where, responsive to receiving the link cluster coordination request, the broadcaster BLUETOOTH device transmits a link cluster coordination response from the broadcaster BLUETOOTH device to the scanner BLUETOOTH device. The link cluster coordination response may be an optional step that is not performed in every example. Thus, the method 900 may end with the link cluster coordination request received at 920. In an example, the devices may be connected via a link within the link cluster at this time. The devices may then communicate with one another using a link or links within the link cluster as described herein. In other examples, after transmitting the coordination response, the broadcaster BLUETOOTH device may be configured to send another broadcast to attempt to form a link with another scanner. In other examples, after transmitting the coordination response, the broadcaster BLUETOOTH device may be configured to communicate with other devices in the link cluster. In other examples, after receiving the coordination response, the scanner BLUETOOTH device may be configured to scan for a broadcast from another broadcaster. In other examples, after receiving the coordination response, the scanner BLUETOOTH device may be configured to communicate with other devices in the link cluster.
Method 1000 begins at 1010, where a broadcaster BLUETOOTH device receives a GAP connect request.
Method 1000 continues at 1020, where the broadcaster BLUETOOTH device transmits a GAP connect response from the broadcaster BLUETOOTH device to a scanner BLUETOOTH device.
Method 1000 continues at 1030, where the broadcaster BLUETOOTH device receives an enable message from the scanner BLUETOOTH device to enable GATT notifications.
Method 1000 continues at 1040, where, responsive to receiving the enable message, the broadcaster BLUETOOTH device transmits GATT notifications regarding connection parameters of one or more links in a link cluster from the broadcaster BLUETOOTH device to the scanner BLUETOOTH device. The broadcaster BLUETOOTH device and the scanner BLUETOOTH device may be configured to communicate over the one or more links based on the connection parameters indicated in the GATT notifications.
Method 1000 continues at 1050, where the broadcaster BLUETOOTH device receives a disable message from the scanner BLUETOOTH device to disable GATT notifications.
Method 1000 continues at 1060, where, responsive to receiving the disable message, the broadcaster BLUETOOTH device disables transmitting GATT notifications regarding one or more links in the link cluster from the broadcaster BLUETOOTH device to the scanner BLUETOOTH device. After 1060, the broadcaster BLUETOOTH device may begin advertising again to scanner BLUETOOTH devices, as described herein.
Examples herein also provide link cluster control and management. Link clusters may perform unicast data exchange in one example. This link cluster control and management for unicast data exchange may support unicast link cluster operation profile modification and/or unicast link cluster feedback and reporting for one or multiple links within a link cluster.
The BLE link cluster control and management procedures described herein for data exchange may be issued based on over-the-air signal exchange (in the case where the link cluster split/aggregation point is at the BLE PHY/modem level) or over HCI single exchange flow (in the case where the split/aggregation point is the BLE controller level) or a combination of both between the link layers of the devices.
The BLE link cluster control and management procedures expand on independent unaware BLE signaling to support link cluster functionality applied at one or more coupled links within a link cluster. In some examples, this signaling is expanded by adding extra link cluster signaling entities, such as multi-link elements or a field. In some examples, to reduce overhead and connection time and responsiveness, one or more of the devices may be configured to perform the link cluster signaling process on only a preferred single link.
In some examples herein, the BLE link cluster link layer defines coordination procedures for controlling coupled links within a link cluster. These coordination procedures are useful for setting or updating the depended parameters of specific links, or of several coupled links, within a link cluster. A number of coordination procedures are described herein. The coordination procedures may include the devices performing a link connection parameter modification request procedure. To perform this procedure, one of the devices may request a specific link or links within a link cluster for modifying or setting a connection parameter. The coordination procedures may include a link connection parameter update procedure to update the link cluster parameters or execute an update procedure. The coordination procedures may include a link PHY parameters modification request procedure to request to modify or set PHY parameters of a link. The coordination procedures may include a link PHY parameters modification update procedure to update PHY parameters of a link or link cluster or execute an update procedure. The coordination procedures may include a synchronized link cluster channel map update procedure to update link cluster channel maps and participate in frequency-hopping link cluster synchronized channel selection. The coordination procedures may also include a link cluster encryption parameters modification procedure to update link cluster encryption control. The coordination procedures may include a feature modification procedure to activate or deactivate supported features of a link cluster. Any of the devices in a link cluster may be configured to perform these procedures.
The coordination procedures may include a link cluster status reporting procedure to report status of a link or links within a link cluster. As an example, the multi-link signaling entities may exchange status information regarding a number of supported links, the PHY characteristics of a link (rate, power, etc.), the transmission operation mode (asynchronous, synchronous, synchronous duplicate, etc.), or other per-link information. One or more of the devices in a link cluster may be configured to perform a status reporting procedure to report the status of any of the links in the link cluster. For example, any of the devices in the link cluster may be configured to exchange information regarding the number of supported links, the rate or power of any of the links, the operation characteristics of any of the links, multi-link transmission operation (e.g., asynchronous or synchronous operation), or any other link information. A first device in the link cluster can send a request to a second device in the link cluster requesting status information, and the second device can respond to the request with the requested status information. Additionally or alternatively, the second device may be configured to report the status information to the first device at regular intervals or based on a schedule.
In procedure flow 1100, link cluster device 1102 may send a notification 1114 to link cluster device 1104 to notify link cluster device 1104 of the link parameters 1112 for a link or links 1110. Link cluster device 1104 may use the link parameters 1112 to reconstruct the data 1108A stored at link cluster device 1102 and create data 1108B stored at link cluster device 1104, which may include the link parameters 1112 for the various links 1110. Therefore, link cluster device 1104 may be notified of changes to the link parameters 1112 with procedure flow 1100.
In examples described herein, the devices in a link cluster can perform the link cluster signaling exchanges described herein over at least one link in the link cluster. The link cluster signaling changes may modify operation settings (such as: link air access operation characteristics, link modem and media access control (MAC) characteristics, link power management, etc., at the packet and the connection interval level) of one (or more) coupled links within the link cluster. The link cluster signaling may enable devices to change transmission modes, such as a synchronized mode, a synchronized duplicate mode, or a joint asynchronized mode as described above. A synchronized mode transmits synchronized packets on separate links. A synchronized duplicate mode transmits duplicate packets on separate links in a synchronized manner. A joint asynchronized mode transmits packets over multiple available links, but copies of packets are not sent.
One example power management coordination procedure supported by link cluster signaling is a power save state. A device as described herein may operate in two modes: active mode and power save mode. In the active mode, the device is always awake and can transmit and receive frames during a sheltered connection interval. In the power save mode, the device can suspend one or more of the links from time to time. If the links are suspended, the device may be connected temporarily via a single link within the link cluster. The single link may be an anchor link, which is a link that controls other links within the link cluster and keeps the network alive in some examples. The device may then resume the other links via link cluster signaling with the anchor link to re-enter the active mode.
Depending on the traffic conditions, channel conditions, and interference at different links and different frequencies, the power management coordination procedure may use link cluster signaling for parameter modification for one or more links within the link cluster, or to temporarily suspend links within the link cluster that will not be used for data transmission. The power management coordination procedure may therefore reduce power consumption in some examples.
Responsive to the request 1220, device A 1202 may update the link connection parameters between device A 1202 and device B 1204 at 1222. Device A 1202 may also update the link connection parameters for device C 1206 at 1224, and/or update the link connection parameters for device D 1208 at 1226.
Method 1300 begins at 1310, where a first BLUETOOTH device connects to a second BLUETOOTH device via one or more links within a link cluster. The devices may be connected using the procedures described herein. In other examples, more than two BLUETOOTH devices may be connected.
Method 1300 continues at 1320, where the first BLUETOOTH device receives a request from the second BLUETOOTH device to change one or more link connection parameters of a link within the link cluster.
Method 1300 continues at 1330, where, responsive to receiving the request, the first BLUETOOTH device changing the link connection parameter of the link within the link cluster. The link connection parameter may be any of the connection parameters described in the various examples herein. In other examples, other BLUETOOTH devices may also update link cluster connection parameters for one or more link within their respective link clusters.
Method 1400 begins at 1410, where a first BLUETOOTH device connects to a second BLUETOOTH via one or more links within a link cluster. The devices may connect to one another via the process described herein, such as in
Method 1400 continues at 1420, where the first BLUETOOTH device enters a power save mode. In the power save mode, the first BLUETOOTH device suspends one or more of the links within the link cluster. The links may be suspended to save power or for other reasons. As an example, if a link will not be used for data transmission, the link may be suspended. In some examples, all but one link is suspended, and the single non-suspended link is used to keep the network alive.
Method 1400 continues at 1430, where the first BLUETOOTH device modifies a link connection parameter of a link within the link cluster via an active link in the link cluster. In one example, the first BLUETOOTH device may send a request to another device to modify a connection parameter, or may modify the link connection parameter and notify other BLUETOOTH devices.
Method 1400 continues at 1440, where the first BLUETOOTH device exits the power save mode and enters an active mode, where the first BLUETOOTH device uses the active link within the link cluster to wake the one or more suspended links within the link cluster. For example, the first BLUETOOTH device may be configured to send a message over the active link to a second BLUETOOTH device to wake a suspended link. The suspended link may be a link between the first and second BLUETOOTH devices, or the suspended link may be a link between the second BLUETOOTH device and a third BLUETOOTH device. The suspended links may be made active upon entering the active mode.
In examples herein, link clusters allow a BLE system to optimize power consumption, latency reduction, and increase system level throughput. Over the air signal exchange or signal exchange over HCI may be useful for discovering the link cluster device functionality, understanding a device's preferred or default configuration, and transmitting a proposed or preferred link cluster joining methodology. Links may be established and/or terminated using the same techniques in some examples. Signaling may be performed on a single link in the link cluster in some examples. Coordination procedures for links within link clusters may include parameter advertisement, parameter establishment, channel map advertisement, encryption establishment, common feature advertisement, and termination. Clusters of links may coordinate and leverage the link cluster operations. Link clusters may synchronize connection parameters of links in some examples. A single link layer may control the link cluster in some examples.
The term “couple” is used throughout the specification. The term may cover connections, communications, or signal paths that enable a functional relationship consistent with this description. For example, if device A generates a signal to control device B to perform an action, in a first example device A is coupled to device B, or in a second example device A is coupled to device B through intervening component C if intervening component C does not substantially alter the functional relationship between device A and device B such that device B is controlled by device A via the control signal generated by device A.
A device that is “configured to” perform a task or function may be configured (e.g., programmed and/or hardwired) at a time of manufacturing by a manufacturer to perform the function and/or may be configurable (or re-configurable) by a user after manufacturing to perform the function and/or other additional or alternative functions. The configuring may be through firmware and/or software programming of the device, through a construction and/or layout of hardware components and interconnections of the device, or a combination thereof.
Unless otherwise stated, “about,” “approximately,” or “substantially” preceding a value means+/−10 percent of the stated value. Modifications are possible in the described examples, and other examples are possible within the scope of the claims.
The present application is related to Attorney Docket Number T101241, U.S. application Ser. No. ______, filed concurrently herewith, which is titled “BLE Link Cluster Control and Management,” and is hereby incorporated herein by reference in its entirety.