Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp4823946ybl; Tue, 4 Feb 2020 02:37:57 -0800 (PST) X-Google-Smtp-Source: APXvYqxfqr+5klVvPyVR1NdKtS25kRAPRzs6Z5YUuXCLOhubbzFYnE3Y0MIRGCDayESvgftsgMRX X-Received: by 2002:aca:c74e:: with SMTP id x75mr3098593oif.140.1580812676926; Tue, 04 Feb 2020 02:37:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580812676; cv=none; d=google.com; s=arc-20160816; b=bxqs3S+1oaneH1Yxa7OfqCztVJjfsYjPSAEyaajwVkHclddrS++OTf5rIFmoV5MeNx Ab1uUBISTHKVRMcE9gXhaU/7kgyy8yELby44nY3zgQ1aZHSmS2ywcY0LfdbeqrbBhxg/ YYB2udsPAAkwUzgedHFG1JE/MRZFutx8+ybFzzOvtLBfHSjvgA0ZeK3l7h6XNm0Whu/X aFsjB1iFQdeAiEs3FzZEh5eBdwiUi2g07rYD3nGpEhmFNW4jDzhStwAivipM2C/ft9zR HhkXIj/bBw4KZx1OLd7i6HbTGEgPEp4+zgU1q3oQmSKWlOnL3p0BPbk5lGFyGyGlPl0q 4BgQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=tPIiBmBPF1hLzW5/rva6zY52SPxj06xu3V/RGr1vYN4=; b=zjEWfpnaegPbwGidVfaNldzwGHz9WjvmoElki1iC3cse9I2SxOuJvP0RDpCyHeyvH6 WDvmLxn/r2Vbv8A9VQysx9bJzzhJ9H55q+ga/OLO9A4ebmbiFZxpBmBJfNo9VqGqORyV UGArSRpcIi2XDen6WoaIw8XnEanAPZjsP5yGgGmfamkX68CTOa7cb45YfalqfvJJvUnp +wm+5cVvT3HY8Ci8AuAiBZIxShp3O+EdquGNZYS219OUn7+9idRvDDK3ZhN1S0DM3czM Yq1RPDQ3TuANkfTPUHxrdZXWAWewqmp5BNanuW5+ViHLDyP6eNVswJo2u/9lBLNykxM3 G6jQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m7si11879572otk.73.2020.02.04.02.37.45; Tue, 04 Feb 2020 02:37:56 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727148AbgBDKfX (ORCPT + 99 others); Tue, 4 Feb 2020 05:35:23 -0500 Received: from nbd.name ([46.4.11.11]:51970 "EHLO nbd.name" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726364AbgBDKfX (ORCPT ); Tue, 4 Feb 2020 05:35:23 -0500 Received: from [149.224.158.146] (helo=bertha.fritz.box) by ds12 with esmtpa (Exim 4.89) (envelope-from ) id 1iyvY8-0000L5-Fo; Tue, 04 Feb 2020 11:35:20 +0100 From: John Crispin To: Johannes Berg , Kalle Valo Cc: linux-wireless@vger.kernel.org, ath11k@lists.infradead.org, Miles Hu , John Crispin Subject: [PATCH V2 2/3] mac80211: add support for setting fixed HE rate/gi/ltf Date: Tue, 4 Feb 2020 11:35:13 +0100 Message-Id: <20200204103514.18111-2-john@phrozen.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200204103514.18111-1-john@phrozen.org> References: <20200204103514.18111-1-john@phrozen.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org From: Miles Hu With nl80211 now able to receive fixed HE rate/gi/ltf settings we want to propagate these further down the stack into the mac80211 drivers. This patch copies the values into the sdata struct. Signed-off-by: John Crispin Signed-off-by: Miles Hu --- net/mac80211/cfg.c | 11 +++++++++++ net/mac80211/ieee80211_i.h | 3 +++ 2 files changed, 14 insertions(+) diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c index a11bd1669c13..5bf5f4754241 100644 --- a/net/mac80211/cfg.c +++ b/net/mac80211/cfg.c @@ -2900,9 +2900,13 @@ static int ieee80211_set_bitrate_mask(struct wiphy *wiphy, memcpy(sdata->rc_rateidx_vht_mcs_mask[i], mask->control[i].vht_mcs, sizeof(mask->control[i].vht_mcs)); + memcpy(sdata->rc_rateidx_he_mcs_mask[i], + mask->control[i].he_mcs, + sizeof(mask->control[i].he_mcs)); sdata->rc_has_mcs_mask[i] = false; sdata->rc_has_vht_mcs_mask[i] = false; + sdata->rc_has_he_mcs_mask[i] = false; if (!sband) continue; @@ -2919,6 +2923,13 @@ static int ieee80211_set_bitrate_mask(struct wiphy *wiphy, break; } } + + for (j = 0; j < NL80211_HE_NSS_MAX; j++) { + if (~sdata->rc_rateidx_he_mcs_mask[i][j]) { + sdata->rc_has_he_mcs_mask[i] = true; + break; + } + } } return 0; diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h index e3cf24cb4615..13868bdca772 100644 --- a/net/mac80211/ieee80211_i.h +++ b/net/mac80211/ieee80211_i.h @@ -963,6 +963,9 @@ struct ieee80211_sub_if_data { bool rc_has_vht_mcs_mask[NUM_NL80211_BANDS]; u16 rc_rateidx_vht_mcs_mask[NUM_NL80211_BANDS][NL80211_VHT_NSS_MAX]; + bool rc_has_he_mcs_mask[NUM_NL80211_BANDS]; + u16 rc_rateidx_he_mcs_mask[NUM_NL80211_BANDS][NL80211_HE_NSS_MAX]; + union { struct ieee80211_if_ap ap; struct ieee80211_if_wds wds; -- 2.20.1