From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id 7C920A0543; Tue, 25 Oct 2022 08:31:03 +0200 (CEST) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 2FA4542B6C; Tue, 25 Oct 2022 08:31:03 +0200 (CEST) Received: from NAM12-BN8-obe.outbound.protection.outlook.com (mail-bn8nam12on2081.outbound.protection.outlook.com [40.107.237.81]) by mails.dpdk.org (Postfix) with ESMTP id 61351410FB for ; Tue, 25 Oct 2022 08:31:01 +0200 (CEST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=DpKNRgvZfzmydEEiGJO692NsbQDkdctKCaGco94pKkhd+sbO2rjGA3pGmiD71jF2vUvuO8qEpd/WLLo70At5SSd8zBFwN5fytrdGiHBxW/OMO628gp4uIhWZJOoyBQjn6f/ZzAwM6xvL53j3PaVBbxt4TXZ5vQ6dzdaSQ/MY+Rr9gR/mUHo7tK7JvVhmZewU07MxWv8oiuVvYbK9SdE86t9Jd7DIeU0Yx0JdDjQXic1q8X6tx8uOSTq5nLpHyXSusjSS0Ta2VAZj8mC1owDUPFBeFsCpO18zvEY47spQAEtOBVv5Nki2irNLIQO3LAEnnD/g29GtZFneDHWxEsi5Iw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; 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=2ZT7ebXDBiEme6TW75i51ZHlYMlh4MTfGoMhLmyuoBA=; b=aVBx/h8vb/XZXj49zcpkwYHw65oZO+NCwlqeefGGkGjvFff5bJ1QUJFxQe3+ks0yR3wVXADKPw4dFYZBV1jsZP/d9gfVE1qQ6JUK+6E4MvFRzB2gm0pPoR4bEWS/jc2VH2udwx7vYTpJ3palnJ82hxCQl4uXfbG8ADlpjp5844yCdxRP9mfEvXOdMvqTweriqyVi3u5/0Wz8VbULoLSYjvTc8kqjNMxVaNKnwhHA+XuR2ZATbfsnHK+Cf3uALdjQqi+iF1eI9wKEeKAHAv22MZ2HJk7i1WASItYGlM9zVh0YrSEzmORn7LWO+Gmsd6lWQ8QaxpAAlna2X8855dh8iw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 216.228.117.160) smtp.rcpttodomain=monjalon.net smtp.mailfrom=nvidia.com; dmarc=pass (p=reject sp=reject pct=100) action=none header.from=nvidia.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=2ZT7ebXDBiEme6TW75i51ZHlYMlh4MTfGoMhLmyuoBA=; b=etLab3gmRpkgshs7LriBFgNFZ+o/yxytTE+loReRJnQX87G5AhSUYd28wpg9/cTLu01kyjznQv1KjrccamvwoJ8KxL6Ak6YqSA9CpCqzY0qhSBnpChrRgJhXl/aSBf/iV9zBSWXuwTmbk5rmveoAdYRNry82BXXHfy8OFR7YriIOWxsHyvlmnSsaov5Gaezlt3sl0taYMqX8dYQg7IY4qDfaCKElqy33SDW4GZ0mHHTrnvTQcr5SRfGMjNRPMyMM1bXntVys5Iyis1jZTngkc+WARYXHEDCCxCoyzHeN5vUUQgLpmYmrWIA1fE2Yv71MQfdj8TKE6nO1wolvCYlTBg== Received: from MW4PR04CA0383.namprd04.prod.outlook.com (2603:10b6:303:81::28) by DM4PR12MB5085.namprd12.prod.outlook.com (2603:10b6:5:388::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5746.28; Tue, 25 Oct 2022 06:30:59 +0000 Received: from CO1NAM11FT050.eop-nam11.prod.protection.outlook.com (2603:10b6:303:81:cafe::b0) by MW4PR04CA0383.outlook.office365.com (2603:10b6:303:81::28) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5746.26 via Frontend Transport; Tue, 25 Oct 2022 06:30:58 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 216.228.117.160) smtp.mailfrom=nvidia.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=nvidia.com; Received-SPF: Pass (protection.outlook.com: domain of nvidia.com designates 216.228.117.160 as permitted sender) receiver=protection.outlook.com; client-ip=216.228.117.160; helo=mail.nvidia.com; pr=C Received: from mail.nvidia.com (216.228.117.160) by CO1NAM11FT050.mail.protection.outlook.com (10.13.174.79) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5746.16 via Frontend Transport; Tue, 25 Oct 2022 06:30:58 +0000 Received: from rnnvmail201.nvidia.com (10.129.68.8) by mail.nvidia.com (10.129.200.66) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.26; Mon, 24 Oct 2022 23:30:53 -0700 Received: from nvidia.com (10.126.230.35) by rnnvmail201.nvidia.com (10.129.68.8) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.29; Mon, 24 Oct 2022 23:30:52 -0700 From: Sean Zhang To: , Matan Azrad , "Viacheslav Ovsiienko" CC: Subject: [v4] net/mlx5: support matching flow on port representor ID Date: Tue, 25 Oct 2022 06:30:35 +0000 Message-ID: <20221025063037.266580-1-xiazhang@nvidia.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20221024014815.10598-1-xiazhang@nvidia.com> References: <20221024014815.10598-1-xiazhang@nvidia.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-Originating-IP: [10.126.230.35] X-ClientProxiedBy: rnnvmail201.nvidia.com (10.129.68.8) To rnnvmail201.nvidia.com (10.129.68.8) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CO1NAM11FT050:EE_|DM4PR12MB5085:EE_ X-MS-Office365-Filtering-Correlation-Id: 7cd833c0-af4e-41b6-f113-08dab6527a85 X-LD-Processed: 43083d15-7273-40c1-b7db-39efd9ccc17a,ExtAddr X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: kLQGfcU6BS2yPPi9asfgRYukNyBjH9n9dLalep5C864UdbsM3q+/otTlAc5ifYBmMmT6XNc0VJ1NbY9rHgBZElqSg3j89RJmQQV2nv/XQOlsFSNl5u8OxINLLbHYXbSy6aPLwY/esSPNlmqTZkYHTJc9hxPr4XByWmll96VmZZbfGWhCo6WkjzLB1xpzjMQ4q+ReMrp04p7Tmv2FtnAQ1jtk3UK7DShYtjqtL986+JsAw4WCc+/Tha+GWWed01LvsJIZWj836CcQFBMwyTGRga6g+Nf+o5YrRhCV7lbo1bn7cZEwjRY8+zimsmhi+5D6+mDzM0CqzeMQ6et+zKo5ydEtZwJwHaYRgjkSKqDbDDohsdoDOEZQC5umuRqGzYNzs2s2V4z/ggCl6HP5HZppfVLg83440kQDArJYH2Yu3sXtBl73cHs/JgKfuMo5AxZXBk9Uc7zxLdw7Lpgb4PMnPPaJwASkVyvHapCvYZSOmYYVpxS0hBIeobQXMFpPgsTZFiBCrk9mss5qZvj1TuXT0fZ331hoqvwxCVevdgLrB4c733GCLXL3cCIgZ6zqoDL+8WeFCdDUZYr2ceUAMrgvqYxOgZcS2jkFpDVIPiui1Pw83U50CVCquEcVFsVjkAy4VALR+hC/10otAcOllZSZl936IYwyVzS/YCIxwecij2gGqXJGJn0co9XR+6CZ2cL4BUqwU9qZVjVZFmo3w7crBD/tNMIToOAlgu7o2Ljcv9LXVOghqqBu3lc3mszIlrDypEMY+Fqu9NsGHdKFWugtd1ZEXXxyRUtsU6XG9pfixzjyZY70LMImji5O4UZyyYfabCFENC1f4NgrDewBun4fboZTmWoa7eYjk4W3gzyR/E8= X-Forefront-Antispam-Report: CIP:216.228.117.160; CTRY:US; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:mail.nvidia.com; PTR:dc6edge1.nvidia.com; CAT:NONE; SFS:(13230022)(4636009)(136003)(39860400002)(376002)(346002)(396003)(451199015)(40470700004)(36840700001)(46966006)(316002)(6636002)(110136005)(966005)(5660300002)(8676002)(4326008)(70206006)(36756003)(8936002)(70586007)(41300700001)(40460700003)(36860700001)(55016003)(82740400003)(40480700001)(356005)(7636003)(6286002)(86362001)(26005)(82310400005)(426003)(47076005)(7696005)(83380400001)(186003)(336012)(16526019)(1076003)(2616005)(6666004)(478600001)(2906002); DIR:OUT; SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 25 Oct 2022 06:30:58.4580 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 7cd833c0-af4e-41b6-f113-08dab6527a85 X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a; Ip=[216.228.117.160]; Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: CO1NAM11FT050.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM4PR12MB5085 X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Add support for port_representor item, it will match on traffic originated from representor port specified in the pattern. This item is supported in FDB steering domain only (in the flow with transfer attribute). For example, below flow will redirect the destination of traffic from ethdev 1 to ethdev 2. testpmd> ... pattern eth / port_representor port_id is 1 / end actions represented_port ethdev_port_id 2 / ... To handle abovementioned item, Tx queue matching is added in the driver, and the flow will be expanded to number of the Tx queues. If the spec of port_representor is NULL, the flow will not be expanded and match on traffic from any representor port. Signed-off-by: Sean Zhang Acked-by: Viacheslav Ovsiienko --- The depending patches as below: [1] http://patches.dpdk.org/project/dpdk/cover/20220930125315.5079-1-suanmingm@nvidia.com --- v4 - update the commit title v3 - rebase to the latest version v2 - commit message updated and add missing feature in doc --- drivers/net/mlx5/mlx5_flow.c | 116 ++++++++++++++++++++++++++++++-- drivers/net/mlx5/mlx5_flow_dv.c | 11 ++- 2 files changed, 122 insertions(+), 5 deletions(-) diff --git a/drivers/net/mlx5/mlx5_flow.c b/drivers/net/mlx5/mlx5_flow.c index e19e9b20ed..64e48ce6d4 100644 --- a/drivers/net/mlx5/mlx5_flow.c +++ b/drivers/net/mlx5/mlx5_flow.c @@ -128,6 +128,15 @@ struct mlx5_flow_expand_node { */ }; +/** Keep same format with mlx5_flow_expand_rss to share the buffer for expansion. */ +struct mlx5_flow_expand_sqn { + uint32_t entries; /** Number of entries */ + struct { + struct rte_flow_item *pattern; /**< Expanded pattern array. */ + uint32_t priority; /**< Priority offset for each expansion. */ + } entry[]; +}; + /* Optional expand field. The expansion alg will not go deeper. */ #define MLX5_EXPANSION_NODE_OPTIONAL (UINT64_C(1) << 0) @@ -576,6 +585,88 @@ mlx5_flow_expand_rss(struct mlx5_flow_expand_rss *buf, size_t size, return lsize; } +/** + * Expand SQN flows into several possible flows according to the Tx queue + * number + * + * @param[in] buf + * Buffer to store the result expansion. + * @param[in] size + * Buffer size in bytes. If 0, @p buf can be NULL. + * @param[in] pattern + * User flow pattern. + * @param[in] sq_specs + * Buffer to store sq spec. + * + * @return + * 0 for success and negative value for failure + * + */ +static int +mlx5_flow_expand_sqn(struct mlx5_flow_expand_sqn *buf, size_t size, + const struct rte_flow_item *pattern, + struct mlx5_rte_flow_item_sq *sq_specs) +{ + const struct rte_flow_item *item; + bool port_representor = false; + size_t user_pattern_size = 0; + struct rte_eth_dev *dev; + struct mlx5_priv *priv; + void *addr = NULL; + uint16_t port_id; + size_t lsize; + int elt = 2; + uint16_t i; + + buf->entries = 0; + for (item = pattern; item->type != RTE_FLOW_ITEM_TYPE_END; item++) { + if (item->type == RTE_FLOW_ITEM_TYPE_PORT_REPRESENTOR) { + const struct rte_flow_item_ethdev *pid_v = item->spec; + + if (!pid_v) + return 0; + port_id = pid_v->port_id; + port_representor = true; + } + user_pattern_size += sizeof(*item); + } + if (!port_representor) + return 0; + dev = &rte_eth_devices[port_id]; + priv = dev->data->dev_private; + buf->entry[0].pattern = (void *)&buf->entry[priv->txqs_n]; + lsize = offsetof(struct mlx5_flow_expand_sqn, entry) + + sizeof(buf->entry[0]) * priv->txqs_n; + if (lsize + (user_pattern_size + sizeof(struct rte_flow_item) * elt) * priv->txqs_n > size) + return -EINVAL; + addr = buf->entry[0].pattern; + for (i = 0; i != priv->txqs_n; ++i) { + struct rte_flow_item pattern_add[] = { + { + .type = (enum rte_flow_item_type) + MLX5_RTE_FLOW_ITEM_TYPE_SQ, + .spec = &sq_specs[i], + }, + { + .type = RTE_FLOW_ITEM_TYPE_END, + }, + }; + struct mlx5_txq_ctrl *txq = mlx5_txq_get(dev, i); + + if (txq == NULL) + return -EINVAL; + buf->entry[i].pattern = addr; + sq_specs[i].queue = mlx5_txq_get_sqn(txq); + mlx5_txq_release(dev, i); + rte_memcpy(addr, pattern, user_pattern_size); + addr = (void *)(((uintptr_t)addr) + user_pattern_size); + rte_memcpy(addr, pattern_add, sizeof(struct rte_flow_item) * elt); + addr = (void *)(((uintptr_t)addr) + sizeof(struct rte_flow_item) * elt); + buf->entries++; + } + return 0; +} + enum mlx5_expansion { MLX5_EXPANSION_ROOT, MLX5_EXPANSION_ROOT_OUTER, @@ -5425,6 +5516,11 @@ flow_meter_split_prep(struct rte_eth_dev *dev, memcpy(sfx_items, items, sizeof(*sfx_items)); sfx_items++; break; + case RTE_FLOW_ITEM_TYPE_PORT_REPRESENTOR: + flow_src_port = 0; + memcpy(sfx_items, items, sizeof(*sfx_items)); + sfx_items++; + break; case RTE_FLOW_ITEM_TYPE_VLAN: /* Determine if copy vlan item below. */ vlan_item_src = items; @@ -6080,7 +6176,8 @@ flow_sample_split_prep(struct rte_eth_dev *dev, }; /* Prepare the suffix subflow items. */ for (; items->type != RTE_FLOW_ITEM_TYPE_END; items++) { - if (items->type == RTE_FLOW_ITEM_TYPE_PORT_ID) { + if (items->type == RTE_FLOW_ITEM_TYPE_PORT_ID || + items->type == RTE_FLOW_ITEM_TYPE_PORT_REPRESENTOR) { memcpy(sfx_items, items, sizeof(*sfx_items)); sfx_items++; } @@ -6893,7 +6990,7 @@ flow_list_create(struct rte_eth_dev *dev, enum mlx5_flow_type type, int indir_actions_n = MLX5_MAX_INDIRECT_ACTIONS; union { struct mlx5_flow_expand_rss buf; - uint8_t buffer[4096]; + uint8_t buffer[8192]; } expand_buffer; union { struct rte_flow_action actions[MLX5_MAX_SPLIT_ACTIONS]; @@ -6907,6 +7004,7 @@ flow_list_create(struct rte_eth_dev *dev, enum mlx5_flow_type type, struct rte_flow_item items[MLX5_MAX_SPLIT_ITEMS]; uint8_t buffer[2048]; } items_tx; + struct mlx5_rte_flow_item_sq sq_specs[RTE_MAX_QUEUES_PER_PORT]; struct mlx5_flow_expand_rss *buf = &expand_buffer.buf; struct mlx5_flow_rss_desc *rss_desc; const struct rte_flow_action *p_actions_rx; @@ -6995,8 +7093,18 @@ flow_list_create(struct rte_eth_dev *dev, enum mlx5_flow_type type, mlx5_dbg__print_pattern(buf->entry[i].pattern); } } else { - buf->entries = 1; - buf->entry[0].pattern = (void *)(uintptr_t)items; + ret = mlx5_flow_expand_sqn((struct mlx5_flow_expand_sqn *)buf, + sizeof(expand_buffer.buffer), + items, sq_specs); + if (ret) { + rte_flow_error_set(error, ENOMEM, RTE_FLOW_ERROR_TYPE_HANDLE, + NULL, "not enough memory for rte_flow"); + goto error; + } + if (buf->entries == 0) { + buf->entries = 1; + buf->entry[0].pattern = (void *)(uintptr_t)items; + } } rss_desc->shared_rss = flow_get_shared_rss_action(dev, indir_actions, indir_actions_n); diff --git a/drivers/net/mlx5/mlx5_flow_dv.c b/drivers/net/mlx5/mlx5_flow_dv.c index dbe55a5103..677b85bd8d 100644 --- a/drivers/net/mlx5/mlx5_flow_dv.c +++ b/drivers/net/mlx5/mlx5_flow_dv.c @@ -7185,6 +7185,7 @@ flow_dv_validate(struct rte_eth_dev *dev, const struct rte_flow_attr *attr, port_id_item = items; break; case RTE_FLOW_ITEM_TYPE_REPRESENTED_PORT: + case RTE_FLOW_ITEM_TYPE_PORT_REPRESENTOR: ret = flow_dv_validate_item_represented_port (dev, items, attr, item_flags, error); if (ret < 0) @@ -13607,6 +13608,7 @@ flow_dv_translate_items_sws(struct rte_eth_dev *dev, mlx5_flow_get_thread_workspace())->rss_desc, }; struct mlx5_dv_matcher_workspace wks_m = wks; + int item_type; int ret = 0; int tunnel; @@ -13616,7 +13618,8 @@ flow_dv_translate_items_sws(struct rte_eth_dev *dev, RTE_FLOW_ERROR_TYPE_ITEM, NULL, "item not supported"); tunnel = !!(wks.item_flags & MLX5_FLOW_LAYER_TUNNEL); - switch (items->type) { + item_type = items->type; + switch (item_type) { case RTE_FLOW_ITEM_TYPE_CONNTRACK: flow_dv_translate_item_aso_ct(dev, match_mask, match_value, items); @@ -13628,6 +13631,12 @@ flow_dv_translate_items_sws(struct rte_eth_dev *dev, wks.last_item = tunnel ? MLX5_FLOW_ITEM_INNER_FLEX : MLX5_FLOW_ITEM_OUTER_FLEX; break; + case MLX5_RTE_FLOW_ITEM_TYPE_SQ: + flow_dv_translate_item_sq(match_value, items, + MLX5_SET_MATCHER_SW_V); + flow_dv_translate_item_sq(match_mask, items, + MLX5_SET_MATCHER_SW_M); + break; default: ret = flow_dv_translate_items(dev, items, &wks_m, match_mask, MLX5_SET_MATCHER_SW_M, error); -- 2.34.1