git: e99cbea414ff - main - net80211: refactor amrr_update() into HT and legacy paths
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Wed, 26 Feb 2025 19:31:46 UTC
The branch main has been updated by adrian:
URL: https://cgit.FreeBSD.org/src/commit/?id=e99cbea414ffa2c439a651e4726896ea8de99c83
commit e99cbea414ffa2c439a651e4726896ea8de99c83
Author:     Adrian Chadd <adrian@FreeBSD.org>
AuthorDate: 2024-12-29 19:38:51 +0000
Commit:     Adrian Chadd <adrian@FreeBSD.org>
CommitDate: 2025-02-26 19:31:21 +0000
    net80211: refactor amrr_update() into HT and legacy paths
    
    Split the amrr_update() routine into HT and legacy paths.
    Currently they're the same, minus HT / non-HT specific comments
    and some logging changes.
    
    HT rates don't monotonically go up (ie, going MCS 7 -> MCS 8 is wrong,
    as MCS8 is "just" two stream MCS0) and failing a rate by a little
    shouldn't necessarily preclude testing the next rate up.
    
    This should be a no-op, besides the logging changes.
    
    Locally tested:
    
    * RTL8192CU, STA mode
    
    Differential Revision:  https://reviews.freebsd.org/D48248
    Reviewed by:    bz, thj
---
 sys/net80211/ieee80211_amrr.c | 101 ++++++++++++++++++++++++++++++++++--------
 1 file changed, 83 insertions(+), 18 deletions(-)
diff --git a/sys/net80211/ieee80211_amrr.c b/sys/net80211/ieee80211_amrr.c
index d366bf71e367..20e90026bfe9 100644
--- a/sys/net80211/ieee80211_amrr.c
+++ b/sys/net80211/ieee80211_amrr.c
@@ -226,26 +226,17 @@ amrr_node_deinit(struct ieee80211_node *ni)
 }
 
 static int
-amrr_update(struct ieee80211_amrr *amrr, struct ieee80211_amrr_node *amn,
+amrr_update_ht(struct ieee80211_amrr *amrr, struct ieee80211_amrr_node *amn,
     struct ieee80211_node *ni)
 {
 	int rix = amn->amn_rix;
-	const struct ieee80211_rateset *rs = NULL;
+	const struct ieee80211_rateset *rs;
 
-	KASSERT(is_enough(amn), ("txcnt %d", amn->amn_txcnt));
-
-	/* 11n or not? Pick the right rateset */
-	if (ieee80211_ht_check_tx_ht(ni)) {
-		/* XXX ew */
-		rs = (struct ieee80211_rateset *) &ni->ni_htrates;
-	} else {
-		rs = &ni->ni_rates;
-	}
+	rs = (struct ieee80211_rateset *)&ni->ni_htrates;
 
 	/* XXX TODO: we really need a rate-to-string method */
-	/* XXX TODO: non-11n rate should be divided by two.. */
 	IEEE80211_NOTE(ni->ni_vap, IEEE80211_MSG_RATECTL, ni,
-	    "AMRR: current rate %d, txcnt=%d, retrycnt=%d",
+	    "AMRR: current rate MCS %d, txcnt=%d, retrycnt=%d",
 	    rs->rs_rates[rix] & IEEE80211_RATE_VAL,
 	    amn->amn_txcnt,
 	    amn->amn_retrycnt);
@@ -266,9 +257,9 @@ amrr_update(struct ieee80211_amrr *amrr, struct ieee80211_amrr_node *amn,
 			amn->amn_success = 0;
 			rix++;
 			/* XXX TODO: we really need a rate-to-string method */
-			/* XXX TODO: non-11n rate should be divided by two.. */
 			IEEE80211_NOTE(ni->ni_vap, IEEE80211_MSG_RATECTL, ni,
-			    "AMRR increasing rate %d (txcnt=%d retrycnt=%d)",
+			    "AMRR increasing rate MCS %d "
+			    "(txcnt=%d retrycnt=%d)",
 			    rs->rs_rates[rix] & IEEE80211_RATE_VAL,
 			    amn->amn_txcnt, amn->amn_retrycnt);
 		} else {
@@ -289,20 +280,94 @@ amrr_update(struct ieee80211_amrr *amrr, struct ieee80211_amrr_node *amn,
 			}
 			rix--;
 			/* XXX TODO: we really need a rate-to-string method */
-			/* XXX TODO: non-11n rate should be divided by two.. */
 			IEEE80211_NOTE(ni->ni_vap, IEEE80211_MSG_RATECTL, ni,
-			    "AMRR decreasing rate %d (txcnt=%d retrycnt=%d)",
+			    "AMRR decreasing rate MCS %d "
+			    "(txcnt=%d retrycnt=%d)",
 			    rs->rs_rates[rix] & IEEE80211_RATE_VAL,
 			    amn->amn_txcnt, amn->amn_retrycnt);
 		}
 		amn->amn_recovery = 0;
 	}
 
+	return (rix);
+}
+
+static int
+amrr_update_legacy(struct ieee80211_amrr *amrr, struct ieee80211_amrr_node *amn,
+    struct ieee80211_node *ni)
+{
+	int rix = amn->amn_rix;
+	const struct ieee80211_rateset *rs;
+
+	rs = &ni->ni_rates;
+
+	/* XXX TODO: we really need a rate-to-string method */
+	IEEE80211_NOTE(ni->ni_vap, IEEE80211_MSG_RATECTL, ni,
+	    "AMRR: current rate %d Mb, txcnt=%d, retrycnt=%d",
+	    (rs->rs_rates[rix] & IEEE80211_RATE_VAL) / 2,
+	    amn->amn_txcnt,
+	    amn->amn_retrycnt);
+
+	if (is_success(amn)) {
+		amn->amn_success++;
+		if (amn->amn_success >= amn->amn_success_threshold &&
+		    rix + 1 < rs->rs_nrates) {
+			amn->amn_recovery = 1;
+			amn->amn_success = 0;
+			rix++;
+			/* XXX TODO: we really need a rate-to-string method */
+			IEEE80211_NOTE(ni->ni_vap, IEEE80211_MSG_RATECTL, ni,
+			    "AMRR increasing rate %d Mb (txcnt=%d retrycnt=%d)",
+			    (rs->rs_rates[rix] & IEEE80211_RATE_VAL) / 2,
+			    amn->amn_txcnt, amn->amn_retrycnt);
+		} else {
+			amn->amn_recovery = 0;
+		}
+	} else if (is_failure(amn)) {
+		amn->amn_success = 0;
+		if (rix > 0) {
+			if (amn->amn_recovery) {
+				amn->amn_success_threshold *= 2;
+				if (amn->amn_success_threshold >
+				    amrr->amrr_max_success_threshold)
+					amn->amn_success_threshold =
+					    amrr->amrr_max_success_threshold;
+			} else {
+				amn->amn_success_threshold =
+				    amrr->amrr_min_success_threshold;
+			}
+			rix--;
+			/* XXX TODO: we really need a rate-to-string method */
+			IEEE80211_NOTE(ni->ni_vap, IEEE80211_MSG_RATECTL, ni,
+			    "AMRR decreasing rate %d Mb (txcnt=%d retrycnt=%d)",
+			    (rs->rs_rates[rix] & IEEE80211_RATE_VAL) / 2,
+			    amn->amn_txcnt, amn->amn_retrycnt);
+		}
+		amn->amn_recovery = 0;
+	}
+
+	return (rix);
+}
+
+static int
+amrr_update(struct ieee80211_amrr *amrr, struct ieee80211_amrr_node *amn,
+    struct ieee80211_node *ni)
+{
+	int rix;
+
+	KASSERT(is_enough(amn), ("txcnt %d", amn->amn_txcnt));
+
+	/* 11n or not? Pick the right rateset */
+	if (ieee80211_ht_check_tx_ht(ni))
+		rix = amrr_update_ht(amrr, amn, ni);
+	else
+		rix = amrr_update_legacy(amrr, amn, ni);
+
 	/* reset counters */
 	amn->amn_txcnt = 0;
 	amn->amn_retrycnt = 0;
 
-	return rix;
+	return (rix);
 }
 
 /*