Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2015832pxj; Wed, 19 May 2021 20:49:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxTrw628e5ByH/p3a09Vjd8y//6pc83gTgJSRebddF79ocUHnogTH6dyMFtNN3dFotrzvlf X-Received: by 2002:a92:c046:: with SMTP id o6mr2810270ilf.296.1621482544727; Wed, 19 May 2021 20:49:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621482544; cv=none; d=google.com; s=arc-20160816; b=mYDWJ5TCzxmVi/LqfN3s+NC3wA7JpL5gxGnnNFIIpswD9U3h9Az2NY3Uw6UCG56no4 e+xHUqD6fHn3UjXTq6uXdSJrT0n/HwifLkvSiviFWqzreMsIAaNdpUGoyQdHmCWF33r5 ImJLtMQ8CLT/pXqG3ly2b9EZbRv9d6io4CdNuyYCsH/XeTUDhXoPDfpQ4QGfUfo8ZnpL hARrpFu6yuvBOK8x/d4BUwSwxS3pE0n/XUMWcBS6gzBKy8O7Yn4x8hy8yt5Mr8+s17DI MkjF8awZEHuAP0GYfvLNN1sMzOPHXcK9NnH3VKhWgTUUBr1JlowU6i0RyGjxQmI0JZDu bFzw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from; bh=1yx1Z6GHRGn8lzm4p2Wpj739l0bI0zyho/6269OT/EQ=; b=bDh2Y28/HDgx/SV6UbBryWaTGUPGfBqofknKiV5V56dYpHkckQwb6PCykBYSaK72ax tLEibjJW4pT0vn6RyRDSVmyXY83E0CaOiG2aacG+kaVVfHLW5ylvCznelX7qFZBcU42G sslKsxcy6rlrrm9G2didWZUPQ3HoJfzJZlxNeuwMYJ64edbIMAGBqdK+opP/2lw0PLNX 6vyHkXKvCbLs1mx5ylYO6Xh7T7ZriFjPHIYK5TgzxzjZpvEmXb7Vallxfa0q5uwQ3e/v zry3EySgW9n/qiHF/EvNKu5nx8gP22SIfX5m0G93UBmjCtJCPPpgNl47YF6aBukkD+K9 DtRQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f2si1457011ioz.41.2021.05.19.20.48.50; Wed, 19 May 2021 20:49:04 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230338AbhETDsS (ORCPT + 99 others); Wed, 19 May 2021 23:48:18 -0400 Received: from mailgw01.mediatek.com ([210.61.82.183]:41011 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S229554AbhETDsS (ORCPT ); Wed, 19 May 2021 23:48:18 -0400 X-UUID: f836aa21dde044bb930e82c11c20b709-20210520 X-UUID: f836aa21dde044bb930e82c11c20b709-20210520 Received: from mtkcas06.mediatek.inc [(172.21.101.30)] by mailgw01.mediatek.com (envelope-from ) (Generic MTA with TLSv1.2 ECDHE-RSA-AES256-SHA384 256/256) with ESMTP id 397042348; Thu, 20 May 2021 11:46:53 +0800 Received: from mtkcas07.mediatek.inc (172.21.101.84) by mtkmbs06n1.mediatek.inc (172.21.101.129) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Thu, 20 May 2021 11:46:52 +0800 Received: from mtkswgap22.mediatek.inc (172.21.77.33) by mtkcas07.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1497.2 via Frontend Transport; Thu, 20 May 2021 11:46:52 +0800 From: To: , CC: , , , , , , , , , , , , , , , , Lorenzo Bianconi Subject: [PATCH 4/7] mt76: mt7921: avoid unnecessary consecutive WiFi resets Date: Thu, 20 May 2021 11:46:38 +0800 Message-ID: <1621482401-29025-4-git-send-email-sean.wang@mediatek.com> X-Mailer: git-send-email 1.7.9.5 In-Reply-To: <1621482401-29025-1-git-send-email-sean.wang@mediatek.com> References: <1621482401-29025-1-git-send-email-sean.wang@mediatek.com> MIME-Version: 1.0 Content-Type: text/plain X-MTK: N Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org From: Sean Wang Avoid unnecessary consecutive WiFi resets by dropping reset request when reset work is working. Co-developed-by: Lorenzo Bianconi Signed-off-by: Lorenzo Bianconi Signed-off-by: Sean Wang --- drivers/net/wireless/mediatek/mt76/mt7921/mac.c | 5 ++++- drivers/net/wireless/mediatek/mt76/mt7921/mt7921.h | 1 + 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/drivers/net/wireless/mediatek/mt76/mt7921/mac.c b/drivers/net/wireless/mediatek/mt76/mt7921/mac.c index ebd365ceb70d..fdc69f306f7e 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7921/mac.c +++ b/drivers/net/wireless/mediatek/mt76/mt7921/mac.c @@ -1312,6 +1312,7 @@ void mt7921_mac_reset_work(struct work_struct *work) int i; dev_err(dev->mt76.dev, "chip reset\n"); + dev->hw_full_reset = true; ieee80211_stop_queues(hw); cancel_delayed_work_sync(&dev->mphy.mac_work); @@ -1338,6 +1339,7 @@ void mt7921_mac_reset_work(struct work_struct *work) ieee80211_scan_completed(dev->mphy.hw, &info); } + dev->hw_full_reset = false; ieee80211_wake_queues(hw); ieee80211_iterate_active_interfaces(hw, IEEE80211_IFACE_ITER_RESUME_ALL, @@ -1349,7 +1351,8 @@ void mt7921_reset(struct mt76_dev *mdev) { struct mt7921_dev *dev = container_of(mdev, struct mt7921_dev, mt76); - queue_work(dev->mt76.wq, &dev->reset_work); + if (!dev->hw_full_reset) + queue_work(dev->mt76.wq, &dev->reset_work); } static void diff --git a/drivers/net/wireless/mediatek/mt76/mt7921/mt7921.h b/drivers/net/wireless/mediatek/mt76/mt7921/mt7921.h index 03bcb210c357..710ad242fd53 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7921/mt7921.h +++ b/drivers/net/wireless/mediatek/mt76/mt7921/mt7921.h @@ -156,6 +156,7 @@ struct mt7921_dev { u16 chainmask; struct work_struct reset_work; + bool hw_full_reset; struct list_head sta_poll_list; spinlock_t sta_poll_lock; -- 2.25.1