From nobody Fri Jan 3 01:24:29 2025 X-Original-To: dev-commits-src-all@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4YPQpj2q0zz5kDB4; Fri, 03 Jan 2025 01:24:29 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R11" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4YPQpj23bgz4P7y; Fri, 3 Jan 2025 01:24:29 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1735867469; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=0KhZ1ul5qpl+UJ8iljTSKYzGh0NyN+o1HadmKSp7B2I=; b=UIj2bT4TNrpCFl9lKrmsRdb5bWp5UNZP/v5VodORz6bTIHqn5LISb/svSk7TOf8DAaGIKF vIe58fSx1T2AwgzTC4bc5XOf4p7fMSLeui19k84vyhl/f6R4oPX+PXLwlX+SbjIif8auSt jGlvz+4pzfM7LyzOJThDmJQhxJGUp4Q8RaXtH5FpR635wPzU8FWs65VEk/793h1J6mMqPM mC+IVc/k8iJ//F8lsEUNHQG3gea71fNmhUviFOC4fo1WCAicxuduPJ05+l7vTFbpPe6IHt R6t5o9VsmVRrdkNoyJ/U9MX75y8DsXBZJdslN2PpuDz8I8OeBnVNzqbw1XJPfQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1735867469; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=0KhZ1ul5qpl+UJ8iljTSKYzGh0NyN+o1HadmKSp7B2I=; b=BTy9llzlHjswOIr6xEet0vrAcbFSqEKBig404xCSW93Z159KAL4TMB3bZheFleVL3+3gDV wo7OOgOBbNNIVeDeFmJmbJJZpE9e+uoRwEH4kVijeRyNisM6CXIVWhovbUoAySA8EB9lNU T+fHIy5PrziGVevGTF37Sh2whbMU0FRUWMPb06Uka3cauA4lzMFIjX2nRUASxY8Je4+B9e 0XnyYeyOBJLmTNmL/zhD1JD2IXsOKJfl/KfUNIHAmt6/rh7n1kuU7L5P+5z3gtr20LNdbt fHV7Epmb1KdavrFL5LpEibqSwUOI3YHTbkIB2cF16NIdN17zOUViuisQRmgkIg== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1735867469; a=rsa-sha256; cv=none; b=JPLnnGFr/vUJ62KwDQ4/RbBryy5CbmuyUDHbUc579VY4n+ssyd05jZFi4E5gNfFOEAHihb W90EgQkdkPE6hyM8+0heNjhGNjJwqH1A6ZxydnyB0HKv7zmcdsizxQg77myv2EE/kRz3KJ oTIYGvRhLT99IB9LBswP36lQgA2JUAALhcApUsDfPSqshSRWlnvWmTE0vbfgA/L1em2MgO Rnd30k7ylyICwSA64XoZQr0vVmGym+BxEecb55KTK575/2CEZZEw3Iak/G4iHlaGGMEy20 4pkT4kZKoKq5tTYTplExBb7uvljHr5XcHPFWe46dQczFyjF1oAX+qOjCQ6Vs+A== ARC-Authentication-Results: i=1; mx1.freebsd.org; none Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 4YPQpj1g35z11X6; Fri, 03 Jan 2025 01:24:29 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.18.1/8.18.1) with ESMTP id 5031OTEb053227; Fri, 3 Jan 2025 01:24:29 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.18.1/8.18.1/Submit) id 5031OT9h053224; Fri, 3 Jan 2025 01:24:29 GMT (envelope-from git) Date: Fri, 3 Jan 2025 01:24:29 GMT Message-Id: <202501030124.5031OT9h053224@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org From: Adrian Chadd Subject: git: 64ecfc27dbd4 - main - rtwn: add forcerate flag to TX descriptor setup List-Id: Commit messages for all branches of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-all List-Help: List-Post: List-Subscribe: List-Unsubscribe: X-BeenThere: dev-commits-src-all@freebsd.org Sender: owner-dev-commits-src-all@FreeBSD.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: adrian X-Git-Repository: src X-Git-Refname: refs/heads/main X-Git-Reftype: branch X-Git-Commit: 64ecfc27dbd486ed764f9696b6e56f88e34ee8a1 Auto-Submitted: auto-generated The branch main has been updated by adrian: URL: https://cgit.FreeBSD.org/src/commit/?id=64ecfc27dbd486ed764f9696b6e56f88e34ee8a1 commit 64ecfc27dbd486ed764f9696b6e56f88e34ee8a1 Author: Adrian Chadd AuthorDate: 2024-12-16 01:28:30 +0000 Commit: Adrian Chadd CommitDate: 2025-01-03 01:24:01 +0000 rtwn: add forcerate flag to TX descriptor setup When doing firmware rate control there will be situations where the rate being passed in needs to actually override the rate control selection. So add a flag to the descriptor setup path to indicate that indeed this particular rate should be forced, rather than rely on the firmware rate control. This is currently a no-op as firmware rate control isn't working in-tree, but it is working for me locally with other changes. Without this, there's no way to force low rates for management, DHCP traffic, and to allow fixed rate via "ifconfig wlanX ucastrate Y" to function. Locally tested: * RTL8192CU, STA mode (firmware and driver/net80211 rate control) Differential Revision: https://reviews.freebsd.org/D48100 Reviewed by: bz, gavin --- sys/dev/rtwn/if_rtwn_tx.c | 14 +++++++++----- sys/dev/rtwn/if_rtwnvar.h | 6 +++--- sys/dev/rtwn/rtl8192c/r92c.h | 2 +- sys/dev/rtwn/rtl8192c/r92c_tx.c | 2 +- sys/dev/rtwn/rtl8812a/r12a.h | 2 +- sys/dev/rtwn/rtl8812a/r12a_tx.c | 2 +- 6 files changed, 16 insertions(+), 12 deletions(-) diff --git a/sys/dev/rtwn/if_rtwn_tx.c b/sys/dev/rtwn/if_rtwn_tx.c index bf45d14f7edc..c59d1de1dea8 100644 --- a/sys/dev/rtwn/if_rtwn_tx.c +++ b/sys/dev/rtwn/if_rtwn_tx.c @@ -117,6 +117,7 @@ rtwn_tx_data(struct rtwn_softc *sc, struct ieee80211_node *ni, struct rtwn_tx_desc_common *txd; struct rtwn_tx_buf buf; uint8_t rate, ridx, type; + bool force_rate = false; u_int cipher; int ismcast; @@ -129,13 +130,16 @@ rtwn_tx_data(struct rtwn_softc *sc, struct ieee80211_node *ni, /* Choose a TX rate index. */ if (type == IEEE80211_FC0_TYPE_MGT || type == IEEE80211_FC0_TYPE_CTL || - (m->m_flags & M_EAPOL) != 0) + (m->m_flags & M_EAPOL) != 0) { rate = tp->mgmtrate; - else if (ismcast) + force_rate = true; + } else if (ismcast) { + force_rate = true; rate = tp->mcastrate; - else if (tp->ucastrate != IEEE80211_FIXED_RATE_NONE) + } else if (tp->ucastrate != IEEE80211_FIXED_RATE_NONE) { + force_rate = true; rate = tp->ucastrate; - else { + } else { if (sc->sc_ratectl == RTWN_RATECTL_NET80211) { /* XXX pass pktlen */ (void) ieee80211_ratectl_rate(ni, NULL, 0); @@ -172,7 +176,7 @@ rtwn_tx_data(struct rtwn_softc *sc, struct ieee80211_node *ni, memset(txd, 0, sc->txdesc_len); txd->txdw1 = htole32(SM(RTWN_TXDW1_CIPHER, rtwn_get_cipher(cipher))); - rtwn_fill_tx_desc(sc, ni, m, txd, ridx, tp->maxretry); + rtwn_fill_tx_desc(sc, ni, m, txd, ridx, force_rate, tp->maxretry); if (ieee80211_radiotap_active_vap(vap)) { struct rtwn_tx_radiotap_header *tap = &sc->sc_txtap; diff --git a/sys/dev/rtwn/if_rtwnvar.h b/sys/dev/rtwn/if_rtwnvar.h index 3913526f8c3c..fa4b6d0a5df7 100644 --- a/sys/dev/rtwn/if_rtwnvar.h +++ b/sys/dev/rtwn/if_rtwnvar.h @@ -319,7 +319,7 @@ struct rtwn_softc { void (*sc_detach_private)(struct rtwn_softc *); void (*sc_fill_tx_desc)(struct rtwn_softc *, struct ieee80211_node *, struct mbuf *, - void *, uint8_t, int); + void *, uint8_t, bool, int); void (*sc_fill_tx_desc_raw)(struct rtwn_softc *, struct ieee80211_node *, struct mbuf *, void *, const struct ieee80211_bpf_params *); @@ -527,9 +527,9 @@ void rtwn_suspend(struct rtwn_softc *); #define rtwn_detach_private(_sc) \ (((_sc)->sc_detach_private)((_sc))) #define rtwn_fill_tx_desc(_sc, _ni, _m, \ - _buf, _ridx, _maxretry) \ + _buf, _ridx, _force, _maxretry) \ (((_sc)->sc_fill_tx_desc)((_sc), (_ni), \ - (_m), (_buf), (_ridx), (_maxretry))) + (_m), (_buf), (_ridx), (_force), (_maxretry))) #define rtwn_fill_tx_desc_raw(_sc, _ni, _m, \ _buf, _params) \ (((_sc)->sc_fill_tx_desc_raw)((_sc), (_ni), \ diff --git a/sys/dev/rtwn/rtl8192c/r92c.h b/sys/dev/rtwn/rtl8192c/r92c.h index a7091be66f64..cab7393caf39 100644 --- a/sys/dev/rtwn/rtl8192c/r92c.h +++ b/sys/dev/rtwn/rtl8192c/r92c.h @@ -117,7 +117,7 @@ void r92c_tx_enable_ampdu(void *, int); void r92c_tx_setup_hwseq(void *); void r92c_tx_setup_macid(void *, int); void r92c_fill_tx_desc(struct rtwn_softc *, struct ieee80211_node *, - struct mbuf *, void *, uint8_t, int); + struct mbuf *, void *, uint8_t, bool, int); void r92c_fill_tx_desc_raw(struct rtwn_softc *, struct ieee80211_node *, struct mbuf *, void *, const struct ieee80211_bpf_params *); void r92c_fill_tx_desc_null(struct rtwn_softc *, void *, int, int, int); diff --git a/sys/dev/rtwn/rtl8192c/r92c_tx.c b/sys/dev/rtwn/rtl8192c/r92c_tx.c index 07a6a184e924..d5cbc3ad9db9 100644 --- a/sys/dev/rtwn/rtl8192c/r92c_tx.c +++ b/sys/dev/rtwn/rtl8192c/r92c_tx.c @@ -259,7 +259,7 @@ r92c_check_enable_ccx_report(struct rtwn_softc *sc, int macid) void r92c_fill_tx_desc(struct rtwn_softc *sc, struct ieee80211_node *ni, - struct mbuf *m, void *buf, uint8_t ridx, int maxretry) + struct mbuf *m, void *buf, uint8_t ridx, bool force_rate, int maxretry) { #ifndef RTWN_WITHOUT_UCODE struct r92c_softc *rs = sc->sc_priv; diff --git a/sys/dev/rtwn/rtl8812a/r12a.h b/sys/dev/rtwn/rtl8812a/r12a.h index 8bf1464b9525..e5c5c7cd6a80 100644 --- a/sys/dev/rtwn/rtl8812a/r12a.h +++ b/sys/dev/rtwn/rtl8812a/r12a.h @@ -131,7 +131,7 @@ void r12a_get_rx_stats(struct rtwn_softc *, struct ieee80211_rx_stats *, /* r12a_tx.c */ void r12a_fill_tx_desc(struct rtwn_softc *, struct ieee80211_node *, - struct mbuf *, void *, uint8_t, int); + struct mbuf *, void *, uint8_t, bool, int); void r12a_fill_tx_desc_raw(struct rtwn_softc *, struct ieee80211_node *, struct mbuf *, void *, const struct ieee80211_bpf_params *); void r12a_fill_tx_desc_null(struct rtwn_softc *, void *, int, int, int); diff --git a/sys/dev/rtwn/rtl8812a/r12a_tx.c b/sys/dev/rtwn/rtl8812a/r12a_tx.c index 822416a09618..cc686668e4a2 100644 --- a/sys/dev/rtwn/rtl8812a/r12a_tx.c +++ b/sys/dev/rtwn/rtl8812a/r12a_tx.c @@ -261,7 +261,7 @@ r12a_calculate_tx_agg_window(struct rtwn_softc *sc, void r12a_fill_tx_desc(struct rtwn_softc *sc, struct ieee80211_node *ni, - struct mbuf *m, void *buf, uint8_t ridx, int maxretry) + struct mbuf *m, void *buf, uint8_t ridx, bool force_rate, int maxretry) { struct ieee80211com *ic = &sc->sc_ic; struct ieee80211vap *vap = ni->ni_vap;