Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp150335pxb; Tue, 10 Nov 2020 23:23:18 -0800 (PST) X-Google-Smtp-Source: ABdhPJwmQaTIdkKzNywqOIrRBZMREchHCQ/tx4c/2gPelE/Ox6laBObMuh16j3vL06mELLLMk/LD X-Received: by 2002:a17:906:3a1a:: with SMTP id z26mr23310142eje.519.1605079398230; Tue, 10 Nov 2020 23:23:18 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1605079398; cv=none; d=google.com; s=arc-20160816; b=xGLSg2+pbh0JhuR3LrcZfRqMN7N25VFNnZFDLHXxQ4cGQHflGo+y3LO82wLU6K+N4y EJX6tvNIkhvGEyPI2Ov7hTlM1WLcuqpcUr0HKyq6zQJijmby//b89X2cPtlwPJcHouah NeLizIB39xqTnJwpzUGt3OKLRD5cCWvvy6H3dIdAVshLUl3x5TH5syeG/PRAzLv2KL9f y8l6aLSIlWzBR779ylPgHJp1t1pZKsVbDkoT3f8XdBWstgOTjnWx3eWZD4ze3Vrh13um /jK84raGpiJzwLRoUVSeIfucDgx8UjNKOkBzKlfvWU9JLceQxYZQpgVE/10QaVsi6xkA aAPg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from :dkim-signature; bh=+cZCPLuvVKIt87SGOI9GoxwODS45RkPLzl4h3mDNwug=; b=NPnaMQmNQ55ff4X65jROOxilu92PC0eHnmbLgpv7Bh81Himb2J3VzwjeRXkrSMe82n 4gUxlhxtfflpd/l2WHq2zQQAIrrb5QFNN7O/gBhLMWqFn+vX6ct/JeXDIYZnJtdcHnd6 fm3SU/1PHl6SlpVnpMyV+kCLVIAXDQr6Eefymg4DH6+BEryGvRtSfxj8Gsc+qV2rzpIV /gqUBK0tt+lXbcr+aXA6C4GyMMEMR3Oo2DfO3f4SQicNaPpXZCM8WcNj7T89/LZfSEMQ YZxH6btoF1KwwEdNehVSefIKncR9eQRY2yuofqCDdICvYlEBYw7JcXRGI5NGlVEc5P8t D6mA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@marvell.com header.s=pfpt0220 header.b=isJ81Lnm; 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=marvell.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j5si844926edl.250.2020.11.10.23.22.55; Tue, 10 Nov 2020 23:23:18 -0800 (PST) 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=@marvell.com header.s=pfpt0220 header.b=isJ81Lnm; 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=marvell.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726533AbgKKHUh (ORCPT + 99 others); Wed, 11 Nov 2020 02:20:37 -0500 Received: from mx0a-0016f401.pphosted.com ([67.231.148.174]:27234 "EHLO mx0b-0016f401.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726316AbgKKHO0 (ORCPT ); Wed, 11 Nov 2020 02:14:26 -0500 Received: from pps.filterd (m0045849.ppops.net [127.0.0.1]) by mx0a-0016f401.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id 0AB758Rv017988; Tue, 10 Nov 2020 23:14:10 -0800 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=marvell.com; h=from : to : cc : subject : date : message-id : mime-version : content-type; s=pfpt0220; bh=+cZCPLuvVKIt87SGOI9GoxwODS45RkPLzl4h3mDNwug=; b=isJ81LnmrqTKzMoM3/CX8qlCVdc6bn/HBhDkcSiIw3euYrxVLwT5z20iG352RjjKFpJK pnbtO6AViMlsmLrgptuT68/lwKpR5pCsgPali+RzbEfNjvwoDzZdqqsi3jO/ITTEGJ2v 6tShUXdrU+gVMZf4zMjZ/FQ5aYxh7k4aRhI6AzMuWDja/a43BXqkLi1U1Rx2ko19zYGf rpTyyWKLl4RFcnqhmlFaKU7/MVf/+LsJw2HPqMq5gWDc7E8ZbaI94wF26WmKVLi0qTBP W3EDfNqfhQBBMweI23i2yGIUohZJDlklUMekHUkct9ckiF8LZAceZVlGubHzsdxnCw/6 8w== Received: from sc-exch03.marvell.com ([199.233.58.183]) by mx0a-0016f401.pphosted.com with ESMTP id 34nstu681q-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-SHA384 bits=256 verify=NOT); Tue, 10 Nov 2020 23:14:10 -0800 Received: from DC5-EXCH01.marvell.com (10.69.176.38) by SC-EXCH03.marvell.com (10.93.176.83) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Tue, 10 Nov 2020 23:14:08 -0800 Received: from maili.marvell.com (10.69.176.80) by DC5-EXCH01.marvell.com (10.69.176.38) with Microsoft SMTP Server id 15.0.1497.2 via Frontend Transport; Tue, 10 Nov 2020 23:14:09 -0800 Received: from hyd1583.caveonetworks.com (unknown [10.29.37.44]) by maili.marvell.com (Postfix) with ESMTP id B9B973F703F; Tue, 10 Nov 2020 23:14:05 -0800 (PST) From: Naveen Mamindlapalli To: , CC: , , , , , , , , Subject: [PATCH v3 net-next 00/13] Add ethtool ntuple filters support Date: Wed, 11 Nov 2020 12:43:51 +0530 Message-ID: <20201111071404.29620-1-naveenm@marvell.com> X-Mailer: git-send-email 2.16.5 MIME-Version: 1.0 Content-Type: text/plain X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.312,18.0.737 definitions=2020-11-11_02:2020-11-10,2020-11-11 signatures=0 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch series adds support for ethtool ntuple filters, unicast address filtering, VLAN offload and SR-IOV ndo handlers. All of the above features are based on the Admin Function(AF) driver support to install and delete the low level MCAM entries. Each MCAM entry is programmed with the packet fields to match and what actions to take if the match succeeds. The PF driver requests AF driver to allocate set of MCAM entries to be used to install the flows by that PF. The entries will be freed when the PF driver is unloaded. * The patches 1 to 4 adds AF driver infrastructure to install and delete the low level MCAM flow entries. * Patch 5 adds ethtool ntuple filter support. * Patch 6 adds unicast MAC address filtering. * Patch 7 adds support for dumping the MCAM entries via debugfs. * Patches 8 to 10 adds support for VLAN offload. * Patch 10 to 11 adds support for SR-IOV ndo handlers. * Patch 12 adds support to read the MCAM entries. Misc: * Removed redundant mailbox NIX_RXVLAN_ALLOC. Change-log: v3: - Fixed Saeed's review comments on v2. - Fixed modifying the netdev->flags from driver. - Fixed modifying the netdev features and hw_features after register_netdev. - Removed unwanted ndo_features_check callback. v2: - Fixed the sparse issues reported by Jakub. Hariprasad Kelam (3): octeontx2-pf: Add support for unicast MAC address filtering octeontx2-pf: Implement ingress/egress VLAN offload octeontx2-af: Handle PF-VF mac address changes Naveen Mamindlapalli (2): octeontx2-pf: Add support for SR-IOV management functions octeontx2-af: Add new mbox messages to retrieve MCAM entries Stanislaw Kardach (1): octeontx2-af: Modify default KEX profile to extract TX packet fields Subbaraya Sundeep (6): octeontx2-af: Verify MCAM entry channel and PF_FUNC octeontx2-af: Generate key field bit mask from KEX profile octeontx2-af: Add mbox messages to install and delete MCAM rules octeontx2-pf: Add support for ethtool ntuple filters octeontx2-af: Add debugfs entry to dump the MCAM rules octeontx2-af: Delete NIX_RXVLAN_ALLOC mailbox message Vamsi Attunuru (1): octeontx2-af: Modify nix_vtag_cfg mailbox to support TX VTAG entries drivers/net/ethernet/marvell/octeontx2/af/Makefile | 2 +- drivers/net/ethernet/marvell/octeontx2/af/common.h | 2 + drivers/net/ethernet/marvell/octeontx2/af/mbox.h | 170 ++- drivers/net/ethernet/marvell/octeontx2/af/npc.h | 106 +- .../ethernet/marvell/octeontx2/af/npc_profile.h | 71 +- drivers/net/ethernet/marvell/octeontx2/af/rvu.c | 16 +- drivers/net/ethernet/marvell/octeontx2/af/rvu.h | 71 +- .../ethernet/marvell/octeontx2/af/rvu_debugfs.c | 197 +++ .../net/ethernet/marvell/octeontx2/af/rvu_nix.c | 305 ++++- .../net/ethernet/marvell/octeontx2/af/rvu_npc.c | 462 ++++++- .../net/ethernet/marvell/octeontx2/af/rvu_npc_fs.c | 1334 ++++++++++++++++++++ .../net/ethernet/marvell/octeontx2/af/rvu_struct.h | 11 + .../net/ethernet/marvell/octeontx2/nic/Makefile | 2 +- .../ethernet/marvell/octeontx2/nic/otx2_common.c | 8 +- .../ethernet/marvell/octeontx2/nic/otx2_common.h | 59 + .../ethernet/marvell/octeontx2/nic/otx2_ethtool.c | 58 +- .../ethernet/marvell/octeontx2/nic/otx2_flows.c | 820 ++++++++++++ .../net/ethernet/marvell/octeontx2/nic/otx2_pf.c | 307 ++++- .../net/ethernet/marvell/octeontx2/nic/otx2_txrx.c | 16 + .../net/ethernet/marvell/octeontx2/nic/otx2_vf.c | 5 + 20 files changed, 3862 insertions(+), 160 deletions(-) create mode 100644 drivers/net/ethernet/marvell/octeontx2/af/rvu_npc_fs.c create mode 100644 drivers/net/ethernet/marvell/octeontx2/nic/otx2_flows.c -- 2.16.5