From patchwork Mon Jan 13 08:22:39 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Wei Fang X-Patchwork-Id: 13936945 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 455DFE7719E for ; Mon, 13 Jan 2025 08:49:59 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:MIME-Version:Content-Type: Content-Transfer-Encoding:References:In-Reply-To:Message-Id:Date:Subject:Cc: To:From:Reply-To:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=KCEdnqAv6xJ8uCZlLxtdljvIMQ4bWcUrAVnJ2LhQ9O0=; b=XPaXAna6RSZmN/lEtUuyH30AcU VaD8HSpSvuq/olSva8wlTvCZTvZNiLmvRyPOLD5uHbywiKBJx+4m6gGQxZEsOGa8MbIywF9MSLad4 /sUhM0+2xNKUmEkpLCHrfK43ckP374uQ6mUYFgWkETgVkk+wTo/rGs4EZoXxWOmSLLVRHjO57i6cW nzA/4P/crNGXpcFLwk4xRgHgXOODLwCdv5Q26ppK/PLabWdxbPXUJ3d/BjOSBlkDijC78ars2zpWs pY4Lyllqm/4L2ZsfwcLpoqDiXZZkB0niRcNwHkieN058CXIpCXHgA3UgVGnCXkptzoaILOxa6I2+5 RTlsfCCw==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1tXG8o-00000004TG4-0akT; Mon, 13 Jan 2025 08:49:46 +0000 Received: from mail-am6eur05on20618.outbound.protection.outlook.com ([2a01:111:f403:2612::618] helo=EUR05-AM6-obe.outbound.protection.outlook.com) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1tXFzf-00000004R15-3at0 for linux-arm-kernel@lists.infradead.org; Mon, 13 Jan 2025 08:40:21 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=nIV52VYWcpbu5Dmhz2QffuGjLt2ZS4b36XAlSB6kD4QVTP7hnCApRkVIgrAr8kmSoWGi5N++hmmnkKuqKbYZW5Xw16xfwnLq2kcZ5L0F00qdnVKpv+Ao+BhyQYn5MsdN9GEBYyuYH5BpL5lJ8+JahRkazS4QCBgp3oo8yZQh2oa6CQbUf3Z0myhg4hi8/w09SRJgccQY3YCUc+WkC2WGCk9bmodqoG3ZITaAbxW8DotycWzZ9EKAnsGSOvTbbA/gKkM0QIoUOTQ8dQtin9qacy9fxSgHeoX6yMB6xOmP2YeaFHGqZJpZDS3EymAJS+XZ2IZZKLguz550VZXoxP5ZzA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=KCEdnqAv6xJ8uCZlLxtdljvIMQ4bWcUrAVnJ2LhQ9O0=; b=UAUx6JXg6+OZeAvYvtQqib4PPweoLvOXQP797v1YgjDptaLJvjp08CkdGMfP5ey+vsx4d4P1/RE7eonDl5cEw3Xss5a+ozjcNU7DhFnVsxshn5LVZ08LTwUoWkfUk41e+5MNQhuE/h6Mm1xv1c33znw9AM+nUwi8eGFIQptiytHWIWavp8kMsg+DbFnvwDOASWmbhZ0/bcXgRdRcdrKlA2RKx3krrsoubAZR+V+GPAnnHAVfXCEYUi6CgCI01kVoVQqnW6k2dW99xwioiGsI5BQnO7m704FHKePCNdmpHXyb0vPrE2jXIKSbxe4vSChiOtx8wuc7OxlqXQV2fY2qcg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=nxp.com; dmarc=pass action=none header.from=nxp.com; dkim=pass header.d=nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nxp.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=KCEdnqAv6xJ8uCZlLxtdljvIMQ4bWcUrAVnJ2LhQ9O0=; b=QFVyKDEv5I9m9dOaU0IuHXXxSGQ41X8jUHbQXqXXIKKexvKouC8FbkIJRlGta3hL1zUxHVEZfSk1O4XURammKJ+Vpnh3PieM4X/lhegh2JWatTSbFDRg/oUXiZp71AEmqay9Z9Br+yuK28Y9jcCnoveaTxEXaGPpUiU2goJaaX2iU3SI8xmJaFWftnTUlvCszjwPrEgPJSPe1h6xvbeH4OvD9ijzRmvIcFSNtgItR41MThTaTB41iEJTJiCpQRHofjzOwfmxANGTDhqUv+/EKOErlc3NCZNE3qiSxHC+6n1jEJqbZ9CRClSxd+Al0m/ZqAb8CBoERNbUbNc7pNooNg== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=nxp.com; Received: from PAXPR04MB8510.eurprd04.prod.outlook.com (2603:10a6:102:211::7) by VI1PR04MB9882.eurprd04.prod.outlook.com (2603:10a6:800:1da::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8335.18; Mon, 13 Jan 2025 08:40:17 +0000 Received: from PAXPR04MB8510.eurprd04.prod.outlook.com ([fe80::a7c2:e2fa:8e04:40db]) by PAXPR04MB8510.eurprd04.prod.outlook.com ([fe80::a7c2:e2fa:8e04:40db%6]) with mapi id 15.20.8335.017; Mon, 13 Jan 2025 08:40:17 +0000 From: Wei Fang To: claudiu.manoil@nxp.com, vladimir.oltean@nxp.com, xiaoning.wang@nxp.com, andrew+netdev@lunn.ch, davem@davemloft.net, edumazet@google.com, kuba@kernel.org, pabeni@redhat.com, christophe.leroy@csgroup.eu Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, linux-arm-kernel@lists.infradead.org, imx@lists.linux.dev Subject: [PATCH v2 net-next 07/13] net: enetc: add RSS support for i.MX95 ENETC PF Date: Mon, 13 Jan 2025 16:22:39 +0800 Message-Id: <20250113082245.2332775-8-wei.fang@nxp.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20250113082245.2332775-1-wei.fang@nxp.com> References: <20250113082245.2332775-1-wei.fang@nxp.com> X-ClientProxiedBy: SI2PR02CA0046.apcprd02.prod.outlook.com (2603:1096:4:196::15) To PAXPR04MB8510.eurprd04.prod.outlook.com (2603:10a6:102:211::7) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PAXPR04MB8510:EE_|VI1PR04MB9882:EE_ X-MS-Office365-Filtering-Correlation-Id: 3240b3c6-a06d-49b1-8d9a-08dd33ade7cc X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|52116014|376014|7416014|1800799024|38350700014; X-Microsoft-Antispam-Message-Info: pzvykXNqLoloyxSsdpcOiq5imfGL9Rl9KWnQIcPr15PsWnyDr/4ChmxLsddlOj/JoDYWPKvuEJAhFst+N8PcDu74StySOb6bjtY4Q+oj5K5fCSlnhV8VruFYfvHBs1+tHWXNp5dRFbXNiOzsXU5U7ymzURWMz3g6+jpI7nuxNye54syUF/Q1Nn0Lru5vRZahgOY7Uq2qH8u7/awbsjAUoGQ30mnMRkwF6/9eQ6x7nGYbJcNk1C0PUwBgPBammTYZ+FwZIa9DYwUZZKda7EuCsWjPaKTxIoUxxAxgBTOgZfOm3JeVmSLYWNwQoJF6R94IM098DN1HlF3lmL0rqNM3705gnudHaf3a2T//z7iBtlA3YbaoqUdsCL6sgJ+bXB9PZUMtsiDoB7TLOsvUIp5Stqc8pPztwCUeTPIQmgbZ5D+eGJ7FhILiFj3Ahiw24jets/zCj4wOOhlHz9wvWyaiTgCatdL1yyHpJgeAovxj4zwQ8FA1H6Edfkf8ROOkzdJGICdcvBnjSb04r6h48AxksLV6Yj/Ma+2BRZrw96rSoUkg0M1ScAzcUxfGoDMormlZ2jG4CcAsWntjFqGEbt6OR7dTVfuqTpl8n1edQirXGPELIcWzQ5IdN6z40jC3Glj1AyJ86u27rLdQmxDkBDsmFjqHZexYok/dgWAFvSSXJXoqS/eWOPdZRC/lJKub2Jj0fc3GnCsyZSHSJwCboTVEZgCerwGm5pPxwfyGKT2ETkeSe4kxH9r/erXznz9Vs8YhBRM16ohPOi1VWyH9EbryXBiEO9T6qyEw0tttSm5D//zR3sUAPYSuDX6nR+9bvdfHf3iRGdPMFX3LvmAQNdBpQvjoSqAe3kVHabhYzVLmzlw7iWTYiYv+hi29OZq7sFZbjGqh3PxQ0ZTWs8mLOyiFh2hSPXzTkOjVVyr5ks2ecwkQsBUBMjqohjMeYUP6RorvG5zVy9ssWuBcupHUr+Lp1VqsdGA2bhRQ2Ly8ra+Gw7lW5nUn1fQ/pP/ICO2yn/3GFJ4f28kaulSWCBSuRiKfyXpvDp5713t2j6azAnQFjCMSRNEefrzO8GzWARCbeYvrdtPt4p1kOmEwXXd/CrplK+kbYSN3fwSAlnAUkirafDwhfAMgMUVUHWqkmuRgXvQrtHr5AW+kYpkjnJmM6I/S9daPZJ8ZzcqIMYnYS7RbwWTvxc8SXV1e66Jc5NuSLI741qlTUkLBroTd8uMhvjaKRJyFs/MgZW0128+lecqKvgj/Lxs/kqip0ZH0IdkFCe+rsE/gQrX1qgeQ15DgAsnltlwFiNTfdt8+x9lX1kjl0ihjnCP++Jb34FekPE1UCxKHNvqFJamGYnc0ioK1aKhpCt2t5pHhM3wW674qyGPUu2eY7NgVp002wI+8sHMDHuAOgALei57DsmJLiLcue95WahygJBREDYA5cXV25rVfHrlViPweqsN1VjeRF34vp4Aq X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PAXPR04MB8510.eurprd04.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(366016)(52116014)(376014)(7416014)(1800799024)(38350700014);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: jfKXLLzErivZQvMAH8kns7ygA00YM3YYBExQlenWO2J9La/2NQU0bV/U8hHZ6KNUYNX2zX9EzFSZKhFcpP3mWkUPosoJ7dqW6qAi1OURjX8kZMBPzv5pXWTHD3TPqliF029naL6Fu2GfMJyThYrsEWZeS3gjeikfrRqnLW/uvXsr4xmZacYkcCbYKF+f+jWGR3kI+sSNyF77qHaaOl+REPO5Xwfs+n1pxmNcFl4QJXGsrr1fzYL8GUznmuVxs3siD9/GlAXqnA9OiEAMP9LaFuk1cL4RRR590ZijOlxMJ/ocM2C72infHD/nf1GK7/WQyjQVNEegXFnYJAI/smmdO5D07osN6SVWiao4omNGneyTMnMR/ee7G3epASNxfK8yylNX6aEI9qefqn/E93t/xmaCQPDerHjCAp5VYEB3AcXUrIUTRxZMuNQ9jeThLkmvGPPSCzAowOyIYgb38BcTXXqEw3/7f173jCLhwjmYtzJEG0sFnvmAxzpHTnTOQFp9q8gEnYXRqKCUQDiUPSlLVtqA6VlZuy4Nc0Y+wqqAZCaMaY4NQj5+Zyx2/QfdfVCEVEFbvzV8ak+G7yQp2lBz8LCl8mFcAwU/Cdkz+53oxeR3o/pOj39UcvDXfAHXQ3gwy727CmEMXtp/8mT2nOx0nIpWqa5LPr84KW31gEouZN/oJsAiVq0MrNwx1RJ0VNRDZSAcg8KppF7cIcXD7FFIOqwED9kQ7vxxzcfH5kwccZ/yTz6KIjyVaUVJyqQyPsjW4nazlRJ03xgREa05IyRsro8rW3MoBLGOV5MijXdUCTz6zdjEMD+lkwgWtlc7yObYX3lOFek9S6T9/4Smxu3MEhll8GiGL0jMuTdOnM/JvCf+pfi6fT5o8Wmz+ME2PF4CGM0KYQ5KYoCRSk9G7R+cqzrPe46Lf5/Nwjb/ZUGviEZyU7tGxRi9D9L7NS4w+nyt1X0nZ1TOLK8QTaDIotE5aNH+fnXk6FayJS8tDteJkGrCl+k6pZviSLWG/vvXby0wM4C9QubkVg+XG7uCJKmbq6VhVdixANWnhWP0Co/m9uTQi6xZjFsOgLTx5xhSe8yeJN/9hQKZsE/ikufQqKrWo/tW9kfJvVtsTIiLR3yg9/kGq9XC5UNGIPt9GzM4xo8XBVtmDfiFBoB0ikOBDEATg1nIPHfY/omd8R/PIHGEC6/C7xWOca/HyTmEalP00Z+VOvEpJt4n4qRMI1KzT2HZl2MxloAiRDq/MjbncmfOXYz2pg6fJcja//yXsrfWIr4l0292jgIcWGM6jA5qNtKzHpR5b8JrSyhbuhE+PoHUq93gDXECavVUFGEotAT/CO8e8zAdHW/NRAQdWhzv9vikn6fWusnUOb5JImJkzPFR3ieLzsCuhN+e2fe27NmOaIIfniZYlwMsHdx4f7YJz/e8ASIZwPKGBIeaBh/Vo96ChK1pHaMCRbuBGZfRaYadnM2GwRM4IaHiX6xmRqIjvz7XXnGw7JHh2o4/JulvEfCif/xAQSSyUTYzUengmjbs7D85j8x718ecf/LpDs5V8GkJigc2NPz4pslzwQVwbpP2iNImnAJD48MliGp86bVI6f38 X-OriginatorOrg: nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 3240b3c6-a06d-49b1-8d9a-08dd33ade7cc X-MS-Exchange-CrossTenant-AuthSource: PAXPR04MB8510.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 13 Jan 2025 08:40:17.1052 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: pL239J+81SDDMuaViF3Pb8rKpXVeJnH4QrcEoUgW+X7E9BWohWyejF6bRJpp/XXxMip/LL7FZLT0OPNGpCdMxA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR04MB9882 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250113_004020_046625_AA120089 X-CRM114-Status: GOOD ( 17.08 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Add Receive side scaling (RSS) support for i.MX95 ENETC PF to improve the network performance and balance the CPU loading. In addition, since both ENETC v1 and ENETC v4 only support the toeplitz algorithm, so a check for hfunc was added. Signed-off-by: Wei Fang --- drivers/net/ethernet/freescale/enetc/enetc.c | 7 +--- drivers/net/ethernet/freescale/enetc/enetc.h | 4 ++ .../net/ethernet/freescale/enetc/enetc4_pf.c | 37 +++++++++++++++---- .../net/ethernet/freescale/enetc/enetc_cbdr.c | 14 +++++++ .../ethernet/freescale/enetc/enetc_ethtool.c | 33 ++++++++++++++++- .../net/ethernet/freescale/enetc/enetc_pf.c | 2 + .../freescale/enetc/enetc_pf_common.c | 6 +-- .../net/ethernet/freescale/enetc/enetc_vf.c | 2 + 8 files changed, 87 insertions(+), 18 deletions(-) diff --git a/drivers/net/ethernet/freescale/enetc/enetc.c b/drivers/net/ethernet/freescale/enetc/enetc.c index 6d21c133e418..233f58e57a20 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc.c +++ b/drivers/net/ethernet/freescale/enetc/enetc.c @@ -2363,7 +2363,7 @@ static int enetc_setup_default_rss_table(struct enetc_si *si, int num_groups) for (i = 0; i < si->num_rss; i++) rss_table[i] = i % num_groups; - enetc_set_rss_table(si, rss_table, si->num_rss); + si->ops->set_rss_table(si, rss_table, si->num_rss); kfree(rss_table); @@ -2394,10 +2394,7 @@ int enetc_configure_si(struct enetc_ndev_priv *priv) if (si->hw_features & ENETC_SI_F_LSO) enetc_set_lso_flags_mask(hw); - /* TODO: RSS support for i.MX95 will be supported later, and the - * is_enetc_rev1() condition will be removed - */ - if (si->num_rss && is_enetc_rev1(si)) { + if (si->num_rss) { err = enetc_setup_default_rss_table(si, priv->num_rx_rings); if (err) return err; diff --git a/drivers/net/ethernet/freescale/enetc/enetc.h b/drivers/net/ethernet/freescale/enetc/enetc.h index fb53fb961364..2b0d27ed924d 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc.h +++ b/drivers/net/ethernet/freescale/enetc/enetc.h @@ -290,6 +290,8 @@ struct enetc_si; struct enetc_si_ops { int (*setup_cbdr)(struct enetc_si *si); void (*teardown_cbdr)(struct enetc_si *si); + int (*get_rss_table)(struct enetc_si *si, u32 *table, int count); + int (*set_rss_table)(struct enetc_si *si, const u32 *table, int count); }; /* PCI IEP device data */ @@ -540,6 +542,8 @@ int enetc_set_fs_entry(struct enetc_si *si, struct enetc_cmd_rfse *rfse, int enetc_get_rss_table(struct enetc_si *si, u32 *table, int count); int enetc_set_rss_table(struct enetc_si *si, const u32 *table, int count); int enetc_send_cmd(struct enetc_si *si, struct enetc_cbd *cbd); +int enetc4_get_rss_table(struct enetc_si *si, u32 *table, int count); +int enetc4_set_rss_table(struct enetc_si *si, const u32 *table, int count); static inline void *enetc_cbd_alloc_data_mem(struct enetc_si *si, struct enetc_cbd *cbd, diff --git a/drivers/net/ethernet/freescale/enetc/enetc4_pf.c b/drivers/net/ethernet/freescale/enetc/enetc4_pf.c index 798c69e83c8f..adb5819c091f 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc4_pf.c +++ b/drivers/net/ethernet/freescale/enetc/enetc4_pf.c @@ -69,9 +69,27 @@ static void enetc4_pf_get_si_primary_mac(struct enetc_hw *hw, int si, put_unaligned_le16(lower, addr + 4); } +static void enetc4_set_rss_key(struct enetc_hw *hw, const u8 *key) +{ + int i; + + for (i = 0; i < ENETC_RSSHASH_KEY_SIZE / 4; i++) + enetc_port_wr(hw, ENETC4_PRSSKR(i), ((u32 *)key)[i]); +} + +static void enetc4_get_rss_key(struct enetc_hw *hw, u8 *key) +{ + int i; + + for (i = 0; i < ENETC_RSSHASH_KEY_SIZE / 4; i++) + ((u32 *)key)[i] = enetc_port_rd(hw, ENETC4_PRSSKR(i)); +} + static const struct enetc_pf_ops enetc4_pf_ops = { .set_si_primary_mac = enetc4_pf_set_si_primary_mac, .get_si_primary_mac = enetc4_pf_get_si_primary_mac, + .set_rss_key = enetc4_set_rss_key, + .get_rss_key = enetc4_get_rss_key, }; static int enetc4_pf_struct_init(struct enetc_si *si) @@ -263,14 +281,6 @@ static void enetc4_set_trx_frame_size(struct enetc_pf *pf) enetc4_pf_reset_tc_msdu(&si->hw); } -static void enetc4_set_rss_key(struct enetc_hw *hw, const u8 *bytes) -{ - int i; - - for (i = 0; i < ENETC_RSSHASH_KEY_SIZE / 4; i++) - enetc_port_wr(hw, ENETC4_PRSSKR(i), ((u32 *)bytes)[i]); -} - static void enetc4_set_default_rss_key(struct enetc_pf *pf) { u8 hash_key[ENETC_RSSHASH_KEY_SIZE] = {0}; @@ -691,6 +701,14 @@ static void enetc4_pf_set_rx_mode(struct net_device *ndev) queue_work(si->workqueue, &si->rx_mode_task); } +static int enetc4_pf_set_features(struct net_device *ndev, + netdev_features_t features) +{ + enetc_set_features(ndev, features); + + return 0; +} + static const struct net_device_ops enetc4_ndev_ops = { .ndo_open = enetc_open, .ndo_stop = enetc_close, @@ -698,6 +716,7 @@ static const struct net_device_ops enetc4_ndev_ops = { .ndo_get_stats = enetc_get_stats, .ndo_set_mac_address = enetc_pf_set_mac_addr, .ndo_set_rx_mode = enetc4_pf_set_rx_mode, + .ndo_set_features = enetc4_pf_set_features, }; static struct phylink_pcs * @@ -1106,6 +1125,8 @@ static void enetc4_pf_netdev_destroy(struct enetc_si *si) static const struct enetc_si_ops enetc4_psi_ops = { .setup_cbdr = enetc4_setup_cbdr, .teardown_cbdr = enetc4_teardown_cbdr, + .get_rss_table = enetc4_get_rss_table, + .set_rss_table = enetc4_set_rss_table, }; static int enetc4_pf_wq_task_init(struct enetc_si *si) diff --git a/drivers/net/ethernet/freescale/enetc/enetc_cbdr.c b/drivers/net/ethernet/freescale/enetc/enetc_cbdr.c index 31bb82ee512d..6d85c0caa04f 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc_cbdr.c +++ b/drivers/net/ethernet/freescale/enetc/enetc_cbdr.c @@ -295,3 +295,17 @@ int enetc_set_rss_table(struct enetc_si *si, const u32 *table, int count) return enetc_cmd_rss_table(si, (u32 *)table, count, false); } EXPORT_SYMBOL_GPL(enetc_set_rss_table); + +int enetc4_get_rss_table(struct enetc_si *si, u32 *table, int count) +{ + return ntmp_rsst_query_or_update_entry(&si->ntmp.cbdrs, + table, count, true); +} +EXPORT_SYMBOL_GPL(enetc4_get_rss_table); + +int enetc4_set_rss_table(struct enetc_si *si, const u32 *table, int count) +{ + return ntmp_rsst_query_or_update_entry(&si->ntmp.cbdrs, + (u32 *)table, count, false); +} +EXPORT_SYMBOL_GPL(enetc4_set_rss_table); diff --git a/drivers/net/ethernet/freescale/enetc/enetc_ethtool.c b/drivers/net/ethernet/freescale/enetc/enetc_ethtool.c index 56ba82830279..a3059498f146 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc_ethtool.c +++ b/drivers/net/ethernet/freescale/enetc/enetc_ethtool.c @@ -626,6 +626,24 @@ static int enetc_get_rxnfc(struct net_device *ndev, struct ethtool_rxnfc *rxnfc, return 0; } +static int enetc4_get_rxnfc(struct net_device *ndev, struct ethtool_rxnfc *rxnfc, + u32 *rule_locs) +{ + struct enetc_ndev_priv *priv = netdev_priv(ndev); + + switch (rxnfc->cmd) { + case ETHTOOL_GRXRINGS: + rxnfc->data = priv->num_rx_rings; + break; + case ETHTOOL_GRXFH: + return enetc_get_rsshash(rxnfc); + default: + return -EOPNOTSUPP; + } + + return 0; +} + static int enetc_set_rxnfc(struct net_device *ndev, struct ethtool_rxnfc *rxnfc) { struct enetc_ndev_priv *priv = netdev_priv(ndev); @@ -698,7 +716,7 @@ static int enetc_get_rxfh(struct net_device *ndev, /* return RSS table */ if (rxfh->indir) - err = enetc_get_rss_table(si, rxfh->indir, si->num_rss); + err = si->ops->get_rss_table(si, rxfh->indir, si->num_rss); return err; } @@ -712,6 +730,12 @@ static int enetc_set_rxfh(struct net_device *ndev, struct enetc_hw *hw = &si->hw; int err = 0; + if (rxfh->hfunc != ETH_RSS_HASH_NO_CHANGE && + rxfh->hfunc != ETH_RSS_HASH_TOP) { + netdev_err(ndev, "Only toeplitz hash function is supported\n"); + return -EOPNOTSUPP; + } + /* set hash key, if PF */ if (rxfh->key && enetc_si_is_pf(si)) { struct enetc_pf *pf = enetc_si_priv(si); @@ -721,7 +745,7 @@ static int enetc_set_rxfh(struct net_device *ndev, /* set RSS table */ if (rxfh->indir) - err = enetc_set_rss_table(si, rxfh->indir, si->num_rss); + err = si->ops->set_rss_table(si, rxfh->indir, si->num_rss); return err; } @@ -1233,6 +1257,11 @@ const struct ethtool_ops enetc4_pf_ethtool_ops = { .set_wol = enetc_set_wol, .get_pauseparam = enetc_get_pauseparam, .set_pauseparam = enetc_set_pauseparam, + .get_rxnfc = enetc4_get_rxnfc, + .get_rxfh_key_size = enetc_get_rxfh_key_size, + .get_rxfh_indir_size = enetc_get_rxfh_indir_size, + .get_rxfh = enetc_get_rxfh, + .set_rxfh = enetc_set_rxfh, }; void enetc_set_ethtool_ops(struct net_device *ndev) diff --git a/drivers/net/ethernet/freescale/enetc/enetc_pf.c b/drivers/net/ethernet/freescale/enetc/enetc_pf.c index f050cf039733..59039d087695 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc_pf.c +++ b/drivers/net/ethernet/freescale/enetc/enetc_pf.c @@ -923,6 +923,8 @@ static int enetc_pf_register_with_ierb(struct pci_dev *pdev) static const struct enetc_si_ops enetc_psi_ops = { .setup_cbdr = enetc_setup_cbdr, .teardown_cbdr = enetc_teardown_cbdr, + .get_rss_table = enetc_get_rss_table, + .set_rss_table = enetc_set_rss_table, }; static struct enetc_si *enetc_psi_create(struct pci_dev *pdev) diff --git a/drivers/net/ethernet/freescale/enetc/enetc_pf_common.c b/drivers/net/ethernet/freescale/enetc/enetc_pf_common.c index 3fd9b0727875..c346e0e3ad37 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc_pf_common.c +++ b/drivers/net/ethernet/freescale/enetc/enetc_pf_common.c @@ -128,15 +128,15 @@ void enetc_pf_netdev_setup(struct enetc_si *si, struct net_device *ndev, if (si->hw_features & ENETC_SI_F_LSO) priv->active_offloads |= ENETC_F_LSO; + if (si->num_rss) + ndev->hw_features |= NETIF_F_RXHASH; + /* TODO: currently, i.MX95 ENETC driver does not support advanced features */ if (!is_enetc_rev1(si)) { ndev->hw_features &= ~(NETIF_F_HW_VLAN_CTAG_FILTER | NETIF_F_LOOPBACK); goto end; } - if (si->num_rss) - ndev->hw_features |= NETIF_F_RXHASH; - ndev->xdp_features = NETDEV_XDP_ACT_BASIC | NETDEV_XDP_ACT_REDIRECT | NETDEV_XDP_ACT_NDO_XMIT | NETDEV_XDP_ACT_RX_SG | NETDEV_XDP_ACT_NDO_XMIT_SG; diff --git a/drivers/net/ethernet/freescale/enetc/enetc_vf.c b/drivers/net/ethernet/freescale/enetc/enetc_vf.c index d7d9a720069b..072e5b40a199 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc_vf.c +++ b/drivers/net/ethernet/freescale/enetc/enetc_vf.c @@ -165,6 +165,8 @@ static void enetc_vf_netdev_setup(struct enetc_si *si, struct net_device *ndev, static const struct enetc_si_ops enetc_vsi_ops = { .setup_cbdr = enetc_setup_cbdr, .teardown_cbdr = enetc_teardown_cbdr, + .get_rss_table = enetc_get_rss_table, + .set_rss_table = enetc_set_rss_table, }; static int enetc_vf_probe(struct pci_dev *pdev,