From patchwork Fri Apr 11 09:57:43 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Wei Fang X-Patchwork-Id: 14048199 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 7ADBBC36010 for ; Fri, 11 Apr 2025 11:19:34 +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=KXE6mMkbt6EIDL5T75YbEsWR/LDSOOWXmbxGTZ1Wjys=; b=n9DKw1X6d1imPHaaeK2QnEXYk1 Et9myGtavSp9kloRgufKRwNV7q/cfdirVFwAiRk/ObdujFk7JKMi3DBJuGD4U9dYlKB1bfN6g8aTf 1NoUF/7VyEnnqNp+9ySHPhO8IGk2Ve3lx9uQcdgi5NIewhL89AZuqPUaMT5pNpULU+eGWPI36eJeq MQOiQk1yKC0CEvBX0DWw5ixLljaVdy1qeYQY6iGYluh966JIpt8/4OgbTDGXcip46ieZG/IhAmHn3 Q+OynUyeJbx+u5L1xVQ0RgPWSrM3yLvH2xLNO49fnS9IXkQ/775f8M3wRjd7kzi+FHMsbrXOnrnrE DUdgNVyA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98.2 #2 (Red Hat Linux)) id 1u3CPZ-0000000DUw2-0myQ; Fri, 11 Apr 2025 11:19:05 +0000 Received: from mail-am6eur05on2062a.outbound.protection.outlook.com ([2a01:111:f403:2612::62a] helo=EUR05-AM6-obe.outbound.protection.outlook.com) by bombadil.infradead.org with esmtps (Exim 4.98.2 #2 (Red Hat Linux)) id 1u3BRu-0000000DLcq-285m for linux-arm-kernel@lists.infradead.org; Fri, 11 Apr 2025 10:17:27 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=J7NqVmPkWxieedXA9viTrGVjO9R6acYIQSrXcjpmEsxFr2+QlvLJpO8pLgwKC7+QJVrvANhPWR5HNHz12fDuI5EOXhYhR1NzRuUvQAGfOn+3P8Vcu/bS0Gw/nrqwO6g/jABt1nfsocywszeQyOy5cvSOmTOW0hb/WZyVSGYZHKRB8ZFIoKUwDhLphY9qTgt/ps86u21CUKIc1GA0HRcg/w3qtt+8Fryu8prBgYGqT4xgMqy4eb7gNS3tGnCKEN1HEMDX1BRdunHu1PQ2v8xQRzg0161Z/sB5UsUjtuVxwsdKywkiq+MxTDYWHmfT65Jq4KXWEBLK4w8beaBPrkyDeQ== 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=KXE6mMkbt6EIDL5T75YbEsWR/LDSOOWXmbxGTZ1Wjys=; b=Gtbb9ugYiTJLrGD7rEaDMp6eFrHsR47inX1+jZ3tWGvMyMvH2mvovl1UL9fqYpWjG1zOGsmDfejKE+jb+X1WDrqRP6EXIr88OvWa3nA/MIwWgrVXNulA71/kIkDzm9cVrZgDa17jf8A1Imzv6Ik5g2HovJTf5mirHaUkjjii8TZgGJ8QhygqLLoL+JFjKcv9MljwJUWKWY6VMS6zDQdgRbCyRykwfdu54IATAoLC/feUfoD7+7Q7C6ttg/+Cc2OLe097r20V36BPp1s7/hK/KoAK106xifeKrRJ5UzPkqjwimxLdHKc+raWtzyzlLeXD5bMaTrc20FIYSxoVSsJXpg== 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=KXE6mMkbt6EIDL5T75YbEsWR/LDSOOWXmbxGTZ1Wjys=; b=Z4JtJUVAUn8EV/215lb3dwZVPGw7ykkw0qYC9AqOQbM/xKUVfyAQuiSuf/Gsg77bY1loBvHc52rDDxEz4BU8DlaMxzDSMGZy3+7vFg5I+m9uYITkAjcmCt10Sd5SuWkR8vVIu3OEeEJCxF6jlL7m4nKYVxsOnCtq6jVOVK7NY0DyAWNr+NyZ9VePxfeQWcauVMG5hpMjYSXLoHtjHkzxYJ0MI3wT+HMckjcgtwQZX/H0klv2EeKiGPN39LTmXYDbG2Dejz5P8pFKGAezUdDyipak+W0s9aIB0r/SjZf+qPHLD4LHwkAKefCGw4gKUravcjFMDvPGTcnYeDHzujTivg== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=nxp.com; Received: from AM9PR04MB8505.eurprd04.prod.outlook.com (2603:10a6:20b:40a::14) by AS8PR04MB8900.eurprd04.prod.outlook.com (2603:10a6:20b:42f::9) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8632.27; Fri, 11 Apr 2025 10:17:22 +0000 Received: from AM9PR04MB8505.eurprd04.prod.outlook.com ([fe80::bb21:d7c8:f7f7:7868]) by AM9PR04MB8505.eurprd04.prod.outlook.com ([fe80::bb21:d7c8:f7f7:7868%3]) with mapi id 15.20.8606.028; Fri, 11 Apr 2025 10:17:22 +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 Cc: christophe.leroy@csgroup.eu, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, imx@lists.linux.dev, linuxppc-dev@lists.ozlabs.org, linux-arm-kernel@lists.infradead.org Subject: [PATCH v5 net-next 05/14] net: enetc: add debugfs interface to dump MAC filter Date: Fri, 11 Apr 2025 17:57:43 +0800 Message-Id: <20250411095752.3072696-6-wei.fang@nxp.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20250411095752.3072696-1-wei.fang@nxp.com> References: <20250411095752.3072696-1-wei.fang@nxp.com> X-ClientProxiedBy: SI2PR01CA0021.apcprd01.prod.exchangelabs.com (2603:1096:4:192::19) To AM9PR04MB8505.eurprd04.prod.outlook.com (2603:10a6:20b:40a::14) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: AM9PR04MB8505:EE_|AS8PR04MB8900:EE_ X-MS-Office365-Filtering-Correlation-Id: a1a12d4d-4cc1-4be6-fcb7-08dd78e20c52 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|52116014|7416014|376014|1800799024|366016|38350700014; X-Microsoft-Antispam-Message-Info: xOGqvCplIxIWBX6Bq4N5WaG2C+gD2MDA3TxZfkGqNKGT6KflR7ThzS22Cf0eN8YftJ+y0W0sT7+OSJUg5YG2dc1yXtzDI6T2IV4PmypaEArbrMdXqG30QNQXgiOHTq7FfuQE4Ihn65s8K2NOjcDHmJR5U8pbyHwmcQVQ9HsYqTi28WdMptAUDB2f/GOcUccP1f6jprDdHsw68c/vBz+mPkHss1TxXB02oZ7i1DCKG7C9Py66+5FENdSVMpF9IEetACUNobNGJRLh4zj9jHs8QGp0R4Um6JJ4rvFoxIAzqMYWe9OyQHI76XF/hBg3Bx79ZXbVTRz0weQShEmJEdfZPaPebcd1KVn3DDvfPmFsqNnxYhXQvajYcyT0viM0TsmpOhr0GtiB6XZCBDt+skSUxkreQtztWz/OJb6Q+t2p9dt+kQpjaMgNgGxAIpHDzwyT0MoVWy0BQ3r9z3v3YXtCJjE0zTk5NX3YWCuV5cPV7y3I0SJfASKNuehzLRN+zSaIzZ1dRK/+Zw4DmGEo4Y6hc8qNFOvpT1Lrnv7ZJoxz10QJnJqSXVlAVA1TBh7GNQvVKCx/FlX6p+om8eGaGg9kddeL3u3+nZsJJb7AQNfe5iPafxUyLkznI8FOAQBQOLOHX/KAnrevC7CRcsgE2DH6zdD+X2Z9Jjo/WVqst0i9OgwlSnK4lHusCxYqnoE+J3vVOZCv9MvUFHyQbjRrlgcyjT76IuD7wO6I51LGh8mUgZSOwNGgd03hTn3bUvGxK6gVMDnFvNm0CMr35Sdxnn2ngQ8xWJa+VgtQ1sUshVdzSsntSZd5boiauI6uxFI7JPqTwE3Mtqwj3BMOyqtg7eYUd2nAclUpfln/xXHQE15qdoxWMhUXI5QnYpyVCQZ8hFJQIApVDchyplwK6PPPZOfRk2umJwrzSifz5MC79s4hdgvb9/FBNYNJWN0KJUKpo2x3Rs9RJ5/vE+IqXQXjXvVhVKMXiL9jPRLI3oCi0LWvFI1sgk24uW/F892s+XDAaYuj9DYhSD46nFYnCK/WdpQJYvQj2PovGLPDqPWFGeTFo2XAEYug60kJWlLwPRa2Y3yXdg1FAw2NAkxeuVBus70D1WwDPyJQ8EJzrf/hoRqQsYllJVK3u+R+UAQA3fFQfTFdbZ3+8q6tGhTZmu3c+yXikjOzWRrhmpGdlZqGHMmhNYEa4b90y9wrJepOUMd7wNGJrOiXrg9sbu/Kg/ZN2fKcuogoKhjCbP3KKqh03irUp08XmvAd4iWXXteVRdSGVoxD/cWczVwEIig4tBd6QwEYuoZa74a1o876QccdMvqV2+MSFlrNohelAN1ADwqy6k8jcufMpQ2QviUEUezcQ0rUn9GdSmnx0MQ0QXKu2W1TbHaO9jEQLKjf8wRP/EhpPX0r1Jn7OWf6/iRSTnDxKR3zBbu8Hw1lXfJOWfvM41KQ8droahfFYGU9trxNJlE12/4wsUSB7tFRxE4YeUkbtQMi1A== X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:AM9PR04MB8505.eurprd04.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(52116014)(7416014)(376014)(1800799024)(366016)(38350700014);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: lU0/YiSO+5DTOmWuaHWiY7sjebAZlWU+64RONbRusBX6N22N4lvAnmMRVgusSUbmMn/F6wuSo1VPomiFQDUy0Eljtg09ekLn4sPLZrOcbkRI574XBJs8MJXrhVWjrP0gdxj+pZrQp3VoImGXsZdNM2nQSB+4wCbRAAXKPo3+fVlJkFCS3c2AHN/it+bfAbzbBmwW5EWJk/HBRFsITttXLQYvSbg8fZjiAvHlrrMFyGB7geuQQArphAbmR42fwVdJw7scwgVOtkyZyfAW8ofZMqS1Ha9sLxr/I/legbP6icGAWaQRHvvuulgQ+Hs+5BNO5l2cyvJBG9Bvc60oabb3jjaKEjKR45Kpil+1iTPUDTljX4kN0iZ0DnA17VsVzNGJrwjqjFTbX/xwwgCYEgrv8E4SSk+oomSTrmNKy8kg1SxFY8Rl6q1+VbEGI8WbMqSV5Xo+gKCAR1jtv9rKS3T3WPyi+msmZGZDA3Qho9RTDKGVPEL8HDl+P+l3JhmldUn6BipSI32xOC68zv8WkJvB/6JT0dskUDqmxNNy7DzUS70Gv5ExeQ6nYERtm56rKpe1rbErKAntXEPvxr6UTYu0fPw/F+nn50HNnypohf9hHW1zLe6VzmysofpaAh/7GjMBttvDMs0MCV618823Moe3uOuhMoRCyQPGhpEv/nQfW+vbvhVm0AZ8ZmNj/Hk3wK3SkzjMfWBT3PrJdCdbRvCNvJ+cM66dN2mJzO7sshq6inr7AKakhzBCWAiaI08uh6lelgn0ApiEhO/RVfDQczz6/zR5aE61VEzXKpYNFbK501zyLSl/mndwA+zHkYwHWMr8niuNsWX9dwRLT400N8D04y6JjrOcZGrujcr8lR8drplyNhshBUYBzgcKZSgpRbU/ajLynge3y66TyoWgv4/XjkbY6IEf0A8iPkNOrCIUssldHiG+BK756zJzX3N1FNDceAZeZg2bSZvIfLbUQ37J+VN9opw9SYIZ48oNlS34x/UeU62QqIimEG5tB+Mv8ntMHirncpEbbO17pQp3vbddtJeB2OjMV+nr6RbCQdCz8Y9C6AhP5h+JUlv/h8AKSngeet0xPSp7wU9YJgDc+JfFFHCsKQ19j2dr3Q36aaFXLTyFycl6J6sAnOb14pLAvb5R9rX5z/5KHd8J27SLEWj6VlSAmjLuczLLm5TwFYEfaVct1B6o6tV6FMPBu1Fru7nIrg4ASnIP6i3lI8cLlI81Nc8yUL6oCENhO/CBJZElgBvbWsZ5FFomFdxu/vucxQDdkHMMeBpgBsgqDKEFF5/6KKoMgBRckcZI5uTUMjf87Wuu/S7dXaNS04CuYZDfttQBaANquALDD0NGAtRZ5CDUcPS/x/p1RxQ2176nKg8cR4M8rSePBJmHh0lP3vqPXINPUd0d1cdYevzsR5mCHdvvQidWSEfJfOVHQm2HQJctPMgl/zaQQ9OA0pqKe6Qts8/d19cbl47XyXY8pgSXwSixITWjzpVnyOzbRocZi+aU/TR/w8FDs+Lovx9oYt/pZPyqtNrxzMY2D3HlcAxGzVygGdp/6oLUV14UV7c1DP88EYvaqXvjxt4Fm+adOv+VhZVF X-OriginatorOrg: nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: a1a12d4d-4cc1-4be6-fcb7-08dd78e20c52 X-MS-Exchange-CrossTenant-AuthSource: AM9PR04MB8505.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 11 Apr 2025 10:17:22.4749 (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: WZ7pzdvn+GpqgZe9ggv9GGibbqtEOPtVHAuTr2aBwkfIts9VxQfqFNbZOtRXoXMkaqwzfebe+433fBjj+ckY4Q== X-MS-Exchange-Transport-CrossTenantHeadersStamped: AS8PR04MB8900 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250411_031726_696427_E8639FCC X-CRM114-Status: GOOD ( 22.87 ) 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 ENETC's MAC filter consists of hash MAC filter and exact MAC filter. Hash MAC filter is a 64-bit entry hash table consisting of two 32-bit registers. Exact MAC filter is implemented by configuring MAC address filter table through command BD ring. The table is stored in ENETC's internal memory and needs to be read through command BD ring. In order to facilitate debugging, added a debugfs interface to get the relevant information about MAC filter. Signed-off-by: Wei Fang --- v5 changes: 1. Replace is_en() with str_enabled_disabled() 2. Remove superfluous "Show" in the debug log 3. Remove keye variable from enetc_mac_filter_show() --- drivers/net/ethernet/freescale/enetc/Makefile | 1 + drivers/net/ethernet/freescale/enetc/enetc.h | 1 + .../ethernet/freescale/enetc/enetc4_debugfs.c | 90 +++++++++++++++++++ .../ethernet/freescale/enetc/enetc4_debugfs.h | 20 +++++ .../net/ethernet/freescale/enetc/enetc4_pf.c | 4 + 5 files changed, 116 insertions(+) create mode 100644 drivers/net/ethernet/freescale/enetc/enetc4_debugfs.c create mode 100644 drivers/net/ethernet/freescale/enetc/enetc4_debugfs.h diff --git a/drivers/net/ethernet/freescale/enetc/Makefile b/drivers/net/ethernet/freescale/enetc/Makefile index 707a68e26971..f1c5ad45fd76 100644 --- a/drivers/net/ethernet/freescale/enetc/Makefile +++ b/drivers/net/ethernet/freescale/enetc/Makefile @@ -16,6 +16,7 @@ fsl-enetc-$(CONFIG_FSL_ENETC_QOS) += enetc_qos.o obj-$(CONFIG_NXP_ENETC4) += nxp-enetc4.o nxp-enetc4-y := enetc4_pf.o +nxp-enetc4-$(CONFIG_DEBUG_FS) += enetc4_debugfs.o obj-$(CONFIG_FSL_ENETC_VF) += fsl-enetc-vf.o fsl-enetc-vf-y := enetc_vf.o diff --git a/drivers/net/ethernet/freescale/enetc/enetc.h b/drivers/net/ethernet/freescale/enetc/enetc.h index 1573ff06fcf4..b53ecc882a90 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc.h +++ b/drivers/net/ethernet/freescale/enetc/enetc.h @@ -304,6 +304,7 @@ struct enetc_si { struct workqueue_struct *workqueue; struct work_struct rx_mode_task; + struct dentry *debugfs_root; }; #define ENETC_SI_ALIGN 32 diff --git a/drivers/net/ethernet/freescale/enetc/enetc4_debugfs.c b/drivers/net/ethernet/freescale/enetc/enetc4_debugfs.c new file mode 100644 index 000000000000..3479c0abe9e6 --- /dev/null +++ b/drivers/net/ethernet/freescale/enetc/enetc4_debugfs.c @@ -0,0 +1,90 @@ +// SPDX-License-Identifier: GPL-2.0+ +/* Copyright 2025 NXP */ + +#include +#include +#include +#include + +#include "enetc_pf.h" +#include "enetc4_debugfs.h" + +static void enetc_show_si_mac_hash_filter(struct seq_file *s, int i) +{ + struct enetc_si *si = s->private; + struct enetc_hw *hw = &si->hw; + u32 hash_h, hash_l; + + hash_l = enetc_port_rd(hw, ENETC4_PSIUMHFR0(i)); + hash_h = enetc_port_rd(hw, ENETC4_PSIUMHFR1(i)); + seq_printf(s, "SI %d unicast MAC hash filter: 0x%08x%08x\n", + i, hash_h, hash_l); + + hash_l = enetc_port_rd(hw, ENETC4_PSIMMHFR0(i)); + hash_h = enetc_port_rd(hw, ENETC4_PSIMMHFR1(i)); + seq_printf(s, "SI %d multicast MAC hash filter: 0x%08x%08x\n", + i, hash_h, hash_l); +} + +static int enetc_mac_filter_show(struct seq_file *s, void *data) +{ + struct enetc_si *si = s->private; + struct enetc_hw *hw = &si->hw; + struct maft_entry_data maft; + struct enetc_pf *pf; + int i, err, num_si; + u32 val; + + pf = enetc_si_priv(si); + num_si = pf->caps.num_vsi + 1; + + val = enetc_port_rd(hw, ENETC4_PSIPMMR); + for (i = 0; i < num_si; i++) { + seq_printf(s, "SI %d Unicast Promiscuous mode: %s\n", i, + str_enabled_disabled(PSIPMMR_SI_MAC_UP(i) & val)); + seq_printf(s, "SI %d Multicast Promiscuous mode: %s\n", i, + str_enabled_disabled(PSIPMMR_SI_MAC_MP(i) & val)); + } + + /* MAC hash filter table */ + for (i = 0; i < num_si; i++) + enetc_show_si_mac_hash_filter(s, i); + + if (!pf->num_mfe) + return 0; + + /* MAC address filter table */ + seq_puts(s, "MAC address filter table\n"); + for (i = 0; i < pf->num_mfe; i++) { + memset(&maft, 0, sizeof(maft)); + err = ntmp_maft_query_entry(&si->ntmp_user, i, &maft); + if (err) + return err; + + seq_printf(s, "Entry %d, MAC: %pM, SI bitmap: 0x%04x\n", i, + maft.keye.mac_addr, le16_to_cpu(maft.cfge.si_bitmap)); + } + + return 0; +} +DEFINE_SHOW_ATTRIBUTE(enetc_mac_filter); + +void enetc_create_debugfs(struct enetc_si *si) +{ + struct net_device *ndev = si->ndev; + struct dentry *root; + + root = debugfs_create_dir(netdev_name(ndev), NULL); + if (IS_ERR(root)) + return; + + si->debugfs_root = root; + + debugfs_create_file("mac_filter", 0444, root, si, &enetc_mac_filter_fops); +} + +void enetc_remove_debugfs(struct enetc_si *si) +{ + debugfs_remove_recursive(si->debugfs_root); + si->debugfs_root = NULL; +} diff --git a/drivers/net/ethernet/freescale/enetc/enetc4_debugfs.h b/drivers/net/ethernet/freescale/enetc/enetc4_debugfs.h new file mode 100644 index 000000000000..96caca35f79d --- /dev/null +++ b/drivers/net/ethernet/freescale/enetc/enetc4_debugfs.h @@ -0,0 +1,20 @@ +/* SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause) */ +/* Copyright 2025 NXP */ + +#ifndef __ENETC4_DEBUGFS_H +#define __ENETC4_DEBUGFS_H + +#if IS_ENABLED(CONFIG_DEBUG_FS) +void enetc_create_debugfs(struct enetc_si *si); +void enetc_remove_debugfs(struct enetc_si *si); +#else +static inline void enetc_create_debugfs(struct enetc_si *si) +{ +} + +static inline void enetc_remove_debugfs(struct enetc_si *si) +{ +} +#endif + +#endif diff --git a/drivers/net/ethernet/freescale/enetc/enetc4_pf.c b/drivers/net/ethernet/freescale/enetc/enetc4_pf.c index 4c2d944d6b05..bbe16c140875 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc4_pf.c +++ b/drivers/net/ethernet/freescale/enetc/enetc4_pf.c @@ -8,6 +8,7 @@ #include #include "enetc_pf_common.h" +#include "enetc4_debugfs.h" #define ENETC_SI_MAX_RING_NUM 8 @@ -1004,6 +1005,8 @@ static int enetc4_pf_probe(struct pci_dev *pdev, if (err) goto err_netdev_create; + enetc_create_debugfs(si); + return 0; err_netdev_create: @@ -1019,6 +1022,7 @@ static void enetc4_pf_remove(struct pci_dev *pdev) struct enetc_si *si = pci_get_drvdata(pdev); struct enetc_pf *pf = enetc_si_priv(si); + enetc_remove_debugfs(si); enetc4_pf_netdev_destroy(si); enetc4_pf_free(pf); destroy_workqueue(si->workqueue);