Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp2447817ybc; Wed, 20 Nov 2019 14:30:17 -0800 (PST) X-Google-Smtp-Source: APXvYqwObcgCVs7XNhtyzhUyM0ZPgl9wRfd2VMOSLk90zCiowtvJ67gBM1Bugth91p/IhzBH1LXo X-Received: by 2002:a17:906:8697:: with SMTP id g23mr8590013ejx.177.1574289016906; Wed, 20 Nov 2019 14:30:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574289016; cv=none; d=google.com; s=arc-20160816; b=as0QHWYBcp0ldwclnAeyB8SXHf2oGsmbakj8BC6AR3WXgEKbpJpuxM+Bj/FxjF6CEU BLOkBV8Ec8RGIk/wQxn4tEjn6ZVAw5KB649yJvRYniFTr01ui+dS08MSJWhuIMjT1wLq 0QcFePCkQ1jm1n8dM0YuxVjjV5A4i05EkQsChUEr/xkh5zQIAPzG1I87SbPwTHHCPjaB JKr42v0Ec6QhTzp/1KF2zyiO+yDbvXUvlaG2thx2/pLJW/s6N00Icsl3y85u+MJx8cRB xpnwUkPseIQyQtDBDlaNj1fwHKW0MKsvyUf6QHnIdQtycSdBg73rTzYdpCHI2GmuxP8h 3gWQ== 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=qV6qMtbhbFX/o5Dnzlj9H/OxZbBpAvQX4FIS/7e8YyA=; b=gQa4lMrNfHH+Q3L6wuM2K1k/4hG+xNJGqXt8Z7qWlz3/a8GWLUTqb1oDLsZShCMSEr nJsEH6IHIHNyJaF1mEBXkNPtwlSD75Fc3rS5dITun8+DDknXq4JHkHv5CCisEwSwuO2Q TrlVt4DGhtMCIJv+oIPr2jdSZA6eJzbpGzI00eRFBU1qhQaIgLfj19piCo7QXK4fkpEi v1SjBmBXu1/qWNmJqz3H/h1EEHoUYTrTxcEwtbUCr4Q9V2uvUC3tXgpLVVByVuboTxfw xDv33CfB0YrrTwsRdYTUQIDLusw9Cfv3Y9UZOzgWf0jRIsSGLcpWgfuv64ZH54Z+l/BD 54Kg== 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 e24si644656ede.392.2019.11.20.14.29.41; Wed, 20 Nov 2019 14:30:16 -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 S1726880AbfKTW2o (ORCPT + 99 others); Wed, 20 Nov 2019 17:28:44 -0500 Received: from smail.rz.tu-ilmenau.de ([141.24.186.67]:49977 "EHLO smail.rz.tu-ilmenau.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726836AbfKTW2m (ORCPT ); Wed, 20 Nov 2019 17:28:42 -0500 Received: from localhost.localdomain (unknown [141.24.207.101]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smail.rz.tu-ilmenau.de (Postfix) with ESMTPSA id EF312580082; Wed, 20 Nov 2019 23:28:39 +0100 (CET) From: Markus Theil To: nbd@nbd.name Cc: linux-wireless@vger.kernel.org, lorenzo.bianconi@redhat.com, Stanislaw Gruszka , Markus Theil Subject: [PATCH v7 5/5] mt76: mt76x02: add channel switch support for usb interfaces Date: Wed, 20 Nov 2019 23:28:26 +0100 Message-Id: <20191120222826.14871-6-markus.theil@tu-ilmenau.de> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191120222826.14871-1-markus.theil@tu-ilmenau.de> References: <20191120222826.14871-1-markus.theil@tu-ilmenau.de> 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 This patch enables channel switch support on mt76 usb interfaces. Signed-off-by: Markus Theil --- drivers/net/wireless/mediatek/mt76/mt76x02_usb_core.c | 7 +++++++ drivers/net/wireless/mediatek/mt76/mt76x02_util.c | 2 +- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/drivers/net/wireless/mediatek/mt76/mt76x02_usb_core.c b/drivers/net/wireless/mediatek/mt76/mt76x02_usb_core.c index 0b3437a30b02..600938a4b0c9 100644 --- a/drivers/net/wireless/mediatek/mt76/mt76x02_usb_core.c +++ b/drivers/net/wireless/mediatek/mt76/mt76x02_usb_core.c @@ -211,6 +211,12 @@ static void mt76x02u_pre_tbtt_work(struct work_struct *work) /* Prevent corrupt transmissions during update */ mt76_set(dev, MT_BCN_BYPASS_MASK, 0xffff); + mt76_csa_check(&dev->mt76); + if (dev->mt76.csa_complete) { + mt76_csa_finish(&dev->mt76); + goto out; + } + ieee80211_iterate_active_interfaces(mt76_hw(dev), IEEE80211_IFACE_ITER_RESUME_ALL, mt76x02_update_beacon_iter, dev); @@ -225,6 +231,7 @@ static void mt76x02u_pre_tbtt_work(struct work_struct *work) mt76x02_mac_set_beacon_finish(dev); +out: mt76x02u_restart_pre_tbtt_timer(dev); } diff --git a/drivers/net/wireless/mediatek/mt76/mt76x02_util.c b/drivers/net/wireless/mediatek/mt76/mt76x02_util.c index 0960fc56b672..df381443cb52 100644 --- a/drivers/net/wireless/mediatek/mt76/mt76x02_util.c +++ b/drivers/net/wireless/mediatek/mt76/mt76x02_util.c @@ -166,7 +166,6 @@ void mt76x02_init_device(struct mt76x02_dev *dev) wiphy->reg_notifier = mt76x02_regd_notifier; wiphy->iface_combinations = mt76x02_if_comb; wiphy->n_iface_combinations = ARRAY_SIZE(mt76x02_if_comb); - wiphy->flags |= WIPHY_FLAG_HAS_CHANNEL_SWITCH; /* init led callbacks */ if (IS_ENABLED(CONFIG_MT76_LEDS)) { @@ -176,6 +175,7 @@ void mt76x02_init_device(struct mt76x02_dev *dev) } } + wiphy->flags |= WIPHY_FLAG_HAS_CHANNEL_SWITCH; wiphy_ext_feature_set(wiphy, NL80211_EXT_FEATURE_VHT_IBSS); hw->sta_data_size = sizeof(struct mt76x02_sta); -- 2.24.0