Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3323368pxf; Mon, 15 Mar 2021 07:08:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxO3dYgpZOnKMO6FxajJlgStWJLPWLda/e6vZH5RwmSkrJQSrFPWZ8onFnDvm11A7aqF75p X-Received: by 2002:aa7:c0cd:: with SMTP id j13mr31161083edp.41.1615817307856; Mon, 15 Mar 2021 07:08:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615817307; cv=none; d=google.com; s=arc-20160816; b=Z+XEW5P5j5inoDCCDOugNtgTM6wwWJUHjJirvZju78X6xtO6RRyiI5izJBj2+4ClAu NDpLlXm22qyQCI2HobtJl6cuqoXGg9e6TdXixLuAN5S2k8DGMVz7CjWpqe+lcQPIcwrn AyP10ED8sBChlv4r29tu/MEF/LYVCFi+FCsGcCopJpo4ucIURLOh7H1oA5CJfl3bvtRB BVVNObtkw9DSPzkGr/s+5hU+rumYdZXLDGihim8cnJdu+VRwTO2A4glAciqGtZKpUokS /WfOkrttO75zYax5aNfp53oBZQVO2+Byw61T8Xa18bvEWSt5kvy4F6vlgtVskiVGvc3N Pb/w== 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=ankiwr8T1TzIKBtM9774zDdnw14y+pLcRo1uzO2ytJ4=; b=gg2pHf+6f8XPImBQeirZaq+XPzpooHW82FEoWHR3fL8a6vu8jry/lk9jGEJtcoeIit txYTcXGTV3QB4pcBFxk1fHQro1rfs85rZwaJXQxomdh0RTdM7AmzV9TdUO0hwIrMx1Df 0PFs3zKhwLar0IVpUXPjTsmERMf4o5JUD423xXp/WVXyE+XvyqwjomWj7e4sBfRlkGfV JkYDph/Ts4FphPlq26zp5iI2szzPdiHxubbHJrAl9KA8f26shouh7S6PCu1lPxTmYvh0 yz4uxMRtXOnKnYexlFXdWc9Jy/4Br/pk5/fu+A3sPF9hdQOBrndMBMFr3kotl+3j3IT4 3jLQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=jru2Srqm; 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 bx25si12066005edb.242.2021.03.15.07.08.02; Mon, 15 Mar 2021 07:08:27 -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=jru2Srqm; 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 S233314AbhCOOFz (ORCPT + 99 others); Mon, 15 Mar 2021 10:05:55 -0400 Received: from mail.kernel.org ([198.145.29.99]:35222 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232030AbhCON5h (ORCPT ); Mon, 15 Mar 2021 09:57:37 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 4F09364EF3; Mon, 15 Mar 2021 13:57:35 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1615816656; bh=NtC98DfpbA7Hk+1xDMzHbYIJouO+VTu7MgiZSC41SVU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=jru2SrqmMNnOUQJMzggiao33VOVb19qkrCaAQRkm8FZrd22Ufc6fGWunfhzXOx1Et JOZBt7m+zRZhKU3PJHiN3N63yz0I0tlgK112x0/x2A2m2pcVikAklum7xUHCL8UgqF UAT63qJHUHsZLFlKY8GD1jRm5mdFNN6mxOEDFmBA= From: gregkh@linuxfoundation.org To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jesse Brandeburg , Vladimir Oltean , "David S. Miller" Subject: [PATCH 5.10 037/290] net: enetc: dont overwrite the RSS indirection table when initializing Date: Mon, 15 Mar 2021 14:52:10 +0100 Message-Id: <20210315135543.172469879@linuxfoundation.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210315135541.921894249@linuxfoundation.org> References: <20210315135541.921894249@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: Greg Kroah-Hartman From: Vladimir Oltean commit c646d10dda2dcde82c6ce5a474522621ab2b8b19 upstream. After the blamed patch, all RX traffic gets hashed to CPU 0 because the hashing indirection table set up in: enetc_pf_probe -> enetc_alloc_si_resources -> enetc_configure_si -> enetc_setup_default_rss_table is overwritten later in: enetc_pf_probe -> enetc_init_port_rss_memory which zero-initializes the entire port RSS table in order to avoid ECC errors. The trouble really is that enetc_init_port_rss_memory really neads enetc_alloc_si_resources to be called, because it depends upon enetc_alloc_cbdr and enetc_setup_cbdr. But that whole enetc_configure_si thing could have been better thought out, it has nothing to do in a function called "alloc_si_resources", especially since its counterpart, "free_si_resources", does nothing to unwind the configuration of the SI. The point is, we need to pull out enetc_configure_si out of enetc_alloc_resources, and move it after enetc_init_port_rss_memory. This allows us to set up the default RSS indirection table after initializing the memory. Fixes: 07bf34a50e32 ("net: enetc: initialize the RFS and RSS memories") Cc: Jesse Brandeburg Signed-off-by: Vladimir Oltean Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- drivers/net/ethernet/freescale/enetc/enetc.c | 11 +++-------- drivers/net/ethernet/freescale/enetc/enetc.h | 1 + drivers/net/ethernet/freescale/enetc/enetc_pf.c | 7 +++++++ drivers/net/ethernet/freescale/enetc/enetc_vf.c | 7 +++++++ 4 files changed, 18 insertions(+), 8 deletions(-) --- a/drivers/net/ethernet/freescale/enetc/enetc.c +++ b/drivers/net/ethernet/freescale/enetc/enetc.c @@ -1098,13 +1098,12 @@ static int enetc_setup_default_rss_table return 0; } -static int enetc_configure_si(struct enetc_ndev_priv *priv) +int enetc_configure_si(struct enetc_ndev_priv *priv) { struct enetc_si *si = priv->si; struct enetc_hw *hw = &si->hw; int err; - enetc_setup_cbdr(hw, &si->cbd_ring); /* set SI cache attributes */ enetc_wr(hw, ENETC_SICAR0, ENETC_SICAR_RD_COHERENT | ENETC_SICAR_WR_COHERENT); @@ -1152,6 +1151,8 @@ int enetc_alloc_si_resources(struct enet if (err) return err; + enetc_setup_cbdr(&si->hw, &si->cbd_ring); + priv->cls_rules = kcalloc(si->num_fs_entries, sizeof(*priv->cls_rules), GFP_KERNEL); if (!priv->cls_rules) { @@ -1159,14 +1160,8 @@ int enetc_alloc_si_resources(struct enet goto err_alloc_cls; } - err = enetc_configure_si(priv); - if (err) - goto err_config_si; - return 0; -err_config_si: - kfree(priv->cls_rules); err_alloc_cls: enetc_clear_cbdr(&si->hw); enetc_free_cbdr(priv->dev, &si->cbd_ring); --- a/drivers/net/ethernet/freescale/enetc/enetc.h +++ b/drivers/net/ethernet/freescale/enetc/enetc.h @@ -293,6 +293,7 @@ void enetc_get_si_caps(struct enetc_si * void enetc_init_si_rings_params(struct enetc_ndev_priv *priv); int enetc_alloc_si_resources(struct enetc_ndev_priv *priv); void enetc_free_si_resources(struct enetc_ndev_priv *priv); +int enetc_configure_si(struct enetc_ndev_priv *priv); int enetc_open(struct net_device *ndev); int enetc_close(struct net_device *ndev); --- a/drivers/net/ethernet/freescale/enetc/enetc_pf.c +++ b/drivers/net/ethernet/freescale/enetc/enetc_pf.c @@ -1115,6 +1115,12 @@ static int enetc_pf_probe(struct pci_dev goto err_init_port_rss; } + err = enetc_configure_si(priv); + if (err) { + dev_err(&pdev->dev, "Failed to configure SI\n"); + goto err_config_si; + } + err = enetc_alloc_msix(priv); if (err) { dev_err(&pdev->dev, "MSIX alloc failed\n"); @@ -1143,6 +1149,7 @@ err_phylink_create: enetc_mdiobus_destroy(pf); err_mdiobus_create: enetc_free_msix(priv); +err_config_si: err_init_port_rss: err_init_port_rfs: err_alloc_msix: --- a/drivers/net/ethernet/freescale/enetc/enetc_vf.c +++ b/drivers/net/ethernet/freescale/enetc/enetc_vf.c @@ -177,6 +177,12 @@ static int enetc_vf_probe(struct pci_dev goto err_alloc_si_res; } + err = enetc_configure_si(priv); + if (err) { + dev_err(&pdev->dev, "Failed to configure SI\n"); + goto err_config_si; + } + err = enetc_alloc_msix(priv); if (err) { dev_err(&pdev->dev, "MSIX alloc failed\n"); @@ -193,6 +199,7 @@ static int enetc_vf_probe(struct pci_dev err_reg_netdev: enetc_free_msix(priv); +err_config_si: err_alloc_msix: enetc_free_si_resources(priv); err_alloc_si_res: