Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp807280ybl; Fri, 6 Dec 2019 06:34:48 -0800 (PST) X-Google-Smtp-Source: APXvYqx7IW2iPbBzHV7v+W78ASq64kW1QZ7ukT45GfUBCZgYLjk5EPZJwicORWqBUBWI9Wk2Ps6J X-Received: by 2002:a05:6808:a83:: with SMTP id q3mr12933857oij.0.1575642888059; Fri, 06 Dec 2019 06:34:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1575642888; cv=none; d=google.com; s=arc-20160816; b=mQsFC7J3a4J88d6SslReS4c8Q2pMYcay1Vh7dAcSrDHLqAzUzSqBQIRKRx8HEHhojJ q1yAV0YhSwjM6BCWu1Q225CeeHq5OtTgYUnqfUf4aOzbDNl5Ym+ll1mS9h+dwXv4RSXB Agp+MnTYigWQxlbpJn3QNg2dRJpU02C+y0DvlzHL1Qmjwpd4ZhLc2kD3nZaXRAurnz6i RqXPTHVQgSNP6llNdPXjxO5qL0cVs8F3BaSkjWu4sDzsKfiL6gq/tsXeZrmtTA8HPROc 9G8J+BOrCIeE/CHxNx1SVkgRKEn8Toj8Qi3u5j4UQCvQHGsFe4VCgey2I5ZBaIUVcCwQ FIBA== 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=ccqlKaeI7xQ0LU+HvWFvaXCNUSVQZ3YcQkV0YSF71KI=; b=P3C0ZrOy23lCf2hztsXBKTXu2LNfWXYW5SYfAaUpAiFXGZ5HXqoobgqNvo1cPd3aNf 8tfAvaeVaqgrjYeHOwC8Iow5HKU15QEkmAJE+WbK9clpLif8qdyW7k1YZ1GM7ilHlusI qeV84aNE6mo7RK7rIabIRJpYZ7we8GpS/ctHliK6wFkkIe9GDNYzHs/uD9qsr68DD0Wz VBE6SRZnUuFbNVixh0cfaom207t+Sdy4hl4OdH184mfnvVVOv3z+QCdqoUuRuDNhYxZh y1qQr09yUlTJo8RXQkCDzDGgXkbqP4jRMop2/UvLweDb4aGDtPXe+CmjxVSamCzQnunb OLJg== 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 185si4626544oie.52.2019.12.06.06.34.36; Fri, 06 Dec 2019 06:34:48 -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 S1726322AbfLFOeI (ORCPT + 99 others); Fri, 6 Dec 2019 09:34:08 -0500 Received: from nbd.name ([46.4.11.11]:36412 "EHLO nbd.name" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726244AbfLFOeI (ORCPT ); Fri, 6 Dec 2019 09:34:08 -0500 Received: from tmo-101-57.customers.d1-online.com ([80.187.101.57] helo=bertha.datto.lan) by ds12 with esmtpa (Exim 4.89) (envelope-from ) id 1idEgG-0004Lm-4R; Fri, 06 Dec 2019 15:34:04 +0100 From: John Crispin To: Johannes Berg , Kalle Valo Cc: linux-wireless@vger.kernel.org, ath11k@lists.infradead.org, John Crispin Subject: [PATCH 3/7] mac80211: add handling for BSS color Date: Fri, 6 Dec 2019 15:33:57 +0100 Message-Id: <20191206143401.4080-3-john@phrozen.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20191206143401.4080-1-john@phrozen.org> References: <20191206143401.4080-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 It is now possible to propagate BSS color settings into the subsystem. Lets make mac80211 also handle them so that we can send them further down the stack into the drivers. We continue to populate the old bss_color field until all users have been updated to use the new he_bss_color struct. Signed-off-by: John Crispin --- include/net/mac80211.h | 2 ++ net/mac80211/cfg.c | 5 ++++- net/mac80211/mlme.c | 8 ++++++++ 3 files changed, 14 insertions(+), 1 deletion(-) diff --git a/include/net/mac80211.h b/include/net/mac80211.h index 16a5525ddab1..994686443553 100644 --- a/include/net/mac80211.h +++ b/include/net/mac80211.h @@ -316,6 +316,7 @@ struct ieee80211_vif_chanctx_switch { * functionality changed for this BSS (AP mode). * @BSS_CHANGED_TWT: TWT status changed * @BSS_CHANGED_HE_OBSS_PD: OBSS Packet Detection status changed. + * @BSS_CHANGED_HE_BSS_COLOR: BSS Color has changed * */ enum ieee80211_bss_change { @@ -348,6 +349,7 @@ enum ieee80211_bss_change { BSS_CHANGED_FTM_RESPONDER = 1<<26, BSS_CHANGED_TWT = 1<<27, BSS_CHANGED_HE_OBSS_PD = 1<<28, + BSS_CHANGED_HE_BSS_COLOR = 1<<29, /* when adding here, make sure to change ieee80211_reconfig */ }; diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c index ed56b0c6fe19..e109b47c4219 100644 --- a/net/mac80211/cfg.c +++ b/net/mac80211/cfg.c @@ -981,7 +981,8 @@ static int ieee80211_start_ap(struct wiphy *wiphy, struct net_device *dev, BSS_CHANGED_P2P_PS | BSS_CHANGED_TXPOWER | BSS_CHANGED_TWT | - BSS_CHANGED_HE_OBSS_PD; + BSS_CHANGED_HE_OBSS_PD | + BSS_CHANGED_HE_BSS_COLOR; int err; int prev_beacon_int; @@ -1054,6 +1055,8 @@ static int ieee80211_start_ap(struct wiphy *wiphy, struct net_device *dev, sdata->vif.bss_conf.twt_responder = params->twt_responder; memcpy(&sdata->vif.bss_conf.he_obss_pd, ¶ms->he_obss_pd, sizeof(struct ieee80211_he_obss_pd)); + memcpy(&sdata->vif.bss_conf.he_bss_color, ¶ms->he_bss_color, + sizeof(struct ieee80211_he_bss_color)); sdata->vif.bss_conf.ssid_len = params->ssid_len; if (params->ssid_len) diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c index 641876982ab9..319d43f4082b 100644 --- a/net/mac80211/mlme.c +++ b/net/mac80211/mlme.c @@ -3372,8 +3372,16 @@ static bool ieee80211_assoc_success(struct ieee80211_sub_if_data *sdata, if (bss_conf->he_support) { bss_conf->bss_color = + bss_conf->he_bss_color.color = le32_get_bits(elems.he_operation->he_oper_params, IEEE80211_HE_OPERATION_BSS_COLOR_MASK); + bss_conf->he_bss_color.partial = + le32_get_bits(elems.he_operation->he_oper_params, + IEEE80211_HE_OPERATION_PARTIAL_BSS_COLOR); + bss_conf->he_bss_color.disabled = + le32_get_bits(elems.he_operation->he_oper_params, + IEEE80211_HE_OPERATION_BSS_COLOR_DISABLED); + changed |= BSS_CHANGED_HE_BSS_COLOR; bss_conf->htc_trig_based_pkt_ext = le32_get_bits(elems.he_operation->he_oper_params, -- 2.20.1