From patchwork Fri Jan 6 08:53:09 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Steen Hegelund X-Patchwork-Id: 3653 Return-Path: Delivered-To: ouuuleilei@gmail.com Received: by 2002:a5d:4e01:0:0:0:0:0 with SMTP id p1csp718668wrt; Fri, 6 Jan 2023 00:54:34 -0800 (PST) X-Google-Smtp-Source: AMrXdXvTWZHl9nZ4sc1DHtIZNylBTAZ99oOjiCcPyNQd7pev5xEfM52bJWB/vSSzHAQty8Esvgnr X-Received: by 2002:a17:907:a485:b0:7c1:709d:fa49 with SMTP id vp5-20020a170907a48500b007c1709dfa49mr59209270ejc.18.1672995274799; Fri, 06 Jan 2023 00:54:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1672995274; cv=none; d=google.com; s=arc-20160816; b=AmN1OdUrD0KLswnSzdNhqYHDt7Ut/Txf6QhL3MlsnYOx9vSH49Y9RpRV1XFEo3G6tA uo1rjexTfsh+eZDvkUKEkwotpcdhjQXMB7M1fnDAdlnNSx3QyUSm2ml8auN4Zz0UFMAs MLR634dlzbDs+MEXcfKz0ixre+pbUHV2454m1/kKu/ZJEvET1stbvbFbXImM3lAqKrxV +5qtVkUdcCooUpmOl7ZGjZt9A9/RFi2gzuDigAmAE9o5t8AO0OBAJNwYC6DMLUOMhBmc Q9nD7hOor3BdNmmxYvpV38PVwCgTo6x4cTuyVLrrSNp4R3aGPSMNwBBz1sF5XAaRTLC/ tVxg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=aoMetypWoAz6lNl/E6ZNgj9Zpty5+s1eJkrUdMwmgsA=; b=OUA/iTwgln924V5cBuijZFtH/nXKlZRSpT0t93zG0eUaazWd2eWdrF/71wKv20ne1a LEj1CSp65D/khWcrtVsoBNMkTFgCDNauyBaf8e7bVE/H1N7IQp9SMTKlMk1bXFi5ubB/ scO52EMWGkav/3WowI7BR1FFD5q+d8N8bcp/yFV4Z1LMHWBrtG12vov6RK4gWSyud0J9 Co6QthPo5nmU8GD+vBJBMTegAw26DU/Q8kJw9oRgDD7i/pkSGTNF7bUkvlYvxh7EZFDV kbMc9OEPn91+wIz7hpisMlwtg1E1remEKpzWvtWKljubL6TcVN2GrlL2JDirqFuXeec1 YdkA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@microchip.com header.s=mchp header.b=Y3zWSA5Z; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=microchip.com Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id qq18-20020a17090720d200b007c0fa609b09si615996ejb.771.2023.01.06.00.54.10; Fri, 06 Jan 2023 00:54:34 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@microchip.com header.s=mchp header.b=Y3zWSA5Z; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=microchip.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230062AbjAFIxm (ORCPT + 99 others); Fri, 6 Jan 2023 03:53:42 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58248 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229737AbjAFIxe (ORCPT ); Fri, 6 Jan 2023 03:53:34 -0500 Received: from esa.microchip.iphmx.com (esa.microchip.iphmx.com [68.232.154.123]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7F4A8669A5; Fri, 6 Jan 2023 00:53:30 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=microchip.com; i=@microchip.com; q=dns/txt; s=mchp; t=1672995210; x=1704531210; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=MmxryeLxcxvGAqL6Nh+RI2p670mn6TUZTzuDuWcR2Io=; b=Y3zWSA5ZOzFWl68UFbi3q7bZ3t1BE93RIqk/DJu9qlONHSjGcGd2Y9TB bH/XMAlnrkO+tyMZb3qdELd1MRCCjSBvf+E0Nazwmq4IN7Vlw+jzL/Aqg emt3Uzf2e1Wr4p8vnB3uFkZepiolIEk5R9QeuRPdhMg/GkZzEIEgMLfKm lZkuP7L4sMVqwMg2c5pj1+4z+08LptK6klhzGPtGzbdUcA6EIqpjbJOFl 97mV4ZsfNSVWLqM0skTXX1IlUiZ3hMsk22/c/8IeSFlxkeWmWDY0bc1Dx 63qy42SNSRxOAw4NZCiUl5e3RYlvsYm/qIA+5IZG3Oh9R18RZ7uMNOXKQ w==; X-IronPort-AV: E=Sophos;i="5.96,304,1665471600"; d="scan'208";a="131114169" Received: from unknown (HELO email.microchip.com) ([170.129.1.10]) by esa6.microchip.iphmx.com with ESMTP/TLS/AES256-SHA256; 06 Jan 2023 01:53:29 -0700 Received: from chn-vm-ex02.mchp-main.com (10.10.85.144) by chn-vm-ex04.mchp-main.com (10.10.85.152) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.16; Fri, 6 Jan 2023 01:53:27 -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.16 via Frontend Transport; Fri, 6 Jan 2023 01:53:24 -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" , , , , "Steen Hegelund" , Daniel Machon , Horatiu Vultur , Lars Povlsen , Dan Carpenter , Michael Walle Subject: [PATCH net-next v2 0/8] Add support for two classes of VCAP rules Date: Fri, 6 Jan 2023 09:53:09 +0100 Message-ID: <20230106085317.1720282-1-steen.hegelund@microchip.com> X-Mailer: git-send-email 2.39.0 MIME-Version: 1.0 X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED, RCVD_IN_MSPIKE_H2,SPF_HELO_PASS,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1754262693391684561?= X-GMAIL-MSGID: =?utf-8?q?1754262693391684561?= This adds support for two classes of VCAP rules: - Permanent rules (added e.g. for PTP support) - TC user rules (added by the TC userspace tool) For this to work the VCAP Loopups must be enabled from boot, so that the "internal" clients like PTP can add rules that are always active. When the TC tool add a flower filter the VCAP rule corresponding to this filter will be disabled (kept in memory) until a TC matchall filter creates a link from chain 0 to the chain (lookup) where the flower filter was added. When the flower filter is enabled it will be written to the appropriate VCAP lookup and become active in HW. Likewise the flower filter will be disabled if there is no link from chain 0 to the chain of the filter (lookup), and when that happens the corresponding VCAP rule will be read from the VCAP instance and stored in memory until it is deleted or enabled again. Version History: ================ v2 Adding a missing goto exit in vcap_add_rule (Dan Carpenter). Added missing checks for error returns in vcap_enable_rule. v1 Initial version Steen Hegelund (8): net: microchip: vcap api: Erase VCAP cache before encoding rule net: microchip: sparx5: Reset VCAP counter for new rules net: microchip: vcap api: Always enable VCAP lookups net: microchip: vcap api: Convert multi-word keys/actions when encoding net: microchip: vcap api: Use src and dst chain id to chain VCAP lookups net: microchip: vcap api: Check chains when adding a tc flower filter net: microchip: vcap api: Add a storage state to a VCAP rule net: microchip: vcap api: Enable/Disable rules via chains in VCAP HW .../ethernet/microchip/lan966x/lan966x_goto.c | 10 +- .../ethernet/microchip/lan966x/lan966x_main.h | 3 +- .../microchip/lan966x/lan966x_tc_flower.c | 30 +- .../microchip/lan966x/lan966x_tc_matchall.c | 16 +- .../microchip/lan966x/lan966x_vcap_impl.c | 24 +- .../microchip/sparx5/sparx5_tc_flower.c | 28 +- .../microchip/sparx5/sparx5_tc_matchall.c | 16 +- .../microchip/sparx5/sparx5_vcap_debugfs.c | 2 +- .../microchip/sparx5/sparx5_vcap_impl.c | 29 +- .../net/ethernet/microchip/vcap/vcap_api.c | 762 +++++++++++++----- .../net/ethernet/microchip/vcap/vcap_api.h | 5 - .../ethernet/microchip/vcap/vcap_api_client.h | 8 +- .../microchip/vcap/vcap_api_debugfs.c | 57 +- .../microchip/vcap/vcap_api_debugfs_kunit.c | 10 +- .../ethernet/microchip/vcap/vcap_api_kunit.c | 32 +- .../microchip/vcap/vcap_api_private.h | 12 +- 16 files changed, 694 insertions(+), 350 deletions(-)