 
                 Patent Grant
 Patent Grant
                     9756651
 9756651
                    This application relates to wireless communications, and more particularly, to a method and apparatus for adjusting an airtime quota of User Equipment to improve quality of service (QoS).
The IEEE 802.11 standard has been widely applied in wireless communications applications in wireless local area network (WLAN). In an 802.11 wireless network, the physical transmission rate has a very large variation, which not only depends on distance from a client to an access point (AP), but also depends on the 802.11 standard modes. The physical rate range specified by 802.11b is from 1 Mbps (Megabits per second) to 11 Mbps, and the physical rate range specified by 802.11n is from 6.5 Mbps to 600 Mbps. A problem of “airtime unfairness” exists in conventional WLAN products. When there are several good quality links (e.g. near end users) and bad quality links (e.g. far end users) in the same WLAN, the bad quality links are assigned with less airtime due to the competitive mechanism of 802.11. Hence, the bad quality links may not have sufficient airtime for packet transmission, thus deteriorating user experience.
Therefore, there is a need for a method and apparatus for adjusting airtime quota of User Equipment to improve quality of service (QoS).
One of the objectives of the present invention is to provide a method and an associated apparatus to adjust throughput and/or airtime of each group of clients, to improve the quality of a user experience.
An embodiment of the present invention provides a wireless device that comprises a scheduler for setting a packet de-queue scheduling of a packet queue device having packets of a plurality of groups which are queued therein. Each of the plurality of groups includes at least one wireless communications client. The scheduler includes an information acquisition circuit, an airtime controller and a scheduling controller. The information acquisition circuit is arranged to obtain an airtime utilization or a throughput utilization of at least one group of the plurality of groups. The airtime controller is arranged to assign a plurality of airtime quota settings to the plurality of groups based on the airtime utilization of the at least one group of the plurality of groups. The scheduling controller is arranged to set the packet de-queue scheduling according to at least the airtime quota settings.
Another embodiment of the present invention provides a method for setting a packet de-queue scheduling of a wireless device having packets of a plurality of groups which are queued therein. Each of the plurality of groups includes at least one wireless communications client. The method includes: obtaining an airtime utilization or a throughput utilization of at least one group of the plurality of groups; assigning a plurality of airtime quota settings to the plurality of groups based on the airtime utilization or the throughput utilization of the at least one group of the plurality of groups; and setting the packet de-queue scheduling according to the airtime quota settings.
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.
    
    
    
    
    
Certain terms are used throughout the description and following claims to refer to particular components. As one skilled in the art will appreciate, manufacturers may refer to a component by different names. This document does not intend to distinguish between components that differ in name but not function. In the following description and in the claims, the terms “include” and “comprise” are used in an open-ended fashion, and thus should not be interpreted as a close-ended term such as “consist of”. Also, the term “couple” is intended to mean either an indirect or direct electrical connection. Accordingly, if one device is coupled to another device, that connection may be through a direct electrical connection, or through an indirect electrical connection via other devices and connections.
Please refer to 
The queuing module 20 is arranged to classify packets received from an upper layer, and queue the packets into queues of at least one group according to a determined classification result. The scheduler 100 is arranged to receive airtime information, the throughput information and the QoS profile 60, and generate a selection result accordingly (e.g. a group identification (ID) and a client identification), so that the de-queuing module 30 may refer to the selection result transmitted from the scheduler 100 to de-queue one or more packets from a selected queue corresponding to a selected group.
The received airtime information may indicate how much airtime is actually used by a WiFi access point for transmitting packets to a client, and/or how much airtime is actually used by a client for receiving packets transmitted from the WiFi access point. In other words, the airtime information of each client may be actively evaluated by a WiFi access point, and/or passively provided by a client linked to the WiFi access point. The received throughput information may include the data amount of packets (denoted as Tx bytes in 
The QoS profile 60 includes conventional wireless standard modes. The scheduler 100 may use various wireless communications policies to compensate for the deficiency of the QoS profile 60, so that the airtime fairness based on the user requirements may be achieved.
Specifically, the scheduler 100 is arranged for setting a packet de-queue scheduling of the packet queue device 50 having packets of a plurality of groups (e.g. groups 0-k) which are queued therein. Each of the plurality of groups corresponds to at least one wireless communications client. For example, group 0 includes clients 0-2, and group k includes clients (n-1) and n, as shown in 
In this embodiment, the scheduler 100 includes an information acquisition circuit 110, an airtime controller 120 and a scheduling controller 130. The information acquisition circuit 110 is arranged to obtain airtime utilization (e.g. the received airtime information) of at least one group of the groups 0-k. In this way, the scheduler 100 may change the de-queue policy for specific users/clients. The airtime controller 120 is arranged to assign a plurality of airtime quota settings to the plurality of groups 0-k at least based on the airtime utilization and/or the throughput of the at least one group of the plurality of groups 0-k. The scheduling controller 130 is arranged to set the packet de-queue scheduling according to at least the airtime quota settings.
The term “airtime quota” may refer to the concept of “token bucket”. The token bucket is an algorithm used in packet switched telecommunications networks. It can be used to check that data transmissions, in the form of packets, conform to defined limits on the bandwidth. When a packet is to be checked for conformance to the defined limits, the bucket is inspected to see if it contains sufficient tokens at that time. If the packet has run out of tokens, the corresponding hotspot will stop serving the packet. Then, the spared airtime may be allocated to other clients.
Please refer to 
Step 202: Receive packets from an upper layer.
Step 204: Queue packets to a corresponding client's queue.
Step 206: Select a target group based on the QoS profile.
Step 208: Select a target client in the selected target group based on an airtime fairness policy employed by a scheduler.
Step 210: De-queue packet(s) for the selected target client in the target group.
Step 212: The scheduler evaluates the amount of transmitted packet bytes and airtime update information associated with the transmitted packet bytes for at least one client, or receives information (e.g., the information provided by a client) indicative of the amount of received packet bytes and airtime update information associated with the received packet bytes for at least one client.
Step 214: The scheduler determines a selection result based on the throughput information (e.g. transmitted/received byte amount of each group), the airtime information (e.g. the airtime utilization of each group that is updated based on the airtime update information of clients belonging to the group), and/or the QoS profile.
Please refer to 
Please note that the first hotspot user and the second hotspot user (hereinafter the hotspot1 user and the hotspot2 user) are connected to two different respective hotspots. Amongst the three users, the home user is a client of the highest-priority group among all the groups. The priorities of the hotspot1 user and the hotspot2 user are both lower than the priority of the home user.
In the period P1, only the groups of the home user and the hotspot1 user are connected to the AP. Since the home user has the highest priority, 60% airtime is reserved for the home user, and 20% airtime is reserved for the hotspot1 user. For example, the AP may lock the airtime upper limit of the hotspot1 user at 20% based on the policy, and the remaining 20% airtime (spare airtime) will be allocated to the home user, to ensure that the home user gets the best service. The hotspot2 user logs in at timing t1, and is allocated with 10% airtime in the period P2. Hence, there is only 10% spare airtime left to the home user during the period P2.
When the home user has low traffic at timing t2 (e.g. the home user stops using the AP at this time), the airtime occupied by the home user drops rapidly—for example, from 70% to 10% during the period P3—and the spare airtime released by the home user will be weighted shared by the hotspot1 user and the hotspot2 user based on the policy during the period P4. Specifically, when the airtime utilization of the highest-priority group (e.g. the group of the home user) is reduced (e.g. low traffic), the airtime controller 120 of the wireless device 1000 will decrease the airtime quota setting assigned to the highest-priority group, and increase the airtime quota setting assigned to at least one lower-priority group in the groups (e.g. the hotspot1 user and the hotspot2 user).
In the example illustrated in 
Please refer to 
In this embodiment, the airtime controller 120 of the scheduler 100 controls a summation of the airtime quota setting assigned to the lower-priority group in which the hotspot1 near-end user and the hotspot1 far-end user are included to not exceed a predetermined airtime threshold (e.g. a 25% airtime upper limit). In addition, the airtime controller 120 controls the summation of throughput of the hotspot1 near-end user and the hotspot1 far-end user of the lower-priority group to not exceed a predetermined throughput threshold (e.g. 25 Mbps). Please note that a difference between this embodiment and the previous embodiment is that the airtime controller 120 in this embodiment is arranged to assign a plurality of airtime quota settings to the plurality of groups based on the throughput of the at least one group of the plurality of groups. That is, the airtime controller 120 controls at least one airtime quota setting assigned to at least one specific group according to the throughput of a specific group (or the summation of the throughput of a plurality of specific groups) and a predetermined throughput threshold.
As shown in 
In other words, the airtime amount allocated to the hotspot1 near-end user which has good connection quality is reduced for airtime fairness, so that the saved airtime amount may be used to assist the hotspot1 far-end user which has poor connection quality. Via this embodiment, the far-end user may have more airtime to benefit from a fair connection service, and does not easily suffer the connection quality drop when they are at a distance from the AP. The hotspot1 far-end user may thereby be fairly served.
At timing t1, the hotspot1 near-end user stops connecting to the AP (i.e. leaves the AP) due to dissatisfaction with the service of the AP (or other reasons), and thus more airtime can be used to assist the hotspot1 far-end user. Further, some spare airtime previously allocated to the home user is also released to the hotspot1 far-end user. The airtime allocated to the hotspot1 far-end user is controlled to not exceed 25%, and the throughput of the hotspot1 far-end user is controlled to not exceed 25 Mbps. The 25% airtime is continuously allocated to the hotspot1 far-end user in the periods P2 and P3 until the throughput of the hotspot1 far-end user reaches 25 Mbps, despite the home user suffering severe channel fading at the timing T2. Under the policy of this embodiment, even though the home user's throughput drops significantly, a best effort is still made for the weaker hotspot user (e.g. the hotspot1 far-end user).
  
In accordance with the policy of this embodiment, the home user is guaranteed to have fastest transmission rate due to its highest priority. As shown in 
When the home user suffers severe channel fading in the period P3, the AP allocates all airtime (i.e. 100% airtime) to the home user once more. Under the policy of this embodiment, all of the airtime allocated to the hotspot1 user in the period P2 will be released to the home user in the period P3. In this way, the home user is guaranteed a full-time high connection quality, and some low-priority users may share the wireless communications service as long as the AP has sufficient airtime margins.
The above policy can also be applied to a case of multiple lower-priority groups. For example, assuming that there are multiple lower-priority groups connected to the AP, when the throughput of the home user reaches a predetermined throughput threshold (e.g. 50 Mbps) in the period P2, the airtime controller 120 decreases an airtime quota setting assigned to the home user, and increases an airtime quota setting assigned to remaining lower-priority users.
To summarize, the embodiments of the present invention provide an apparatus and methods for adjusting airtime quota of User Equipment to improve quality of service (QoS) . By transferring part of the airtime used by a primary user (e.g. the home user) to a low connection quality user (e.g. a far-end user), the connection quality of this low connection quality user may be improved.
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.
This application claims the benefit of U.S. provisional application No. 62/094,081, filed on Dec. 19, 2014, and incorporated herein by reference.
| Number | Name | Date | Kind | 
|---|---|---|---|
| 6564047 | Steele | May 2003 | B1 | 
| 20080144599 | Chen | Jun 2008 | A1 | 
| 20130336319 | Liu | Dec 2013 | A1 | 
| 20140160929 | Wu | Jun 2014 | A1 | 
| Number | Date | Country | 
|---|---|---|
| 1 817 878 | Jul 2009 | EP | 
| 2014141026 | Sep 2014 | WO | 
| Number | Date | Country | |
|---|---|---|---|
| 20160183283 A1 | Jun 2016 | US | 
| Number | Date | Country | |
|---|---|---|---|
| 62094081 | Dec 2014 | US |