wifi: mac80211: cleanup airtime arithmetic with ieee80211_sta_keep_active()
authorDmitry Antipov <dmantipov@yandex.ru>
Wed, 6 Dec 2023 06:09:27 +0000 (09:09 +0300)
committerJohannes Berg <johannes.berg@intel.com>
Tue, 12 Dec 2023 09:36:59 +0000 (10:36 +0100)
Prefer native jiffies-wide 'unsigned long' for the 'last_active' field of
'struct airtime_info' and introduce 'ieee80211_sta_keep_active()' for airtime
check in 'ieee80211_txq_keep_active()' and 'ieee80211_sta_register_airtime()'.

Signed-off-by: Dmitry Antipov <dmantipov@yandex.ru>
Reviewed-by: Toke Høiland-Jørgensen <toke@toke.dk>
Link: https://msgid.link/20231206060935.612241-1-dmantipov@yandex.ru
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
net/mac80211/ieee80211_i.h
net/mac80211/sta_info.c
net/mac80211/sta_info.h
net/mac80211/tx.c

index 9dd51481fb87591ccc50d20df03318761d176507..29312f6638a15a41c9697600e012b629013aa46f 100644 (file)
@@ -92,11 +92,14 @@ enum ieee80211_status_data {
        IEEE80211_STATUS_SUBDATA_MASK   = 0xff0,
 };
 
-/*
- * Keep a station's queues on the active list for deficit accounting purposes
- * if it was active or queued during the last 100ms
- */
-#define AIRTIME_ACTIVE_DURATION (HZ / 10)
+static inline bool
+ieee80211_sta_keep_active(struct sta_info *sta, u8 ac)
+{
+       /* Keep a station's queues on the active list for deficit accounting
+        * purposes if it was active or queued during the last 100ms.
+        */
+       return time_before_eq(jiffies, sta->airtime[ac].last_active + HZ / 10);
+}
 
 struct ieee80211_bss {
        u32 device_ts_beacon, device_ts_presp;
index 0ba613dd1cc478e81d2836742e9a5e7a3ad03b0c..27ccdfea5c6a6c778314857893c5c5cede477a33 100644 (file)
@@ -2268,7 +2268,6 @@ void ieee80211_sta_register_airtime(struct ieee80211_sta *pubsta, u8 tid,
        struct ieee80211_local *local = sta->sdata->local;
        u8 ac = ieee80211_ac_from_tid(tid);
        u32 airtime = 0;
-       u32 diff;
 
        if (sta->local->airtime_flags & AIRTIME_USE_TX)
                airtime += tx_airtime;
@@ -2279,8 +2278,7 @@ void ieee80211_sta_register_airtime(struct ieee80211_sta *pubsta, u8 tid,
        sta->airtime[ac].tx_airtime += tx_airtime;
        sta->airtime[ac].rx_airtime += rx_airtime;
 
-       diff = (u32)jiffies - sta->airtime[ac].last_active;
-       if (diff <= AIRTIME_ACTIVE_DURATION)
+       if (ieee80211_sta_keep_active(sta, ac))
                sta->airtime[ac].deficit -= airtime;
 
        spin_unlock_bh(&local->active_txq_lock[ac]);
index 7acf2223e47aa20867b4933d94cf10f2ead7c701..5ef1554f991f6da963dfa12f5be0e4f2c9b2b857 100644 (file)
@@ -138,7 +138,7 @@ enum ieee80211_agg_stop_reason {
 struct airtime_info {
        u64 rx_airtime;
        u64 tx_airtime;
-       u32 last_active;
+       unsigned long last_active;
        s32 deficit;
        atomic_t aql_tx_pending; /* Estimated airtime for frames pending */
        u32 aql_limit_low;
index ed4fdf655343f2ef5c4e655e88df66898eb101ff..314998fdb1a5a4853f84a90edf2ba2312933719a 100644 (file)
@@ -4013,14 +4013,13 @@ ieee80211_txq_set_active(struct txq_info *txqi)
                return;
 
        sta = container_of(txqi->txq.sta, struct sta_info, sta);
-       sta->airtime[txqi->txq.ac].last_active = (u32)jiffies;
+       sta->airtime[txqi->txq.ac].last_active = jiffies;
 }
 
 static bool
 ieee80211_txq_keep_active(struct txq_info *txqi)
 {
        struct sta_info *sta;
-       u32 diff;
 
        if (!txqi->txq.sta)
                return false;
@@ -4029,9 +4028,7 @@ ieee80211_txq_keep_active(struct txq_info *txqi)
        if (ieee80211_sta_deficit(sta, txqi->txq.ac) >= 0)
                return false;
 
-       diff = (u32)jiffies - sta->airtime[txqi->txq.ac].last_active;
-
-       return diff <= AIRTIME_ACTIVE_DURATION;
+       return ieee80211_sta_keep_active(sta, txqi->txq.ac);
 }
 
 struct ieee80211_txq *ieee80211_next_txq(struct ieee80211_hw *hw, u8 ac)