Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp630018pxv; Thu, 15 Jul 2021 11:58:41 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxNH5lI5q2YDGa+RBaOzyDBnS99OA2lHqHnwhdOE1WB+pEW7QIUuxIJ3iEW3Y3MCKY8eyTM X-Received: by 2002:a17:907:76f0:: with SMTP id kg16mr7004339ejc.309.1626375521008; Thu, 15 Jul 2021 11:58:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626375521; cv=none; d=google.com; s=arc-20160816; b=IrHJFP6HG5BsN3su/nHCvrvSfxEwLdGUxp/2Q0OPi5f1NkgR9UEAz7Fqgkyvv5nHve Xv4/Q1aCR6Wl9NJPeRe2vKl8Vo1m/iyWYvZnSByp6eI+xWqSwR6CRU5YK3DEZdbyKXQS 0ZQXImO27idZ3/ipj+25wAvkeEGj8Kw9aGAnvk4aaKGXm6mlyGz2VyyFMQlHaQ8eqABE USjOcgeNJj55TF3Gc6rzoQSPAg2Jgx5O/icmReRQ1HbQMLQsvtgdview7WI/jlZaXeVE R/riNM/mLHyos7ZS/0rqqtfn8mo+DzHvw+kpV+bbcjTx8kXZi5EdTPdotQhD78N1QnOA XkFw== 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=jvynmIYHLHJ13VH6eRR9gRRiKJTN53BkHYsv9uY3hgw=; b=Y20Ok6Cfw8rxIPMMgsX3HE3w1c4XdIfIc4BzXSO2mmxnSg0jSCUSRdMlQfCtyl2jPH mHpcoFq5V7ZJMD1u2MboWIUKZd6fvUFiQPAi+dvf71rHJ5AfhiGnTn033tW9SphH0j5S x9ovtIzrJVhus+EgSfCPXFaf37nIrUsmZwV7GZ4QUfnXEPVmnXvqkNf7V1IYbRVfQjNe GbLH3ec0tRFjN0+ynjY3i9D157jdIRITWgrpA92AfcDwRubAZ7Y7evR0bHc3bK4mUSwL LwqbhPZZgQF3IVopXNRypJwuV0zzxGfcbe4RBMdE1EqbR5z/3la1AQcA8VOhjeSBlWNH Th9w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="zyCt/e8N"; 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 e23si8440797eje.315.2021.07.15.11.58.17; Thu, 15 Jul 2021 11:58:40 -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="zyCt/e8N"; 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 S242249AbhGOS7e (ORCPT + 99 others); Thu, 15 Jul 2021 14:59:34 -0400 Received: from mail.kernel.org ([198.145.29.99]:56358 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240121AbhGOSwg (ORCPT ); Thu, 15 Jul 2021 14:52:36 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 8FB06613DC; Thu, 15 Jul 2021 18:49:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626374983; bh=9VgLUQBs92xOKfCw9yNr7isD9zAUSEpSnUkmlmOKwBw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=zyCt/e8NYItATzZ0gYotd/wjboDfZ3ep/FIvyg7ZZiyvjfs9WK9p/vzLabIVHxiPt 1OB92haa2RZ2a5M6epo6bDrxLAxSmy2sz9aKNOzGhKz880Ng4HeuGOUd+jb4rcOSJS 1pCk4p7ZE+o5DqGNk4oYe38F5Cf5gonF+eZzoyiY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Thiraviyam Mariyappan , Johannes Berg , Sasha Levin Subject: [PATCH 5.10 110/215] mac80211: consider per-CPU statistics if present Date: Thu, 15 Jul 2021 20:38:02 +0200 Message-Id: <20210715182618.970578131@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210715182558.381078833@linuxfoundation.org> References: <20210715182558.381078833@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: Johannes Berg [ Upstream commit d656a4c6ead6c3f252b2f2532bc9735598f7e317 ] If we have been keeping per-CPU statistics, consider them regardless of USES_RSS, because we may not actually fill those, for example in non-fast-RX cases when the connection is not compatible with fast-RX. If we didn't fill them, the additional data will be zero and not affect anything, and if we did fill them then it's more correct to consider them. This fixes an issue in mesh mode where some statistics are not updated due to USES_RSS being set, but fast-RX isn't used. Reported-by: Thiraviyam Mariyappan Link: https://lore.kernel.org/r/20210610220814.13b35f5797c5.I511e9b33c5694e0d6cef4b6ae755c873d7c22124@changeid Signed-off-by: Johannes Berg Signed-off-by: Sasha Levin --- net/mac80211/sta_info.c | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/net/mac80211/sta_info.c b/net/mac80211/sta_info.c index 13250cadb420..e18c3855f616 100644 --- a/net/mac80211/sta_info.c +++ b/net/mac80211/sta_info.c @@ -2088,10 +2088,9 @@ static struct ieee80211_sta_rx_stats * sta_get_last_rx_stats(struct sta_info *sta) { struct ieee80211_sta_rx_stats *stats = &sta->rx_stats; - struct ieee80211_local *local = sta->local; int cpu; - if (!ieee80211_hw_check(&local->hw, USES_RSS)) + if (!sta->pcpu_rx_stats) return stats; for_each_possible_cpu(cpu) { @@ -2191,9 +2190,7 @@ static void sta_set_tidstats(struct sta_info *sta, int cpu; if (!(tidstats->filled & BIT(NL80211_TID_STATS_RX_MSDU))) { - if (!ieee80211_hw_check(&local->hw, USES_RSS)) - tidstats->rx_msdu += - sta_get_tidstats_msdu(&sta->rx_stats, tid); + tidstats->rx_msdu += sta_get_tidstats_msdu(&sta->rx_stats, tid); if (sta->pcpu_rx_stats) { for_each_possible_cpu(cpu) { @@ -2272,7 +2269,6 @@ void sta_set_sinfo(struct sta_info *sta, struct station_info *sinfo, sinfo->rx_beacon = sdata->u.mgd.count_beacon_signal; drv_sta_statistics(local, sdata, &sta->sta, sinfo); - sinfo->filled |= BIT_ULL(NL80211_STA_INFO_INACTIVE_TIME) | BIT_ULL(NL80211_STA_INFO_STA_FLAGS) | BIT_ULL(NL80211_STA_INFO_BSS_PARAM) | @@ -2307,8 +2303,7 @@ void sta_set_sinfo(struct sta_info *sta, struct station_info *sinfo, if (!(sinfo->filled & (BIT_ULL(NL80211_STA_INFO_RX_BYTES64) | BIT_ULL(NL80211_STA_INFO_RX_BYTES)))) { - if (!ieee80211_hw_check(&local->hw, USES_RSS)) - sinfo->rx_bytes += sta_get_stats_bytes(&sta->rx_stats); + sinfo->rx_bytes += sta_get_stats_bytes(&sta->rx_stats); if (sta->pcpu_rx_stats) { for_each_possible_cpu(cpu) { -- 2.30.2