From patchwork Tue Jul 24 14:29:18 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Ido Schimmel X-Patchwork-Id: 10542293 X-Patchwork-Delegate: jiri@resnulli.us Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id 4FEF5112E for ; Tue, 24 Jul 2018 14:43:02 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 3EFD8212D6 for ; Tue, 24 Jul 2018 14:43:02 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 31F5428C3E; Tue, 24 Jul 2018 14:43:02 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.8 required=2.0 tests=BAD_ENC_HEADER,BAYES_00, DKIM_SIGNED,MAILING_LIST_MULTI,T_DKIM_INVALID autolearn=ham version=3.3.1 Received: from lists.ozlabs.org (lists.ozlabs.org [203.11.71.2]) (using TLSv1.2 with cipher DHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.wl.linuxfoundation.org (Postfix) with ESMTPS id 61A0228708 for ; Tue, 24 Jul 2018 14:43:01 +0000 (UTC) Received: from lists.ozlabs.org (lists.ozlabs.org [IPv6:2401:3900:2:1::3]) by lists.ozlabs.org (Postfix) with ESMTP id 41Zh0z4RzCzF07s for ; Wed, 25 Jul 2018 00:42:59 +1000 (AEST) Authentication-Results: lists.ozlabs.org; dmarc=pass (p=none dis=none) header.from=mellanox.com Authentication-Results: lists.ozlabs.org; dkim=fail reason="signature verification failed" (1024-bit key; unprotected) header.d=Mellanox.com header.i=@Mellanox.com header.b="MK5uSdtM"; dkim-atps=neutral X-Original-To: linux-mlxsw@lists.ozlabs.org Delivered-To: linux-mlxsw@lists.ozlabs.org Authentication-Results: lists.ozlabs.org; spf=pass (mailfrom) smtp.mailfrom=mellanox.com (client-ip=104.47.0.68; helo=eur01-he1-obe.outbound.protection.outlook.com; envelope-from=idosch@mellanox.com; receiver=) Authentication-Results: lists.ozlabs.org; dmarc=pass (p=none dis=none) header.from=mellanox.com Authentication-Results: lists.ozlabs.org; dkim=pass (1024-bit key; unprotected) header.d=Mellanox.com header.i=@Mellanox.com header.b="MK5uSdtM"; dkim-atps=neutral Received: from EUR01-HE1-obe.outbound.protection.outlook.com (mail-he1eur01on0068.outbound.protection.outlook.com [104.47.0.68]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-SHA384 (256/256 bits)) (No client certificate requested) by lists.ozlabs.org (Postfix) with ESMTPS id 41ZgkK33FtzDrM8 for ; Wed, 25 Jul 2018 00:30:17 +1000 (AEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Mellanox.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=G/2jhMvUbIFxD7EVJfAzJI1mXl6x2VmAAmlK1FydoCQ=; b=MK5uSdtMTHMCoGKL30ktpD+IOs73cJsZEpL2owSyx7NgrmePtfdiioJw33ToDn/4Ee6EqKZBlepd55clsunGdEJkeDx0DPAtu9XCPhbeiOV03GEoKNovLCwH3AIwTPytRKWty438QPzrokdPKb2yydl0att7tPXlwxbT8tFW2a4= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=idosch@mellanox.com; Received: from splinter.mtl.com (193.47.165.251) by AM4PR0501MB2322.eurprd05.prod.outlook.com (2603:10a6:200:53::23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.973.16; Tue, 24 Jul 2018 14:30:03 +0000 From: Ido Schimmel To: linux-internal@mellanox.com Subject: [PATCH net-next mlxsw v4 10/18] mlxsw: spectrum_acl: Allow encoding a partial key Date: Tue, 24 Jul 2018 17:29:18 +0300 Message-Id: <20180724142926.13033-11-idosch@mellanox.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20180724142926.13033-1-idosch@mellanox.com> References: <20180724142926.13033-1-idosch@mellanox.com> MIME-Version: 1.0 X-Originating-IP: [193.47.165.251] X-ClientProxiedBy: VI1P189CA0018.EURP189.PROD.OUTLOOK.COM (2603:10a6:802:2a::31) To AM4PR0501MB2322.eurprd05.prod.outlook.com (2603:10a6:200:53::23) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: aa0eb0a0-7702-4513-1f4c-08d5f171f234 X-MS-Office365-Filtering-HT: Tenant X-Microsoft-Antispam: BCL:0; PCL:0; RULEID:(7020095)(4652040)(8989117)(5600073)(711020)(4618075)(2017052603328)(7153060)(7193020); SRVR:AM4PR0501MB2322; X-Microsoft-Exchange-Diagnostics: 1; AM4PR0501MB2322; 3:/v7PxjXRAgecTcPCLx7JBaAX2eUTzN7hx7YwCbETn/EBadSgCFH8AVIslYyRyRm2Cxp1920FuzTFI5srpdMnO4vWBOaITORhn7Ih+mYQ3033QkZ9gFs7g97KZvWsnf6MtJY70EgFeixcM21MwjLeNiNY9gn8ViXFLDFDeJM/UEWT3lbwqU9rjGgm4aTSYFgS9ZUgePruvISIGfTVrApMenuvuKoBoN0Q/EtmWH+ygxilLtJFwIJSZ8zRBr+C5gpM; 25:6E5OPuzSxnJOiiFBfBm5RWOKtAP+xGXaeZmZYjw/8cUCt3woWyX9rSU1zrD0Po/AocLmNehz+oRIMVgjqDwamMlebPeTMLRERXcpxByM/q1ZDSZ3zFJCS9yNSa8ovgVUG3CMNngzNaDlVjanfzI5oDYGoNHXdk1/BR/lcXdFIAM91DctjilqK2CDgh/9DGvRZpf942kdRmXspWYbrbAoCmtpWMbwubmeWBelNtHz5hPN2Mf6ICa+jfXTS9+IwuZxr58VKY13N7KdKa6zuL7+EpIOnraDYipAU4K9S4aWTx7aC2qSAb7dCh+lHdA70td2rYNPj4rdLEXIGwwAZsKBOQ==; 31:mXibt88a5YLgaqORgaOFXeGbMhEKrPJQ2+zFOgTkzjUcvnRg51voLWhYT0+kFj6sXZMHTZcJfOYwhIbEWbU4Ar1SvPg9UWb1ftVwZi96yLS2M0rOC21pLJUKhXyy3wPxMYVvyBwjYhgrN+ZKfpTNK81X6GsefEcUSE7wKKFzT/alOvnwZQUTGqO9m9X8JxvIrc1rG2x+rq9rXD1W3oBPOCY1CbXKn3EOhK3GTsurWJo= X-MS-TrafficTypeDiagnostic: AM4PR0501MB2322: X-Microsoft-Exchange-Diagnostics: 1; AM4PR0501MB2322; 20:zOAFy6llefmIzXSIXAwGlo3J5gfINGUJPrOz7EHaV4XVxpEyJsllk6FCNfvJRPjKtltgWjTzVxqb01bXDCRWoSnS+ZpAN5cTCfb2yli44rA+YIV68sRpX0buhux/TrCEPjeBemJWwNK1NixRKPGYyfneUypvBoS+kfRftwEV77QDKwfstogWb/7fF/CrhigviDPAnK5u8M++9G0vGlfmwJdoAZz2sL3QK79HuGyDSMGEsxvA3MFQwzEPHZWHLTM9mihegv45js41UrMOkIkDAbxYIkUlmbhKPrJodf+zzai0el7BylQC75lalbj8SsHFxbGrcTXtmYslPYHR2bqfR4u6NZurXQQAFM2p0fYMIO+3cPzUr6uBXv+6Ndvw6H3RtB9Sv5ud1nRc1YLxFP654phcc11Ep4dUTczhQlsArbZExfwR5i62A3AiR1VPwA1mS8VDb6hurjcMFcBCFY5oBJGGUce7RaqprudAa5raraJfVJqtXOV6Qrhdp9X0aNB+; 4:5wtVN1ORE5EqvAXehZj1Ut6EDoT142gSnkMQPIDhqRoVigXOwIyrJ/XTD1QZkYshHweXdYqNic1X1Ae4v7UqRvTqfKz6rZNSxnP5VMLRoQ+hefgD783+tfNWYLvXUail1A6V1jNwwO62jiXgZWkc99kQ1IMHJWY2dp7xvBqkz74qyFsuUoUpc9hZAXUfEYk2UNqy5OevdgkP6pXiYCtYpMiFx2F19/lAfjvpH68ILm8qp4a43iijY8kPXN3YQon+cSL/Y1WoeDfeDGy2wbKwow== X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-MS-Exchange-SenderADCheck: 1 X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(8211001083)(6040522)(2401047)(5005006)(8121501046)(10201501046)(3002001)(93006095)(93001095)(3231311)(944501410)(52105095)(6055026)(149027)(150027)(6041310)(20161123558120)(20161123562045)(20161123564045)(20161123560045)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(6072148)(201708071742011)(7699016); SRVR:AM4PR0501MB2322; BCL:0; PCL:0; RULEID:; SRVR:AM4PR0501MB2322; X-Forefront-PRVS: 0743E8D0A6 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10009020)(1496009)(346002)(396003)(376002)(39860400002)(366004)(136003)(199004)(189003)(53936002)(97736004)(7736002)(305945005)(446003)(34206002)(107886003)(575784001)(6512007)(486006)(4326008)(25786009)(26005)(478600001)(6486002)(11346002)(16526019)(6116002)(105586002)(2616005)(956004)(16586007)(53416004)(316002)(3846002)(66066001)(1076002)(47776003)(2361001)(5660300001)(68736007)(51416003)(50226002)(2906002)(76176011)(8936002)(37006003)(106356001)(81156014)(86362001)(8676002)(386003)(36756003)(81166006)(6636002)(48376002)(2351001)(52116002)(6666003)(14444005)(476003)(50466002)(6506007); DIR:OUT; SFP:1101; SCL:1; SRVR:AM4PR0501MB2322; H:splinter.mtl.com; FPR:; SPF:None; LANG:en; PTR:InfoNoRecords; A:1; MX:1; Received-SPF: None (protection.outlook.com: mellanox.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; AM4PR0501MB2322; 23:xsEhOeB79FxOzvCFEz4DzIh9qm4GUvwc7UBaqtj?= hSoIdz+8WKZUO4PE68s37y2sGsNXrGbCpkKUfrcHwsV/sz/hjUoiNCQrSgYbsEKYNL4sZbOxmutv9t9FEC0CLc9ZaoX9t1CGXGnc12pEyUFoA+8C8LLVmd+MkqNCoFlLBl0SXogsmUyE0dzmVYICAEt29thReu/RxarZ0LiPSWq+sYhVtiAZubibeWdqmlmsEm7swFMC1k3iF5NHjqTURlIQmk6a2Zz2zyKG3oWxhCOOSdXM4YM+DFZokz8dAABTb4vIQXFyocB3PA2ZsVoL/NX67Rgb/Ow3w+MiKWQ55XKGxjM0nVzpO2ySF4OCrelEJ81BsifUmboAr8z2ZkuybBjLW/qgDLUDsK6aL+Ld3TM8lCoD9mISTYZl9OqfTgHNyUgOCQPrRzsyN+EbDujV8f/CIAZQo6sFBv73e0RfRHPQvGUuW5ZiyfQG7YdcckaI8GFatEnWar0bV6DwHQxWa0R0kmJeNFdtosuNCl7P3ws9fNUlOAemYV3vBQHSsWiGtKNnzQrB5C8inSpeLlcDF+CWR4Ya81hIqXWNjM9zsq7XiIrzZmMRADaTvcNwyDi20+h88Jr2+heQCwpW/7U66jsB9LO4RAel1vVsCwhL9Yjd5aOIfOmJZKNxl3EOVnbD3jOrTzY9cpoYf5TzPskS1IvzIlXuJilUI1l7VsguvHBMZn9rsiK6Bx/QsBSek1lqWvkP1iPUqHNlD9BpPtb13eVeMMiNWG1aOZ2xQGN8YsQYTtgWleXefBekd1HDPP9UySfrP0JuynhcyRoYPA+98Wr7rtXDUCgGZvl/ZxM1x9459G7PutYWzhZeCUtvOePHurP344aX2z2RuUqHSFsusIw1moHJXNr5sW7osnRc0VG3UZe4nb+ZFueyrYInQ64pwSLhxAWLtzpdmUO5BqS/I6X9+ZTt8l9wq1SYwY/0khfQlYL9xxEbOMxetmuZPE/aFcUVXOZiQkkhY+W2OAvQnW0UJJdci7z2gf+7uow1972YI927pyFgjtdmrTST/aM9M3bMVucRugQAelGFXZ6ADWJp54KmiTcWjfYB1e7fP1Y+iEztaBkyJBwPaVPTusPVr0J7eYTTS+TmTLS7nHcmQlLMDcq5+t+YY6A7mx/MKZBBnjKtx4rHKCJjT+kBCS9i5pz1pyxm+B+xzMFLcEQRHpflHjmZ5m6oAgpfqMMQaN0q1j0jJGWwiT+BI6NKziRGzKhPtIUtel5isi3yGbBviQuglc8tHn9ISX36X0CyvN7o8wYjDFcSdTN2K77kQBq1BCfpymlfLl3NK6lYXrpig6mlR9dNQgcW866HT9cgezFh3jQ== X-Microsoft-Antispam-Message-Info: J9onlZsWjGapdsfaomNYUgoQY+2QO2J8dZnmlgfrAMeDZEARXC39BNjlxk1exc2f8+4HUBwgx0e6V3BLVQdsvVgIOxYeU6h8Y75kptpw4LJVUM6OrhfMHijbofp/8Cuyts/9hZeYCeCrm/vaux9oxe80D1C225KPjQPklct7AoVETJQGwn0OKRMmEI9dFamInD6i6CZ00V/Hr3uKD0YmlX8b0KOrVXHaUL07TIGXI8BlfGCKwn96HR/Kh7ykaqn8y1eq/XD672QkIRKwJDhQymsKTpOj4ltiGWM1/YAwozYnpBUz8tD6UOxheaNRF3PSrK5+3E1vtOdVGT3z776jqEfv9YYSO+HavdPPKHe6FYg= X-Microsoft-Exchange-Diagnostics: 1; AM4PR0501MB2322; 6:LMCAhe04lu99RF6Q8jPr0xrn2JXK1fZR/Y8ZdIkZd67X5cFSvcx8qv7J7aMmJSy21Hq+y7JFLnQoGQs2Cva+Qg/Af8mTjE5zbplW5NVyW1ChXXb8g8C/gb15gLmkMSI0jnj5Kkmju1VAg1uPq3IPK7PoDztOXQxElL4PPY6Fw6dVGL1DQL+TOkt6dPsmMTmabqsYpsJY+jZ1XKABsgtKgbEQArUcBN4CnuXB20Q9xDLlkfikiocHFmTZUzxbALjrSvNMwjEDAPVnCggiCmR2OEFkxZ8FWwSyUE3IVZZDfYc6G95JyfG9m3LDm5V45ZIY63No8M9MT2hPm/EvmeeoypHuugOCdBxKRXfgl0B5uVzJ3NGA8QIG7wx2yvwGpcWO0fBKzodYUm5FWPMcxTlD07hBBZMCIHPyIKmxep1ae0KHVhnD1xhZnYiP2txiEEMbz5/YZcOI8oSb4D06Kjmeug==; 5:BL+yHlzjBbiy2fc2rBTx45+spcr00Fd+SDXf8mjzDHkTDEg56PBaoEG/q51DRiFqHgmZL6sYOOeHUhsQHbIDjgkZbZcuyFeGE7jSt980jUPMOM6xNU4HivR+9OazAQ19XRSqFwRI19dGF5VEB/NE3dJhsrMekBVTYN6fze6QShw=; 7:yvAJs1MAifYR9akiIJL+ytJuGYPwofNbzyuiXY9WK8Ys2l1sBisTTqRSodkIsGNSAee4MVyBWHYe8JlZSXxN90OAMlpwhdUISikdiAaZz43IRKHTycHFfWW6gFxPRhtFlAiroyFKaiioucfA+yY7sXSXC3mZ4ofkM5wpiNshvuNjx/pCm9rGpUHFStKxSnXSuKcc7+zNyUQRdytB3Kir9w3Faj2Saod78La/CVRHmX3iBLCR+dQFyzSJ0gJBhqzz SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: Mellanox.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 24 Jul 2018 14:30:03.3800 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: aa0eb0a0-7702-4513-1f4c-08d5f171f234 X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: a652971c-7d2e-4d9b-a6a4-d149256f461b X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM4PR0501MB2322 X-BeenThere: linux-mlxsw@lists.ozlabs.org X-Mailman-Version: 2.1.27 Precedence: list List-Id: mlxsw driver development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: linux-mlxsw-bounces+patchwork-linux-mlxsw=patchwork.kernel.org@lists.ozlabs.org X-Virus-Scanned: ClamAV using ClamSMTP When working with 12 key blocks in the A-TCAM, rules are split into two records, which constitute two lookups. The two records are linked using a "large entry key ID". The ID is assigned to key blocks 6 to 11 and resolved during the first lookup. The second lookup is performed using the ID and the remaining key blocks. Allow encoding a partial key so that it can be later used to check if an ID can be reused. This is done by adding two arguments to the existing encode function that specify the range of the block indexes we would like to encode. The key and mask arguments become optional, as we will not need to encode both of them all the time. Signed-off-by: Ido Schimmel Reviewed-by: Jiri Pirko --- Notes: v2: * Extend mlxsw_afk_encode() instead of creating a new function .../net/ethernet/mellanox/mlxsw/core_acl_flex_keys.c | 10 ++++++---- .../net/ethernet/mellanox/mlxsw/core_acl_flex_keys.h | 2 +- .../net/ethernet/mellanox/mlxsw/spectrum_acl_ctcam.c | 5 ++++- 3 files changed, 11 insertions(+), 6 deletions(-) diff --git a/drivers/net/ethernet/mellanox/mlxsw/core_acl_flex_keys.c b/drivers/net/ethernet/mellanox/mlxsw/core_acl_flex_keys.c index 5f8485c7640e..9649b4d9349a 100644 --- a/drivers/net/ethernet/mellanox/mlxsw/core_acl_flex_keys.c +++ b/drivers/net/ethernet/mellanox/mlxsw/core_acl_flex_keys.c @@ -457,7 +457,7 @@ mlxsw_sp_afk_encode_one(const struct mlxsw_afk_element_inst *elinst, void mlxsw_afk_encode(struct mlxsw_afk *mlxsw_afk, struct mlxsw_afk_key_info *key_info, struct mlxsw_afk_element_values *values, - char *key, char *mask) + char *key, char *mask, int block_start, int block_end) { char block_mask[MLXSW_SP_AFK_KEY_BLOCK_MAX_SIZE]; char block_key[MLXSW_SP_AFK_KEY_BLOCK_MAX_SIZE]; @@ -465,7 +465,7 @@ void mlxsw_afk_encode(struct mlxsw_afk *mlxsw_afk, enum mlxsw_afk_element element; int block_index, i; - for (i = 0; i < key_info->blocks_count; i++) { + for (i = block_start; i <= block_end; i++) { memset(block_key, 0, MLXSW_SP_AFK_KEY_BLOCK_MAX_SIZE); memset(block_mask, 0, MLXSW_SP_AFK_KEY_BLOCK_MAX_SIZE); @@ -482,8 +482,10 @@ void mlxsw_afk_encode(struct mlxsw_afk *mlxsw_afk, values->storage.mask); } - mlxsw_afk->ops->encode_block(block_key, i, key); - mlxsw_afk->ops->encode_block(block_mask, i, mask); + if (key) + mlxsw_afk->ops->encode_block(block_key, i, key); + if (mask) + mlxsw_afk->ops->encode_block(block_mask, i, mask); } } EXPORT_SYMBOL(mlxsw_afk_encode); diff --git a/drivers/net/ethernet/mellanox/mlxsw/core_acl_flex_keys.h b/drivers/net/ethernet/mellanox/mlxsw/core_acl_flex_keys.h index 2ffde915349b..18d9bfed6001 100644 --- a/drivers/net/ethernet/mellanox/mlxsw/core_acl_flex_keys.h +++ b/drivers/net/ethernet/mellanox/mlxsw/core_acl_flex_keys.h @@ -259,6 +259,6 @@ void mlxsw_afk_values_add_buf(struct mlxsw_afk_element_values *values, void mlxsw_afk_encode(struct mlxsw_afk *mlxsw_afk, struct mlxsw_afk_key_info *key_info, struct mlxsw_afk_element_values *values, - char *key, char *mask); + char *key, char *mask, int block_start, int block_end); #endif diff --git a/drivers/net/ethernet/mellanox/mlxsw/spectrum_acl_ctcam.c b/drivers/net/ethernet/mellanox/mlxsw/spectrum_acl_ctcam.c index ef0d4c0a5a1f..11b19272ab13 100644 --- a/drivers/net/ethernet/mellanox/mlxsw/spectrum_acl_ctcam.c +++ b/drivers/net/ethernet/mellanox/mlxsw/spectrum_acl_ctcam.c @@ -76,6 +76,7 @@ mlxsw_sp_acl_ctcam_region_entry_insert(struct mlxsw_sp *mlxsw_sp, { struct mlxsw_afk *afk = mlxsw_sp_acl_afk(mlxsw_sp->acl); char ptce2_pl[MLXSW_REG_PTCE2_LEN]; + unsigned int blocks_count; char *act_set; u32 priority; char *mask; @@ -91,7 +92,9 @@ mlxsw_sp_acl_ctcam_region_entry_insert(struct mlxsw_sp *mlxsw_sp, region->tcam_region_info, offset, priority); key = mlxsw_reg_ptce2_flex_key_blocks_data(ptce2_pl); mask = mlxsw_reg_ptce2_mask_data(ptce2_pl); - mlxsw_afk_encode(afk, region->key_info, &rulei->values, key, mask); + blocks_count = mlxsw_afk_key_info_blocks_count_get(region->key_info); + mlxsw_afk_encode(afk, region->key_info, &rulei->values, key, mask, 0, + blocks_count - 1); /* Only the first action set belongs here, the rest is in KVD */ act_set = mlxsw_afa_block_first_set(rulei->act_block);