Received: by 2002:a17:90a:88:0:0:0:0 with SMTP id a8csp29054pja; Fri, 22 Nov 2019 03:02:45 -0800 (PST) X-Google-Smtp-Source: APXvYqzcDWM+1vt+VQXPprib+aGZj8mKsBL55q61+dTkLUKxHCxxSIBpqaLaRZpGskDLPi/iH66N X-Received: by 2002:a17:906:c7d5:: with SMTP id dc21mr21465542ejb.267.1574420565122; Fri, 22 Nov 2019 03:02:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574420565; cv=none; d=google.com; s=arc-20160816; b=v0PYADXUJPFgwQYczsMUe0X9w2+/ts3YgMSpiFznWyyNQIJeGZQm7+1WVt+nmaifNt eff6NNKuRWSvvA8eUYhsCv7tHoH/UW3MBk3lEIJMcp0L5qJ7kX2wQtXfjLqxli9F0LN+ zERrl8Z53sRTGW7ytkcV4xgWaXmDsZVYCiWyf6J+pRxL5qJnsG+a85aX+mqlL6vW6PCn SdPeaoiFEgdOX8JkSX3JtnA2PXKp6/9XivIXKzrV+77VXtw9Ns5aK7tEX8nYC92Im3nE NRDyVkC59dru6cnU9Gu3uyf8kRhoClFF1CvHAngAK+GLs7eXufMvXaPnU48HlIAemUCX 9stQ== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=NA2VneEksX+DJ+kHvOS5/mE4ue4WNWy97HKh9ggM+gY=; b=lFSzHP0+t8/2KZV9ve7D+aCV2DnOeEjnc5tRdo2Gk6GLdszmewQyRWe+Of8yqx0bQJ EcP050CdASUjTpNAM7YriozocBt046buPlZK/BnrnFpfJpApq6QzxHgNVB33YJTZwyJo i6PmG6xfGcMXzBCCOC2AlMM5A9hPxxZYE7v4hXeMrWyLf4FAlYT7m50q4xQNGiJB9VIg hnxCbZdR6IM8d6m5EkbXaFDrxmO6IYLW7xLqi2zM7vEk5zqWpG5gVOFbF5S0AxbyEJGl HvQ7mB6nLtTczVFbFej6dl2pO+0nPBc1BuDwtVdEgYBLc8MqWQPSsLeP9Ku4EaNMeQDN evFg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=UBuO29+N; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-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 v6si3968408ejj.375.2019.11.22.03.02.14; Fri, 22 Nov 2019 03:02:45 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=UBuO29+N; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730878AbfKVK7M (ORCPT + 99 others); Fri, 22 Nov 2019 05:59:12 -0500 Received: from mail.kernel.org ([198.145.29.99]:49936 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730387AbfKVK7L (ORCPT ); Fri, 22 Nov 2019 05:59:11 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 4EE1720706; Fri, 22 Nov 2019 10:59:10 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1574420350; bh=IWdzDFSf/TRr9ci4D2Ci/WM12+j7L/sItckgGxtTqy4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=UBuO29+NCMUhIootlDXcvwYv6X9HK5HjYGvP0XJUMrHQ/J3totu1I7cxyybKj4fYh i5H1/3+8m4VyVy3t/d3KT5ciMtnaCkDPC3C5ElDWVs6I4vLPDtJ1hjKnzSi793ap2n JwCmqs8EPZorYG6JT/OszOHIIz8v+21SvyuMhHMQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Felix Fietkau , Sasha Levin Subject: [PATCH 4.19 033/220] mt76: fix handling ps-poll frames Date: Fri, 22 Nov 2019 11:26:38 +0100 Message-Id: <20191122100914.763259022@linuxfoundation.org> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191122100912.732983531@linuxfoundation.org> References: <20191122100912.732983531@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Felix Fietkau [ Upstream commit 36d910960fae3f9e74bedf3e0ef39ee26bdaa51f ] Hardware station lookup for pspoll frames can fail, which makes the driver ignore ps-poll frames. Fix the resulting powersave issues by looking up the station for pspoll frames in software Signed-off-by: Felix Fietkau Signed-off-by: Sasha Levin --- drivers/net/wireless/mediatek/mt76/mac80211.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/drivers/net/wireless/mediatek/mt76/mac80211.c b/drivers/net/wireless/mediatek/mt76/mac80211.c index ade4a2029a24a..1b5abd4816ed7 100644 --- a/drivers/net/wireless/mediatek/mt76/mac80211.c +++ b/drivers/net/wireless/mediatek/mt76/mac80211.c @@ -548,6 +548,12 @@ mt76_check_ps(struct mt76_dev *dev, struct sk_buff *skb) struct mt76_wcid *wcid = status->wcid; bool ps; + if (ieee80211_is_pspoll(hdr->frame_control) && !wcid) { + sta = ieee80211_find_sta_by_ifaddr(dev->hw, hdr->addr2, NULL); + if (sta) + wcid = status->wcid = (struct mt76_wcid *) sta->drv_priv; + } + if (!wcid || !wcid->sta) return; -- 2.20.1