Received: by 2002:ab2:6857:0:b0:1ef:ffd0:ce49 with SMTP id l23csp2613778lqp; Mon, 25 Mar 2024 04:35:19 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWt0plq5RuJ8JBk4GkCje0BFaAD7pyId52tzDE+WZ/OmhTyh0lZt/K2f5usmH1YAwZfqnOoTEJITqDsq9Se1iJfGlYiJVKOApSBda2bEw== X-Google-Smtp-Source: AGHT+IGDckREHyt+u1X6nZaONKBD3rQus2plIut77mEfRlgxvkPLDarBxbUOBh06fr1M2o2Ac8Vy X-Received: by 2002:a81:6903:0:b0:610:db2a:91f1 with SMTP id e3-20020a816903000000b00610db2a91f1mr5432824ywc.19.1711366518998; Mon, 25 Mar 2024 04:35:18 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1711366518; cv=pass; d=google.com; s=arc-20160816; b=fQ+nx3bOyhSybVt1mSa9j0JXGfrrA/KNY6aglqKd3Evf/WiZzZixndbzMjKd2Dn3FK Q5mfd5dJBzZV8lSZZzbiGCrKc9NfG+IHLfDJzruLRqisLkqS0LFW5K6kmQK+T80Nmv4V ZHppZEM/pAznutfmW3L6D5n/tmcukgPdRrSwfsNn1DS/r8Kn5nssFC7IZuxKo5xVkKg7 HYKqErqu5wD5qcZeGCXoXhZyXMldDvMVxrXH4nBlpmOEuG55i/4bKths5au1vP8OjxZN SJnk0eGecHUZCLcuER3fh5RIO1qil30wG+BDcTsI3yA/8ZpifBewHZBsZgKRlZsN5UG0 fxnA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=OqjmbdjPbC1OI9XXFpltnq8pIK8eUF1CEoQ2FTE9Tb4=; fh=75dLTr36I5W9FBN+Z3weG/mVZD8GM7lGUnkhMFCKvJc=; b=swFRXzypGhG/tgO4XqrYsyYtcewbS0XIrQo/w5xiwqOcbhrmgOb+KBgh2JLPBRJIPG spaYK9vghIZkStoN3dzQhf98BvPwQ8gurLCzTLhwm+dKYvX1lonJWsIqMc0CkciGVGTx HmfMjW+rai/LZOo688ugp++vjCM62yu+IQR7NkHg5WkFqXiXFXMeUDHsk43ODjOGJg04 d9ET8t7pKPo5ZlqxNYcu5bgPlhRi6FN0eyUsB3fD9m6HiCYMiObmsppfnNS+ZwcyxUK3 jRbNjkZYXDT2140sXpPp9vTTsTMHWNiPftR2vpS8CY7P4uyTMR9zIKb+3p2Rtqh89bkl Z7Zg==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=GmU4ZSGF; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-115653-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-115653-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id u19-20020a05620a121300b0078a3aafb564si5031685qkj.369.2024.03.25.04.35.18 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 25 Mar 2024 04:35:18 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-115653-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=GmU4ZSGF; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-115653-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-115653-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id B84B21C34E0A for ; Mon, 25 Mar 2024 11:35:18 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 061D9207E62; Mon, 25 Mar 2024 02:51:40 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="GmU4ZSGF" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id C5BA31514C4; Sun, 24 Mar 2024 23:05:25 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711321526; cv=none; b=XET+JkN9FqVUREw2bfXmRnog1qkXIb46Vxjq1pJue92xeTXEW4qp9Qtp0g7MhHxp1ogMyVYC6QkiEL0gXO8pdUUtkqsER7f0IY51jZgTJXxSO6jMeNRsRxUO2X/h1lbXO1UYjuErWxR4Zqy4lCsufr11ydfxyiyWc/T/pBcGO4Q= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711321526; c=relaxed/simple; bh=HLcs4XIl7/cVvj62X5G73Fk/Tnj+aiSkM7qcUcob1Ag=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=l/tEkmn9sujnaZs2RV4Xktb2JvOlENfV0vqDK8WG4NTSFg2812pFxT87trJ478CdhP1A4ntRjIvXGWV9HEW05pj1vuYxkn1w0wsbzZsTfDVr9DespWE9JriTYtEenOhRhP7bSoElQ2LCZVlalSmHmGuZbH3CVBhAd887p/BFEFg= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=GmU4ZSGF; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id F1A6BC43390; Sun, 24 Mar 2024 23:05:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1711321525; bh=HLcs4XIl7/cVvj62X5G73Fk/Tnj+aiSkM7qcUcob1Ag=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=GmU4ZSGFBenAYUBZh/NmSzOrxB0lZBEmoKQqCesvR83fX9KT/phJas0shXAPSajmm D0fbrKPgWT4KYAYJxhRdULnQkbdw5y19yYFH8JuRpz/wGlDXy7yJi1spNIuPVfASKo 8Yw7QVUrvOD7AqFNsOTn2F5oEQaHTnLI9Y4Nz+dyyLAXs6pqDpRmJFkmZHZ/sACkBo zpBuDKqD7V8KkZS+x/7KFNYFzK1oopfci9wrqi9WgXwDaMvm+54t6lf7XOnsqD5DNx LOTidQO9eCBEFiKp18nWPvUZIMgYmZr/6gqI/1K4teU0kk/o+az372DK8pCtDy81dw rNZX7Kf+wBp5g== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Peter Chiu , Shayne Chen , Felix Fietkau , Sasha Levin Subject: [PATCH 6.6 252/638] wifi: mt76: mt7996: fix TWT issues Date: Sun, 24 Mar 2024 18:54:49 -0400 Message-ID: <20240324230116.1348576-253-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240324230116.1348576-1-sashal@kernel.org> References: <20240324230116.1348576-1-sashal@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit From: Peter Chiu [ Upstream commit 5c832c228f6a7ba7e900c5296ce0fb3844bafec5 ] This patch fixes the following TWT issues: - Change table_mask to u16 to support up to 16 TWT stations - Reject TWT flows for duplicated establishment - Fix possible unaligned pointer - Remove unsupported TWT_CONTROL_WAKE_DUR_UNIT flag - The minimum TWT duration supported by mt7996 chipsets is 64. Reply with TWT_SETUP_CMD_DICTATE if the min_twt_dur is smaller than 64 Fixes: 98686cd21624 ("wifi: mt76: mt7996: add driver for MediaTek Wi-Fi 7 (802.11be) devices") Signed-off-by: Peter Chiu Signed-off-by: Shayne Chen Signed-off-by: Felix Fietkau Signed-off-by: Sasha Levin --- .../net/wireless/mediatek/mt76/mt7996/mac.c | 53 ++++++++++++++++--- .../wireless/mediatek/mt76/mt7996/mt7996.h | 3 +- 2 files changed, 47 insertions(+), 9 deletions(-) diff --git a/drivers/net/wireless/mediatek/mt76/mt7996/mac.c b/drivers/net/wireless/mediatek/mt76/mt7996/mac.c index 26d5675202ba9..b0d0ae5080e82 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7996/mac.c +++ b/drivers/net/wireless/mediatek/mt76/mt7996/mac.c @@ -2433,6 +2433,34 @@ static int mt7996_mac_check_twt_req(struct ieee80211_twt_setup *twt) return 0; } +static bool +mt7996_mac_twt_param_equal(struct mt7996_sta *msta, + struct ieee80211_twt_params *twt_agrt) +{ + u16 type = le16_to_cpu(twt_agrt->req_type); + u8 exp; + int i; + + exp = FIELD_GET(IEEE80211_TWT_REQTYPE_WAKE_INT_EXP, type); + for (i = 0; i < MT7996_MAX_STA_TWT_AGRT; i++) { + struct mt7996_twt_flow *f; + + if (!(msta->twt.flowid_mask & BIT(i))) + continue; + + f = &msta->twt.flow[i]; + if (f->duration == twt_agrt->min_twt_dur && + f->mantissa == twt_agrt->mantissa && + f->exp == exp && + f->protection == !!(type & IEEE80211_TWT_REQTYPE_PROTECTION) && + f->flowtype == !!(type & IEEE80211_TWT_REQTYPE_FLOWTYPE) && + f->trigger == !!(type & IEEE80211_TWT_REQTYPE_TRIGGER)) + return true; + } + + return false; +} + void mt7996_mac_add_twt_setup(struct ieee80211_hw *hw, struct ieee80211_sta *sta, struct ieee80211_twt_setup *twt) @@ -2444,8 +2472,7 @@ void mt7996_mac_add_twt_setup(struct ieee80211_hw *hw, enum ieee80211_twt_setup_cmd sta_setup_cmd; struct mt7996_dev *dev = mt7996_hw_dev(hw); struct mt7996_twt_flow *flow; - int flowid, table_id; - u8 exp; + u8 flowid, table_id, exp; if (mt7996_mac_check_twt_req(twt)) goto out; @@ -2458,9 +2485,19 @@ void mt7996_mac_add_twt_setup(struct ieee80211_hw *hw, if (hweight8(msta->twt.flowid_mask) == ARRAY_SIZE(msta->twt.flow)) goto unlock; + if (twt_agrt->min_twt_dur < MT7996_MIN_TWT_DUR) { + setup_cmd = TWT_SETUP_CMD_DICTATE; + twt_agrt->min_twt_dur = MT7996_MIN_TWT_DUR; + goto unlock; + } + + if (mt7996_mac_twt_param_equal(msta, twt_agrt)) + goto unlock; + flowid = ffs(~msta->twt.flowid_mask) - 1; - le16p_replace_bits(&twt_agrt->req_type, flowid, - IEEE80211_TWT_REQTYPE_FLOWID); + twt_agrt->req_type &= ~cpu_to_le16(IEEE80211_TWT_REQTYPE_FLOWID); + twt_agrt->req_type |= le16_encode_bits(flowid, + IEEE80211_TWT_REQTYPE_FLOWID); table_id = ffs(~dev->twt.table_mask) - 1; exp = FIELD_GET(IEEE80211_TWT_REQTYPE_WAKE_INT_EXP, req_type); @@ -2507,10 +2544,10 @@ void mt7996_mac_add_twt_setup(struct ieee80211_hw *hw, unlock: mutex_unlock(&dev->mt76.mutex); out: - le16p_replace_bits(&twt_agrt->req_type, setup_cmd, - IEEE80211_TWT_REQTYPE_SETUP_CMD); - twt->control = (twt->control & IEEE80211_TWT_CONTROL_WAKE_DUR_UNIT) | - (twt->control & IEEE80211_TWT_CONTROL_RX_DISABLED); + twt_agrt->req_type &= ~cpu_to_le16(IEEE80211_TWT_REQTYPE_SETUP_CMD); + twt_agrt->req_type |= + le16_encode_bits(setup_cmd, IEEE80211_TWT_REQTYPE_SETUP_CMD); + twt->control = twt->control & IEEE80211_TWT_CONTROL_RX_DISABLED; } void mt7996_mac_twt_teardown_flow(struct mt7996_dev *dev, diff --git a/drivers/net/wireless/mediatek/mt76/mt7996/mt7996.h b/drivers/net/wireless/mediatek/mt76/mt7996/mt7996.h index 7354e5cf8e674..d5ef4137290db 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7996/mt7996.h +++ b/drivers/net/wireless/mediatek/mt76/mt7996/mt7996.h @@ -43,6 +43,7 @@ #define MT7996_MAX_TWT_AGRT 16 #define MT7996_MAX_STA_TWT_AGRT 8 +#define MT7996_MIN_TWT_DUR 64 #define MT7996_MAX_QUEUE (__MT_RXQ_MAX + __MT_MCUQ_MAX + 3) /* NOTE: used to map mt76_rates. idx may change if firmware expands table */ @@ -237,7 +238,7 @@ struct mt7996_dev { struct rchan *relay_fwlog; struct { - u8 table_mask; + u16 table_mask; u8 n_agrt; } twt; -- 2.43.0