Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp658927pxv; Thu, 15 Jul 2021 12:43:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwO1R/sJjLmpvJujWBUa0TPOs79RVBhTJ+ZMp6v7l8Hhj0u8q1PIi1V33/9CaH0l36fHGqQ X-Received: by 2002:a05:6402:1ca4:: with SMTP id cz4mr9366724edb.52.1626378194030; Thu, 15 Jul 2021 12:43:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626378194; cv=none; d=google.com; s=arc-20160816; b=0nMEcgH+PAiMrxMc0w4jDYtUfRrCjNCOslL5hzNMZIkRTCM6Ppb7Lrn8pklL8/Lkdw v37dbGlkE5VBB4HTxhUrwwseK7Yf0oKEEMOjPhnmFe2XHfKRzLSQMgK5Rblu5mfBlWbt CNi6gsuAsJ2VZyJuX/HQVu6bRzIkJQKscFovjke/xzy5AqBXhDhRo0jIgiUDwVruMOP5 ROLvmHYPFRrogCEiLtWXky7hU+p76oJy03D1axmi5VQumsEu7vm1fCeCN4aTtH6YEPO1 SKZrh33Hi84MS3JzR/xvgnqzF4sJoHomadVyGo/NYpB79ZdCyt2B0s6o8qU73evGm3fi Jucg== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=QAAIeydYIGMiPuVbIt/1A2Z1xQ2hWzW4viq03eimFE8=; b=Rp3k76nJpHXFSW7DLHci3Jg8tu5dRsGavAbDAoUvkADcOL+Utvzm2jLdhVXCER5zT6 6n+cf25QPaLDZ3CDRs/j4j6L0eWdSGEU6isA4oTACY4HeGvHraUyhg8P6HwMDlcLOh6P lubBQ7RV3K2U8KzRb5QN5dymfBE62sixeeOBZhIVZ3rbhdPynLOOjplqxaYC9owNb8F+ e8qNO/+mnHmGoS/zbTfgs3474gRhcMk2P7plC7TLC+7sezIQuv9VdNcEOpeysAMQu2fG H1Ff/o6xLdy8b+kG6OgJJP4SN/kEvl0rVCLQza+zrvY791fa57O0T9sT2G6qheXDlzjJ XEjA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=RMqHsFPM; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b1si8360993edx.272.2021.07.15.12.42.51; Thu, 15 Jul 2021 12:43:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-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=@linuxfoundation.org header.s=korg header.b=RMqHsFPM; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1344249AbhGOTkC (ORCPT + 99 others); Thu, 15 Jul 2021 15:40:02 -0400 Received: from mail.kernel.org ([198.145.29.99]:50954 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244236AbhGOTOh (ORCPT ); Thu, 15 Jul 2021 15:14:37 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id D032D61370; Thu, 15 Jul 2021 19:09:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626376192; bh=wnTsomYnCGOELAZ0AQCx5ATOgWQGSdNf0X4ppMtv3h0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=RMqHsFPMA1iVZ2efc+HaXpL1duzF2CQ5Evl0tAlmGYSvcd4H0M7gUnrodt89bwXED rAX3K52rNgKmbmWks7MWMOvySKXYbmbFsRAp0jLnd7T8EqhsliPshr24V3cg7AgEYv 9HCyTVOIUrM37tmFqZVNpCcuBzRQfrz5IE0j8fdc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, "Deren.Wu" , Lorenzo Bianconi , Felix Fietkau , Sasha Levin Subject: [PATCH 5.13 124/266] mt76: mt7921: enable hw offloading for wep keys Date: Thu, 15 Jul 2021 20:37:59 +0200 Message-Id: <20210715182635.794504242@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210715182613.933608881@linuxfoundation.org> References: <20210715182613.933608881@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Lorenzo Bianconi [ Upstream commit a60951d4faa0ef2e475797dd217c2eaee32ed1c2 ] Enable wep key hw offloading for sta mode. This patch fixes WoW support for wep connections. Tested-by: Deren.Wu Signed-off-by: Lorenzo Bianconi Signed-off-by: Felix Fietkau Signed-off-by: Sasha Levin --- .../net/wireless/mediatek/mt76/mt7921/main.c | 22 ++++++++++++++----- .../wireless/mediatek/mt76/mt7921/mt7921.h | 2 ++ 2 files changed, 19 insertions(+), 5 deletions(-) diff --git a/drivers/net/wireless/mediatek/mt76/mt7921/main.c b/drivers/net/wireless/mediatek/mt76/mt7921/main.c index bd77a04a15fb..992a74e122e5 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7921/main.c +++ b/drivers/net/wireless/mediatek/mt76/mt7921/main.c @@ -376,6 +376,10 @@ static int mt7921_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, key->flags |= IEEE80211_KEY_FLAG_GENERATE_MMIE; wcid_keyidx = &wcid->hw_key_idx2; break; + case WLAN_CIPHER_SUITE_WEP40: + case WLAN_CIPHER_SUITE_WEP104: + if (!mvif->wep_sta) + return -EOPNOTSUPP; case WLAN_CIPHER_SUITE_TKIP: case WLAN_CIPHER_SUITE_CCMP: case WLAN_CIPHER_SUITE_CCMP_256: @@ -383,8 +387,6 @@ static int mt7921_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, case WLAN_CIPHER_SUITE_GCMP_256: case WLAN_CIPHER_SUITE_SMS4: break; - case WLAN_CIPHER_SUITE_WEP40: - case WLAN_CIPHER_SUITE_WEP104: default: return -EOPNOTSUPP; } @@ -402,6 +404,12 @@ static int mt7921_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, cmd == SET_KEY ? key : NULL); err = mt7921_mcu_add_key(dev, vif, msta, key, cmd); + if (err) + goto out; + + if (key->cipher == WLAN_CIPHER_SUITE_WEP104 || + key->cipher == WLAN_CIPHER_SUITE_WEP40) + err = mt7921_mcu_add_key(dev, vif, mvif->wep_sta, key, cmd); out: mt7921_mutex_release(dev); @@ -608,9 +616,12 @@ int mt7921_mac_sta_add(struct mt76_dev *mdev, struct ieee80211_vif *vif, if (ret) return ret; - if (vif->type == NL80211_IFTYPE_STATION && !sta->tdls) - mt76_connac_mcu_uni_add_bss(&dev->mphy, vif, &mvif->sta.wcid, - true); + if (vif->type == NL80211_IFTYPE_STATION) { + mvif->wep_sta = msta; + if (!sta->tdls) + mt76_connac_mcu_uni_add_bss(&dev->mphy, vif, + &mvif->sta.wcid, true); + } mt7921_mac_wtbl_update(dev, idx, MT_WTBL_UPDATE_ADM_COUNT_CLEAR); @@ -640,6 +651,7 @@ void mt7921_mac_sta_remove(struct mt76_dev *mdev, struct ieee80211_vif *vif, if (vif->type == NL80211_IFTYPE_STATION) { struct mt7921_vif *mvif = (struct mt7921_vif *)vif->drv_priv; + mvif->wep_sta = NULL; ewma_rssi_init(&mvif->rssi); if (!sta->tdls) mt76_connac_mcu_uni_add_bss(&dev->mphy, vif, diff --git a/drivers/net/wireless/mediatek/mt76/mt7921/mt7921.h b/drivers/net/wireless/mediatek/mt76/mt7921/mt7921.h index 710ad242fd53..957084c3ca43 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7921/mt7921.h +++ b/drivers/net/wireless/mediatek/mt76/mt7921/mt7921.h @@ -100,6 +100,8 @@ struct mt7921_vif { struct mt76_vif mt76; /* must be first */ struct mt7921_sta sta; + struct mt7921_sta *wep_sta; + struct mt7921_phy *phy; struct ewma_rssi rssi; -- 2.30.2