Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp398596pxb; Wed, 24 Feb 2021 05:21:51 -0800 (PST) X-Google-Smtp-Source: ABdhPJw5UySNTdd64MzHVI6KcI22dXqFn/OxPlIfSvo6Htm9aATHkEiZoFT6n/xp8oP7HwP9nNtB X-Received: by 2002:a17:906:a2c6:: with SMTP id by6mr2864521ejb.493.1614172911527; Wed, 24 Feb 2021 05:21:51 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614172911; cv=none; d=google.com; s=arc-20160816; b=IcaYMau9CNQuJaU7nKSFLmbNTKMnb9ypV8d2y1tzuo5NG1kx+5D6gyhUEaUBRUM8QG ZpuUk6K+zLshnsVVOhC486QY+d36vo0qeBtsZha06harG7bS3QO/CMy4HxCUJJ41OSuj 18tV0NrllYHvmybC7ViellOgEt9ImfW5FqONx01Nu5hXjCe2m3hg6d0+8EFkk544I22f CahtzDVu7zw61dcyxlU6W/5za2BLU1jaXvIUIoXkdptQ8CGQgEJ9BAsrX4dK4l9Ego3/ TwZxv2/n/eLFuoHrB5d8JtKyw0aU4glL2xidkHbFlYsBpZi6iuhVI1N6zS9R7hTox0od cenQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=QpDL6LaDKyI2CmBSq5vl4V4SAb2PLXSXSHUcyIlU0Bc=; b=ID8bRWv9PJgIqi//zpFmJ8BpsGJeVyk3faicwWQ3k2HUmjZGwNj+lgmYiCaDI40D+k ALWxQYDavxFNHJTcqbX7najgqeYSCVL0XLYxAJ9E2AusZwasJ4UQVk6G7u7hleGMUp13 lCp2MWbN9XP/gtseQkDKcmyzPmX7motubCs1gHoBxgGP6o3ttwCGrPj1YRyw9pvqF3oB dg8H5W69WBSLZF1C91QgRghl9TiTW4bfjd4+yVEJdBim9FtqbJuQnndO3hWmtM1CgNn1 viYSYY45krhYAV/PPLsncNu8YOcvfvIxO4A3g5bMkR8oPNyDa0FSVDOU6Xbt8gYKWDZf avmQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=DBm3FVTz; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t21si1118756edq.109.2021.02.24.05.21.28; Wed, 24 Feb 2021 05:21:51 -0800 (PST) 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; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=DBm3FVTz; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235192AbhBXMw0 (ORCPT + 99 others); Wed, 24 Feb 2021 07:52:26 -0500 Received: from mail.kernel.org ([198.145.29.99]:50210 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235132AbhBXMwA (ORCPT ); Wed, 24 Feb 2021 07:52:00 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 9C14C64F00; Wed, 24 Feb 2021 12:50:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1614171041; bh=pB60cSJi0Ze+knx8uReireMiJFSGZmwLAtf5XiBC5Ho=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=DBm3FVTzbKlE10zv1RyDPkGIY8oGEj4JFXJplMVcRiHaraExwd2GQ+J78+PeR06JT 1NP4yF6z9rxugvDKwPkWET7O8llB5ndj4TduEUu7/W2irN0kqalcwqVHcyoIjyBN5V z6vg/1YBPOHv6KDAW5aDxatPIKaPUvd9S4KOWHmItxz/a2nWku6mN1ytZ1zOglhdZ2 fOlBNIQ0+XBzHasQ4olyFPjfKECMWRoSVNT+oQuJ+1zO46YfkJbj6lWGSHKFUx2llN ZjvD/Xg/bWr8PyBiHVG1mCNTDPQUU+v26bqkAskWF0kj7qni/oqMkgj/gn33MBOTga 6iw7RSe/TaIrg== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Ryder Lee , Bo Jiao , Felix Fietkau , Sasha Levin , linux-wireless@vger.kernel.org, netdev@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org Subject: [PATCH AUTOSEL 5.11 11/67] mt76: mt7915: reset token when mac_reset happens Date: Wed, 24 Feb 2021 07:49:29 -0500 Message-Id: <20210224125026.481804-11-sashal@kernel.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20210224125026.481804-1-sashal@kernel.org> References: <20210224125026.481804-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org From: Ryder Lee [ Upstream commit f285dfb98562e8380101095d168910df1d07d8be ] Reset buffering token in mt7915_mac_reset_work() to avoid possible leakege, which leads to Tx stop after mac reset. Tested-by: Bo Jiao Signed-off-by: Ryder Lee Signed-off-by: Felix Fietkau Signed-off-by: Sasha Levin --- .../net/wireless/mediatek/mt76/mt7915/init.c | 18 +------------- .../net/wireless/mediatek/mt76/mt7915/mac.c | 24 +++++++++++++++++++ .../wireless/mediatek/mt76/mt7915/mt7915.h | 1 + 3 files changed, 26 insertions(+), 17 deletions(-) diff --git a/drivers/net/wireless/mediatek/mt76/mt7915/init.c b/drivers/net/wireless/mediatek/mt76/mt7915/init.c index 102a8f14c22d4..2ec18aaa82807 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7915/init.c +++ b/drivers/net/wireless/mediatek/mt76/mt7915/init.c @@ -672,28 +672,12 @@ int mt7915_register_device(struct mt7915_dev *dev) void mt7915_unregister_device(struct mt7915_dev *dev) { - struct mt76_txwi_cache *txwi; - int id; - mt7915_unregister_ext_phy(dev); mt76_unregister_device(&dev->mt76); mt7915_mcu_exit(dev); mt7915_dma_cleanup(dev); - spin_lock_bh(&dev->token_lock); - idr_for_each_entry(&dev->token, txwi, id) { - mt7915_txp_skb_unmap(&dev->mt76, txwi); - if (txwi->skb) { - struct ieee80211_hw *hw; - - hw = mt76_tx_status_get_hw(&dev->mt76, txwi->skb); - ieee80211_free_txskb(hw, txwi->skb); - } - mt76_put_txwi(&dev->mt76, txwi); - dev->token_count--; - } - spin_unlock_bh(&dev->token_lock); - idr_destroy(&dev->token); + mt7915_tx_token_put(dev); mt76_free_device(&dev->mt76); } diff --git a/drivers/net/wireless/mediatek/mt76/mt7915/mac.c b/drivers/net/wireless/mediatek/mt76/mt7915/mac.c index f504eeb221f95..1b4d65310b887 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7915/mac.c +++ b/drivers/net/wireless/mediatek/mt76/mt7915/mac.c @@ -1485,6 +1485,27 @@ mt7915_dma_reset(struct mt7915_phy *phy) MT_WFDMA1_GLO_CFG_TX_DMA_EN | MT_WFDMA1_GLO_CFG_RX_DMA_EN); } +void mt7915_tx_token_put(struct mt7915_dev *dev) +{ + struct mt76_txwi_cache *txwi; + int id; + + spin_lock_bh(&dev->token_lock); + idr_for_each_entry(&dev->token, txwi, id) { + mt7915_txp_skb_unmap(&dev->mt76, txwi); + if (txwi->skb) { + struct ieee80211_hw *hw; + + hw = mt76_tx_status_get_hw(&dev->mt76, txwi->skb); + ieee80211_free_txskb(hw, txwi->skb); + } + mt76_put_txwi(&dev->mt76, txwi); + dev->token_count--; + } + spin_unlock_bh(&dev->token_lock); + idr_destroy(&dev->token); +} + /* system error recovery */ void mt7915_mac_reset_work(struct work_struct *work) { @@ -1525,6 +1546,9 @@ void mt7915_mac_reset_work(struct work_struct *work) mt76_wr(dev, MT_MCU_INT_EVENT, MT_MCU_INT_EVENT_DMA_STOPPED); + mt7915_tx_token_put(dev); + idr_init(&dev->token); + if (mt7915_wait_reset_state(dev, MT_MCU_CMD_RESET_DONE)) { mt7915_dma_reset(&dev->phy); diff --git a/drivers/net/wireless/mediatek/mt76/mt7915/mt7915.h b/drivers/net/wireless/mediatek/mt76/mt7915/mt7915.h index 0339abf360d3f..94bed8a3a050a 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7915/mt7915.h +++ b/drivers/net/wireless/mediatek/mt76/mt7915/mt7915.h @@ -463,6 +463,7 @@ int mt7915_tx_prepare_skb(struct mt76_dev *mdev, void *txwi_ptr, struct ieee80211_sta *sta, struct mt76_tx_info *tx_info); void mt7915_tx_complete_skb(struct mt76_dev *mdev, struct mt76_queue_entry *e); +void mt7915_tx_token_put(struct mt7915_dev *dev); int mt7915_init_tx_queues(struct mt7915_phy *phy, int idx, int n_desc); void mt7915_queue_rx_skb(struct mt76_dev *mdev, enum mt76_rxq_id q, struct sk_buff *skb); -- 2.27.0