From patchwork Wed Nov 2 11:57:30 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Steen Hegelund X-Patchwork-Id: 13028061 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 67CACC4332F for ; Wed, 2 Nov 2022 11:59:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version: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:In-Reply-To:References: List-Owner; bh=J3PQDe9A2QvSBK9tbkzBaWZOEV43NAMnYaqUmrLxgUA=; b=pksUuncXZw847W VOvXiUVn2eizj8MXIwWUZcZgCRqStFWc7vNsRp7Wi39YVK/XXE+JcfoOLhKy2dqops5wOYwWSknjw IrsD8IxXcuuXQ25hUKF38pqyC3UKoH4ZqbgG45IOh11VANlvBFNW6y9bAzdYxJlioLIxsgEVbNPXi leAnKADFxI+kmyW2gVf76fdr60DF3UTRY0pbLpUH4tCUGUPRBB0WV2F4fjdk9DzgmKYa91WXXGoq5 xAdyphAuzWGBzLGNuSG7tZJm+fbQ0h8Y3yfEbomn6feT0Fypn40D5QuhkFT5/h0ctgrry8O8ItoES e1C0R/YetSfdbUKrORCA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1oqCNn-00Ar80-RF; Wed, 02 Nov 2022 11:58:11 +0000 Received: from esa.microchip.iphmx.com ([68.232.154.123]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1oqCNa-00Ar12-T0 for linux-arm-kernel@lists.infradead.org; Wed, 02 Nov 2022 11:58:01 +0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=microchip.com; i=@microchip.com; q=dns/txt; s=mchp; t=1667390278; x=1698926278; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=eHXjCjR53EpmujEkku0tYqKqKQxplCZnvIGw4J5fU5o=; b=OmRReAH+LfJzGhpQF8h8QXOQsP5w9upKPN+DAGWIkZKBnmsi8z+/JPYY Y4mfDrtpBFErPwgRIHhlTEXlFLmZPKsVcxEw2+YcR2iLO/uaFeEPscOEe rK3FhxssZFrwEyBqN4x6deqPbnC/2TZ68cA26rrNui1cF7L4Fup+CBwSw ioJsH+tRCoJzPkdUY2h/Gy+9BPv9I4O8hrfWCM6WkzLZ/xU84sHaDBN4Z phiK45JKAAZRWhmL+tKyNzLAqQZ4jlyUOE5vdbSWryFzoqPHDw3/6p3bE nvALZ1iPuKRfUrXVQ1MgcH3X4JuzY2hbifKNRmdFtUD7r9e/XBZaKE/qs Q==; X-IronPort-AV: E=Sophos;i="5.95,232,1661842800"; d="scan'208";a="121449310" Received: from unknown (HELO email.microchip.com) ([170.129.1.10]) by esa6.microchip.iphmx.com with ESMTP/TLS/AES256-SHA256; 02 Nov 2022 04:57:47 -0700 Received: from chn-vm-ex02.mchp-main.com (10.10.85.144) by chn-vm-ex03.mchp-main.com (10.10.85.151) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.12; Wed, 2 Nov 2022 04:57:46 -0700 Received: from den-dk-m31857.microchip.com (10.10.115.15) by chn-vm-ex02.mchp-main.com (10.10.85.144) with Microsoft SMTP Server id 15.1.2507.12 via Frontend Transport; Wed, 2 Nov 2022 04:57:43 -0700 From: Steen Hegelund To: "David S . Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni CC: Steen Hegelund , , Randy Dunlap , "Casper Andersson" , Russell King , Wan Jiabing , "Nathan Huckleberry" , , , , "Daniel Machon" , Horatiu Vultur , Lars Povlsen Subject: [PATCH net-next v4 0/7] Extend TC key support for Sparx5 IS2 VCAP Date: Wed, 2 Nov 2022 12:57:30 +0100 Message-ID: <20221102115737.4118808-1-steen.hegelund@microchip.com> X-Mailer: git-send-email 2.38.1 MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20221102_045759_013107_6C91E5C4 X-CRM114-Status: GOOD ( 13.74 ) 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 This provides extended tc flower filter key support for the Sparx5 VCAP functionality. It builds on top of the initial IS2 VCAP support found in this series: https://lore.kernel.org/all/20221020130904.1215072-1-steen.hegelund@microchip.com/ Overview: ========= The added flower filter key (dissector) support is this: - ipv4_addr (sip and dip) - ipv6_addr (sip and dip) - control (IPv4 fragments) - portnum (tcp and udp port numbers) - basic (L3 and L4 protocol) - vlan (outer vlan tag info) - tcp (tcp flags) - ip (tos field) The IS2 VCAP supports classified VLAN information which amounts to the outer VLAN info in case of multiple tags. Functionality: ============== Before frames can match IS2 VCAP rules with e.g an IPv4 source address, the IS2 VCAPs keyset configuration must include keyset that contains a IPv4 source address and this must be configured for the lookup/port/traffic-type that you want to match on. The Sparx5 IS2 VCAP has the following traffic types: - Non-Ethernet frames - IPv4 Unicast frames - IPv4 Multicast frames - IPv6 Unicast frames - IPv6 Multicast frames - ARP frames So to cover IPv4 traffic the two IPv4 categories must be configured with a keyset that contains IPv4 address information such as the VCAP_KFS_IP4_TCP_UDP keyset. The IPv4 and IPv6 traffic types are configured with useful default keysets, in later series we will use the tc template functionality when we want to change these defaults. The flower filter must contain a goto action as its last action and the chain id must specify a destination outside the current VCAP lookup. Delivery: ========= This is current plan for delivering the full VCAP feature set of Sparx5: Version History: ================ v4 Add support for TC flower filter goto action and a check of the actions: check action combinations and the goto chain id. v3 Add some more details to the explanation in the commit message about support for MAC_ETYPE keysets and "protocol all" as well as the classified VLAN information. This is done to help testing the feature. No implementation changes in this version. v2 Split one of the KUNIT tests into 3 tests to fix a kernel robot build warning. v1 Initial version Steen Hegelund (7): net: microchip: sparx5: Differentiate IPv4 and IPv6 traffic in keyset config net: microchip: sparx5: Adding more tc flower keys for the IS2 VCAP net: microchip: sparx5: Find VCAP lookup from chain id net: microchip: sparx5: Adding TC goto action and action checking net: microchip: sparx5: Match keys in configured port keysets net: microchip: sparx5: Let VCAP API validate added key- and actionfields net: microchip: sparx5: Adding KUNIT tests of key/action values in VCAP API .../microchip/sparx5/sparx5_tc_flower.c | 481 +++++++++++++++++- .../microchip/sparx5/sparx5_vcap_impl.c | 168 +++++- .../net/ethernet/microchip/vcap/vcap_api.c | 268 +++++++++- .../ethernet/microchip/vcap/vcap_api_client.h | 15 + .../ethernet/microchip/vcap/vcap_api_kunit.c | 447 ++++++++++++++++ 5 files changed, 1338 insertions(+), 41 deletions(-)