From patchwork Mon Jan 13 08:22:35 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Wei Fang X-Patchwork-Id: 13936911 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 C5066E7719E for ; Mon, 13 Jan 2025 08:44:58 +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=BaE2Ypc92Ok6czI2zettvmxX+IrZP2lNiBLQFEzkJOI=; b=g1HFs2OLrpxK9eET0NziI6ySI/ FFjAggAS1VrrZ/WxSKsOKs10GTkn8MQozrURXx17+3siMhN1HTDDNgS5ktdytlFmOijnnCWG52ZEk EWiMtn4HAoLsFkPRP0TDwU6okTjBLTLUeiZtiNp+98MZxP76ushYPKv6lT2ozaq6VibiiTKo/3i/j llGtBvk2CP+e9wXnAutbKLjautPvT+8yKGZUiJGNN3ddUmG+bes+UsjY4tOJQw2tAxT0wTSPuGgT2 mdg8rKq1R36g1jO0SyYWcMP7t4OUCpbfhwgau9c/5vl+wcOERINA/XOpgSleXjZECZ2IW9IfpKpRz S0qOAsFg==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1tXG40-00000004SQa-43RA; Mon, 13 Jan 2025 08:44:48 +0000 Received: from mail-vi1eur05on20624.outbound.protection.outlook.com ([2a01:111:f403:2613::624] helo=EUR05-VI1-obe.outbound.protection.outlook.com) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1tXFzO-00000004QtJ-10Cw for linux-arm-kernel@lists.infradead.org; Mon, 13 Jan 2025 08:40:03 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=SpLeF6ZfVlBhbeqIl5xISMQi+uRqGUtzz6VgRGZADyjnfUVhfsjbqV9I8iGHn3uibzDFB0P27tJdNRpuifSelCBekQ60gC4vgPvWZhl+Kb2OZ+XDWWt5SRZo7yhKBP/yZE2QVLFFMhuG8LTvLec2QBryyPibc6rT2Q7kzt0+HYThC7XfuvuEd4qkphkSPD02nzxpDoAkl3PEWzo5YrvL324Rpy5iJBAOB9nI71m1jsCzfVrII0Il+AUBx2Iupoporeha7z8GqA7b7T0eX8IIAqoNjhfSkaZRXQBEjRIIUcwo47jPm44Tj3b3YjtYRHaTKh2WRw2ZrJe6hzLRwgTiaQ== 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=BaE2Ypc92Ok6czI2zettvmxX+IrZP2lNiBLQFEzkJOI=; b=Rxqwvsb9X1uTfOR1MtYnfpPUq6InMXxjDvV5XZv4/WMuZx9aWFINn4BCtY4zukG3iGigGv1ZlMkoWhoaP2Nwt2ROhwqMixsSsX4YvB/b0bFZdhX2hpX3PHwF1y31CcfUOFJ40BmOQ4gkNu/thmCUnKfHVJSk5ojJhBpKDL+74i3//KpUDT3uSL6skYcJBrGBbPFMAkpclk+Foy57pxn8vBPcKP/kWnfNsaywgnSgWufiHpnALrs2bfb5jDaKn5zMcTsdtXvRajkCstj2Ttdi5xmv+RiolTBGQwcnw4Xfifby+FuV/mnc8iq8GofzfnVevF1IMFy6olDcg6CGrpAdhg== 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=BaE2Ypc92Ok6czI2zettvmxX+IrZP2lNiBLQFEzkJOI=; b=gUcGQvVQPhSwYRP+wHaqqzyUQancmoJNmVb+hgJgDT3P75+KOJcks/jtsROaVF9rHvHi5C1EYPWmoTFlNm57s2HxsEYoNftFsTRJUFQMmmG1EqFv1AgPiAqQKmGpXtsWajVyjqoD6U4yurWuOfkOEritm+nYN3TqBwuY6JsHyp7XGFNR6MLzFPqe2jFaSD+yGS9l+8AhKk+lskGb1IgeNKMV14jZz7YtyXpzzCWTSjLp15FJpZxzHmBe199TU12M+DPapzmEhLIKLB3AlITTbmmVA+eJ/9kNrDYrH/J0OJmvNGCxYOCp3oWiMkpQoehInjBacPcNq4O35PIaqjL2QA== 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:39:59 +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:39:59 +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 03/13] net: enetc: move generic MAC filterng interfaces to enetc-core Date: Mon, 13 Jan 2025 16:22:35 +0800 Message-Id: <20250113082245.2332775-4-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: a2de7f88-463a-4ee9-4e58-08dd33addc81 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: qTUtWVvr9cRJhK3KhyB4Rne+HY6FFfAxuCb5WSAnWGpod2HZGTLFDoQJIiYwyCjSdwoRf5guUwkUNjMr6T0+bK84KXl/Vaw/OFCbIEdY2JpOdqXd4qfKzdaxtJeAfiGAl5RRwa+rLDYvDOfEzojOg4ql+sIUbrP5Q1zjP/4R4vOEdx1HIoABKlOZsZMi0E7RHQY6B27hiz5+Nyx3RsBwzS16/hJWpHT4kVCmQ5IARhlOOsuyn9MwZ9sBzYJni2WngABp0V/MRV8NxMZoG6AKNWbbbxoAp9CIkbuTS28zz6obxROp08A8EjYWqiVJqWoXymvrZ5uAtE5It5L4D9HLWkaD8wsgx4z70TXbodysN/pQlK6Ei/TRUMiTJB5sJ+p0xXj84urRpt2ekJ8AqeJPdBErVxLD2SldjUi552/2QLZ2IATIyE31/80HqNy95vZvdGzKdO/heXyVLXlbc0VgK2xd9BT1y6JI3fACdJoeXfkiTwphBzujQ23xsLzxFPF9iQ7wCywOPkPwoOQh9TL52THduTpfPVcb5iIYBGBBJUPNVOwu+kMFYGbd1GgUqb2UF2d8VEk38X0MvrU1YiPlVGWhESAdhO1npDBkfHmmml9tPDantEjtatakl1c0qwofkMRcKgzvXCnTwaBafW06JYdEJ8CGAyheacMNJ430m8VZU1tPARFuU5/XWstesHG65ThbXJnqsfagqNmeT59r8XibyzN43wUibpnonmlG8+G0UgMEgPYYMCStce0EBiGiWzG90VHiTKqVO4ZIozM1G3rj7wpAT8mGBtVwpvTWESsm2xgQHCttm1AABpAzfhTAxGnhxmmq48dapJRg9GfDQCKx5LbUNSjm62+non0SNmgWPZ/py+34fnbuduYnrvZCgDOj6cbMk9yBmWBzGTwBmYcYiRlvafD//1t0AWy+eVSunfYLnVGXaJYvENYOtBoQTSsv+yA7MIkORx0Iz8NDZoWoRa05C5n7YQ/B2Ccv4UxTAJkHMR37lPXBs+KjDTzXAqcECHySlIZs3+ctZpexygq8XKnLIIxzm3Dxu75K8edSqhuok3MG72craSKpYSfh31jg9Oyz1S9aETLTLMwqibW9deJkWPfq5lIRLRme/X2V9PSKrPnaUFG3d42S9a+nTvFDmXJgqZkqTEURCAzEnPxWll5yEdVoRQawmQcakStUG37LnVaRmtOhj1FSajRFC2AdJDf9vOu/n6mSntweQ90WgcopHKiQjFztQNwysJWB/DyfSuvIcnDwZJOWtZR18lCYJ6ZaH4kzhynW2dk/UU8G9UCi9H/WBX5Ps8+ZZGyYAsdghyD/mQjiC8qqiYkqhRqVh0k4UbjCql+rTCrXyrTE3t9fnu2ZAqJvXyLqkPlZSbNKZPRZYvKm16k2/hHuXOsjlp5IwaP5SPh7KbFuTc/wtk98dwDQitCJ4KjIoW4N+NXYSrJ5KwRTTZsXnAAU 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: x2sbEl76j3fjRXOaSd4ITQzDS9qZJeMbMl80UiUpzQBV3fZ2N+ZnU3YvCBH4fFHg6CbSqeEY0KNwe7g7/oPwfNXq2210c4lP+XQUYfSJnd80PtoVPsdeXNIE+KAw/Lie62zuobnrCulnpiAbbAdYDaaa3PM+RpEzk3w+QHkcGN7FZ0UNForDzuCajBVRA8DfqGd8Ek7G0Xj+LsDtP09UVjWVumlDafMRpE2tbg8c9JZ/XqnxT/wbfofDN/ITCpS+ewB+p6FED/+3uf0zsT/EJgw6uLd5DRt8lGu6w2nEHcL0BYK/tVe41xtD7BI0uCC2Wfvm5ykyqom0pVQGpFvJI8ekXQSBcfhtvcbO80zYxcOlhAbRjdjy5bSLE/vqfZjt9scL+6L8rS0OoNnNh24EfoXiOEQvwKyg4Lm83Ve/wlT3eTSqQjt2aVgrN6CC3rxo5n0NgP8F9WjTXNk59iRObilOTBYQfq2pDhxW7u00m6vfwNgjkBRXuya2TA4hr+3HWqD1/LE0Svj1lwqlnT8tOaHfgt7KRAwy3VVFmp2ERv+vK1eIyEpU0K9VdoTZNjwjC+klotc5T8YLigvO80eERMtIsB/qYAYoBBJOuImUmzZXrJygSLzSp+xz18OxH6dQcoARr+5jwdM23LgbndR65d1N2Y0Ru8Zl9w6eieUid5SjDGwfpr3Zaz1iozRVpqz6Wk+Sb/5QcK4IYocOfKv1bDjjhUxscYxS5zHsmfi8sq/NcXK1PndIUs40iE2+9F5jAX24K6ZCJgi2gxAptAYW2yzkDFDd5RApLtNsx4cmuUkRq1CFwDW5UOieCXVqfEeh4nEvhjT0PfkannH0BGxSvBNloVs1BJ5/ceg/+413qI9/VIruOnPUp/1vRUNdSHrrVR3PQGB071LNIxQCK751b0bElTrd0kEE8pmMijufRto8ffjzgiH9Qe/eEdlLhU68k9KI4FvNQn75XmtssJgjLFdhxvv/wuFe/ncsKLfkz7imumhtMdJPXJJR0TRVq+GZmcsXomEdX8OAkMm0tGe59w0glw2m7BYz9k6x6E3w9fcqPVl8UFhRIlnc7o7fgJBINMmwWK2ABoXtLX/IsYS+TNR1sndSmWeb2wyWvb1rjHrzq4jOq0u2zemtOTMD32VQ9Q95elFbCnGvmyi8a3t8IKhjZEe1tPmqDGdH0oIpW1sVxduOa+XNJVDcHiLJm33jAr0eH7Cl6NCGanV+O/Brsy4xL31CPF/cs3wa5RXCbOQyd7eWIn8RJzOqeX40Kr21O+Q+8jfJF6vKhGQruaPCflTyl8DIWSDPcX2wQWuoyhof6u8WllyYl7w7n8U3vdr5kL4sFcQPbsFdxVuycNDIVNfwmxnuXozcFWiENOHLHm81w36vQIFEwnip7GkncvJ28K5B/zFjrXrsFuuWmDYU9DpumQSmn8wSGdYNAGlDd68i9rUY9qWs72GgB5va0PNo/Up/TA1VlbpT1Rhg9LVEKX/YRGR5hjuubz9Qb+RCvAGJSk8c4+iBrWP09GVdPcjNG24P2BjUCL8n8XvfCsZUQOfKySGVzkXi2fsmqKuZW4BZGIp6QJbYj5HOTZ5cXOzz X-OriginatorOrg: nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: a2de7f88-463a-4ee9-4e58-08dd33addc81 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:39:58.9755 (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: NOWo1O9sG2sIVINUIXHeNVLdIy+g3lgbQYBprRId42Ngyq6f+//SFohGdJNZRFllw5QC0zgL+241bdoWKzObpw== X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR04MB9882 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250113_004002_445846_3A652F58 X-CRM114-Status: GOOD ( 19.61 ) 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 Although only ENETC PF can access the MAC address filter table, the table entries can specify MAC address filtering for one or more SIs based on SI_BITMAP, which means that the table also supports MAC address filtering for VFs. Currently, only the ENETC v1 PF driver supports MAC address filtering. In order to add the MAC address filtering support for the ENETC v4 PF driver and VF driver in the future, the relevant generic interfaces are moved to the enetc-core driver. At the same time, the struct enetc_mac_filter is moved from enetc_pf to enetc_si, because enetc_si is a structure shared by PF and VFs. This lays the basis for i.MX95 ENETC PF and VFs to support MAC address filtering. Signed-off-by: Wei Fang --- drivers/net/ethernet/freescale/enetc/enetc.c | 36 ++++++++++++++ drivers/net/ethernet/freescale/enetc/enetc.h | 17 +++++++ .../net/ethernet/freescale/enetc/enetc_pf.c | 49 +++---------------- .../net/ethernet/freescale/enetc/enetc_pf.h | 14 ------ 4 files changed, 60 insertions(+), 56 deletions(-) diff --git a/drivers/net/ethernet/freescale/enetc/enetc.c b/drivers/net/ethernet/freescale/enetc/enetc.c index 6a6fc819dfde..6d21c133e418 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc.c +++ b/drivers/net/ethernet/freescale/enetc/enetc.c @@ -36,6 +36,42 @@ static void enetc_change_preemptible_tcs(struct enetc_ndev_priv *priv, enetc_mm_commit_preemptible_tcs(priv); } +static int enetc_mac_addr_hash_idx(const u8 *addr) +{ + u64 fold = __swab64(ether_addr_to_u64(addr)) >> 16; + u64 mask = 0; + int res = 0; + int i; + + for (i = 0; i < 8; i++) + mask |= BIT_ULL(i * 6); + + for (i = 0; i < 6; i++) + res |= (hweight64(fold & (mask << i)) & 0x1) << i; + + return res; +} + +void enetc_add_mac_addr_ht_filter(struct enetc_mac_filter *filter, + const unsigned char *addr) +{ + int idx = enetc_mac_addr_hash_idx(addr); + + /* add hash table entry */ + __set_bit(idx, filter->mac_hash_table); + filter->mac_addr_cnt++; +} +EXPORT_SYMBOL_GPL(enetc_add_mac_addr_ht_filter); + +void enetc_reset_mac_addr_filter(struct enetc_mac_filter *filter) +{ + filter->mac_addr_cnt = 0; + + bitmap_zero(filter->mac_hash_table, + ENETC_MADDR_HASH_TBL_SZ); +} +EXPORT_SYMBOL_GPL(enetc_reset_mac_addr_filter); + static int enetc_num_stack_tx_queues(struct enetc_ndev_priv *priv) { int num_tx_rings = priv->num_tx_rings; diff --git a/drivers/net/ethernet/freescale/enetc/enetc.h b/drivers/net/ethernet/freescale/enetc/enetc.h index 4ff0957e69be..9380d3e8ca01 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc.h +++ b/drivers/net/ethernet/freescale/enetc/enetc.h @@ -23,6 +23,18 @@ #define ENETC_CBD_DATA_MEM_ALIGN 64 +#define ENETC_MADDR_HASH_TBL_SZ 64 + +enum enetc_mac_addr_type {UC, MC, MADDR_TYPE}; + +struct enetc_mac_filter { + union { + char mac_addr[ETH_ALEN]; + DECLARE_BITMAP(mac_hash_table, ENETC_MADDR_HASH_TBL_SZ); + }; + int mac_addr_cnt; +}; + struct enetc_tx_swbd { union { struct sk_buff *skb; @@ -302,6 +314,8 @@ struct enetc_si { int hw_features; const struct enetc_drvdata *drvdata; const struct enetc_si_ops *ops; + + struct enetc_mac_filter mac_filter[MADDR_TYPE]; }; #define ENETC_SI_ALIGN 32 @@ -484,6 +498,9 @@ 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_get_driver_data(struct enetc_si *si); +void enetc_add_mac_addr_ht_filter(struct enetc_mac_filter *filter, + const unsigned char *addr); +void enetc_reset_mac_addr_filter(struct enetc_mac_filter *filter); int enetc_open(struct net_device *ndev); int enetc_close(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 a214749a4af6..cc3e52bd3096 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc_pf.c +++ b/drivers/net/ethernet/freescale/enetc/enetc_pf.c @@ -72,30 +72,6 @@ static void enetc_set_isol_vlan(struct enetc_hw *hw, int si, u16 vlan, u8 qos) enetc_port_wr(hw, ENETC_PSIVLANR(si), val); } -static int enetc_mac_addr_hash_idx(const u8 *addr) -{ - u64 fold = __swab64(ether_addr_to_u64(addr)) >> 16; - u64 mask = 0; - int res = 0; - int i; - - for (i = 0; i < 8; i++) - mask |= BIT_ULL(i * 6); - - for (i = 0; i < 6; i++) - res |= (hweight64(fold & (mask << i)) & 0x1) << i; - - return res; -} - -static void enetc_reset_mac_addr_filter(struct enetc_mac_filter *filter) -{ - filter->mac_addr_cnt = 0; - - bitmap_zero(filter->mac_hash_table, - ENETC_MADDR_HASH_TBL_SZ); -} - static void enetc_add_mac_addr_em_filter(struct enetc_mac_filter *filter, const unsigned char *addr) { @@ -104,16 +80,6 @@ static void enetc_add_mac_addr_em_filter(struct enetc_mac_filter *filter, filter->mac_addr_cnt++; } -static void enetc_add_mac_addr_ht_filter(struct enetc_mac_filter *filter, - const unsigned char *addr) -{ - int idx = enetc_mac_addr_hash_idx(addr); - - /* add hash table entry */ - __set_bit(idx, filter->mac_hash_table); - filter->mac_addr_cnt++; -} - static void enetc_clear_mac_ht_flt(struct enetc_si *si, int si_idx, int type) { bool err = si->errata & ENETC_ERR_UCMCSWP; @@ -145,10 +111,9 @@ static void enetc_set_mac_ht_flt(struct enetc_si *si, int si_idx, int type, } } -static void enetc_sync_mac_filters(struct enetc_pf *pf) +static void enetc_sync_mac_filters(struct enetc_si *si) { - struct enetc_mac_filter *f = pf->mac_filter; - struct enetc_si *si = pf->si; + struct enetc_mac_filter *f = si->mac_filter; int i, pos; pos = EMETC_MAC_ADDR_FILT_RES; @@ -192,10 +157,10 @@ static void enetc_sync_mac_filters(struct enetc_pf *pf) static void enetc_pf_set_rx_mode(struct net_device *ndev) { struct enetc_ndev_priv *priv = netdev_priv(ndev); - struct enetc_pf *pf = enetc_si_priv(priv->si); - struct enetc_hw *hw = &priv->si->hw; bool uprom = false, mprom = false; struct enetc_mac_filter *filter; + struct enetc_si *si = priv->si; + struct enetc_hw *hw = &si->hw; struct netdev_hw_addr *ha; u32 psipmr = 0; bool em; @@ -214,7 +179,7 @@ static void enetc_pf_set_rx_mode(struct net_device *ndev) /* first 2 filter entries belong to PF */ if (!uprom) { /* Update unicast filters */ - filter = &pf->mac_filter[UC]; + filter = &si->mac_filter[UC]; enetc_reset_mac_addr_filter(filter); em = (netdev_uc_count(ndev) == 1); @@ -230,7 +195,7 @@ static void enetc_pf_set_rx_mode(struct net_device *ndev) if (!mprom) { /* Update multicast filters */ - filter = &pf->mac_filter[MC]; + filter = &si->mac_filter[MC]; enetc_reset_mac_addr_filter(filter); netdev_for_each_mc_addr(ha, ndev) { @@ -243,7 +208,7 @@ static void enetc_pf_set_rx_mode(struct net_device *ndev) if (!uprom || !mprom) /* update PF entries */ - enetc_sync_mac_filters(pf); + enetc_sync_mac_filters(si); psipmr |= enetc_port_rd(hw, ENETC_PSIPMR) & ~(ENETC_PSIPMR_SET_UP(0) | ENETC_PSIPMR_SET_MP(0)); diff --git a/drivers/net/ethernet/freescale/enetc/enetc_pf.h b/drivers/net/ethernet/freescale/enetc/enetc_pf.h index a26a12863855..2b9d0f625f01 100644 --- a/drivers/net/ethernet/freescale/enetc/enetc_pf.h +++ b/drivers/net/ethernet/freescale/enetc/enetc_pf.h @@ -6,18 +6,6 @@ #define ENETC_PF_NUM_RINGS 8 -enum enetc_mac_addr_type {UC, MC, MADDR_TYPE}; -#define ENETC_MAX_NUM_MAC_FLT ((ENETC_MAX_NUM_VFS + 1) * MADDR_TYPE) - -#define ENETC_MADDR_HASH_TBL_SZ 64 -struct enetc_mac_filter { - union { - char mac_addr[ETH_ALEN]; - DECLARE_BITMAP(mac_hash_table, ENETC_MADDR_HASH_TBL_SZ); - }; - int mac_addr_cnt; -}; - #define ENETC_VLAN_HT_SIZE 64 enum enetc_vf_flags { @@ -52,8 +40,6 @@ struct enetc_pf { int total_vfs; /* max number of VFs, set for PF at probe */ struct enetc_vf_state *vf_state; - struct enetc_mac_filter mac_filter[ENETC_MAX_NUM_MAC_FLT]; - struct enetc_msg_swbd rxmsg[ENETC_MAX_NUM_VFS]; struct work_struct msg_task; char msg_int_name[ENETC_INT_NAME_MAX];