The present disclosure relates generally to wireless systems, and more particular to wireless systems and devices that include different radio circuits that can share a same medium, or otherwise interfere with one another.
The availability of unlicensed wireless bands, such as the 2.4 GHz ISM (International Scientific and Medical) band has given rise to various wireless protocols/standards that share essentially the same medium. Various IEEE 802.11 wireless standards (collectively referred to as WLAN herein) operate in the 2.4 GHz band. While WLAN provides many advantageous features, it is desirable to provide systems that include other wireless protocols, such as those that consume less power but operate at lower range, such as Bluetooth (BT), including Bluetooth Low Energy. This has given rise to WLAN-BT “coexistence” (coex) devices. Such devices can include both WLAN circuits and BT circuits that share a transmission medium (i.e., BT channels overlapping a WLAN channel). A drawback to coex devices can be the potential for interference between WLAN and BT transmission and/or the inability for such transmissions to occur simultaneously, particularly when one protocol is transmitting while the other is receiving.
One conventional approach to addressing competing accesses to the same medium can be to assign priority to one protocol. For example, when BT transmissions are to occur, WLAN transmissions are terminated. A drawback to such an approach can be that WLAN transmissions can be deferred too often, degrading WLAN throughput/performance.
Another conventional approach can be to use the existing WLAN protection mechanism Clear-to-Send-to-Self (CTS-to-Self). A CTS-to-Self was typically used to accommodate legacy WLAN versions, but has been adopted to protect WLAN receive operations from being susceptible to rate fluctuations due to coexisting radio circuits, such as BT or other protocols, such as Zigbee or Thread. Ideally, WLAN circuits would cancel on-going activity after receiving a request from a coexisting BT circuit, and transmit a CTS-to-Self. The CTS-to-Self can be sent out with the duration communicated from the BT circuits. If the cancelled on-going WLAN activity is WLAN Tx, then no degradation in WLAN performance is observed. However, if the cancelled WLAN activity is WLAN Rx, there can be negative impacts on performance. First, because of on-going WLAN activity in a basic service set (BSS), the WLAN circuit might not get an opportunity to win the medium and transmit a CTS-to-self. Second, when WLAN circuits cancel a receive request, the requesting (to send) device receives no acknowledgement (ACK). Such a requesting device that continues to make requests and receive no ACKs, can mis-interpret the situation as a poor transmission environment, and switch to a lower transmission rate in a next attempt, degrading performance.
Referring still to
At time t1, BT RF Active can indicate that BT activity is imminent. In response, WLAN DUT can drop data reception from the WLAN Peer. As a result, transmissions from peer device are not acknowledged by the DUT. Also at time t1, the DUT can assess the channel to determine if a CTS-2-Self frame can be transmitted. However, due to channel activity (e.g., by the peer device), the CTS-2-Self frame is not transmitted.
At time t2, following a delay “BT Advance”, actual BT activity can begin. However, because a CTS-2-Self frame was not transmitted by the DUT, such BT activity may be adversely affected by other activity on the medium. From time t2 to t3, the peer device would re-transmit and would not receive a response from the DUT. This can lead the peer device to re-transmit in subsequent tries with an even more scaled down rate.
At time t3, BT RF Active can return to inactive as actual BT Activity ends.
At time t4, a same set of conditions can occur, with BT Activity being indicated, and the DUT being unable to return an ACK to the peer device and unable to transmit a CTS-2-Self frame as it cannot get control of the medium.
Because of the low protection success rates that can occur in situations like that of
It would be desirable to arrive at some way of improving medium access for devices having WLAN circuits and another coex wireless circuits.
Embodiments can include devices and/or systems having IEEE 802.11 wireless compatible (WLAN) circuits and one or more coexisting wireless (coex) circuits. By operation of WLAN circuits, an estimated duration for coex communications can be determined. In response to at least a medium being free, WLAN circuits can transmit a first clear-to-send-to-self (CTS-to-self) frame at an estimated start time for the coex communications. The first CTS-to-self frame can have a first duration equivalent to the estimated duration for the coex communications. In response to receiving an actual coex communication start signal indicating an actual start for the coex communications, WLAN circuits can determine if the duration of the first CTS-to-self frame is sufficient to cover an actual duration for the actual coex communications. If the first duration is not sufficient to cover the actual duration, a second CTS-to-self frame can be transmitted with a second duration that extends beyond the first duration sufficient to cover the actual duration.
Embodiments can include combination devices and systems having IEEE 802.11 wireless compatible (WLAN) circuits and one or more other coexisting (coex) radio circuits. Coex circuits can share a medium with WLAN circuits and/or the operation of WLAN circuits can interfere (e.g., generate interfering harmonics) with the coex circuits. WLAN circuits can receive data on future coex activity, including the estimated duration of such activity. Prior to future coex activity, WLAN circuits can “back-off” from servicing requests to ensure control of the medium around the time of coex activity. At the time of coex activity, WLAN circuits can issue a Clear-to-Send-to-Self (CTS-to-Self) having a duration equal to or greater than the estimated duration of the coex activity.
In some embodiments, after issuing a first CTS-to-self, WLAN circuits can determine if a duration of the first CTS-to-self is sufficient to protect the coex activity. If not, WLAN circuits can issue a second CTS-to-self having a duration sufficient to cover the coex activity. This evaluation can be done by WLAN circuits after receiving duration information from a coex radio circuit. In some embodiments, such an evaluation can be done at the time coex circuits actually assert an active indication of coex radio activity. Communication of duration information by coex circuits can occur over any suitable communication channel, including but not limited to a general coexistence interface (GCI), a serial enhanced coexistence interface (SECI) or a custom interface.
In some embodiments, WLAN circuits can also issue power mode indication frames in addition to CTS-to-self frames to protect coex activity. In particular, for coex activity of larger durations, WLAN circuits can issue a frame indicating a low power mode, which can result in peer devices refraining from transmitting to the WLAN circuits.
As shown in timing diagram 118B-0, in response to a WLAN access request 110, a device 100 determines that a duration of an access request 112a can be completed prior to t_est. Consequently, as shown in timing diagram 118B-1, the requested access can be executed 112a′ including sending an ACK 114. However, in alternate embodiments, WLAN circuits may not make such a determination, and can cease WLAN operations in response to receiving coex data 108.
In this way, WLAN circuits can determine an estimated duration for future coex circuit activity, and back-off an WLAN request that might interfere. WLAN circuits can then issue a CTS-to-self to reserve the medium for the estimated duration of the coex circuit activity. If the CTS-to-self is determined to be too short for the actual coex activity, a second CTS-to-Self can be issued having sufficient duration to reserve the medium for the coex activity.
According to embodiments, in a system having WLAN circuits that coexist with BT circuits, BT activity can be deterministic. In response to such deterministic BT activity, WLAN circuits can estimate the amount of time left for imminent BT activity and back-off WLAN operations (e.g., receive operations) when such operations cannot be accommodated before the imminent BT activity. WLAN circuits can then transmit a CTS-to-Self to protect the BT activity.
BT circuits can also communicate a duration of imminent BT activity in advance to the actual BT activity. This can be used to establish a duration of the CTS-to-Self. In some embodiments, a duration of future BT circuit transmit operations can be determined from BT circuit buffers. In some embodiments, a duration of future BT circuit receive operations can be determined from BT circuit reception history.
In some embodiments, future BT activity can be provided by WLAN circuits sampling BT circuit data over an interface, such as a general coexistence interface (GCI), as but one of many examples. In some embodiments, WLAN circuits can sample BT circuit data a second time when the actual BT activity occurs. In response to such BT activity data, WLAN circuits can issue a second CTS-to-Self in the event the duration of the first CTS-to-Self is not sufficient to cover the actual BT activity duration.
“GCI Data Sampling” shows the reception of BT transmission data by WLAN DUT circuits from coex BT circuits over a global coexistence interface (GCI). A GCI can be configured to enable WLAN circuits to communicate via a serial data protocol with other coexisting circuits, such as BT circuits, but also cellular communication circuits in some embodiments. In some embodiments, a WLAN DUT circuits can request BT transmission data. In other embodiments, coex BT circuits can transmit such data automatically to WLAN DUT circuits.
“CTS-2-Self-1” shows a first CTS-to-Self issued by WLAN DUT circuits in response to anticipated BT Activity. “CTS-2-Self-2” shows a second CTS-to-Self issued by WLAN DUT circuits. “CTS-2-Self-1 DUR Effect” can indicate a duration indicated by a CTS-to-Self-1. “CTS-2-Self-2 DUR Effect” can indicate a duration indicated by a CTS-to-Self-2.
Referring still to
At time t0, WLAN DUT device can acquire sample data over a GCI that can indicate a state of BT circuits. Such an action can result in WLAN DUT circuits determining a duration of future BT Activity, and in some embodiments an estimated start time for such future BT activity. Further, in response to such data, WLAN circuits begin backing-off from communications with WLAN peer device (or any other devices of the BSS) to ensure the medium will be clear. WLAN DUT circuits can then begin monitoring the medium for an opportunity to transmit a CTS-to-Self.
At time t1, with the medium uncontested, WLAN DUT circuits can transmit a first CTS-to-Self having a duration equal to an estimated BT Active time derived from the GCI data sampling at time t0. CTS-2-Self-1 DUR Effect shows how the medium can be reserved from time t1 to time t5 in response to the CTS-2-Self 1.
At time t3, BT RF Active can go active. At about this time, WLAN DUT circuits can sample BT data over the GCI again. Such an action can enable WLAN DUT circuits to determine if the first CTS-to-Self has a duration sufficient to protect the entire BT Active time period. In the embodiment shown, it is determined the first CTS-to-Self is sufficient for the BT activity.
At time t4, actual BT activity can start and then conclude at time t5, within a medium reserved period established by the first CTS-to-Self.
At time t6, operations can start in the same fashion as at time t0.
At time t7, operations can differ from the previous case. Upon sampling BT circuit state data over the GCI, WLAN DUT circuits can determine that the duration of the first CTS-to-Self is not sufficient to protect actual BT active time. That is, the first CTS-to-Self medium reservation period will end at time t9, before BT Activity has ended. Consequently, WLAN DUT circuits can issue a second CTS-to-Self that last from time t8 to time 10, which adequately protects BT circuit activity.
The capability of issuing a second CTS-to-Self can prevent “under protection” of BT Activity. Under protection can arise in the event a network allocation vector (NAV) generated in a peer WLAN device from a first CTS-to-Self expires, and the per WLAN device accesses the medium while it is still in use by the coexisting circuit (e.g., BT). Further, in such a case, a WLAN peer may initiate packets and an unresponsive WLAN circuit may cause the WLAN peer to scale down transmission rates (MCS index) in subsequent retries.
In this way, a WLAN circuit can sample state data for coexisting BT circuits, and upon determining that BT activity is planned, back-off from WLAN activity. When the medium is free the WLAN circuit can issue a first CTS-to-Self to reserve the medium for BT activity. When the actual BT activity begins, if the first CTS-to-Self is not of sufficient duration, a second CTS-to-Self can be issued to ensure BT activity is protected.
In some embodiments, WLAN circuits can operate with another coexisting radio circuits (e.g., BT circuits), where coex activity occurrence is deterministic but coex activity duration is not deterministic. WLAN circuits can provide a hybrid mode of protection that can use a CTS-to-Self mechanism or a power management state to reserve a medium, particularly for coexisting circuit activity having a duration over a predetermined length.
Referring to
Operations starting at time t2 show operations like those starting at time t0 in
At time t3, WLAN DUT circuits can sample BT circuit state data over GCI. However, at this time WLAN DUT circuits make a determination that a duration of BT activity will exceed the predetermined limit. Consequently, at time t4, WLAN DUT circuits can issue a power management transmission. In some embodiments, such a transmission can include a “null” packet having a power management bit set to indicate a “power-down” configuration (PM bit reset to 0). In response to such a transmission, peer WLAN devices can refrain from communicating with WLAN DUT circuits. The power management mode can result in a protection duration from time t5 to time t7 (PM Protection DUR). In some embodiments, a duration of PM Protection DUR can be predetermined. In other embodiments, a duration of PM Protection DUR can be ended by WLAN DUT circuits issuing another power management transmission that indicates the end of the power-down mode.
At time t6, a BT RF Active can indicate BT activity, which can follow from time t5 to time t7, and thus can be protected by the PM protection duration.
A hybrid protection arrangement like that of
In this way, for some transmission activity of coexisting circuits (e.g., below a predetermined duration), WLAN circuits can issue one or more CTS-to-Self frames to reserve the medium for the coexisting circuits. However, for other transmission activity (e.g., over a predetermined duration), WLAN circuits can issue a power management transmission to reserve the medium for a longer time period. Such a power management transmission can improve the medium efficiency for an entire BSS by not blocking the medium for a relatively long duration.
An RF section 428 can include circuits for receiving and transmitting data over one or more media according to one or more IEEE 802.11 wireless standards. An IF section 430 can enable communication with coex radio circuits, including receiving and/or requesting coex data on future coex activity, as well as receiving an indication when actual coex activity occurs and data on the actual coex activity.
A controller section 426 can include a back-off process for coex transmissions 426-0, a CTS-to-Self process for coex transmissions 426-1 and can store coex data 426-2. A back-off process 426-0 can take any suitable form. In some embodiments, upon receiving coex data over IF section 430, a back-off process 426-0 can determine if any requested WLAN activity extend past an estimated start time of future coex activity, and then execute or not execute such WLAN activity. However, in other embodiments, after receiving coex data, a back-off process 426-0 can cease WLAN operations at the earliest possible time. In this way, a back-off process can help enable WLAN circuits to preserve a medium with a CTS-to-self and/or power management frame.
A CTS-to-Self process 426-1 can generate CTS-to-Self frames in response to coex circuits states. Upon receiving data for future coex activity over IF section 430, a CTS-to-Self process 426-1 can generate data for a CTS-to-Self frame that will result in a duration (e.g., NAV) that is at least as long as the expected coex activity. Such a CTS-to-Self frame can then be transmitted when actual coex activity is indicated, or in other embodiments, at an expected coex activity start time. In some embodiments, upon receiving data for actual coex activity, a CTS-to-Self process 426-1 can determine if a previous CTS-to-Self has a sufficient duration to cover the coex activity. If not, a CTS-to-Self process 426-1 can generate a second CTS-to-Self frame of sufficient duration to cover the coex activity.
Coex data 426-3 can include data received over IF 430 that can be used by back-off and CTS-to-Self processes 426-0/1. Coex data 426-3 can include any of: an estimated duration of future coex activity (dur_est), a duration of actual coex activity (dur_act), and an estimated start time for future coex activity (t_est).
In this way, WLAN circuits can include an interface to receive data indicating future coex radio circuit activity. In response to such data, WLAN circuits can back-off WLAN activity to enable the issuance of one or more CTS-to-Self frames to protect the coex radio activity.
Tx buffers 536 can store data for future transmission from BT circuits 532 and Rx buffers 538 can store data wirelessly received by BT circuits 532. A BT radio IF 540 can organize BT data for transmission by BT RF circuits 542, as well as extract data received by BT RF circuits 542. BT RF circuits 542 can include circuits for receiving and transmitting data over one or more media according to one or more BT standards. An IF section 544 can enable communication with WLAN circuits, including the transmission of data on future BT activity, as well as an indication of actual BT activity. Memory circuits 546 can include volatile memory circuits, nonvolatile memory circuits, or combinations thereof. Memory circuits 546 can store data for BT circuits 532, including a history of BT data reception 546-2.
A BT controller section 534 can include a transmit BT data process 546 and a transmit BT active process 548. A transmit BT data process 546 can determine information about future BT activity, and transmit or otherwise make available such data for WLAN circuits. Such information can include, but is not limited to, an estimated duration of a future BT activity (dur_est), and in some embodiments, an estimated start time (t_est) for future BT activity 546-1. In the embodiment shown, dur_est can be determined from a state of Tx buffer 536 and/or historical data for Rx transmissions 546-2. A transmit BT active process 548 can transmit an indication to WLAN circuits signifying the start of actual BT activity. In some embodiments, such an indication can be accompanied by an actual duration (dur_act) 548-0 for the imminent BT activity.
In this way, BT circuits can determine a duration of future BT activity, and transmit such data to WLAN circuits, followed by an indication corresponding to when such BT activity actually occurs.
According to embodiments, data that can indicate future coex activity can be received by a system, or generated by circuits within such a system.
In operation, coex circuits 632 can receive coex schedule data 654 from any suitable source, including but not limited to, an internal source 652-0 or an external source 652-1. Coex schedule data 654 can be data related to future coex activity as described herein and equivalents. An internal source 652-0 can provide any suitable data values or signals that can indicate future activity for coex circuits. In some embodiments, an internal source 652-0 can include a transmit buffer state or a slot mask (e.g., BT slot mask). An external source 652-1 can include an application executed by other portions (not shown) of the system 650.
Coex schedule data 654 can be transmitted over communication path 606 to WLAN circuits 624 via coex IF section 644 and WLAN IF section 630. Within WLAN circuits 624, a CTS-to-Self generator 626-1 can generate one or more CTS-to-Self frames having a duration sufficient to cover the duration of coex activity indicated by coex schedule data.
When coex circuit 632 is going to be active on a shared medium, coex RF control circuits 642 can generate a coex active indication which can be received by WLAN circuits 624. In response, WLAN RF control circuits 628 can issue the CTS-to-Self frame. Further, a second CTS-to-Self frame can be generated in the event a duration of the first is not sufficient to protect the coex activity.
In this way, coex circuits can receive future coex activity data that can be accessed by WLAN circuits to generate a protective CTS-to-Self for the coex activity.
In operation, a coex schedule data generator 756 can monitor activity of coex RF control circuits 742, and from such data determine future coex activity data. Such operations can include any of those described herein, including accumulating and evaluating historical data or including such historical data as training data for an artificial intelligence system. Coex schedule data can be used by CTS-to-self generator 726-1 to generate one or more CTS-to-self frames to protect future coex activity, as described herein or equivalents.
In this way, coex circuits can generate future coex activity data from past coex activity that can be accessed by WLAN circuits to generate one or more protective CTS-to-Self frames for the coex activity.
In operation, when coex circuits 832 are active, data regarding such coex activity can be forwarded to WLAN circuits over IF sections 844/830. Within WLAN circuits 824, a coex schedule data generator 856 can evaluate received past coex data to generate future coex schedule data according to any of the embodiments described herein or an equivalent. Such future coex schedule data can be used by CTS-to-self generator 826-1 to generate one or more CTS-to-self frames to protect future coex activity, as described herein or equivalents.
In this way, WLAN circuits can receive coex activity data from past to determine future coex activity. Such data can be used by the WLAN circuits to generate one or more protective CTS-to-Self frames for the coex activity.
Embodiments can include coex circuits in communication with WLAN circuits according to any suitable communication path that can enable WLAN circuits to receive future coex activity data as well as an indication of actual coex activity. In some embodiments, coex circuits can communicate via a serial bus according to one or more serial data protocols.
BT circuits 932 can include BT schedule data 954, BT Tx/Rx control circuits 942-0, BT RF circuits 942-1 and a coex IF 944. BT schedule data 954 can include information on future BT activity, and can be generated according to any of the methods described herein or equivalents. BT schedule data 954 can include dur_est, and optionally, t_est values. Such values (dur_est, t_est) can be transmitted over serial bus 906 to WLAN circuits 924. In some such data can be transmitted in response to a request from WLAN circuits 924. BT Tx/Rx circuits 942-0 can control BT transmissions, and can indicate to WLAN circuits 924 when actual BT transmissions occur (t_act). BT RF circuits 942-1 can be connected to an antenna system 958, and can transmit/receive BT transmissions. Coex IF 944 can be an interface designed for exchanging data between co-located wireless circuits, including a serial enhanced coexistence interface (SECI), which can be a two-wire interface, or a GCI, which can be a three wire interface.
WLAN circuits 924 can include a WLAN coex IF 930, CTS-to-self generator 926-1, WLAN Tx/Rx control circuits 928-0 and WLAN RF circuits 928-1. A WLAN coex IF 930 can correspond to that of coex IF 944, including being an SECI and/or GCI. A CTS-to-self generator 926-1 can generate one or more CTS-to-Self frames in response to BT schedule as described herein and equivalents. WLAN Tx/Rx circuits 928-0 can control WLAN transmissions. WLAN RF circuits 928-1 can be connected to an antenna system 958, and can transmit/receive WLAN transmissions.
In this way, coex systems can transmit coex (e.g., BT) schedule data to WLAN circuits over interfaces designed for communication between coexisting circuits, including but not limited to, SECI and GCI.
Embodiments can include coex circuits in communication with WLAN circuits with interfaces modified to utilize existing serial buses to transmit future coex activity data to WLAN circuits. In some embodiments, coex circuits can communicate via a three wire serial bus.
A system 1050 can differ from that of
In this way, coex systems can transmit coex schedule data to WLAN circuits over existing serial bus types, including three wire buses, using modified bus interfaces.
A BT processor section 1162 can execute instructions for BT operations, including a transmit BT schedule function 1146 that can transmit future BT activity data to WLAN circuits 1124 and a transmit BT active function 1148 that can transmit a BT active indication to WLAN circuits 1124. A BT memory section 1160 can store data for BT future activity, including BT schedule data 1154. BT schedule data 1154 can include data on future BT transmissions, and in some embodiments, data on future BT receptions. In some embodiments, BT schedule data 1154 can include, or can be derived from a slot allocation mask 1154-0. As noted herein, future BT transmissions can be determined using a state of transmit buffers 1136.
BT control circuits 1142-0 can include circuits for performing functions according to one or more BT standards, and can include BT Tx buffers 1136, from which a BT activity duration can be determined.
BT RF circuits 1142 can be controlled by BT control circuits 1142-0 and can include radio circuits to enable transmission of packets according to one or more BT standards. In the embodiment shown, BT RF circuits 1142 can drive one or more BT power amplifiers (PA) 1172-0 and receive input signals from a BT low noise amplifier (LNA) 1170-0.
Media control circuits 1164 can communicate with WLAN circuits 1124 over bridge 1180 to control access to a transmission media (e.g., 2.4 GHz band). First I/O circuits 1166-0 can enable communication with system 1150 according to any of the embodiments described herein or equivalents.
BT processor section 1160, BT memory section 1162, BT control circuits 1142-0, media control circuit 1164, and first I/O circuits 1166-0 can communicate with one another over a bus 1168.
WLAN circuits 1124 can include a processor section 1176, a memory section 1174, second I/O circuits 1166-1, bridge control circuit 1178, WLAN control circuits 1128 and WLAN radio circuits 1128-1. A processor section 1176 can execute instructions for WLAN operations, including a back-off operation 1126-0 and CTS-to-self operations 1126-1. A back-off operation 1126-0 can, in response to receiving data regarding future BT activity, refuse to perform WLAN operations. In some embodiments, such an operation can make a determination as whether a WLAN operation can be executed before an estimated start time for future BT activity. CTS-to-self operations 1126-1 can generate and issue conventional CTS-to-self frames 1126-1A for the accommodation of legacy WLAN versions. However, in addition, CTS-to-self operations 1126-1 can generate and issue initial CTS-to-self frames 1126-1B to protect expected BT activity, as described herein. Further, adjustment CTS-to-self frames 1126-1C can be generated and issued to extend a protection duration in the event a duration of the initial CTS-to-self frame 1126-1B
Second I/O circuits 1166-1 can enable communication with the system 1150 according to any of the embodiments described herein or equivalents, including communications with BT circuits 1104 over an interface 1144/1130, which can be a GCI and/or SECI. In some embodiments, BT processor section 1162 can transmit BT schedule data and transmit active indications via interface 1144/1130. In some embodiments, interface 1144/11130 can enable a system to interface with other wireless systems, such as cellular network systems, including but not limited to 3G, 4G, LTE and 5G networks.
WLAN control circuits 1128 can include circuits for performing functions according to one or more IEEE 802.11 wireless standards, including those operating in the 2.4 and 5 GHz band. In some embodiments, this can include IEEE 802.11 compatible media access control (MAC) layer circuits 1128-0 and IEEE 802.11 compatible physical interface layer (PHY) circuits 1128-0 and WLAN PHY circuits 1128-1. WLAN RF circuits 1128-1 can include multi-band radio circuits that transmit and receive data on one or more WLAN bands (e.g., 2.4 GHz, 5 GHz). In the embodiment shown, WLAN RF circuits 1128-1 can drive one or more 2.4 GHz band PA(s) 1172-1, a 5 GHz band PA 1172-2, and receive input signals from a 2.4 GHz LNA 1170-1 and a 5 GHz LNA 1170-2.
Processor section 1176, bridge control circuit 1178, and WLAN control circuits 1128 can be connected to one another over a backplane 1182.
System 1150 can be connected to an antenna system 1154. Antenna system 1154 can include one or more physical antennas, as well as switches for enabling different connections to such antennas.
In some embodiments, a system 1150 can include BT circuits 1132 and WLAN circuits 1124 formed with a same integrated circuit substrate.
In some embodiments, coex circuits or WLAN circuits can include a coex schedule data generator, which can generate data for future coex activity from past coex activity data.
In this way, coex circuits and/or WLAN circuits can use historical coex activity data to derive estimated future coex activity data which can be used by WLAN circuits to generate one or more protective CTS-to-self frames.
According to embodiments, data for future coex activity can be generated with a machine learning system.
An error function 1356-1 can compare output values 1316′ from model 1356-0′ with training output values 1346-0(t+1), to generate an error value. An error function 1356-1 can base error on the desired feature for improvement/optimization. Parameter adjust section 1356-2 can adjust parameters of model 1356-0′ in response to error values generated by error function 1356-1. Such parameter adjustments can be made to reduce the error (e.g., improve desired feature) and can take any suitable form, such as a version of gradient descent in the case of some neural network models.
All or a portion of systems 1356/1356T can be located on a system/device that includes coex circuits and WLAN circuits, or can be remote from such a system (e.g., a server system). In one embodiment of the latter case, a system can include a trained model 1356-0. However, other embodiments can include models that are trained as the system/device operates (e.g., acquired coex historical data).
In this way, a system having coex circuits with WLAN circuits that can generate estimated future coex activity with a machine learning system. Such estimated future coex activity data can be used by WLAN circuits to generate one or more protective CTS-to-self frames for the future coex activity.
While embodiments can include systems and devices with various interconnected components, embodiments can also include unitary devices having coex circuits and WLAN circuits with low passive isolation. In some embodiments, such unitary devices can be advantageously compact single integrated circuits (i.e., chips).
However, it is understood that a device according to embodiments can include any other suitable integrated circuit packaging type, as well as direct bonding of a device chip onto a circuit board or substrate.
While embodiments can include single integrated circuit devices, embodiments can include larger devices which an improve the performance of coexisting radio circuits the share the same medium.
In some embodiments, systems can include Internet-of-things (IoT) type devices, that are wireless capable, including but not limited to: lighting devices 1550A, locking devices 1550B, instrumentation devices 1550C, security devices 1550D and entertainment devices 1550E. In some embodiments, a system can be a gateway or router device 1550F that can serve as an access point (AP) for a BSS, but include another coex wireless circuit.
In this way, embodiments can include IoT type devices, as well as devices that can serve as APs in a BSS.
Embodiments can enjoy application in subsystems of motor vehicles to enable multiple communication types, including WLAN and one or more coexisting protocols.
In this way, automobiles can include combination devices with WLAN circuits that share a medium with one or more coex circuits, as described herein and equivalents.
While the operations, devices and systems descried herein disclose various methods according to embodiments, additional methods will be described with reference to flow diagrams.
A method 1790 can determine if a WLAN communication request is received 1790-1. Such an action can include WLAN circuits receiving communications from other devices, including but not limited to: detecting a request to send from a peer device of network. However, such an action can also include an internal request (e.g., an application serviced by the WLAN circuits). If a WLAN communication request is received (Y from 1790-1), a determination can be made as to whether the requested communication can be completed before a future coex communication (e.g., before an estimated start time) 1790-2.
If a requested WLAN communication is determined to be completable before a future coex communication (Y from 1790-2), a method 1790 can execute such WLAN communication 1790-3. Such an action can include issuing an acknowledgement (ACK) for the request. If a requested WLAN communication is determined to not be completable before a future coex communication (N from 1790-2), a method 1790 can ignore the WLAN request 1790-4. Such an action can include not returning an acknowledgement for the WLAN communication request. A method 1790 can continue to make such determinations in response to WLAN requests until a coex active indication is received (N from 1790-5).
A coex active indication (Y from 1790-5) can indicate coex activity is taking place or is imminent. Such an indication can take any suitable form, and in some embodiments can be a message transmitted from coex circuits (e.g., serial data or a dedicated signal). However, such an indication can be determined by WLAN circuits reading a state of coex circuits (e.g., reading a register or memory location).
In response to receiving a coex active indication (Y from 1790-5), a first CTS-to-self can be transmitted having a duration equal to or greater than an estimated duration of the coex activity 1790-6. In some embodiments, a method 1790 can also include determining if an actual duration of the coex activity is greater than a duration of a first CTS-to-self 1790-7. If it is (Y from 1790-7), a second CTS-to-self can be transmitted having a duration sufficient to cover the actual coex duration 1790-8. A method can then return to 1790-0. If a duration of a first CTS-to-self 1790-7 is sufficient to cover coex activity (N from 1790-7), a method can return to 1790-0.
In this way, a CTS-to-self frame can be generated having a duration greater than or equal to a duration of future coex circuit activity.
Data for future coex communications can be transmitted to WLAN circuits 1892-3. Such an action can include any of those described herein or equivalents, including transmitting such data over a serial bus. When a coex communication is ready (Y from 1892-4), a method 1892 can transmit an active indication to WLAN circuits 1892-4. Such an action can include any of those described herein or equivalents. A method 1892 can then execute the coex communication corresponding the future coex communication.
In this way, coex communications can transmit estimated data for future coex communications as well as an active indication when such communications commence.
WLAN circuits 1902 can determine if a duration of future BT activity is greater than predetermined limit 1994-1. If a duration is not longer than the limit (N from 1994-1), WLAN circuits 1902 can prepare a first CTS-to-self frame with a duration greater than the estimated BT activity duration 1994-2.
A method 1994 can include WLAN circuits determining whether requested WLAN access can be completed before future BT activity 1994-3. In some embodiments, such an action can include determining if a WLAN request to access media is received 1994-4. In some embodiments, such an action can include detecting a request to send from another device. If such a request is received (Y from 1994-4), WLAN circuits 1902 can determine if the requested WLAN access will extend beyond the estimated BT start time 1994-5. If so (Y from 1994-5), the WLAN access will be executed and acknowledgement generated 1994-6. If not (N from 1994-5), the WLAN access can be ignored (e.g., not executed) 1994-7.
BT circuits 1904 can transmit BT active indication 1994-8 to WLAN circuits. In some embodiments such an action can enable WLAN circuits to determine an actual BT duration (dur_act). BT activity can then start 1994-14 and subsequently end 1994-15.
If the estimated BT duration is below the predetermined limit (N from 1994-1), WLAN circuits can transmit a first CTS-to-self 1994-9. WLAN circuits 1902 can determine if an actual duration of BT activity can fit within the first CTS-to-self 1994-10. If not (N from 1994-10), a second CTS-to-self can be prepared and transmitted that can cover an actual BT activity duration 1994-11. After BT activity ends 1994-15, a method 1994 can then return to start 1994-16.
If the estimated BT duration is over the predetermined limit (Y from 1994-1), WLAN circuits 1902 can prepare and transmit a null data frame with a power management bit set to “0” (1994-12). After BT activity ends 1995-15, WLAN circuits 1902 can prepare and transmit a null data frame with a power management bit set to “1” (1994-15). A method 1994 can then return to start 1994-16.
In this way WLAN circuits can issue CTS-to-self frames or transmit a power management state to protect coex BT circuit transmissions.
Embodiments can include WLAN circuits that issue CTS-to-self frames or WLAN power management communications to protect coex circuits that directly share a medium by transmitting and receiving on the same frequencies. However, embodiments can also include WLAN circuits that issue such communications to prevent the generation of harmonic frequencies that can interfere with coex communications.
Advancing protection for coex circuits as described herein can help to improve the success rate of such protection, and thereby lessen chances for the peer to mis-interpret to scale down a coding rate (e.g., MCS index). This can help to improve the co-existence performance over conventional approaches.
Advancing protection for transmitting WLAN circuits (i.e., backing off from a WLAN transmission operation) can help reduce or prevent WLAN circuits from unnecessarily scheduling transmissions that would result in the abrupt switch (e.g., antenna switching) from WLAN circuits to coex circuits (e.g., Bluetooth) in the middle of the WLAN transmission. This can help conserve processing power and unnecessary transmission power.
Embodiments are directed to methods, devices and systems that include, by operation of WLAN circuits, determining an estimated start time and estimated duration of coex communications. In response to at least a medium being free, a first CTS-to-self frame can be transmitted that has a first duration equivalent to the estimated duration for the coex communications. In response to receiving an actual coex communication start signal indicating an actual start for the coex communications, WLAN circuits can determine if the duration of the first CTS-to-self frame is sufficient to cover an actual duration for the coex communications. If the first duration is not sufficient to cover the actual duration, a second CTS-to-self frame can be transmitted with a second duration that extends beyond the first duration sufficient to cover the actual duration.
Embodiments are directed to methods, devices and systems that include WLAN circuits having a controller section configured to determine an estimated duration for coex communications, the coex communications being compatible with a second communications protocol different than WLAN. The controller section can generate a first CTS-to-self data having a first duration equivalent to the estimated duration for the future coex communications and receive an actual coex communication start signal indicating an actual start for the coex communications. In response to determining that an actual duration of the coex communication extends beyond the first duration, WLAN circuits can generate second CTS-to-self data having a second duration that extends beyond the first duration sufficient to cover the actual duration. Media access control (MAC) circuits can be configured to create at least the first and second CTS-to-self frames from first and second CTS-to-self data. Physical layer (PHY) circuits can be configured to receive WLAN frames and transmit WLAN frames, including first and second CTS-to-self frames.
A system can include WLAN circuits configured to determine an estimated start time and estimated duration for coex communications, transmit a first CTS-to-self frame having a first duration equivalent to the estimated duration for the coex communications, and receive an actual coex communication start signal indicating an actual start for the coex communications. WLAN circuits can also, in response to determining that an actual duration of the coex communication extends beyond the first duration, transmit a second CTS-to-self frame having a second duration that extends beyond the first duration sufficient to cover the actual duration. A system can also include coex communication circuits configured to communicate on the same medium as WLAN communications but according to a second communications protocol different than WLAN, and generate the actual coex communication start signal.
Methods devices and systems according to embodiments can include, in response to receiving a predetermined request for WLAN activity, determining if the WLAN activity would extend beyond the estimated start time. If the WLAN activity would extend beyond the estimated start time, not executing the WLAN activity, and if the WLAN activity would not extend beyond the estimated start time, executing the WLAN activity.
Methods devices and systems according to embodiments can include, the predetermined request including a RTS frame from another WLAN device; and executing the access includes transmitting a clear-to-send (CTS) frame in response to the RTS frame.
Methods devices and systems according to embodiments can further include WLAN circuits receiving coex communication data from the coex wireless circuit; and determining the estimated start time for the coex communications from the coex communication data.
Methods devices and systems according to embodiments can further include, by operation of the WLAN circuits receiving coex communication data from the coex wireless circuit; and determining the estimated duration of the coex communications from the coex communication data.
Methods devices and systems according to embodiments can further include, determining the estimated duration for the coex communications from historical data from previous activity of the coex circuit.
Methods devices and systems according to embodiments can include the coex wireless circuit being selected from the group of: a Bluetooth compatible circuit, a Zigbee compatible circuit and a Thread compatible wireless circuit.
Methods devices and systems according to embodiments can include coex wireless circuits having transmit buffers configured to store data for transmission according to the second communications protocol. The coex circuits are configured to generate the coex communications data from at least a state of the transmission buffers.
Methods devices and systems according to embodiments can include coex wireless circuits and WLAN circuits formed with a same substrate.
Methods devices and systems according to embodiments can include a second communications protocol that includes Bluetooth, including Bluetooth Low Energy. The coex communications circuit include memory circuits configured to store a slot allocation mask (SAM), and configured to generate the coex communications data from the SAM.
Methods devices and systems according to embodiments can further include a serial bus coupled between the WLAN circuits and the coex communication circuits; the coex communication circuits are configured to generate coex communication data; and the WLAN circuits are configured to determine the estimated start time and estimated duration from the coex communication data.
Methods devices and systems according to embodiments can further include the coex communication circuits include a transmit buffer and are configured to generate duration data from at least a state of the transmit buffer; and the WLAN circuits are configured to determine the estimated duration from the duration data.
Methods devices and systems according to embodiments can include the WLAN circuits are configured to in response to receiving a predetermined request for the WLAN circuits to access the medium with a WLAN communication, determining if the WLAN communication would extend beyond the estimated start time, if the WLAN communication would extend beyond the estimated start time, not executing the WLAN communication, and if the access would not extend beyond the estimated start time, executing the WLAN communication.
It should be appreciated that reference throughout this specification to “one embodiment” or “an embodiment” means that a particular feature, structure or characteristic described in connection with the embodiment is included in at least one embodiment of the present invention. Therefore, it is emphasized and should be appreciated that two or more references to “an embodiment” or “one embodiment” or “an alternative embodiment” in various portions of this specification are not necessarily all referring to the same embodiment. Furthermore, the particular features, structures or characteristics may be combined as suitable in one or more embodiments of the invention.
Similarly, it should be appreciated that in the foregoing description of exemplary embodiments of the invention, various features of the invention are sometimes grouped together in a single embodiment, figure, or description thereof for the purpose of streamlining the disclosure aiding in the understanding of one or more of the various inventive aspects. This method of disclosure, however, is not to be interpreted as reflecting an intention that the claims require more features than are expressly recited in each claim. Rather, inventive aspects lie in less than all features of a single foregoing disclosed embodiment. Thus, the claims following the detailed description are hereby expressly incorporated into this detailed description, with each claim standing on its own as a separate embodiment of this invention.
While this invention has been described with reference to illustrative embodiments, this description is not intended to be construed in a limiting sense. Various modifications and combinations of the illustrative embodiments, as well as other embodiments of the invention, will be apparent to persons skilled in the art upon reference to the description. It is therefore intended that the appended claims encompass any such modifications or embodiments.