Received: by 2002:a05:6a10:a852:0:0:0:0 with SMTP id d18csp616427pxy; Wed, 5 May 2021 09:36:51 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzftGRG5YloQnWW+xHK6/+vTsShBje/IJx/REJrRNW3RZPH6LQat9+8fKMzq/lkNqs7bnu1 X-Received: by 2002:a17:906:2746:: with SMTP id a6mr28099804ejd.265.1620232611144; Wed, 05 May 2021 09:36:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620232611; cv=none; d=google.com; s=arc-20160816; b=oJ2QShFijiqX4Lr8eEod0gO0kT402b2Hx8N5tqXkQrejPsU7S+83zxXh01LnXqhCcr G8I26eKCawzpmzWZbzl9W6Zy9h7lz7Zql0QjHjytj+WjiEtQ5brzMl/vOtTUiTiaGwX/ LxUS1HzpMNEql1E5Elwv0yxX2wMUw1e9KoL6di0BEfnVVjToCQg7/8Xou2vRE7udpUmA TcqNI1u+zP3+dc6YWWREwyrQdC/ZrX8BZ99XC3YmgDNSlo9xLFAtbxLpK1eT8uwK1gQa WCSPa7QSvYNw962y6Zpvl/b3OvZzOQ+N+6j2pH9oz15IgUUrBQfbViBVVesm8ROEYNpS z6CA== 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=A8DL5kpGlzYZ5cx0PTHhTnKY3kakwlmLBR7anLLR1rY=; b=lGZOqNEChvPNZQrKcXRw0kBGnbLgFQRqiooMVBc7zdIRYmcV5p/mnmwyvexbc+4d11 kBKZegXkuxYmLu+NXYxuQJmXZapNOmCWobcyqDIwlj1oRjVKsb1eeHQVIc0xj1B5Vf65 5CYi/WJNHhY6ZK37xHkLw+IYA/ozRtgv5YuX4GgX7IWr9MKhKy2+wc9iVCr8jCS4He4v g1V9GtZimhja8lZYwm0FYjVaS9dm5JXW/MfAH2WOKvl8AwcKozPRvUVREbdWYLRwLdHA rCDLdmBTAEPzDjY3PkmsRtbTLDNnWSEzyY7CRMCaPjdrPmcmFH+nbAqTVMvRrrWsCTE5 +kvQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=B8n07rh8; 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 g18si14515156edp.374.2021.05.05.09.36.27; Wed, 05 May 2021 09:36:51 -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; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=B8n07rh8; 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 S235044AbhEEQgu (ORCPT + 99 others); Wed, 5 May 2021 12:36:50 -0400 Received: from mail.kernel.org ([198.145.29.99]:52900 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234744AbhEEQew (ORCPT ); Wed, 5 May 2021 12:34:52 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 6978861436; Wed, 5 May 2021 16:32:49 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1620232370; bh=a6ayTyQFJO7D2HeeSEFr9P03nh0rXIxRKuFcNLp5WPQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=B8n07rh88O1ehnOa/M8LSbDEZrIollaq+DzEfHYl29dWdQS/yG3v3JkqEYimcZg82 nzeOeDMvw2r+T4KUkqrJLz0BBdByoTrIyqbl6V7yOeeJi1Jq0yc83ql2rTz2ylSuEx fqc6E4pS2QP7m19G2iSUMXz2tokYdAHe8B/bSBC10cWGq/yyTQ+oER63dtFErccPv6 s1i61Ld5mVQWfTcWO6YE/tJwlZSMCdsrHGZ4MoDP7Z4tXUC2FDap6TBiXlmxPrqcyz y3/+87b7ubol0iMzxPBzY8L9C3GbAMN2+2wwfIjw1GIrdwLuiyZ7VRHfmfBmccEGUY pYIdixf0wXYFw== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: 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.12 061/116] mt76: mt7915: fix key set/delete issue Date: Wed, 5 May 2021 12:30:29 -0400 Message-Id: <20210505163125.3460440-61-sashal@kernel.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210505163125.3460440-1-sashal@kernel.org> References: <20210505163125.3460440-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: Felix Fietkau [ Upstream commit 1da4fd48d28436f8b690cdc2879603dede6d8355 ] Deleting a key with the previous key index deletes the current key Rework the code to better keep track of multiple keys and check for the key index before deleting the current key Signed-off-by: Felix Fietkau Signed-off-by: Sasha Levin --- .../net/wireless/mediatek/mt76/mt7915/main.c | 25 +++++++++++++------ 1 file changed, 18 insertions(+), 7 deletions(-) diff --git a/drivers/net/wireless/mediatek/mt76/mt7915/main.c b/drivers/net/wireless/mediatek/mt76/mt7915/main.c index d4969b2e1ffb..33590ff6e281 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7915/main.c +++ b/drivers/net/wireless/mediatek/mt76/mt7915/main.c @@ -317,7 +317,9 @@ static int mt7915_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, struct mt7915_sta *msta = sta ? (struct mt7915_sta *)sta->drv_priv : &mvif->sta; struct mt76_wcid *wcid = &msta->wcid; + u8 *wcid_keyidx = &wcid->hw_key_idx; int idx = key->keyidx; + int err = 0; /* The hardware does not support per-STA RX GTK, fallback * to software mode for these. @@ -332,6 +334,7 @@ static int mt7915_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, /* fall back to sw encryption for unsupported ciphers */ switch (key->cipher) { case WLAN_CIPHER_SUITE_AES_CMAC: + wcid_keyidx = &wcid->hw_key_idx2; key->flags |= IEEE80211_KEY_FLAG_GENERATE_MMIE; break; case WLAN_CIPHER_SUITE_TKIP: @@ -347,16 +350,24 @@ static int mt7915_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, return -EOPNOTSUPP; } - if (cmd == SET_KEY) { - key->hw_key_idx = wcid->idx; - wcid->hw_key_idx = idx; - } else if (idx == wcid->hw_key_idx) { - wcid->hw_key_idx = -1; - } + mutex_lock(&dev->mt76.mutex); + + if (cmd == SET_KEY) + *wcid_keyidx = idx; + else if (idx == *wcid_keyidx) + *wcid_keyidx = -1; + else + goto out; + mt76_wcid_key_setup(&dev->mt76, wcid, cmd == SET_KEY ? key : NULL); - return mt7915_mcu_add_key(dev, vif, msta, key, cmd); + err = mt7915_mcu_add_key(dev, vif, msta, key, cmd); + +out: + mutex_unlock(&dev->mt76.mutex); + + return err; } static int mt7915_config(struct ieee80211_hw *hw, u32 changed) -- 2.30.2