From patchwork Tue Jul 9 07:29:18 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Chaoyong He X-Patchwork-Id: 142244 X-Patchwork-Delegate: ferruh.yigit@amd.com Return-Path: X-Original-To: patchwork@inbox.dpdk.org Delivered-To: patchwork@inbox.dpdk.org Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id 76FF7455D7; Tue, 9 Jul 2024 09:29:52 +0200 (CEST) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 2AF7742EB1; Tue, 9 Jul 2024 09:29:51 +0200 (CEST) Received: from NAM10-MW2-obe.outbound.protection.outlook.com (mail-mw2nam10on2109.outbound.protection.outlook.com [40.107.94.109]) by mails.dpdk.org (Postfix) with ESMTP id F2F0F42EAD for ; Tue, 9 Jul 2024 09:29:47 +0200 (CEST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=sK44u4XbTO8NCKkJKeQPDbOgT5OtRhjFkz0wW/pZXVAPNoRw+d3URNSaE1f1BaLG2I4osWQRbPG+2PgFfhB9kD6Hk+jChbcpGEXSPtx2Ek6H/Qi2diBHIL6BKw+B5CS7i6KmKQl5JHviKiK0YaxCO+RESnreTQpy46f8UkWu7qXr30PKGCYLJqlI//bYy4j6zDyndS5DgiaQWOcpw64xcVyu1P1QgvDfzJLHM10UF8UsQc/FKxcBabwwqeFQEjSSUVj9LEuv/Kw8zT+hxTSBrQtVZw6nSN0limGp8/c9+glxHmZRLQCiJEBcM6l/eyVXlaZAohXpA5a+WEB7HX/mdw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; 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=/YHnSUZEU46GqXL23kg1z70eGyV0lm5d0UZHOvyYa6k=; b=lHDMCDT4fNGgc+fIBt4bKwciURZCMUncqzwyhwTz2l+4oJFyM7ySoFoZ3hdFv7lUU75hJzr2OUt/v/ZdZ0C/ucS56wm091xDlv8DF1HEZuHP+tr3aBBETeFJImL+cbaieu6PTyNYMKTe0QaVNbTAo8zx3mh/wg/oB3Umjx63E+jYu+JXGOs1YzxKf64e/qvp35LQWNMqrrDG7GJWy0vblO9YLjd3S6fmRhwr5N2wkNJOFYk78ZJeRB3mbnY378WA/TLLVSaRA8dIMXcMVybZau+YUHSdWs6jc52LWVk6kbmlm4+TC2m9DVHbhvJ5oPeHxSxrS7X8qvVk6urHJ7axKg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=corigine.com; dmarc=pass action=none header.from=corigine.com; dkim=pass header.d=corigine.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=corigine.onmicrosoft.com; s=selector2-corigine-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=/YHnSUZEU46GqXL23kg1z70eGyV0lm5d0UZHOvyYa6k=; b=Zi6PqoJERgNLMiNN0PAJVSy3JnFD6fBujkCEp9mPC61YnREj+mwX7gv9ZpflIdYzdM+KHCDLTDuXkc2lsIpdTrpkFYYdbbyQsFZMPrM/vLj8GGAXIxxaFsh38PQM9rz+XqXA1T78R1qXPG/5k5/e+iPJf9KaTGRImC2hOHirziA= Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=corigine.com; Received: from SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5) by SA1PR13MB4958.namprd13.prod.outlook.com (2603:10b6:806:189::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7741.36; Tue, 9 Jul 2024 07:29:44 +0000 Received: from SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::b900:5f05:766f:833]) by SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::b900:5f05:766f:833%4]) with mapi id 15.20.7741.033; Tue, 9 Jul 2024 07:29:44 +0000 From: Chaoyong He To: dev@dpdk.org Cc: oss-drivers@corigine.com, Long Wu , Chaoyong He Subject: [PATCH v3 1/4] net/nfp: export more interfaces of NFDk Date: Tue, 9 Jul 2024 15:29:18 +0800 Message-Id: <20240709072921.246520-2-chaoyong.he@corigine.com> X-Mailer: git-send-email 2.39.1 In-Reply-To: <20240709072921.246520-1-chaoyong.he@corigine.com> References: <20240708055854.107739-1-chaoyong.he@corigine.com> <20240709072921.246520-1-chaoyong.he@corigine.com> X-ClientProxiedBy: SJ0PR13CA0232.namprd13.prod.outlook.com (2603:10b6:a03:2c1::27) To SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: SJ0PR13MB5545:EE_|SA1PR13MB4958:EE_ X-MS-Office365-Filtering-Correlation-Id: 867bb5b1-0bd0-4f3d-1206-08dc9fe8e774 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; ARA:13230040|1800799024|52116014|366016|376014|38350700014; X-Microsoft-Antispam-Message-Info: ccKCsXb23VBBQ/1XCFWpEV3fVUTAvLYAtBslQ3i0JZU1cr8hgA3+ODC3hB2kbyvPBmVboS45sqifwwrfBUtMbmm0FZl3y5gCkW/EBpA3Q9GoyofFTMyKgmVH0B5wbvIkniWCgjLgSpCMkArbxAC4VVvDwLVWGLR88HMNZWNVE4uFrJFp+/EJn8/Qmvodm2WxJhofjbrEj2vSo+BTq/a+i4K6uOdWyJsY2hkb1/EifgAYEGg5UqGGmaipsCTu89/PnQTiMKdZryvaGH+Xv/DyrzFaKnS7ojGWf8oJO6ASzSLbxZ2SyLr8pqFpxU1Vm3csblUDPlE5iHeXEK0sGB11MZZuwLux2HW9PztOJ9ggVTi6Y219UWXqIgl3EvjpY4/fK5+HbzK/uOs4AAoxpDhkYh4Hg5soKJ58TqBEVqbLyJWn0GV3dt+FPxfdEd3DSeLG7eHpoZcTPQ5ZbyR90FBShREjUS1YLmJfSNJ5ADv1ftSuwDEHrCu6D9SNjeHtIWHScig3e7ZH46DkAvzu/lCdZ3qJeToaEDFtWr4SzfZOZ74kxFPsSzcGen2v//GaSHJRbx7uuPlNmx/3ufzhdgw5zQgnwVXRshjxfDW3R72afVzM6BIpgxB2ZNvQ1/NKTS3nyWIvj71ruJDVBZAkxMl6OgSv3Q5MH3ffqm13xLgfoMM7iOQNDiOUgGT85dLnVpoDNg1r72YVQoYlGwSaoeIzkYj5Wshf9KTjmio1O4M/UMLjjr9YLS+2jI+5zkd4RyvgzabMAoXs0Yty6rcZMgCKwtYsaUbzfRgot1U/6lXWv3nESm3BKgSTs4R3mRHVDd3N/lvcSGaviBmEXnGlfIhg05wGTEn0aPT7b8I3KDJKI0IAeNsK5GeTDmaEBx/CDrJ05lnGUmawy+aoQzIKCxPwpNcNUeqZIil4doHTb8oVUs43/PDstP37g9+eiI81IzLnDQ94TvfmKk7gUCdMzZGHeUjxhvKhjyhb63H/zAblGV51XgXDBK98ldS2BQ7H+niIXxCivtC07VjtPl+CEOyHE17Vzu97oK3BPE0Ym6L9mtkgrHRvg2i5kZd1O4zoDFA65twP/evHRtT+pJCBrMsLKFgvx39oai+OBQ2mJMRdhZcJT2PHQOZIK/T6wPHXOO5Jq9QwHVkIzfB/ywzOJoXxi1dQmr3POb9jzeenLlqC0rN1ZKpRzc7XdK0lm7FXToq3iu6C74hp2w4N/cC+v84F59n/qSs8vxIlGCjo1Q26gRvtjTyIvW42hGPOld7sA6hxq4dbJVfveba3JK7S8WjybJrkheAVOJYTYYgOblAYnfgYGAS6wfmzgvuihIv7vQxinENy8wfWQxKd0fnxZ4AkS7SyN7T9yzhUGAyVc27WjXtlmucZ/JCmqDKmfZg4GWMhWsd0hULJUlsoBqz+sD8VIA== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:SJ0PR13MB5545.namprd13.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230040)(1800799024)(52116014)(366016)(376014)(38350700014); DIR:OUT; SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: 2oVBRMhHsRlP71MnLPO2pn0sKyKMSXKhQSBGcMX0phb2ENTU2coTFs3VI6seRKZVO2fd6IuGc3poytnN+74YHxlz9CQwGF67ZUgNsGNzh16ul2SlC+z4+V3LcyFEGym7kx5bxdhATemc5pUvCzUhxNSopbaOq6vdb8ySgN3foBvZbiqlaMU8q4MavoMbcLkO+nzW2irMKfEWiLa2Y+230wMw1hm61tuJ5hbr142WxJ5yPOs5wQM7SbNuXsLmAcmMhFlNEQd0HX7dr9BcB/sjAyODdZYBblhrVoZMPcta2TTgvtzmy2IsTc2hbCy3iwLuD5JUIyOjRPzIPVW2SbHmp9EU99C5sxyKXI6lt4p3jVTG8e55XqfD/VpADOMANtAcLaCFQrL72F0dXQMrGLun/Y6vQQWg1Y2nsuprAowCo9xrqcvXqrMBKSmKo6VXjSN6Rte+OiIK4O1DZqxotN00PH46eG3YbrhoAzJzd+CO5tdl7+Qtl3UWgHwNvDLxxm+C/oAPEcx26ggFoGEuHCVG6u2J6WGhyWeioyDFFLKt7H6+hjDedNCUfV13maqFyrzznh3t9CdM+Hk/0g7gwnNPgUvnxoLSF5WO3P89HmQupF6vs/HwDqxyEjDIWfpic1MdNh402nvMeLtYbeEO656LaVpWDjcf13OSzn6DTRYnKbXGLiKn8jweM56FNci9Qfq1KL73XUGgGckpQax+tsrDOlUiQbBMJDwb21UZD4fZQLtP0Akrq7eOVkpgo8Zu6ufyIE0CO9AHMNXEPxiqqoIVmfUL0u+YiowG8BOFD7RgLBSg7ktyuGlU/gGIm3vgvykiPPo1d7MxfKsgWaz4hfd3VJ7oQOc/7DmDexeFAHocvN+2kza0a7GUsOviXYtsG4fPOkifg86tRWRQtWnhhlh/mIBgt4+kFCw2EUM0O0BgsOvQfYiOnBSbPIvo9xF7ZGyDLm3ShXrEPRP3lTf/LF4tvMtWndTQBsoBK7U6rSX7azPoB8HwvA4fktJSqrDSZokyd988kph+rV8tkJgsCfc9VU4vP8aKr8PFOcTdSaLznVSdxqGt+shBB4zBwmS95LTOtwiAXTEpa/yVmg8YeFmIqqDJqohGo/SLxL48AHi5vw5usS/ma0pXiePBqu0TxW5hRIOGIWJp3RIlPUU5gCjp+lH4BMlnFx1XwJNto/KDkYWEVhkBEvF+642rT9am/o7xBSNKh7cy5S3lHoN3mXb3V/3eZT47f6ZuSbAAfbJZF8mvbQl3CSvyR7QgKTNJKJXxFv5bOKMUoWy2QW/qCb0JyzO2uKn8Wv5F0TodIhyCH98C1UFBTJyTZzizSYj+XtwadqCvpVEBRhrvohu+FEDvzNc43OEygIxryHer/zbRHGJr08HjT/akorS60zmRh5fRo3LhQfX83XHd832d4EeDG/FQ2yd+utEu5E0cDW9IGQvhYXMvRbqaPWbLbH1dENCbuLaK/WOwxeECnLpGw7vNRer2E53qdWsN6qTOrr0JIaEIc1lJIjrswZnkllkvQa1PmqFkguW82fGPt7JI3COChSy0TDI1TuLp04z0ZybxTPUwgm5kd2Y449wyCy2e05jHvcdzeWFE0blO7YDV4no9cg== X-OriginatorOrg: corigine.com X-MS-Exchange-CrossTenant-Network-Message-Id: 867bb5b1-0bd0-4f3d-1206-08dc9fe8e774 X-MS-Exchange-CrossTenant-AuthSource: SJ0PR13MB5545.namprd13.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Jul 2024 07:29:44.7454 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: fe128f2c-073b-4c20-818e-7246a585940c X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: hYJy2xI5lW7viGZYT/BCBN4cJRQWGQLXKGyIsAEbQYAanTvPTld3KmoXaNZNonG6e1An5tK8uu3cm9dAfsCr42LSTtru2B2DhOOs1vHuYB8= X-MS-Exchange-Transport-CrossTenantHeadersStamped: SA1PR13MB4958 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 From: Long Wu NFP will support NFDk vector Tx function, so move some functions to header file for use by vector Tx function. Signed-off-by: Long Wu Reviewed-by: Chaoyong He --- drivers/net/nfp/nfdk/nfp_nfdk.h | 45 ++++++++++++++++++++++++++++++ drivers/net/nfp/nfdk/nfp_nfdk_dp.c | 43 +--------------------------- 2 files changed, 46 insertions(+), 42 deletions(-) diff --git a/drivers/net/nfp/nfdk/nfp_nfdk.h b/drivers/net/nfp/nfdk/nfp_nfdk.h index 2767fd51cd..89a98d13f3 100644 --- a/drivers/net/nfp/nfdk/nfp_nfdk.h +++ b/drivers/net/nfp/nfdk/nfp_nfdk.h @@ -6,7 +6,10 @@ #ifndef __NFP_NFDK_H__ #define __NFP_NFDK_H__ +#include + #include "../nfp_rxtx.h" +#include "nfp_net_common.h" #define NFDK_TX_DESC_PER_SIMPLE_PKT 2 @@ -161,6 +164,45 @@ nfp_net_nfdk_txq_full(struct nfp_net_txq *txq) return (nfp_net_nfdk_free_tx_desc(txq) < txq->tx_free_thresh); } +static inline uint16_t +nfp_net_nfdk_headlen_to_segs(uint16_t headlen) +{ + /* First descriptor fits less data, so adjust for that */ + return DIV_ROUND_UP(headlen + NFDK_TX_MAX_DATA_PER_DESC - NFDK_TX_MAX_DATA_PER_HEAD, + NFDK_TX_MAX_DATA_PER_DESC); +} + +/* Set TX CSUM offload flags in TX descriptor of nfdk */ +static inline uint64_t +nfp_net_nfdk_tx_cksum(struct nfp_net_txq *txq, + struct rte_mbuf *mb, + uint64_t flags) +{ + uint64_t ol_flags; + struct nfp_net_hw *hw = txq->hw; + + if ((hw->super.cap & NFP_NET_CFG_CTRL_TXCSUM) == 0) + return flags; + + ol_flags = mb->ol_flags; + + /* Set TCP csum offload if TSO enabled. */ + if ((ol_flags & RTE_MBUF_F_TX_TCP_SEG) != 0) + flags |= NFDK_DESC_TX_L4_CSUM; + + if ((ol_flags & RTE_MBUF_F_TX_TUNNEL_MASK) != 0) + flags |= NFDK_DESC_TX_ENCAP; + + /* IPv6 does not need checksum */ + if ((ol_flags & RTE_MBUF_F_TX_IP_CKSUM) != 0) + flags |= NFDK_DESC_TX_L3_CSUM; + + if ((ol_flags & RTE_MBUF_F_TX_L4_MASK) != 0) + flags |= NFDK_DESC_TX_L4_CSUM; + + return flags; +} + uint32_t nfp_flower_nfdk_pkt_add_metadata(struct rte_mbuf *mbuf, uint32_t port_id); uint16_t nfp_net_nfdk_xmit_pkts_common(void *tx_queue, @@ -177,5 +219,8 @@ int nfp_net_nfdk_tx_queue_setup(struct rte_eth_dev *dev, const struct rte_eth_txconf *tx_conf); int nfp_net_nfdk_tx_maybe_close_block(struct nfp_net_txq *txq, struct rte_mbuf *pkt); +int nfp_net_nfdk_set_meta_data(struct rte_mbuf *pkt, + struct nfp_net_txq *txq, + uint64_t *metadata); #endif /* __NFP_NFDK_H__ */ diff --git a/drivers/net/nfp/nfdk/nfp_nfdk_dp.c b/drivers/net/nfp/nfdk/nfp_nfdk_dp.c index 8b8c191b82..173aabf0b9 100644 --- a/drivers/net/nfp/nfdk/nfp_nfdk_dp.c +++ b/drivers/net/nfp/nfdk/nfp_nfdk_dp.c @@ -6,7 +6,6 @@ #include "nfp_nfdk.h" #include -#include #include #include "../flower/nfp_flower.h" @@ -15,38 +14,6 @@ #define NFDK_TX_DESC_GATHER_MAX 17 -/* Set TX CSUM offload flags in TX descriptor of nfdk */ -static uint64_t -nfp_net_nfdk_tx_cksum(struct nfp_net_txq *txq, - struct rte_mbuf *mb, - uint64_t flags) -{ - uint64_t ol_flags; - struct nfp_net_hw *hw = txq->hw; - - if ((hw->super.ctrl & NFP_NET_CFG_CTRL_TXCSUM) == 0) - return flags; - - ol_flags = mb->ol_flags; - - /* Set L4 csum offload if TSO/UFO enabled. */ - if ((ol_flags & RTE_MBUF_F_TX_TCP_SEG) != 0 || - (ol_flags & RTE_MBUF_F_TX_UDP_SEG) != 0) - flags |= NFDK_DESC_TX_L4_CSUM; - - if ((ol_flags & RTE_MBUF_F_TX_TUNNEL_MASK) != 0) - flags |= NFDK_DESC_TX_ENCAP; - - /* IPv6 does not need checksum */ - if ((ol_flags & RTE_MBUF_F_TX_IP_CKSUM) != 0) - flags |= NFDK_DESC_TX_L3_CSUM; - - if ((ol_flags & RTE_MBUF_F_TX_L4_MASK) != 0) - flags |= NFDK_DESC_TX_L4_CSUM; - - return flags; -} - /* Set TX descriptor for TSO of nfdk */ static uint64_t nfp_net_nfdk_tx_tso(struct nfp_net_txq *txq, @@ -100,14 +67,6 @@ nfp_flower_nfdk_pkt_add_metadata(struct rte_mbuf *mbuf, return FLOWER_PKT_DATA_OFFSET; } -static inline uint16_t -nfp_net_nfdk_headlen_to_segs(uint16_t headlen) -{ - /* First descriptor fits less data, so adjust for that */ - return DIV_ROUND_UP(headlen + NFDK_TX_MAX_DATA_PER_DESC - NFDK_TX_MAX_DATA_PER_HEAD, - NFDK_TX_MAX_DATA_PER_DESC); -} - static inline void nfp_net_nfdk_tx_close_block(struct nfp_net_txq *txq, uint32_t nop_slots) @@ -170,7 +129,7 @@ nfp_net_nfdk_tx_maybe_close_block(struct nfp_net_txq *txq, return nop_slots; } -static int +int nfp_net_nfdk_set_meta_data(struct rte_mbuf *pkt, struct nfp_net_txq *txq, uint64_t *metadata) From patchwork Tue Jul 9 07:29:19 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Chaoyong He X-Patchwork-Id: 142245 X-Patchwork-Delegate: ferruh.yigit@amd.com Return-Path: X-Original-To: patchwork@inbox.dpdk.org Delivered-To: patchwork@inbox.dpdk.org Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id 5A1D1455D7; Tue, 9 Jul 2024 09:29:58 +0200 (CEST) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 7944142EB9; Tue, 9 Jul 2024 09:29:52 +0200 (CEST) Received: from NAM10-DM6-obe.outbound.protection.outlook.com (mail-dm6nam10on2138.outbound.protection.outlook.com [40.107.93.138]) by mails.dpdk.org (Postfix) with ESMTP id 5351E42EB1 for ; Tue, 9 Jul 2024 09:29:49 +0200 (CEST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=OWKV0nzCrMMcy5NXuw5aDZDn8iN97SH8LkhK4l1ma3eQ9AIk4frJ5vSM0YL68DsheUHSTW3Ns0//5Jqoiox2JUoHVmsezLoj02zBB5a8yUvOC14V+RAZN5Rzf8KsEt6qt8IhKpFdSyrf/ucydcQ58iK/ebDCC/Uf08d8oGeH9hb4/93qHyZvcj7letLM4FThmBixPr8nylYkNaGnLEgoHcn4ITRnh6BbLKNgyYUiNj9EA0UZHHO6Id/EFpH2UGX6exU5WyflsfHcuEdkrsOtBXXFaj+h0rh/0tUI+Voeyx/evMKDYPMYXqsDxv76b5BFPI5uN+UStnEcKw/G7Nh4Jg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; 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=rGlAR3WiKOvJh4D6gwWtxBQYHwlpFbLCk9q5S3sAdl4=; b=pwrlmDcJTqDS9uh5BAQhVIckltVzR5mC1UyzzgqIXZHDioGT4MSvtlLmO/bFsLXNUzyoa4LkfsxinAQMt5N+3PSTdr59nM8OM+1qc0HSNY3uG/QKmssEYyA98vk0qFukWucZgXp+jHO+TD4BpUcaqJpVu6+gH0FRaccQM3urVz6Or0ErFAEbwEnU/Cq3RGIFMm+fhQ9ZGwmbLzrN54CSy11HuPc5/r8zsEwqu13LGhtgxzz14mdgKSCthyKzB4cO9TmSd6cv+aCWWwDOZJIldOU94Cw18mfquGJ9AZ6ihFE59tQlPfMBFZbP9YezHtP5FPH73e+y7BqWQ4pcwB1QJw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=corigine.com; dmarc=pass action=none header.from=corigine.com; dkim=pass header.d=corigine.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=corigine.onmicrosoft.com; s=selector2-corigine-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=rGlAR3WiKOvJh4D6gwWtxBQYHwlpFbLCk9q5S3sAdl4=; b=E5haR7t54WgMWsQL7bervx8/G+yEwwFUuchXCN9LMc5GWSx5PKu4x0qLI4U9VH/EX3Jb+K6b6UYy9E98soE26ruTnaVFnTC1iQ/EFQheGamCA+0n4OgqjjxeJk5jUue9sIYarDUSd4oUeVIUuAeMaEmpku0a2PFa2B4DEjZIlAM= Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=corigine.com; Received: from SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5) by SA1PR13MB4958.namprd13.prod.outlook.com (2603:10b6:806:189::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7741.36; Tue, 9 Jul 2024 07:29:46 +0000 Received: from SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::b900:5f05:766f:833]) by SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::b900:5f05:766f:833%4]) with mapi id 15.20.7741.033; Tue, 9 Jul 2024 07:29:46 +0000 From: Chaoyong He To: dev@dpdk.org Cc: oss-drivers@corigine.com, Long Wu , Chaoyong He Subject: [PATCH v3 2/4] net/nfp: support AVX2 Tx function Date: Tue, 9 Jul 2024 15:29:19 +0800 Message-Id: <20240709072921.246520-3-chaoyong.he@corigine.com> X-Mailer: git-send-email 2.39.1 In-Reply-To: <20240709072921.246520-1-chaoyong.he@corigine.com> References: <20240708055854.107739-1-chaoyong.he@corigine.com> <20240709072921.246520-1-chaoyong.he@corigine.com> X-ClientProxiedBy: SJ0PR13CA0232.namprd13.prod.outlook.com (2603:10b6:a03:2c1::27) To SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: SJ0PR13MB5545:EE_|SA1PR13MB4958:EE_ X-MS-Office365-Filtering-Correlation-Id: 6f6a7177-c329-40f5-90c6-08dc9fe8e879 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; ARA:13230040|1800799024|52116014|366016|376014|38350700014; X-Microsoft-Antispam-Message-Info: rEg+TV9Cft6bCH3btc/rVjlc+C6ayxsBpd0wErbPLx7YVRvoVlDywAciUdJIxfKYwvGcOsXdgPOdZgQVNqHxLS65+D3soIJnlw3zlm/Kjygqu/xUh2com13RrUEShsK1cLNQ93QWlOobBFvvuNshk3N44WmTaO3L4D+OyrsflsI/SOnG19n0uMKRXWOnPibWRS9+wSfxQNhy4a16KaQapZtXKu3Lu6Qfelf/tZT+271M6jDGdlbXwSO5R5yg7pl8PqTn2jSneeyTt2uFV/EhS9RsHNjnf7fUbjnPwKb42y4iposp5OamETNkyr3i1mXoLfj4Ch3KaU8NL2KCy0vBQJkIBMXaG2LNqCaFouJbZa5VUqzCSdvL0Zfhnzwz/untnflLJOLYnrLx9Ow+tF/mmlZdtlplbAt4FtQauEcpE7mXV5PIiwoySffvJXHwtd/b5IDzcPoHr900B6s7TRRPzzhayux1iZjbNg8E3UhKGEnmwmCW9aiEziM11a5g2Rzub0Gk5tvgV4L1l16Ebhtc5yC+UmemhTZZk88MI+JnhxKLII7w24bxjkGEHR4AIrAFQIVZFQIlmM6IHatOCTmwefj+GU/CIesd5RHWl2/IKhHcmnXH9diIQT+kEOHmLyaCHl/67M6kjRe6FS1S5YIMHCgOepGYfVtHfKWdVIr3ziKlTFx9fqDNOOlHETxa9YmOyHTT+UCqPcZKdjm09CW5yqHGjT7DoiKFDsq0wKVhKP0qPJ3Wv6hraOkngr0oRsNozjAfvvUcJ49R0zV2Nr9j04ZazbvkGply5Q9OZnVmR5HK/a631SmQkq+LoV6zN0MHF/dx6l6nYf1dyu9gU0L/wT59SZ8MUYpdj/iFtUipRuuMQUgHmqC8e0oSVCkxf/FuRyYcxBhovQldENXSjkXeNVuPDbn4w/3Q0LM37bOyu1R/AwBC0GPi/iqQiB3q1mEOIZ2MNDRXVewOz9r2rO9dsnBd4+10YH57niHW0/3u0PcNlt6G6oxWAvEzikmyqkBBlaU7GXgE0UkkSKtRlNVT6huGdTlcbGRgLO5FibO1MmZJP5yV+4vh2I7yiIZBO4cvhnKgZ5g7k8yujwMVhKHj81HYCyO2PJBTvp3JSqWXff8G/H6W+Fbtd3h0PKt63dxgcgAkISPNGNAylihqoJjRl0KdtchlsYgimPVE1V6HDS6FxBZ/zjQZ4hWIpq6ah59nYm1Yu1XIwoOzlSeatXhEw0XvUGEW0kmAfd8Y4/kWnD+8LRyA78pX4jgvNA2QG7Ve88gTRAJ78liM6dyD4wm7L+5cLgJKyt4J/N0hXEaY/nPuaNZIM4mbODClZKiTL36SLEOu/SQxrdHQ3qMDaXeFo03g2jovkl/4iBx01OfMHa5TfEwOrs2j3ImB5v2xyMZt X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:SJ0PR13MB5545.namprd13.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230040)(1800799024)(52116014)(366016)(376014)(38350700014); DIR:OUT; SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: oL+qC5ivO/+H/4Zva/HLdXb1OvPYSZJrfUL3/CZ7uHkofGrWFlbqq0EaxyRq4iCbObGbPISbFJuOb4RKLHWdm419C84dqTYoTriHZY3aVe1oEpllV62tYMb7RNoJQDw8uT/S1XY68gaKPEvAWNaQIj8eaDIpmVQZqmveREnWJtwqq5sPpBInXhC7uZ8ad0GbxE35y9fUqKShe6ZAwUaHJ27vdu9mDkJ36sDV9nCfcxixENavxp5cfLE3Vo8YTuU+koFr9gy4ElzdLvFY21AnpFxRmIR/fwD/XWM+vzru4WDlmSLr2HWc9vB7Hz060SLcgyiuVQemBRDHcTp7AM0MJCL2sGL5404aSG3SA+rf/DzDYaes+69e7jInc5FbIPucF2SCe9+zIQcr9TOVvXooSKdqV9Nzf82WQAthm5ClAl79+XUOnYolaQnlI6gPjjiC3eFK6D8plAIaYZk//4qgUXitKuEQByKZ9fNeOMWLbvAZsc7MNsrne74Z4W7QAcGn5XFi2l+gLGhdFd18eZzHjgRcTsobNFgesSwdL/4TXebbDUhhNjJGPqm62mc2oS3S1rdGfJhNi9HB6B0u8OGber3Iniv/UvyQzW6V+uLMb9RXpIBkJGCQf++Ul7mYOsKcCQVht59GC/Jjewg8W6ltIAhleqsxFJh5z2fQzYW8KCAAVvhw47a7JRSRx64xeKf5kx2p07a9CNUMg9f1juBA7eZqSBYEbjMTNQ6soHpdOnTu75UoDtjQmNbb2OJK1BbkZlP1pR5AHY6tu413A6MAKiRf7bfn4ICqmaLndyVOanJZfuAxvoB3hr2I+9a5d0AJ/D5tXNiCaDkqkZ4mv23vsuU5qLlUMDzQP70NINsc9wQUHXur98GZ7d1fzYVJHOSkXdi15pINvPyovknwSPULzHeg5QPm27skrNLnsf71MJA7QDDUzkqYg8eHcGxiJm9a4tjChyGBMS7sBfth3GWYi0kyrL2Nb0MZrSRliwZfFccKkUfZdD3i88T+pBDNY4k8rfBIRf5xB5KIH4MqwzZjk2xww6SS3xDlJhgrcJZxKiXHNLlHDgGGGEuAg8eY+muoB0J/ex0CAO+7l9E89cJLyYpMYZLEr/uUb0pw14Qbro8iOycT5WIMRlZsboXzVQkHK3AECsEQclb0oPF+nCnQhdA3xLvTKhF/W2xZDao0AnykY98t464CgMcr/P0G+bXZR1hoyAMY1xg80JkkKMnWIWN0evY3gx17Qa7iymRzd8tJoNZkMMAWz+Y2wprA9pxSi6rml8TBt9ata+fYn6qdLDqnrCejgOQ7JU9OTbRANeI4Tpk05PLNDsNvdhQB0Hm+Lb5nsIi/jjBTc1fm0yiziHFkZQC1qVR57TqaDLwExm0BD1aw2L+iRUHgcjOBoZ5xn9D2TWyuENRtHFkNnQ4U1e/RVpJaA8L5PMcvkj2Cgf7Z5Xu9F0m5eHrM+aUwGuBDcazm5T3lOAyc6IO1fNWaNDtSN4fnna6iNa+qtFRWaXP+iCiyy4V2GgMLPoc5KPiNYVfmFSE/TuX3pAwV1L8Q4sX9GcF85zB/O0sZwSNj0KkqbScvxE8X4BmDqu92YcKLoTYRCp5Ad6nSYqS9Bd2vDA== X-OriginatorOrg: corigine.com X-MS-Exchange-CrossTenant-Network-Message-Id: 6f6a7177-c329-40f5-90c6-08dc9fe8e879 X-MS-Exchange-CrossTenant-AuthSource: SJ0PR13MB5545.namprd13.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Jul 2024 07:29:46.4467 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: fe128f2c-073b-4c20-818e-7246a585940c X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: Se8DymTO+fpitbkfGF0kjPmEjqROHfFrX+YQSUcacm24FYgUpCK35Oi2kX1RYDvi12miYYnP7AaVgboInHvHnYszEZGg9T+zRCP/YwngBlA= X-MS-Exchange-Transport-CrossTenantHeadersStamped: SA1PR13MB4958 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 From: Long Wu Use AVX2 instructions to accelerate Tx performance. The acceleration only works on X86 machine. Signed-off-by: Long Wu Reviewed-by: Chaoyong He --- drivers/net/nfp/meson.build | 20 + drivers/net/nfp/nfdk/nfp_nfdk.h | 1 + drivers/net/nfp/nfdk/nfp_nfdk_dp.c | 12 + drivers/net/nfp/nfdk/nfp_nfdk_vec.h | 36 ++ drivers/net/nfp/nfdk/nfp_nfdk_vec_avx2_dp.c | 432 ++++++++++++++++++++ drivers/net/nfp/nfdk/nfp_nfdk_vec_stub.c | 14 + drivers/net/nfp/nfp_ethdev.c | 3 +- drivers/net/nfp/nfp_ethdev_vf.c | 3 +- drivers/net/nfp/nfp_rxtx.h | 5 +- drivers/net/nfp/nfp_rxtx_vec.h | 13 + drivers/net/nfp/nfp_rxtx_vec_avx2.c | 21 + drivers/net/nfp/nfp_rxtx_vec_stub.c | 16 + 12 files changed, 573 insertions(+), 3 deletions(-) create mode 100644 drivers/net/nfp/nfdk/nfp_nfdk_vec.h create mode 100644 drivers/net/nfp/nfdk/nfp_nfdk_vec_avx2_dp.c create mode 100644 drivers/net/nfp/nfdk/nfp_nfdk_vec_stub.c create mode 100644 drivers/net/nfp/nfp_rxtx_vec.h create mode 100644 drivers/net/nfp/nfp_rxtx_vec_avx2.c create mode 100644 drivers/net/nfp/nfp_rxtx_vec_stub.c diff --git a/drivers/net/nfp/meson.build b/drivers/net/nfp/meson.build index d805644ec5..463a482a32 100644 --- a/drivers/net/nfp/meson.build +++ b/drivers/net/nfp/meson.build @@ -16,6 +16,7 @@ sources = files( 'flower/nfp_flower_service.c', 'nfd3/nfp_nfd3_dp.c', 'nfdk/nfp_nfdk_dp.c', + 'nfdk/nfp_nfdk_vec_stub.c', 'nfpcore/nfp_cppcore.c', 'nfpcore/nfp_crc.c', 'nfpcore/nfp_elf.c', @@ -43,7 +44,26 @@ sources = files( 'nfp_net_flow.c', 'nfp_net_meta.c', 'nfp_rxtx.c', + 'nfp_rxtx_vec_stub.c', 'nfp_service.c', ) +if arch_subdir == 'x86' + includes += include_directories('../../common/nfp') + + avx2_sources = files( + 'nfdk/nfp_nfdk_vec_avx2_dp.c', + 'nfp_rxtx_vec_avx2.c', + ) + + nfp_avx2_lib = static_library('nfp_avx2_lib', + avx2_sources, + dependencies: [static_rte_ethdev, static_rte_bus_pci], + include_directories: includes, + c_args: [cflags, '-mavx2'] + ) + + objs += nfp_avx2_lib.extract_all_objects(recursive: true) +endif + deps += ['hash', 'security', 'common_nfp'] diff --git a/drivers/net/nfp/nfdk/nfp_nfdk.h b/drivers/net/nfp/nfdk/nfp_nfdk.h index 89a98d13f3..29d862f6f0 100644 --- a/drivers/net/nfp/nfdk/nfp_nfdk.h +++ b/drivers/net/nfp/nfdk/nfp_nfdk.h @@ -222,5 +222,6 @@ int nfp_net_nfdk_tx_maybe_close_block(struct nfp_net_txq *txq, int nfp_net_nfdk_set_meta_data(struct rte_mbuf *pkt, struct nfp_net_txq *txq, uint64_t *metadata); +void nfp_net_nfdk_xmit_pkts_set(struct rte_eth_dev *eth_dev); #endif /* __NFP_NFDK_H__ */ diff --git a/drivers/net/nfp/nfdk/nfp_nfdk_dp.c b/drivers/net/nfp/nfdk/nfp_nfdk_dp.c index 173aabf0b9..2cea5688b3 100644 --- a/drivers/net/nfp/nfdk/nfp_nfdk_dp.c +++ b/drivers/net/nfp/nfdk/nfp_nfdk_dp.c @@ -11,6 +11,8 @@ #include "../flower/nfp_flower.h" #include "../nfp_logs.h" #include "../nfp_net_meta.h" +#include "../nfp_rxtx_vec.h" +#include "nfp_nfdk_vec.h" #define NFDK_TX_DESC_GATHER_MAX 17 @@ -511,6 +513,7 @@ nfp_net_nfdk_tx_queue_setup(struct rte_eth_dev *dev, dev->data->tx_queues[queue_idx] = txq; txq->hw = hw; txq->hw_priv = dev->process_private; + txq->simple_always = true; /* * Telling the HW about the physical address of the TX ring and number @@ -521,3 +524,12 @@ nfp_net_nfdk_tx_queue_setup(struct rte_eth_dev *dev, return 0; } + +void +nfp_net_nfdk_xmit_pkts_set(struct rte_eth_dev *eth_dev) +{ + if (nfp_net_get_avx2_supported()) + eth_dev->tx_pkt_burst = nfp_net_nfdk_vec_avx2_xmit_pkts; + else + eth_dev->tx_pkt_burst = nfp_net_nfdk_xmit_pkts; +} diff --git a/drivers/net/nfp/nfdk/nfp_nfdk_vec.h b/drivers/net/nfp/nfdk/nfp_nfdk_vec.h new file mode 100644 index 0000000000..14319d6cf6 --- /dev/null +++ b/drivers/net/nfp/nfdk/nfp_nfdk_vec.h @@ -0,0 +1,36 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright(c) 2024 Corigine, Inc. + * All rights reserved. + */ + +#ifndef __NFP_NFDK_VEC_H__ +#define __NFP_NFDK_VEC_H__ + +#include + +#include + +#include "../nfp_net_common.h" +#include "nfp_nfdk.h" + +static inline bool +nfp_net_nfdk_is_simple_packet(struct rte_mbuf *pkt, + struct nfp_net_hw *hw) +{ + if (pkt->data_len > NFDK_TX_MAX_DATA_PER_HEAD) + return false; + + if ((hw->super.cap & NFP_NET_CFG_CTRL_LSO_ANY) == 0) + return true; + + if ((pkt->ol_flags & RTE_MBUF_F_TX_TCP_SEG) == 0) + return true; + + return false; +} + +uint16_t nfp_net_nfdk_vec_avx2_xmit_pkts(void *tx_queue, + struct rte_mbuf **tx_pkts, + uint16_t nb_pkts); + +#endif /* __NFP_NFDK_VEC_H__ */ diff --git a/drivers/net/nfp/nfdk/nfp_nfdk_vec_avx2_dp.c b/drivers/net/nfp/nfdk/nfp_nfdk_vec_avx2_dp.c new file mode 100644 index 0000000000..6d1359fdb1 --- /dev/null +++ b/drivers/net/nfp/nfdk/nfp_nfdk_vec_avx2_dp.c @@ -0,0 +1,432 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright(c) 2024 Corigine, Inc. + * All rights reserved. + */ + +#include +#include +#include + +#include "../nfp_logs.h" +#include "nfp_nfdk.h" +#include "nfp_nfdk_vec.h" + +/* + * One simple packet needs 2 descriptors so if send 4 packets driver will use + * 8 descriptors at once. + */ +#define NFDK_SIMPLE_BURST_DES_NUM 8 + +#define NFDK_SIMPLE_DES_TYPE (NFDK_DESC_TX_EOP | \ + (NFDK_DESC_TX_TYPE_HEAD & (NFDK_DESC_TX_TYPE_SIMPLE << 12))) + +static inline int +nfp_net_nfdk_vec_avx2_xmit_simple_set_des2(struct rte_mbuf *pkt, + struct nfp_net_txq *txq, + uint64_t *des_addr, + uint64_t *des_meta, + bool repr_flag) +{ + int ret; + __m128i dma_addr; + __m128i dma_hi; + __m128i data_off; + __m128i dlen_type; + uint64_t metadata; + + if (repr_flag) { + metadata = NFDK_DESC_TX_CHAIN_META; + } else { + ret = nfp_net_nfdk_set_meta_data(pkt, txq, &metadata); + if (unlikely(ret != 0)) + return ret; + } + + data_off = _mm_set_epi64x(0, pkt->data_off); + dma_addr = _mm_add_epi64(_mm_loadu_si128((__m128i *)&pkt->buf_addr), data_off); + dma_hi = _mm_srli_epi64(dma_addr, 32); + + dlen_type = _mm_set_epi64x(0, (pkt->data_len - 1) | NFDK_SIMPLE_DES_TYPE); + + *des_addr = _mm_extract_epi64(_mm_add_epi64(_mm_unpacklo_epi32(dma_hi, dma_addr), + _mm_slli_epi64(dlen_type, 16)), 0); + + *des_meta = nfp_net_nfdk_tx_cksum(txq, pkt, metadata); + + return 0; +} + +static inline int +nfp_net_nfdk_vec_avx2_xmit_simple_send1(struct nfp_net_txq *txq, + struct nfp_net_nfdk_tx_desc *txds, + struct rte_mbuf *pkt, + bool repr_flag) +{ + int ret; + __m128i des_data; + uint64_t des_addr; + uint64_t des_meta; + + ret = nfp_net_nfdk_vec_avx2_xmit_simple_set_des2(pkt, txq, &des_addr, + &des_meta, repr_flag); + if (unlikely(ret != 0)) + return ret; + + txq->wr_p = D_IDX(txq, txq->wr_p + NFDK_TX_DESC_PER_SIMPLE_PKT); + if ((txq->wr_p & (NFDK_TX_DESC_BLOCK_CNT - 1)) != 0) + txq->data_pending += pkt->data_len; + else + txq->data_pending = 0; + + des_data = _mm_set_epi64x(des_meta, des_addr); + + _mm_store_si128((void *)txds, des_data); + + return 0; +} + +static inline int +nfp_vec_avx2_nfdk_xmit_simple_send4(struct nfp_net_txq *txq, + struct nfp_net_nfdk_tx_desc *txds, + struct rte_mbuf **pkt, + bool repr_flag) +{ + int ret; + uint16_t i; + __m256i des_data0_1; + __m256i des_data2_3; + uint64_t des_addr[4]; + uint64_t des_meta[4]; + + for (i = 0; i < 4; i++) { + ret = nfp_net_nfdk_vec_avx2_xmit_simple_set_des2(pkt[i], txq, + &des_addr[i], &des_meta[i], repr_flag); + if (unlikely(ret != 0)) + return ret; + } + + for (i = 0; i < 4; i++) { + txq->wr_p = D_IDX(txq, txq->wr_p + NFDK_TX_DESC_PER_SIMPLE_PKT); + if ((txq->wr_p & (NFDK_TX_DESC_BLOCK_CNT - 1)) != 0) + txq->data_pending += pkt[i]->data_len; + else + txq->data_pending = 0; + } + + des_data0_1 = _mm256_set_epi64x(des_meta[1], des_addr[1], des_meta[0], des_addr[0]); + des_data2_3 = _mm256_set_epi64x(des_meta[3], des_addr[3], des_meta[2], des_addr[2]); + + _mm256_store_si256((void *)txds, des_data0_1); + _mm256_store_si256((void *)(txds + 4), des_data2_3); + + return 0; +} + +static inline void +nfp_net_nfdk_vec_avx2_xmit_mbuf_store4(struct rte_mbuf **mbuf, + struct rte_mbuf **tx_pkts) +{ + __m256i mbuf_room0_1; + __m256i mbuf_room2_3; + + mbuf_room0_1 = _mm256_set_epi64x(0, (uintptr_t)tx_pkts[1], 0, + (uintptr_t)tx_pkts[0]); + mbuf_room2_3 = _mm256_set_epi64x(0, (uintptr_t)tx_pkts[3], 0, + (uintptr_t)tx_pkts[2]); + + _mm256_store_si256((void *)mbuf, mbuf_room0_1); + _mm256_store_si256((void *)(mbuf + 4), mbuf_room2_3); +} + +static inline uint16_t +nfp_net_nfdk_vec_avx2_xmit_simple_pkts(struct nfp_net_txq *txq, + struct rte_mbuf **tx_pkts, + uint16_t nb_pkts, + uint16_t simple_close, + bool repr_flag) +{ + int ret; + uint16_t npkts = 0; + uint16_t need_txds; + uint16_t free_descs; + struct rte_mbuf **lmbuf; + struct nfp_net_nfdk_tx_desc *ktxds; + + PMD_TX_LOG(DEBUG, "Working for queue %hu at pos %u and %hu packets", + txq->qidx, txq->wr_p, nb_pkts); + + need_txds = nb_pkts << 1; + if (nfp_net_nfdk_free_tx_desc(txq) < need_txds || nfp_net_nfdk_txq_full(txq)) + nfp_net_tx_free_bufs(txq); + + free_descs = nfp_net_nfdk_free_tx_desc(txq); + if (unlikely(free_descs < NFDK_TX_DESC_PER_SIMPLE_PKT)) { + if (unlikely(simple_close > 0)) + goto xmit_end; + + return 0; + } + + PMD_TX_LOG(DEBUG, "Queue: %hu. Sending %hu packets", txq->qidx, nb_pkts); + + /* Sending packets */ + while (npkts < nb_pkts && free_descs >= NFDK_TX_DESC_PER_SIMPLE_PKT) { + ktxds = &txq->ktxds[txq->wr_p]; + lmbuf = &txq->txbufs[txq->wr_p].mbuf; + + /* + * If can not send burst, just send one. + * 1. Tx ring will come to the tail. + * 2. Do not need to send 4 packets. + * 3. If pointer address unaligned on 32-bit boundary. + * 4. If free descriptors are not enough. + */ + if ((txq->tx_count - txq->wr_p) < NFDK_SIMPLE_BURST_DES_NUM || + (nb_pkts - npkts) < 4 || + ((uintptr_t)ktxds & 0x1F) != 0 || + free_descs < NFDK_SIMPLE_BURST_DES_NUM) { + ret = nfp_net_nfdk_vec_avx2_xmit_simple_send1(txq, + ktxds, tx_pkts[npkts], repr_flag); + if (unlikely(ret != 0)) + goto xmit_end; + + rte_pktmbuf_free(*lmbuf); + + _mm_storel_epi64((void *)lmbuf, + _mm_loadu_si128((void *)&tx_pkts[npkts])); + npkts++; + free_descs -= NFDK_TX_DESC_PER_SIMPLE_PKT; + continue; + } + + ret = nfp_vec_avx2_nfdk_xmit_simple_send4(txq, ktxds, + &tx_pkts[npkts], repr_flag); + if (unlikely(ret != 0)) + goto xmit_end; + + rte_pktmbuf_free_bulk(lmbuf, NFDK_SIMPLE_BURST_DES_NUM); + + nfp_net_nfdk_vec_avx2_xmit_mbuf_store4(lmbuf, &tx_pkts[npkts]); + + npkts += 4; + free_descs -= NFDK_SIMPLE_BURST_DES_NUM; + } + +xmit_end: + /* Increment write pointers. Force memory write before we let HW know */ + rte_wmb(); + nfp_qcp_ptr_add(txq->qcp_q, NFP_QCP_WRITE_PTR, ((npkts << 1) + simple_close)); + + return npkts; +} + +static inline void +nfp_net_nfdk_vec_avx2_xmit_simple_close_block(struct nfp_net_txq *txq, + uint16_t *simple_close) +{ + uint16_t i; + uint16_t wr_p; + uint16_t nop_slots; + __m128i zero_128 = _mm_setzero_si128(); + __m256i zero_256 = _mm256_setzero_si256(); + + wr_p = txq->wr_p; + nop_slots = D_BLOCK_CPL(wr_p); + + for (i = nop_slots; i >= 4; i -= 4, wr_p += 4) { + _mm256_store_si256((void *)&txq->ktxds[wr_p], zero_256); + rte_pktmbuf_free_bulk(&txq->txbufs[wr_p].mbuf, 4); + _mm256_store_si256((void *)&txq->txbufs[wr_p], zero_256); + } + + for (; i >= 2; i -= 2, wr_p += 2) { + _mm_store_si128((void *)&txq->ktxds[wr_p], zero_128); + rte_pktmbuf_free_bulk(&txq->txbufs[wr_p].mbuf, 2); + _mm_store_si128((void *)&txq->txbufs[wr_p], zero_128); + } + + for (; i >= 1; i--, wr_p++) { + _mm_storel_epi64((void *)&txq->ktxds[wr_p], zero_128); + rte_pktmbuf_free(txq->txbufs[wr_p].mbuf); + _mm_storel_epi64((void *)&txq->txbufs[wr_p], zero_128); + } + + txq->data_pending = 0; + txq->wr_p = D_IDX(txq, txq->wr_p + nop_slots); + + (*simple_close) += nop_slots; +} + +static inline uint32_t +nfp_net_nfdk_vec_avx2_xmit_simple_prepare(struct nfp_net_txq *txq, + uint16_t *simple_close) +{ + uint16_t wr_p; + __m128i zero_128 = _mm_setzero_si128(); + + wr_p = txq->wr_p; + + _mm_storel_epi64((void *)&txq->ktxds[wr_p], zero_128); + rte_pktmbuf_free(txq->txbufs[wr_p].mbuf); + _mm_storel_epi64((void *)&txq->txbufs[wr_p], zero_128); + + txq->wr_p = D_IDX(txq, wr_p + 1); + (*simple_close)++; + + return txq->wr_p; +} + +static inline void +nfp_net_nfdk_vec_avx2_xmit_simple_check(struct nfp_net_txq *txq, + struct rte_mbuf *pkt, + bool *simple_flag, + bool *pending_flag, + uint16_t *data_pending, + uint32_t *wr_p, + uint16_t *simple_close) +{ + uint32_t data_pending_temp; + + /* Let the first descriptor index even before send simple packets */ + if (!(*simple_flag)) { + if ((*wr_p & 0x1) == 0x1) + *wr_p = nfp_net_nfdk_vec_avx2_xmit_simple_prepare(txq, simple_close); + + *simple_flag = true; + } + + /* Simple packets only need one close block operation */ + if (!(*pending_flag)) { + if ((*wr_p & (NFDK_TX_DESC_BLOCK_CNT - 1)) == 0) { + *pending_flag = true; + return; + } + + data_pending_temp = *data_pending + pkt->data_len; + if (data_pending_temp > NFDK_TX_MAX_DATA_PER_BLOCK) { + nfp_net_nfdk_vec_avx2_xmit_simple_close_block(txq, simple_close); + *pending_flag = true; + return; + } + + *data_pending = data_pending_temp; + + *wr_p += 2; + } +} + +static inline uint16_t +nfp_net_nfdk_vec_avx2_xmit_simple_count(struct nfp_net_txq *txq, + struct rte_mbuf **tx_pkts, + uint16_t head, + uint16_t nb_pkts, + uint16_t *simple_close) +{ + uint32_t wr_p; + uint16_t simple_idx; + struct rte_mbuf *pkt; + uint16_t data_pending; + bool simple_flag = false; + bool pending_flag = false; + uint16_t simple_count = 0; + + *simple_close = 0; + wr_p = txq->wr_p; + data_pending = txq->data_pending; + + for (simple_idx = head; simple_idx < nb_pkts; simple_idx++) { + pkt = tx_pkts[simple_idx]; + if (!nfp_net_nfdk_is_simple_packet(pkt, txq->hw)) + break; + + simple_count++; + if (!txq->simple_always) + nfp_net_nfdk_vec_avx2_xmit_simple_check(txq, pkt, &simple_flag, + &pending_flag, &data_pending, &wr_p, simple_close); + } + + return simple_count; +} + +static inline uint16_t +nfp_net_nfdk_vec_avx2_xmit_others_count(struct nfp_net_txq *txq, + struct rte_mbuf **tx_pkts, + uint16_t head, + uint16_t nb_pkts) +{ + uint16_t others_idx; + struct rte_mbuf *pkt; + uint16_t others_count = 0; + + for (others_idx = head; others_idx < nb_pkts; others_idx++) { + pkt = tx_pkts[others_idx]; + if (nfp_net_nfdk_is_simple_packet(pkt, txq->hw)) + break; + + others_count++; + } + + return others_count; +} + +static inline uint16_t +nfp_net_nfdk_vec_avx2_xmit_common(void *tx_queue, + struct rte_mbuf **tx_pkts, + uint16_t nb_pkts) +{ + uint16_t i; + uint16_t avail = 0; + uint16_t simple_close; + uint16_t simple_count; + uint16_t simple_avail; + uint16_t others_count; + uint16_t others_avail; + struct nfp_net_txq *txq = tx_queue; + + for (i = 0; i < nb_pkts; i++) { + simple_count = nfp_net_nfdk_vec_avx2_xmit_simple_count(txq, tx_pkts, i, + nb_pkts, &simple_close); + if (simple_count > 0) { + if (!txq->simple_always) + txq->simple_always = true; + + simple_avail = nfp_net_nfdk_vec_avx2_xmit_simple_pkts(txq, + tx_pkts + i, simple_count, simple_close, + false); + + avail += simple_avail; + if (simple_avail != simple_count) + break; + + i += simple_count; + } + + if (i == nb_pkts) + break; + + others_count = nfp_net_nfdk_vec_avx2_xmit_others_count(txq, tx_pkts, + i, nb_pkts); + + if (txq->simple_always) + txq->simple_always = false; + + others_avail = nfp_net_nfdk_xmit_pkts_common(tx_queue, + tx_pkts + i, others_count, false); + + avail += others_avail; + if (others_avail != others_count) + break; + + i += others_count; + } + + return avail; +} + +uint16_t +nfp_net_nfdk_vec_avx2_xmit_pkts(void *tx_queue, + struct rte_mbuf **tx_pkts, + uint16_t nb_pkts) +{ + return nfp_net_nfdk_vec_avx2_xmit_common(tx_queue, tx_pkts, nb_pkts); +} diff --git a/drivers/net/nfp/nfdk/nfp_nfdk_vec_stub.c b/drivers/net/nfp/nfdk/nfp_nfdk_vec_stub.c new file mode 100644 index 0000000000..146ec21d51 --- /dev/null +++ b/drivers/net/nfp/nfdk/nfp_nfdk_vec_stub.c @@ -0,0 +1,14 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright(c) 2024 Corigine, Inc. + * All rights reserved. + */ + +#include "nfp_nfdk_vec.h" + +uint16_t __rte_weak +nfp_net_nfdk_vec_avx2_xmit_pkts(__rte_unused void *tx_queue, + __rte_unused struct rte_mbuf **tx_pkts, + __rte_unused uint16_t nb_pkts) +{ + return 0; +} diff --git a/drivers/net/nfp/nfp_ethdev.c b/drivers/net/nfp/nfp_ethdev.c index 8c0cacd3fc..a7b40af712 100644 --- a/drivers/net/nfp/nfp_ethdev.c +++ b/drivers/net/nfp/nfp_ethdev.c @@ -28,6 +28,7 @@ #include "nfp_ipsec.h" #include "nfp_logs.h" #include "nfp_net_flow.h" +#include "nfp_rxtx_vec.h" /* 64-bit per app capabilities */ #define NFP_NET_APP_CAP_SP_INDIFF RTE_BIT64(0) /* Indifferent to port speed */ @@ -964,7 +965,7 @@ nfp_net_ethdev_ops_mount(struct nfp_net_hw *hw, if (hw->ver.extend == NFP_NET_CFG_VERSION_DP_NFD3) eth_dev->tx_pkt_burst = nfp_net_nfd3_xmit_pkts; else - eth_dev->tx_pkt_burst = nfp_net_nfdk_xmit_pkts; + nfp_net_nfdk_xmit_pkts_set(eth_dev); eth_dev->dev_ops = &nfp_net_eth_dev_ops; eth_dev->rx_queue_count = nfp_net_rx_queue_count; diff --git a/drivers/net/nfp/nfp_ethdev_vf.c b/drivers/net/nfp/nfp_ethdev_vf.c index e7c18fe90a..b955624ed6 100644 --- a/drivers/net/nfp/nfp_ethdev_vf.c +++ b/drivers/net/nfp/nfp_ethdev_vf.c @@ -14,6 +14,7 @@ #include "nfp_logs.h" #include "nfp_net_common.h" +#include "nfp_rxtx_vec.h" #define NFP_VF_DRIVER_NAME net_nfp_vf @@ -240,7 +241,7 @@ nfp_netvf_ethdev_ops_mount(struct nfp_net_hw *hw, if (hw->ver.extend == NFP_NET_CFG_VERSION_DP_NFD3) eth_dev->tx_pkt_burst = nfp_net_nfd3_xmit_pkts; else - eth_dev->tx_pkt_burst = nfp_net_nfdk_xmit_pkts; + nfp_net_nfdk_xmit_pkts_set(eth_dev); eth_dev->dev_ops = &nfp_netvf_eth_dev_ops; eth_dev->rx_queue_count = nfp_net_rx_queue_count; diff --git a/drivers/net/nfp/nfp_rxtx.h b/drivers/net/nfp/nfp_rxtx.h index 9806384a63..3ddf717da0 100644 --- a/drivers/net/nfp/nfp_rxtx.h +++ b/drivers/net/nfp/nfp_rxtx.h @@ -69,9 +69,12 @@ struct __rte_aligned(64) nfp_net_txq { /** Used by NFDk only */ uint16_t data_pending; + /** Used by NFDk vector xmit only */ + bool simple_always; + /** * At this point 58 bytes have been used for all the fields in the - * TX critical path. We have room for 6 bytes and still all placed + * TX critical path. We have room for 5 bytes and still all placed * in a cache line. */ uint64_t dma; diff --git a/drivers/net/nfp/nfp_rxtx_vec.h b/drivers/net/nfp/nfp_rxtx_vec.h new file mode 100644 index 0000000000..c92660f963 --- /dev/null +++ b/drivers/net/nfp/nfp_rxtx_vec.h @@ -0,0 +1,13 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright(c) 2024 Corigine, Inc. + * All rights reserved. + */ + +#ifndef __NFP_RXTX_VEC_AVX2_H__ +#define __NFP_RXTX_VEC_AVX2_H__ + +#include + +bool nfp_net_get_avx2_supported(void); + +#endif /* __NFP_RXTX_VEC_AVX2_H__ */ diff --git a/drivers/net/nfp/nfp_rxtx_vec_avx2.c b/drivers/net/nfp/nfp_rxtx_vec_avx2.c new file mode 100644 index 0000000000..50638e74ab --- /dev/null +++ b/drivers/net/nfp/nfp_rxtx_vec_avx2.c @@ -0,0 +1,21 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright(c) 2024 Corigine, Inc. + * All rights reserved. + */ + +#include + +#include +#include + +#include "nfp_rxtx_vec.h" + +bool +nfp_net_get_avx2_supported(void) +{ + if (rte_vect_get_max_simd_bitwidth() >= RTE_VECT_SIMD_256 && + rte_cpu_get_flag_enabled(RTE_CPUFLAG_AVX2) == 1) + return true; + + return false; +} diff --git a/drivers/net/nfp/nfp_rxtx_vec_stub.c b/drivers/net/nfp/nfp_rxtx_vec_stub.c new file mode 100644 index 0000000000..1bc55b67e0 --- /dev/null +++ b/drivers/net/nfp/nfp_rxtx_vec_stub.c @@ -0,0 +1,16 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright(c) 2024 Corigine, Inc. + * All rights reserved. + */ + +#include + +#include + +#include "nfp_rxtx_vec.h" + +bool __rte_weak +nfp_net_get_avx2_supported(void) +{ + return false; +} From patchwork Tue Jul 9 07:29:20 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Chaoyong He X-Patchwork-Id: 142246 X-Patchwork-Delegate: ferruh.yigit@amd.com Return-Path: X-Original-To: patchwork@inbox.dpdk.org Delivered-To: patchwork@inbox.dpdk.org Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id B3AEE455D8; Tue, 9 Jul 2024 09:30:04 +0200 (CEST) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 3C0EB42EC3; Tue, 9 Jul 2024 09:29:54 +0200 (CEST) Received: from NAM10-DM6-obe.outbound.protection.outlook.com (mail-dm6nam10on2138.outbound.protection.outlook.com [40.107.93.138]) by mails.dpdk.org (Postfix) with ESMTP id BF24242EB2 for ; Tue, 9 Jul 2024 09:29:49 +0200 (CEST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=y2ZU+meclF4raEOyMAX3f0F5SIh2dzjgXeXk0cnuZRYo4P32eAPzKfcvederju+YT6mn6iKNwNVK7wF5sXz0IZbRrqNO2fsM7i7Sn6vSY4Mst3b2DFDDJlKaImwM3KTWgGTOGTvM53wUnpX7IQnnuvOOE2qFg/vtQ4D2YZl8fiAbPBvRbkxeFAiTCi6wlDHYOithrVqWQ+dvU1mocunV3/L34JbtQLaMfQr2M14whRT8yTMgGLa4skEaJmNP0hZUpWKafM/VnTPoGmuW7caG7LhMRJWckynFVZDnqjD9XtwFPMv42Hxl7GR9pspr9mgOyNVVqssk4VSiE2Oii1Qxdg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; 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=N6JCFJ1UfYjxx3p4MczPGXGg1TietJWwueWtE9jfUuI=; b=Id1ystLUZziwe5TRMsOmt+s6m8XoBhT8r1g63gsaxsU3QzIRkdsRXjgve3hx6N1/CzCYVkq8O6p5zCmbu9cto5Gn/e04d+Nkouo0lQMJdKaT8nQ8VYVXx8yFHDRhfPB8qstLH4NsjMO3eCAUHWaHrAB1XRoAW/qlUbPj5LOVT602AlyKLQT4PdJjKMn4kGi5OXtWDpiwgyKM9Y1pLJ2d+nTSfoB6hx3rLx5jHG0OHT1vm2zofpGRfMaUI9f3xoYMQ5djWIqaeb08xGqp5DhQUaw/M6ezVL1nU9Spqan6E9JBzdAF8i09i0ALp2BUh8YGemlsIzb8p3dCyLSWcqIyXA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=corigine.com; dmarc=pass action=none header.from=corigine.com; dkim=pass header.d=corigine.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=corigine.onmicrosoft.com; s=selector2-corigine-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=N6JCFJ1UfYjxx3p4MczPGXGg1TietJWwueWtE9jfUuI=; b=IPaEV10RPIf+bmYo9zzSnXA+VRnAMPfoOZoDhiHWe8l9kU1Rgt/SIX5uk5LF9t1Ae0ETA6HMRlvZly6fmY/2/DwMh110HbHe2qDg/RgVDajCQpj2vHXq7JCNnUk1/WDV5SKW9EZTpoJ48PNsOMTbk8vz/N6x+3HKkf+T2hGZ/JI= Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=corigine.com; Received: from SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5) by SA1PR13MB4958.namprd13.prod.outlook.com (2603:10b6:806:189::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7741.36; Tue, 9 Jul 2024 07:29:48 +0000 Received: from SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::b900:5f05:766f:833]) by SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::b900:5f05:766f:833%4]) with mapi id 15.20.7741.033; Tue, 9 Jul 2024 07:29:48 +0000 From: Chaoyong He To: dev@dpdk.org Cc: oss-drivers@corigine.com, Long Wu , Peng Zhang , Chaoyong He Subject: [PATCH v3 3/4] net/nfp: support AVX2 Rx function Date: Tue, 9 Jul 2024 15:29:20 +0800 Message-Id: <20240709072921.246520-4-chaoyong.he@corigine.com> X-Mailer: git-send-email 2.39.1 In-Reply-To: <20240709072921.246520-1-chaoyong.he@corigine.com> References: <20240708055854.107739-1-chaoyong.he@corigine.com> <20240709072921.246520-1-chaoyong.he@corigine.com> X-ClientProxiedBy: SJ0PR13CA0232.namprd13.prod.outlook.com (2603:10b6:a03:2c1::27) To SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: SJ0PR13MB5545:EE_|SA1PR13MB4958:EE_ X-MS-Office365-Filtering-Correlation-Id: d4159e9d-c299-4f72-7cb0-08dc9fe8e999 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; ARA:13230040|1800799024|52116014|366016|376014|38350700014; X-Microsoft-Antispam-Message-Info: a+jy6sFvBEHgR1HZrUrNut2r+1g07gMMYGP4fARI794WJjKmCHqD9yGFwKMppc0Vqbl/uOuHbGTzu6RT7TyD0zZMMbfeJh0V2jutkzoiMqEH2C9Ty6wXtV5NUcyVKHxGBAEPXsru8ep1UlQ73kBHDZbBdTnoc9SJEj+dth17hFRu+86d/DKEK7RQ+6+24hRea8TvKPP4FrSQ9hsiKAZJCEU8RPrmtlblajqRbCdcl+8Kag0zUNsZiurO8wg6hNydEiiX2CCPBnwFFaa2HdiQWWDAc0qEB8lRM53b9Cybixn83LH+G/Ils5PWp4r4YLzOdBJ36sLAdJEs8oP9f9p0zSH+HwIXiDVh1U9TT8sc64qnxh59Am7GiEPa3aBisBtBU33P7ty/6ETgOy0+vKubO7eTr1cM/Qq0rtRQ/5yVLtUE/45oNAuY/1Q19KspSEBSFPy+3sruiJ17+Af+MekAvJ2quiCP/+wutnFQrCbr8kvuJZsRuoW7uyyyWdaXIjmcMEJ+KfjjH8PnaPxVmsehcNDtRtnwwPIM92RbWWU3CkZeT/OJ337g9qdxOuf6Ffj5xyE31rBDM9dWSJAEEw6ZjcQ/piGTUyV7ykCgA9GLzSj7ornTOE1UJb3BgIGtIjL/ji03NWf+/vjlhacRiw+iL25LXSCTRXIVbDoM4+uYa1Au9PyhUtbAPvrD7WZS5AVd90gexxNVGWeh+iTUGK1zSySbz8G9qkDUWH6YpYCsKKUgJ0yrKoZ+FhYsufft8AiRdg4jCbJk10TieNvk1oHTfeEphWOI8vn+8TZviBIYU7/TbHkjuTc61tLrX/tsbANgAmiQWy97pGceRQh1JGiFliPE/J9MZqglvaK1FYdmlUutnVBm7rfSWtHcuvWhsTD32Fh9sczWXas72T1Apitlab5h7w1cy2r1Pa8/As978cwFUMQeglcsfQwb4xipKWyJLHNhthPzzwzJES0euAZ9Rd/CLbbmV1djyU7/VcGZoSQ8hf9moy2oTBBK+gIJXy63y4GEsyxDTDlb47okXNed71H/7sk/slnAty/XJ4hmCLRDlPckVyf0f7+jKCVjbNUcg1+xwHWoQpn1seHIniT9Hlm9DhtX8AjQ3Y1T6OdEb9jcgOxiHVIguv3YZdD9RYl7pAr5KKkZ9d2/r/f5SNW84vzXCyHQcJS90zjfImKWbkl5ZMC9zRMGMGQiI9ok0eO/WhfByydRKfyO5+0vC+FPSs+Krt3GxonSuUbZK3bSDZGLn7DBWVAvMh+5OWCOwob+OX/Ez0O0My/vxHK2+nRkr/3jGvwZNeJvRKR6xszNrhYMDfh8BOXkiPZmbo2sROCpkINlhv3SEI6YFossnw//lkXXyVTSa3UGK2iifYGWKTvWqBDwYeSuInCO42cy+rREeDkpn9HgqI6IupEpm0zDVw== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:SJ0PR13MB5545.namprd13.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230040)(1800799024)(52116014)(366016)(376014)(38350700014); DIR:OUT; SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: IeOilEHn1r59VdMWSEYDOM2yq7UodsGTXi9DDihB4bK84IKL/I8DXHUJ1Ew6mwYBaLZFHWWFNWWBJVjcALWVFMI8fb1HWFTYr/nzCkYUCuLv9yrwQ5rn+cp9wqgrj/EYzUwnIfzRSqVMpgcRJw9nYxV6HGYBh69iNfR3Ltzn4a2qhCp6rbVZCdtBuetodqFK7aXlw5PgY85icu+mmJTgg/ZDCLGVXauoGw8AFwXWRyha3GbSW9D2hv50dZCcFVbwUsxoYaRUEHteMY6ITheEif2FKzyqHbQPM735mcvT/rVAPw5F/AiAboXWsNQs5hRWkTP1GZIRFe9MB/k+qQAbVnXlizOYAl4pZ9A8Xei3joDnsmCAlJCXqwcXuySBbgnyOMqAvQwVZnrhFnXpVCEOWZLuCl4JswmYlPTzOm/EKCI/N6csYehWldjulyZin/DWlkyAE9lYPQ7FkXd8LgpKkQqyDbomD0Nn5b2oy0WhTJd2Jho/ym9SAmRG/kcYsempjFMzV9IvOLhKkcTOeGUQ32yrc/a4Kc4i7VRl+xsOOi4/1wKqFlmMBsCsBW2oWdOr4YJniK8mh8rtWtFGfJ4w+ljrR1uyYeNDNnMpVcFfJuo5wHVCtKDhZtRZAdCkNvjFdJQsr1REWlKVKERDRe4l9IclWq9NTI6Ik1ydfKPIA3yeWPqpu0PSeCFatW1dpQs+ndc4atMpYCElq/mYzX/A3Swi2OBYIIavEjxxWLc0R3kq6qkhs7BsoY66UYlqIX2MMyRxflxdCdR/xyzbGJfsWHslk+Cfj8E1tzIn4ZLYvPznAIIw6YFPi6KMtCFvhBc0v3EI31Zo8Mdb7l3XBmbapN/jvxEERn0n6BUuPU79Y55DdvI3wrU+4YZq+slrCnZXgqD+P0rV0rnnvdXZt9JCtans8FJ/ulS4wxaOxthufs5R8KdTl96z/wdQYE10kWn5N1fku3bYPRbcF7K0CTcjqo0OKScTTRALQnjxNNR00lINv31QZgignzLtyoRsBJnnqcN4aqo6l5LdKIXRznO0l8tTivr1fJ499MHQhKk7u+i97O7HTp4bKhKBzXg8Ii7eIE+6gOoSqdQlaz3ihYnOxtS5i5fPrLBJVFrr9W1PHprDvD2LFYevs2jpTARZ7S7/WYlaZJDQs6DM+EK0USA6w4HfE9hkAVeYwu0SKSCb/OAVFomMRsiFCUlKYjiv6XQk1D5bHeW16/+KMOCTbzJeslR8/hbRlgd5x7lAiOfAo0SHJvp3hpTbn6ej/umMd9B/OOjXmKX8j9ZsciwxZ1Q0D6OfOkHyeQXgNK2R5pRQUABfi8mcM7BsWMhMq5OP8Pv7D4omrsM85Ey5fB+ByzwMj5SvvciNKdsqh8WwcgqEs04rUKDxvtgE6sWE+PaZTE0nZfSYw72nROktyal+/C6IxXQmZKd6bGBqRkje4cAB8dltOUxbiGZNyhwvoupaUAF4HbKCB/eFsmPHkWG9kCLALWLJi+uEx+ieKQW/NGSmQx2Flk/UL5lRmOcUIgF03OwFsWuSOrNs9qb3xzOT4/4V/+51jAwC54iUEQ0p/Zep6z5pftsf/GikXoWIqh47G/jJlkST7AI4EeEFtTfdDylM/g== X-OriginatorOrg: corigine.com X-MS-Exchange-CrossTenant-Network-Message-Id: d4159e9d-c299-4f72-7cb0-08dc9fe8e999 X-MS-Exchange-CrossTenant-AuthSource: SJ0PR13MB5545.namprd13.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Jul 2024 07:29:48.3705 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: fe128f2c-073b-4c20-818e-7246a585940c X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 9ZCcvvYj+4+8W/qIVMiNrn29xlBXFzUEtE+VYXoUwJbCIZLYCa2cNRf0C4V2mMkAifBItDH02ut+KidF24yyXTKyagIVSogvXfg3kVSCBSY= X-MS-Exchange-Transport-CrossTenantHeadersStamped: SA1PR13MB4958 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 From: Long Wu Use AVX2 instructions to accelerate Rx performance. The acceleration only works on X86 machine. Signed-off-by: Peng Zhang Signed-off-by: Long Wu Reviewed-by: Chaoyong He --- drivers/net/nfp/nfp_ethdev.c | 2 +- drivers/net/nfp/nfp_ethdev_vf.c | 2 +- drivers/net/nfp/nfp_net_meta.c | 1 + drivers/net/nfp/nfp_rxtx.c | 10 ++ drivers/net/nfp/nfp_rxtx.h | 1 + drivers/net/nfp/nfp_rxtx_vec.h | 4 + drivers/net/nfp/nfp_rxtx_vec_avx2.c | 252 ++++++++++++++++++++++++++++ drivers/net/nfp/nfp_rxtx_vec_stub.c | 9 + 8 files changed, 279 insertions(+), 2 deletions(-) diff --git a/drivers/net/nfp/nfp_ethdev.c b/drivers/net/nfp/nfp_ethdev.c index a7b40af712..bd35df2dc9 100644 --- a/drivers/net/nfp/nfp_ethdev.c +++ b/drivers/net/nfp/nfp_ethdev.c @@ -969,7 +969,7 @@ nfp_net_ethdev_ops_mount(struct nfp_net_hw *hw, eth_dev->dev_ops = &nfp_net_eth_dev_ops; eth_dev->rx_queue_count = nfp_net_rx_queue_count; - eth_dev->rx_pkt_burst = &nfp_net_recv_pkts; + nfp_net_recv_pkts_set(eth_dev); } static int diff --git a/drivers/net/nfp/nfp_ethdev_vf.c b/drivers/net/nfp/nfp_ethdev_vf.c index b955624ed6..cdf5da3af7 100644 --- a/drivers/net/nfp/nfp_ethdev_vf.c +++ b/drivers/net/nfp/nfp_ethdev_vf.c @@ -245,7 +245,7 @@ nfp_netvf_ethdev_ops_mount(struct nfp_net_hw *hw, eth_dev->dev_ops = &nfp_netvf_eth_dev_ops; eth_dev->rx_queue_count = nfp_net_rx_queue_count; - eth_dev->rx_pkt_burst = &nfp_net_recv_pkts; + nfp_net_recv_pkts_set(eth_dev); } static int diff --git a/drivers/net/nfp/nfp_net_meta.c b/drivers/net/nfp/nfp_net_meta.c index b31ef56f17..07c6758d33 100644 --- a/drivers/net/nfp/nfp_net_meta.c +++ b/drivers/net/nfp/nfp_net_meta.c @@ -80,6 +80,7 @@ nfp_net_meta_parse_single(uint8_t *meta_base, rte_be32_t meta_header, struct nfp_net_meta_parsed *meta) { + meta->flags = 0; meta->flags |= (1 << NFP_NET_META_HASH); meta->hash_type = rte_be_to_cpu_32(meta_header); meta->hash = rte_be_to_cpu_32(*(rte_be32_t *)(meta_base + 4)); diff --git a/drivers/net/nfp/nfp_rxtx.c b/drivers/net/nfp/nfp_rxtx.c index 1db79ad1cd..4fc3374987 100644 --- a/drivers/net/nfp/nfp_rxtx.c +++ b/drivers/net/nfp/nfp_rxtx.c @@ -17,6 +17,7 @@ #include "nfp_ipsec.h" #include "nfp_logs.h" #include "nfp_net_meta.h" +#include "nfp_rxtx_vec.h" /* * The bit format and map of nfp packet type for rxd.offload_info in Rx descriptor. @@ -867,3 +868,12 @@ nfp_net_tx_queue_info_get(struct rte_eth_dev *dev, info->conf.offloads = dev_info.tx_offload_capa & dev->data->dev_conf.txmode.offloads; } + +void +nfp_net_recv_pkts_set(struct rte_eth_dev *eth_dev) +{ + if (nfp_net_get_avx2_supported()) + eth_dev->rx_pkt_burst = nfp_net_vec_avx2_recv_pkts; + else + eth_dev->rx_pkt_burst = nfp_net_recv_pkts; +} diff --git a/drivers/net/nfp/nfp_rxtx.h b/drivers/net/nfp/nfp_rxtx.h index 3ddf717da0..fff8371991 100644 --- a/drivers/net/nfp/nfp_rxtx.h +++ b/drivers/net/nfp/nfp_rxtx.h @@ -244,5 +244,6 @@ void nfp_net_rx_queue_info_get(struct rte_eth_dev *dev, void nfp_net_tx_queue_info_get(struct rte_eth_dev *dev, uint16_t queue_id, struct rte_eth_txq_info *qinfo); +void nfp_net_recv_pkts_set(struct rte_eth_dev *eth_dev); #endif /* __NFP_RXTX_H__ */ diff --git a/drivers/net/nfp/nfp_rxtx_vec.h b/drivers/net/nfp/nfp_rxtx_vec.h index c92660f963..8720662744 100644 --- a/drivers/net/nfp/nfp_rxtx_vec.h +++ b/drivers/net/nfp/nfp_rxtx_vec.h @@ -10,4 +10,8 @@ bool nfp_net_get_avx2_supported(void); +uint16_t nfp_net_vec_avx2_recv_pkts(void *rx_queue, + struct rte_mbuf **rx_pkts, + uint16_t nb_pkts); + #endif /* __NFP_RXTX_VEC_AVX2_H__ */ diff --git a/drivers/net/nfp/nfp_rxtx_vec_avx2.c b/drivers/net/nfp/nfp_rxtx_vec_avx2.c index 50638e74ab..7c18213624 100644 --- a/drivers/net/nfp/nfp_rxtx_vec_avx2.c +++ b/drivers/net/nfp/nfp_rxtx_vec_avx2.c @@ -5,9 +5,14 @@ #include +#include +#include #include #include +#include "nfp_logs.h" +#include "nfp_net_common.h" +#include "nfp_net_meta.h" #include "nfp_rxtx_vec.h" bool @@ -19,3 +24,250 @@ nfp_net_get_avx2_supported(void) return false; } + +static inline void +nfp_vec_avx2_recv_set_des1(struct nfp_net_rxq *rxq, + struct nfp_net_rx_desc *rxds, + struct rte_mbuf *rxb) +{ + __m128i dma; + __m128i dma_hi; + __m128i vaddr0; + __m128i hdr_room = _mm_set_epi64x(0, RTE_PKTMBUF_HEADROOM); + + dma = _mm_add_epi64(_mm_loadu_si128((__m128i *)&rxb->buf_addr), hdr_room); + dma_hi = _mm_srli_epi64(dma, 32); + vaddr0 = _mm_unpacklo_epi32(dma_hi, dma); + + _mm_storel_epi64((void *)rxds, vaddr0); + + rxq->rd_p = (rxq->rd_p + 1) & (rxq->rx_count - 1); +} + +static inline void +nfp_vec_avx2_recv_set_des4(struct nfp_net_rxq *rxq, + struct nfp_net_rx_desc *rxds, + struct rte_mbuf **rxb) +{ + __m128i dma; + __m128i dma_hi; + __m128i vaddr0; + __m128i vaddr1; + __m128i vaddr2; + __m128i vaddr3; + __m128i vaddr0_1; + __m128i vaddr2_3; + __m256i vaddr0_3; + __m128i hdr_room = _mm_set_epi64x(0, RTE_PKTMBUF_HEADROOM); + + dma = _mm_add_epi64(_mm_loadu_si128((__m128i *)&rxb[0]->buf_addr), hdr_room); + dma_hi = _mm_srli_epi64(dma, 32); + vaddr0 = _mm_unpacklo_epi32(dma_hi, dma); + + dma = _mm_add_epi64(_mm_loadu_si128((__m128i *)&rxb[1]->buf_addr), hdr_room); + dma_hi = _mm_srli_epi64(dma, 32); + vaddr1 = _mm_unpacklo_epi32(dma_hi, dma); + + dma = _mm_add_epi64(_mm_loadu_si128((__m128i *)&rxb[2]->buf_addr), hdr_room); + dma_hi = _mm_srli_epi64(dma, 32); + vaddr2 = _mm_unpacklo_epi32(dma_hi, dma); + + dma = _mm_add_epi64(_mm_loadu_si128((__m128i *)&rxb[3]->buf_addr), hdr_room); + dma_hi = _mm_srli_epi64(dma, 32); + vaddr3 = _mm_unpacklo_epi32(dma_hi, dma); + + vaddr0_1 = _mm_unpacklo_epi64(vaddr0, vaddr1); + vaddr2_3 = _mm_unpacklo_epi64(vaddr2, vaddr3); + + vaddr0_3 = _mm256_inserti128_si256(_mm256_castsi128_si256(vaddr0_1), + vaddr2_3, 1); + + _mm256_store_si256((void *)rxds, vaddr0_3); + + rxq->rd_p = (rxq->rd_p + 4) & (rxq->rx_count - 1); +} + +static inline void +nfp_vec_avx2_recv_set_rxpkt1(struct nfp_net_rxq *rxq, + struct nfp_net_rx_desc *rxds, + struct rte_mbuf *rx_pkt) +{ + struct nfp_net_hw *hw = rxq->hw; + struct nfp_net_meta_parsed meta; + + rx_pkt->data_len = rxds->rxd.data_len - NFP_DESC_META_LEN(rxds); + /* Size of the whole packet. We just support 1 segment */ + rx_pkt->pkt_len = rxds->rxd.data_len - NFP_DESC_META_LEN(rxds); + + /* Filling the received mbuf with packet info */ + if (hw->rx_offset) + rx_pkt->data_off = RTE_PKTMBUF_HEADROOM + hw->rx_offset; + else + rx_pkt->data_off = RTE_PKTMBUF_HEADROOM + NFP_DESC_META_LEN(rxds); + + rx_pkt->port = rxq->port_id; + rx_pkt->nb_segs = 1; + rx_pkt->next = NULL; + + nfp_net_meta_parse(rxds, rxq, hw, rx_pkt, &meta); + + /* Checking the checksum flag */ + nfp_net_rx_cksum(rxq, rxds, rx_pkt); +} + +static inline void +nfp_vec_avx2_recv1(struct nfp_net_rxq *rxq, + struct nfp_net_rx_desc *rxds, + struct rte_mbuf *rxb, + struct rte_mbuf *rx_pkt) +{ + nfp_vec_avx2_recv_set_rxpkt1(rxq, rxds, rx_pkt); + + nfp_vec_avx2_recv_set_des1(rxq, rxds, rxb); +} + +static inline void +nfp_vec_avx2_recv4(struct nfp_net_rxq *rxq, + struct nfp_net_rx_desc *rxds, + struct rte_mbuf **rxb, + struct rte_mbuf **rx_pkts) +{ + nfp_vec_avx2_recv_set_rxpkt1(rxq, rxds, rx_pkts[0]); + nfp_vec_avx2_recv_set_rxpkt1(rxq, rxds + 1, rx_pkts[1]); + nfp_vec_avx2_recv_set_rxpkt1(rxq, rxds + 2, rx_pkts[2]); + nfp_vec_avx2_recv_set_rxpkt1(rxq, rxds + 3, rx_pkts[3]); + + nfp_vec_avx2_recv_set_des4(rxq, rxds, rxb); +} + +static inline bool +nfp_vec_avx2_recv_check_packets4(struct nfp_net_rx_desc *rxds) +{ + __m256i data = _mm256_loadu_si256((void *)rxds); + + if ((_mm256_extract_epi8(data, 3) & PCIE_DESC_RX_DD) == 0 || + (_mm256_extract_epi8(data, 11) & PCIE_DESC_RX_DD) == 0 || + (_mm256_extract_epi8(data, 19) & PCIE_DESC_RX_DD) == 0 || + (_mm256_extract_epi8(data, 27) & PCIE_DESC_RX_DD) == 0) + return false; + + return true; +} + +uint16_t +nfp_net_vec_avx2_recv_pkts(void *rx_queue, + struct rte_mbuf **rx_pkts, + uint16_t nb_pkts) +{ + uint16_t avail; + uint16_t nb_hold; + bool burst_receive; + struct rte_mbuf **rxb; + struct nfp_net_rx_desc *rxds; + struct nfp_net_rxq *rxq = rx_queue; + + if (unlikely(rxq == NULL)) { + PMD_RX_LOG(ERR, "RX Bad queue"); + return 0; + } + + avail = 0; + nb_hold = 0; + burst_receive = true; + while (avail < nb_pkts) { + rxds = &rxq->rxds[rxq->rd_p]; + rxb = &rxq->rxbufs[rxq->rd_p].mbuf; + + if ((_mm_extract_epi8(_mm_loadu_si128((void *)(rxds)), 3) + & PCIE_DESC_RX_DD) == 0) + goto recv_end; + + rte_prefetch0(rxq->rxbufs[rxq->rd_p].mbuf); + + if ((rxq->rd_p & 0x3) == 0) { + rte_prefetch0(&rxq->rxds[rxq->rd_p]); + rte_prefetch0(&rxq->rxbufs[rxq->rd_p]); + rte_prefetch0(rxq->rxbufs[rxq->rd_p + 1].mbuf); + rte_prefetch0(rxq->rxbufs[rxq->rd_p + 2].mbuf); + rte_prefetch0(rxq->rxbufs[rxq->rd_p + 3].mbuf); + } + + if ((rxq->rd_p & 0x7) == 0) { + rte_prefetch0(rxq->rxbufs[rxq->rd_p + 4].mbuf); + rte_prefetch0(rxq->rxbufs[rxq->rd_p + 5].mbuf); + rte_prefetch0(rxq->rxbufs[rxq->rd_p + 6].mbuf); + rte_prefetch0(rxq->rxbufs[rxq->rd_p + 7].mbuf); + } + + /* + * If can not receive burst, just receive one. + * 1. Rx ring will coming to the tail. + * 2. Do not need to receive 4 packets. + * 3. If pointer address unaligned on 32-bit boundary. + * 4. Rx ring does not have 4 packets or alloc 4 mbufs failed. + */ + if ((rxq->rx_count - rxq->rd_p) < 4 || + (nb_pkts - avail) < 4 || + ((uintptr_t)rxds & 0x1F) != 0 || + !burst_receive) { + _mm_storel_epi64((void *)&rx_pkts[avail], + _mm_loadu_si128((void *)rxb)); + + /* Allocate a new mbuf into the software ring. */ + if (rte_pktmbuf_alloc_bulk(rxq->mem_pool, rxb, 1) < 0) { + PMD_RX_LOG(DEBUG, "RX mbuf alloc failed port_id=%u queue_id=%hu", + rxq->port_id, rxq->qidx); + nfp_net_mbuf_alloc_failed(rxq); + goto recv_end; + } + + nfp_vec_avx2_recv1(rxq, rxds, *rxb, rx_pkts[avail]); + + avail++; + nb_hold++; + continue; + } + + burst_receive = nfp_vec_avx2_recv_check_packets4(rxds); + if (!burst_receive) + continue; + + _mm256_storeu_si256((void *)&rx_pkts[avail], + _mm256_loadu_si256((void *)rxb)); + + /* Allocate 4 new mbufs into the software ring. */ + if (rte_pktmbuf_alloc_bulk(rxq->mem_pool, rxb, 4) < 0) { + burst_receive = false; + continue; + } + + nfp_vec_avx2_recv4(rxq, rxds, rxb, &rx_pkts[avail]); + + avail += 4; + nb_hold += 4; + } + +recv_end: + if (nb_hold == 0) + return nb_hold; + + PMD_RX_LOG(DEBUG, "RX port_id=%u queue_id=%u, %d packets received", + rxq->port_id, (unsigned int)rxq->qidx, nb_hold); + + nb_hold += rxq->nb_rx_hold; + + /* + * FL descriptors needs to be written before incrementing the + * FL queue WR pointer + */ + rte_wmb(); + if (nb_hold > rxq->rx_free_thresh) { + PMD_RX_LOG(DEBUG, "port=%hu queue=%hu nb_hold=%hu avail=%hu", + rxq->port_id, rxq->qidx, nb_hold, avail); + nfp_qcp_ptr_add(rxq->qcp_fl, NFP_QCP_WRITE_PTR, nb_hold); + nb_hold = 0; + } + rxq->nb_rx_hold = nb_hold; + + return avail; +} diff --git a/drivers/net/nfp/nfp_rxtx_vec_stub.c b/drivers/net/nfp/nfp_rxtx_vec_stub.c index 1bc55b67e0..c480f61ef0 100644 --- a/drivers/net/nfp/nfp_rxtx_vec_stub.c +++ b/drivers/net/nfp/nfp_rxtx_vec_stub.c @@ -6,6 +6,7 @@ #include #include +#include #include "nfp_rxtx_vec.h" @@ -14,3 +15,11 @@ nfp_net_get_avx2_supported(void) { return false; } + +uint16_t __rte_weak +nfp_net_vec_avx2_recv_pkts(__rte_unused void *rx_queue, + __rte_unused struct rte_mbuf **rx_pkts, + __rte_unused uint16_t nb_pkts) +{ + return 0; +} From patchwork Tue Jul 9 07:29:21 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Chaoyong He X-Patchwork-Id: 142247 X-Patchwork-Delegate: ferruh.yigit@amd.com Return-Path: X-Original-To: patchwork@inbox.dpdk.org Delivered-To: patchwork@inbox.dpdk.org Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id 5D68A455D7; Tue, 9 Jul 2024 09:30:15 +0200 (CEST) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id E673242F19; Tue, 9 Jul 2024 09:29:55 +0200 (CEST) Received: from NAM11-DM6-obe.outbound.protection.outlook.com (mail-dm6nam11on2101.outbound.protection.outlook.com [40.107.223.101]) by mails.dpdk.org (Postfix) with ESMTP id DF59142EB9 for ; Tue, 9 Jul 2024 09:29:51 +0200 (CEST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=smym/8S65PUKnvaCWnMd6QqTkP8PtURD7RwJkjq9murAEtqOYpkOip2alFp7kKZaUSc7SesH544X+7UY/xvyQhcEH/AMv4VxhITx+dlqMpVZGOaU60qylBjzdRscI4QqaLS3q5LMC8Epfsto1XttKT5MwMMYm1Jw4LZC1sjIaLAYAfKGVs5Q8oZdRWUznbr1MXgbEPmi/atphH6CvaiLr+tIKbwET349xOMZl33/i+eYGm1f1PJXiTlk2BEQK/Gp2b3vigKNMYHOaA9QqlTPraNGEd3KKvd6hW+3FqcH+jrT/+kX7jVcuosN+/vXvtgvNUoocOMSvABsELYzrtEu/A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; 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=p64hUxkicniOAYwq8iKQMxOI6MhjeHh5BudBbr/9XQA=; b=NRMLEURppvEQbsACMaNrCBpZWnqtc/dwHv/5J/WH633fOEtv3zbHjhtdWcUfg6B8QoTXjBx0V9Tujq7nJYdjazHqO13T/eTZwe6enV29FfNf+QAkDxo7cGFTi89Rt1KH7OV1DxpDV8oRshBfEKfOH40xAFgLhOBn4IBRL3UsSS7MQHM5cxKAWnFz6iJ8EL/wlMLlZoIwNKdFcYtjhKzBvSDgPGup9j4Y4nz2s9cRZK8XOwv3iGVNGVbAoGsBwFCvoAajALYsRFtc+u98aqUD1800rqbLLv6siIrX6JS7pfnjkZCDHL21Nu9c5Y+dqhmdElwE+wyqrZ8nG4UdRWm5qA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=corigine.com; dmarc=pass action=none header.from=corigine.com; dkim=pass header.d=corigine.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=corigine.onmicrosoft.com; s=selector2-corigine-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=p64hUxkicniOAYwq8iKQMxOI6MhjeHh5BudBbr/9XQA=; b=OqCm5x2R3s2XKsNmBd9ZKXZKJ+4Oah+WH4NZxTY7ah1RGXuWD/r1PZEwXXAZua8XLexNuXL5AJpgz1e8jxbp9WXEied5/7c0Yzp1kfLWF1Tr0kwwwW+GOUCdyWTbmHcvGYN5KpjXNS1Ur2l0o4W4b+WM1iGhc5mOuZtKQX/Jokk= Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=corigine.com; Received: from SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5) by SA1PR13MB4958.namprd13.prod.outlook.com (2603:10b6:806:189::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7741.36; Tue, 9 Jul 2024 07:29:50 +0000 Received: from SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::b900:5f05:766f:833]) by SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::b900:5f05:766f:833%4]) with mapi id 15.20.7741.033; Tue, 9 Jul 2024 07:29:50 +0000 From: Chaoyong He To: dev@dpdk.org Cc: oss-drivers@corigine.com, Long Wu , Chaoyong He Subject: [PATCH v3 4/4] net/nfp: vector Rx function supports parsing ptype Date: Tue, 9 Jul 2024 15:29:21 +0800 Message-Id: <20240709072921.246520-5-chaoyong.he@corigine.com> X-Mailer: git-send-email 2.39.1 In-Reply-To: <20240709072921.246520-1-chaoyong.he@corigine.com> References: <20240708055854.107739-1-chaoyong.he@corigine.com> <20240709072921.246520-1-chaoyong.he@corigine.com> X-ClientProxiedBy: SJ0PR13CA0232.namprd13.prod.outlook.com (2603:10b6:a03:2c1::27) To SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: SJ0PR13MB5545:EE_|SA1PR13MB4958:EE_ X-MS-Office365-Filtering-Correlation-Id: 4cf97bf3-3235-4bfb-bd02-08dc9fe8eaa5 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; ARA:13230040|1800799024|52116014|366016|376014|38350700014; X-Microsoft-Antispam-Message-Info: wjH70fv9JMdK+nyOjiWL8W54JhRzbNfMktY9ERwZoLt+iA2WmnC9MlKBuAPuHEJdq4PFECuQGNKMrQJJoErScuULp+u6xO3jVwJ0VcjSVa1ltVLZ3YAZUFXkntZ3qgnHACWHG3S8tuSNrwWsimhOMzAvAKCfBv8XrcsOJQaUE8q1KpjJKgl+RUFiSPKgetkUcBKVu2SDI+QQCaOBMCG/EQKtPj0l3tf2/OIqjw+C5t0RXDcdOMA8IZiQGsGxukm9LKcuDu9V9WoBA1Se9jaZ6s57qslGarVGDwoSjy1NoJNuF6fL65qAEi1UqlIhyiehDgESXftkvfJXYK8kfLoclpqu/0bTmbkll+/kFRMe8PZ9vgYP374H0MZ1m32VfstuOfwpzQ0/za8wwuYrRwCOr5WyLmrMOFD15CFlPg+V7nJ5gLhli0/Hhwls6xF6k+ov3LGj4GNPqOyQOh9vtTtxe8epytEbK1ramSBPXuq+2aubX8DSim6BYgf6KPR+1RG1a988FMJ5kbjK3QlpEU0B0bOYt1ANwaVMrEa0U0Xek8tZLL6mdVM781KE0+iTWpBI90+erVfMZcBVYk444fNxj+bl64xbRHRUFTq/4fMQq01w4Y59s07lMAWffatp7u1Pewk/gKTwXhaqf9/BYoV2UmKSHPMNfV7O4CppUcr/zb1I3cnVQGij6ymkGUqssYMf5R1JyNYBGk7DGMdSipOOQdCpYlzUtl20OUdfnMDV9StoCPrD7vVNjIMslX9SPOUh6uJyJWzHGr/CwvNi3Nesw1yLPmfkhRJSMBCioNgsP8R0znK2Ptemrhf71KT+pmLxbiuJBvjx1cu30tif0ifYnCFUS0oQ0DZTkXwmDGAAq0hlEMFfiwbjzjFiSLL78jCcVrRp9TG6I82egcIESoZIwr8Z7DG75oALgqYHsFclOBcu15h3S7UqpLrYopizRtplZPMmpx19xx/Iighyxw4pLw2fWlBV4GVkjfHj8/MH+TqV+C4OwGooYPBAnXW/XyU8zemsAU+nX0iGv35cf01psqqH7BnPJi8hD5LzC5Tt/UYMZN0EqlDwO0tQNyY0dDSi4zBJ0DcULhfkrtPpBtkW5TQDtAk07uGh/phzqZ0wzTZ4z1vUizKaT5dYXYtEM1+Zwt86wiltHNYQ8GKPkudulHlJEa7WFfG4WFeaoL7ZcWrnJLJqmYXaig+NgkfLRkmbO1Os31gTysghb4ceQy6kGEYCns90Yy5AYiWs7/5nEtjkZzz7NAX9Tr9L5ZWMLa4tQp9HUuQwIQunNgY7ro7aEQMqDHGWMnjUim7loKLCopUKCZoRnaQ+a8hs1JWn8w5CFNT5R5dlA1h9zPeg6f9yMnr7ckjCKeFIGTJx0jx2bBxegVx0raUPQybQG+2SOAfxPNbjFDqt6FdX9zyNyRpdLw== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:SJ0PR13MB5545.namprd13.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230040)(1800799024)(52116014)(366016)(376014)(38350700014); DIR:OUT; SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: D25BlfsNtcSCRUTs0qF22YhsGOLknsqQre8qGJBghAlM0vXf7bdIFuHfm1a30pen0YsCebPuRoBQb0me0OOPWsRu0EYPU8kpjhHk2aH7onSo9pZNHk5RoTtqMi4xbjWktmMqXWgxngPhXlye/i729PYw4Sh38Ht+QWF+DcYBIms4mn/zATE3fRhqZ5MkVs+pZECs4ex0I6iczSClshpVoQ1DxWlmzdBF09GBUnKjiVGFGPjandngGGCyoDXt1baH3t66MI8MufH+/ODg66bBUAsg4FYQ7GS9gXuUa3hRLzY2Pl3tmjeijmbZfiMkkNO23wKsGw9lfXukkgsBNztu5OYmgNMFuln9PVVZycQ1bNAZlM7zzEX9LnpPbMRGUvuXsbheuL5weBnFlOy6ThbiuPSsFiQJGjIx+W/AGdOdobdd/VTrk63QrBYC5/pJUojRt4okWbH6SIV/a0R1Pye3tesJt74Zxt3e9nii2BigS/UZjrNAAQAPSPdLavCArmtTT1SyWp4PmXaxYUaJu6emoeQomsb3OUDleUpeAbFFM7+lcxTSbG0rTw6r1sIv8IUBpu8b8ERu4fHp9FHhJuKfdLWelwtb12n/wb4QD/Vc9YCVOxb79yJoXs+89x4QiuAItfjZ2hZYxvr2ajTBTIw3uAiq1BL5ycknG/evaJyUUj4n7JgKdnc/xEz770ueXVwJufApNH+COIYfN0taY5Y722Wvup3ECaMgu4DNAj0HAO3iLGAHkNJeVYuta7RlY195f+N31rk/SjfMaD+ikUC5Tg6LYwrcXnKpN4d5EoYkPUrDQvxFnRfnY5SBXTrGIUk+D/dBdOcsv2CqN3k1klz5EP9YvivC93wb/PXxbu2yb34fHg6HezKJuSwHjBr7u9pR6cmR4Bwo8NUjBMvOEFdkXily4axpy09rnjm/u7ey6TBtyjGpjtXd0TrD4Xswi+s/F5cbyTZMPn5Dp/F2VJ1hw+QLYUfQ4HszfTEqCV3ZQh+DMFH3SMhHa+ilekw7/vvhOkNOdDuZQJLSM675T+Je8YsCzo+ReYnpn9By31LhdknDWy/VsykX1yCoWYGJl2latKtPIsNeTObyPd2xrZIr1WGDM+KY01RlElJDI7WlZ/uxUDtIdSycv0Qm+uqzffrT8aDocvJhsUIFOMrLyrth9QCCNW0sAmjW27K9HkNlgIheErCyUub7suH3dDh5L7feWqGsq34GulhV0s+xUgs76g8xcfJiIPLWmcu0ueejZ8PDTlYPVw8ia1LPDc4y+UPKM/0m40VEZnoKkLx7Gjpcy7+5gyPDVGB/Ym3qzxmvVzmHaxtquij67d2suEyfwaxJRxi9foZ3li2hrBJnWmpzAuIzdrnDIWurYzioRz/2B1GgOIWuK/2Yoo7ulogLVaBQb2T2GCBXpMAUiLmQBMoBrrVX1WSLkCytqCS4fh1QDA5ssXyf+OAjqdVIIX6c3j6hol7qlkFQIkoopM9hERI3BycZ5zFUwNitM7lKOwqqmPFYmBgEHLz2Kyf9kldiGHmF/1lCues33/BbsvnFd1hmZ/r18CEMEHj/Dp+CDPqqEdOZn48azkkmscVGtcVazkZ/pnevdMJK9AAEXMIG7O2sDw== X-OriginatorOrg: corigine.com X-MS-Exchange-CrossTenant-Network-Message-Id: 4cf97bf3-3235-4bfb-bd02-08dc9fe8eaa5 X-MS-Exchange-CrossTenant-AuthSource: SJ0PR13MB5545.namprd13.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Jul 2024 07:29:50.0851 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: fe128f2c-073b-4c20-818e-7246a585940c X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: REME2tTf1zuSvmsGOvNY3LHn/2pxhSqwjlvehmng1u/dFJwP/rh2g/jiMJRDPRBotwAJdvyLNDPFvvPcu4DNAnwvUXMafsy4FB0LqOyCD98= X-MS-Exchange-Transport-CrossTenantHeadersStamped: SA1PR13MB4958 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 From: Long Wu Vector AVX2 Rx function supports parsing packet type and set it to mbuf. Signed-off-by: Long Wu Reviewed-by: Chaoyong He --- drivers/net/nfp/nfp_net_common.c | 2 +- drivers/net/nfp/nfp_rxtx.c | 2 +- drivers/net/nfp/nfp_rxtx.h | 3 +++ drivers/net/nfp/nfp_rxtx_vec_avx2.c | 2 ++ 4 files changed, 7 insertions(+), 2 deletions(-) diff --git a/drivers/net/nfp/nfp_net_common.c b/drivers/net/nfp/nfp_net_common.c index 08693d5fba..3d916cd147 100644 --- a/drivers/net/nfp/nfp_net_common.c +++ b/drivers/net/nfp/nfp_net_common.c @@ -1455,7 +1455,7 @@ nfp_net_supported_ptypes_get(struct rte_eth_dev *dev, size_t *no_of_elements) RTE_PTYPE_INNER_L4_SCTP, }; - if (dev->rx_pkt_burst != nfp_net_recv_pkts) + if (dev->rx_pkt_burst == NULL) return NULL; net_hw = dev->data->dev_private; diff --git a/drivers/net/nfp/nfp_rxtx.c b/drivers/net/nfp/nfp_rxtx.c index 4fc3374987..da41a0e663 100644 --- a/drivers/net/nfp/nfp_rxtx.c +++ b/drivers/net/nfp/nfp_rxtx.c @@ -350,7 +350,7 @@ nfp_net_set_ptype(const struct nfp_ptype_parsed *nfp_ptype, * @param mb * Mbuf to set the packet type. */ -static void +void nfp_net_parse_ptype(struct nfp_net_rxq *rxq, struct nfp_net_rx_desc *rxds, struct rte_mbuf *mb) diff --git a/drivers/net/nfp/nfp_rxtx.h b/drivers/net/nfp/nfp_rxtx.h index fff8371991..c717d97003 100644 --- a/drivers/net/nfp/nfp_rxtx.h +++ b/drivers/net/nfp/nfp_rxtx.h @@ -245,5 +245,8 @@ void nfp_net_tx_queue_info_get(struct rte_eth_dev *dev, uint16_t queue_id, struct rte_eth_txq_info *qinfo); void nfp_net_recv_pkts_set(struct rte_eth_dev *eth_dev); +void nfp_net_parse_ptype(struct nfp_net_rxq *rxq, + struct nfp_net_rx_desc *rxds, + struct rte_mbuf *mb); #endif /* __NFP_RXTX_H__ */ diff --git a/drivers/net/nfp/nfp_rxtx_vec_avx2.c b/drivers/net/nfp/nfp_rxtx_vec_avx2.c index 7c18213624..508ec7faa5 100644 --- a/drivers/net/nfp/nfp_rxtx_vec_avx2.c +++ b/drivers/net/nfp/nfp_rxtx_vec_avx2.c @@ -111,6 +111,8 @@ nfp_vec_avx2_recv_set_rxpkt1(struct nfp_net_rxq *rxq, nfp_net_meta_parse(rxds, rxq, hw, rx_pkt, &meta); + nfp_net_parse_ptype(rxq, rxds, rx_pkt); + /* Checking the checksum flag */ nfp_net_rx_cksum(rxq, rxds, rx_pkt); }