The present invention is related to a scheduling method and an electronic device using the same, and more particularly, to a scheduling method and an electronic device for increasing a probability of receiving specific frames when two wireless connections coexist, in order to avoid specific frames lost.
With the advancement of wireless communication technology, various wireless communication systems are developed, such as mobile communication systems (GSM, 3G, LTE), wireless local area networks (Wi-Fi, Wimax), wireless personal local area networks (Bluetooth, Zigbee), etc. In order to prevent interferences among the communication systems, operating frequency bands and communication techniques, such as modulation, encoding, encryption, etc., employed by the communication systems are usually different. However, under the limited wireless communication resources, some of the communication systems have to share the same operating frequency band, leading to an interference issue.
For example, according to protocol specifications of Bluetooth and Wi-Fi, i.e. IEEE 802.15.1 and IEEE 802.11, the operating frequency bands thereof are defined around 2.4 GHz (5 GHz employed in IEEE 802.11a) within an industrial scientific medical (ISM) band. The ISM band is world-wide reserved for industrial, scientific and medical usages, and can be utilized without permission if some regulations are followed, to prevent affecting other frequency bands. In such a situation, even though the protocol specifications, modulating methods and encoding methods of Bluetooth and Wi-Fi are different, radio signals of Bluetooth and Wi-Fi may still cause interference to each other because of sharing the same operating frequency band, such that packets lost or frames lost may happen in both Bluetooth and Wi-Fi connections. If Bluetooth or Wi-Fi systems fail to receive packets or frames which include necessary information of wireless networks, the Bluetooth or Wi-Fi systems may suffer errors or even lose connections. For example, beacons are frames sent from an access point for carrying necessary information of a wireless network in a Wi-Fi system. If a station in the Wi-Fi system keeps losing or missing the beacons sequentially, the station may disconnect with the access point and lose Wi-Fi connection.
Note that, Bluetooth and Wi-Fi are taken for example since Bluetooth and Wi-Fi are usually employed in the same electronic product, such as a laptop computer, personal digital assistance (PDA), etc., such that disconnecting problem is obvious and crucial. Besides, since the ISM band can be utilized without permission, other communication systems using the ISM band may induce the same disconnecting problem. Therefore, it is a common goal in the industry to develop a scheduling method that keeps Wi-Fi and Bluetooth connections alive simultaneously and still maintain transmission quality of Wi-Fi and Bluetooth connections.
It is therefore a primary objective of the present invention to provide a scheduling method and an electronic device for increasing a probability of receiving the specific frames when two wireless connections coexist.
The present invention discloses a scheduling method for an electronic device comprising a first wireless module and a second wireless module for transmitting and receiving wireless signals of a first wireless communication system and a second wireless communication system respectively. The scheduling method comprises determining an arrival timing of a specific frame periodically transmitted by a base station of the first wireless communication system; determining an interval covering the arrival timing of the specific frame; disabling the second wireless module during the interval for facilitating the first wireless module to hunt the specific frames; and enabling the second wireless module when the interval expires.
The present invention further discloses an electronic device. The electronic device comprising a first wireless module, for transmitting and receiving wireless signals of a first wireless communication system and determining an arrival timing of a specific frame periodically transmitted by a base station of the first wireless communication system; a second wireless module, for transmitting and receiving wireless signals of a second wireless communication system; and a scheduler, coupled to the first wireless module and the second wireless module, for determining an interval covering the arrival timing of the specific frame, disabling the second wireless module during the interval for facilitating the first wireless module to hunt the specific frame, and enabling the second wireless module when the interval expires.
These and other objectives of the present invention will no doubt become obvious to those of ordinary skill in the art after reading the following detailed description of the preferred embodiment that is illustrated in the various figures and drawings.
Please refer to
In detail, the first wireless module 100 may determine the arrival timings t1-tn based on a timer 106 thereof. Since the timer 106 may not synchronize with the base station 104, the arrival timings t1-tn may not accurate as well. As shown in
More specifically, in a scenario that the first wireless module 100 and the second wireless module 110 connect to the first wireless communication system 102 and the second wireless communication system 112 respectively, the first wireless module 100 determines the arrival timings t1-tn of the specific frames b1-bn periodically transmitted by the base station 104 of the first wireless communication system 102 and expects to receive the specific frames b1-bn at the arrival timings t1-tn. The scheduler 120 sets a number Nb of intervals in which the first wireless module 100 does not receive the specific frames b1-bn to be zero in the beginning. However, since the second wireless module 110 is exchanging radio signals with the second wireless communication system 112, the specific frames b1-bn are interfered and thus the first wireless module 100 may fail to receive the specific frames b1-bn. In such a situation, the scheduler 120 increases 1 to the number Nb if any of the specific frames b1-bn is lost, and sets the number Nb to be zero if any of the specific frames b1-bn is received.
Further, as shown in
Note that, the specific frames b1-bn carry necessary information of the first wireless communication system 102, e.g. beacons for a Wi-Fi system, which is not limited thereto. According to different protocols, necessary information of wireless network may be carried by sub-frames, transport blocks, packets or units of different protocols. Those skilled in the art can make modification according to different system requirements.
The operations of the electronic device 10 mentioned above can be summarized to a frame hunting process 50, as illustrated in FIG. 5A, 5B AND 5C. The frame hunting process 50 includes the following steps:
Step 500: Start.
Step 501: The first wireless module 100 determines arrival timings t1-tn of the specific frames b1-bn periodically transmitted by the base station 404 of the first wireless communication system 402.
Step 502: The scheduler 120 sets the number Nb to be zero.
Step 503: The first wireless module 100 expects to receive the specific frames b1-bn at the arrival timings t1-tn. If any of the specific frames b1-bn is lost, go to Step 504. If any of the specific frames b1-bn is received, go to Step 502.
Step 504: The scheduler 120 increases 1 to the number Nb. If the number Nb is greater than the first threshold th1, go to Step 506; otherwise, go to Step 503.
Step 506: The first wireless module 100 transmits the synchronization request PP to the base station 104, and the base station 104 transmits the synchronization request response PR back to the first wireless module 100.
Step 508: The first wireless module 100 adjusts the timer 106 according to the timestamp TS contained in the synchronization request response PR, and adjusts the arrival timings t1-tn according to the timer 106, to increase a probability of receiving the specific frames b1-bn.
Step 510: The first wireless module 100 expects to receive the specific frames b1-bn at the arrival timings t1-tn. If any of the specific frames b1-bn is lost, go to Step 511. If any of the specific frames b1-bn is received, go to Step 502.
Step 511: The scheduler 120 increases 1 to the number Nb. If the number Nb is greater than the second threshold th2, go to Step 512; otherwise, go to Step 510.
Step 512: The scheduler 120 determines the intervals T1-Tn respectively covering the arrival timings t1-tn.
Step 513: The scheduler 120 disables the second wireless module 110 during the intervals T1-Tn for reducing interference to the first wireless module 100, to increase the probability of receiving the specific frames b1-bn.
Step 514: The first wireless module 100 expects to receive the specific frames b1-bn at the arrival timings t1-tn and the scheduler 120 enables the second wireless module 110 out of the intervals T1-Tn. If any of the specific frames b1-bn is lost, go to Step 516. If any of the specific frames b1-bn is received, go to Step 502.
Step 516: The scheduler 120 increases 1 to the number Nb. If the number Nb is greater than the third threshold th3, go to Step 518; otherwise, go to Step 513.
Step 518: The scheduler 120 extends or shifts the intervals T1-Tn respectively covering the arrival timings t1-tn.
Step 519: The scheduler 120 disables the second wireless module 110 during the intervals T1-Tn for reducing interference to the first wireless module 100, to increase the probability of receiving the specific frames b1-bn.
Step 520: The first wireless module 100 expects to receive the specific frames b1-bn at the arrival timings t1-tn and the scheduler 120 enables the second wireless module 110 out of the intervals T1-Tn. If any of the specific frames b1-bn is lost, go to Step 522. If any of the specific frames b1-bn is received, go to Step 502.
Step 522: The scheduler 120 increases 1 to the number Nb. If the number Nb is greater than the third threshold th3, go to Step 524; otherwise go to Step 519.
Step 524: The electronic device 10 determines that network provided by the base station 104 is no longer available, and drops a connection between the first wireless module 100 and the base station 104.
Step 526: End.
Please note that the frame hunting process 50 can be further divided into sub-processes 550, 560, 570. The sub-process 550 includes Step 503 to Step 508, the sub-process 560 includes Step 510 to Step 513, and the sub-process 570 includes Step 514 to Step 518. Any of the sub-processes 550, 560, 570 can be executed independently and an order of the sub-processes 550, 560, 570 in the process 50 can be reordered as well. Those skilled in the art can further recombine the sub-processes 550, 560, 570 to obtain a new process according to different requirements of systems. For example, please refer to
Step 600: Start.
Step 601: The first wireless module 100 determines arrival timings t1-tn of the specific frames b1-bn periodically transmitted by the base station 104 of the first wireless communication system 102.
Step 602: The scheduler 120 sets the number Nb to be zero.
Step 604: The first wireless module 100 expects to receive the specific frames b1-bn at the arrival timings t1-tn. If any of the specific frames b1-bn is lost, go to Step 606. If any of the specific frames b1-bn is received, go to Step 602.
Step 606: The scheduler 120 increases 1 to the number Nb. If the number Nb is greater than the first threshold th1, go to Step 608; otherwise go to Step 604.
Step 608: The scheduler 120 determines the intervals T1-Tn respectively covering the arrival timings t1-tn.
Step 609: The scheduler 120 disables the second wireless module 110 during the intervals T1-Tn for reducing interference to the first wireless module 100, to increase the probability of receiving the specific frames b1-bn.
Step 610: The first wireless module 100 expects to receive the specific frames b1-bn at the arrival timings t1-tn and the scheduler 120 enables the second wireless module 110 out of the intervals T1-Tn. If any of the specific frames b1-bn is lost, go to Step 612. If any of the specific frames b1-bn is received, go to Step 602.
Step 612: The scheduler 120 increases 1 to the number Nb. If the number Nb is greater than the second threshold th2, go to Step 614; otherwise, go to Step 609.
Step 614: The first wireless module 100 transmits the synchronization request PP to the base station 104, and the base station 104 transmits the synchronization request response PR back to the first wireless module 100.
Step 616: The first wireless module 100 adjusts the timer 106 according to the timestamp TS contained in the synchronization request response PR, and adjusts the arrival timings t1-tn according to the timer 106, to increase a probability of receiving the specific frames b1-bn.
Step 617: The scheduler 120 disables the second wireless module 110 during the intervals T1-Tn for reducing interference to the first wireless module 100, to increase the probability of receiving the specific frames b1-bn.
Step 618: The first wireless module 100 expects to receive the specific frames b1-bn at the arrival timings t1-tn and the scheduler 120 enables the second wireless module 110 out of the intervals T1-Tn. If any of the specific frames b1-bn is lost, go to Step 620. If any of the specific frames b1-bn is received, go to Step 602.
Step 620: The scheduler 120 increases 1 to the number Nb. If the number Nb is greater than the third threshold th3, go to Step 622; otherwise go to Step 617.
Step 622: The electronic device 10 determines that network provided by the base station 104 is no longer available, and drops a connection between the first wireless module 100 and the base station 104.
Step 624: End.
In addition, the sub-processes 550, 560, 570 of the frame hunting process 50 can be repeated to increase a probability of receiving the specific frames b1-bn. For example, the intervals T1-Tn can be extended more than one times until any of the specific frames b1-bn is received (i.e. the intervals T1-Tn become longer if the number Nb is increased but each of the intervals T1-Tn is required to be shorter than a transmitting interval between two sequential specific frames among the specific frames b1-bn). Please refer to
Step 700: Start.
Step 701: The first wireless module 100 determines arrival timings t1-tn of the specific frames b1-bn periodically transmitted by the base station 104 of the first wireless communication system 102.
Step 702: The scheduler 120 sets the number Nb to be zero.
Step 704: The first wireless module 100 expects to receive the specific frames b1-bn at the arrival timings t1-tn. If any of the specific frames b1-bn is lost, go to Step 706. If any of the specific frames b1-bn is received, go to Step 702.
Step 706: The scheduler 120 increases 1 to the number Nb. If the number Nb is greater than the first threshold th1, go to Step 708; otherwise, go to Step 704.
Step 708: The scheduler 120 determines the intervals T1-Tn respectively covering the arrival timings t1-tn.
Step 709: The scheduler 120 disables the second wireless module 110 during the intervals T1-Tn for reducing interference to the first wireless module 100, to increase the probability of receiving the specific frames b1-bn.
Step 710: The first wireless module 100 expects to receive the specific frames b1-bn at the arrival timings t1-tn and the scheduler 120 enables the second wireless module 110 out of the intervals T1-Tn. If any of the specific frames b1-bn is lost, go to Step 712. If any of the specific frames b1-bn is received, go to Step 702.
Step 712: The scheduler 120 increases 1 to the number Nb. If the number Nb is greater than the second threshold th2, go to Step 714; otherwise, go to Step 709.
Step 714: The scheduler 120 extends or shifts the intervals T1-Tn respectively covering the arrival timings t1-tn according to the number Nb. If any of intervals T1-Tn is longer than the transmitting interval TI between two sequential specific frames among the specific frames b1-bn, go to Step 722; otherwise, go to Step 715.
Step 715: The scheduler 120 disables the second wireless module 110 during the intervals T1-Tn for reducing interference to the first wireless module 100, to increase the probability of receiving the specific frames b1-bn.
Step 718: The first wireless module 100 expects to receive the specific frames b1-bn at the arrival timings t1-tn and the scheduler 120 enables the second wireless module 110 out of the intervals T1-Tn. If any of the specific frames b1-bn is lost, go to Step 720. If any of the specific frames b1-bn is received, go to Step 702.
Step 720: The scheduler 120 increases 1 to the number Nb. If the number Nb is greater than the third threshold th3, go to Step 722; otherwise, go to Step 714.
Step 722: The electronic device 10 determines that network provided by the base station 104 is no longer available, and drops a connection between the first wireless module 100 and the base station 104.
Step 724: End.
Noticeably, according to different wireless protocols used between the second wireless module 110 and the second wireless system 112, the second wireless module 110 may need to transmit packets to the second wireless system 112 periodically or in some specific times. Therefore, packets lost between the second wireless module 110 and the second wireless system 112 cannot avoid if the second wireless module 110 is disabled by the scheduler 120 and also a packet needs to be transmit by the second wireless module 110 within disabled interval. In such a situation, the scheduling method of the present invention can minimize packets lost of the second wireless module 110. For example, when the second wireless module 110 transmits packets to the second wireless communication system 112 through a Bluetooth synchronous connection-oriented (SCO) link, a SCO packet which transmission interval is 1.25 ms needs to be transmitted by the second wireless module 110 every 3.25 ms. In the same time, the first wireless modules 100 connects with the first wireless communication system 102 through a Wi-Fi connection, and the time slot and transmission time between two specific frames (e.g. beacons in Wi-Fi system) of Wi-Fi are 5 ms and 100 ms respectively. As shown in
In the prior art, when two wireless modules share the same frequency band, if one of the two wireless modules transmits radio signals without considering operation of another wireless module, disconnection of the another wireless module may occur. In comparison, according to the present invention, a wireless module is disabled during intervals of covering arrival timings of specific frames of another wireless module to avoid disconnection of the another wireless module.
To sum up, for two wireless modules sharing frequency band in an electronic device, the present invention can increase a probability of receiving specific frames when two wireless connections coexist, in order to avoid specific frames lost.
Those skilled in the art will readily observe that numerous modifications and alterations of the device and method may be made while retaining the teachings of the invention. Accordingly, the above disclosure should be construed as limited only by the metes and bounds of the appended claims.