From patchwork Fri Jul 1 02:20:14 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Chaoyong He X-Patchwork-Id: 113591 X-Patchwork-Delegate: andrew.rybchenko@oktetlabs.ru 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 591B6A0093; Fri, 1 Jul 2022 04:22:11 +0200 (CEST) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 2C7FD42B72; Fri, 1 Jul 2022 04:21:27 +0200 (CEST) Received: from NAM11-CO1-obe.outbound.protection.outlook.com (mail-co1nam11on2102.outbound.protection.outlook.com [40.107.220.102]) by mails.dpdk.org (Postfix) with ESMTP id 9F8E242B7D for ; Fri, 1 Jul 2022 04:21:24 +0200 (CEST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=lU2WkDCt/IMFTMWQdQT69ZJNYZqQ3R6C1gzruksbfb0yiRaKRPD0TlwyaN6taS7zcsc+nyiJ213NCS/dQSUisetfo+GZd4jzp34v72Xl9mSGxyhwvUY+BpQYwHZmdPQN4lXr1+jTT6KYSEieefiJLg4RjVTowjpLY324NThfGcD810ZW0h1HKTaKA3SHl8JHsKmJVGK6NLOvlRov00bfoFDHW5y+foWoOF9zI+NWm7TXY1ZWxCvGMo3CTryrLRBTTwWOQsI+diDDcBmMBoJVwnNjzHQQdyULw+DIz5W/UWR0Cr8t1Mbsm3m7Z7oNHOo0bogLSxKMiCKfQauM216sHQ== 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=dc+OB3u+oAIlKVE9MJQ+4zssHKMWo0Nx0Shds1ecQwk=; b=SuyTDvzxc4V6OREgL2xCmg0vhMv94fiBEwq7e0322sWCxjCdTBYBcQ0RbkeBi/kmCcuQZco6anIzsfTdpGxJ9saQzvDthoxVFyF8Ve3/gsVmxlw9AWTK5QH+ARNuNKziQSxoV2Crqwbphdfhe061pmyYLUAS9QnBy6B6SJuwNCEfiaSfr0hvXkrfJHZN8MvfgQf18CZavvc2YQibrOj51PTZwEbKp8MpvWOMi5iUKEBcT/AZX5S25M3mgnSoe4NeWzrlbYYM6bmK5VTjcXY0fKihbqnZRQHvIE/CQ40xUnSdaN7pJyoy0kXNSTo7sEzkOeTuIzgddoQrRAsiqoQevw== 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=dc+OB3u+oAIlKVE9MJQ+4zssHKMWo0Nx0Shds1ecQwk=; b=tRPjji96pYLJokS/ksbSywJkjorecL9pxmjisUgpfpMvb7kPtzBDSwVhKIF1vS6mXgXhO3kc/HCt+Vb3LN2upqKvF4vGy/XDMkiVbmqQurWTzFJyt64qtzW23T8HnTjQvNOk2waumm7fpkwYB/BwlJoM8DwzEHgXfpBXNpXmS7k= 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 BL3PR13MB5107.namprd13.prod.outlook.com (2603:10b6:208:352::20) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5417.8; Fri, 1 Jul 2022 02:21:22 +0000 Received: from SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::5d9e:9ce5:51d1:2021]) by SJ0PR13MB5545.namprd13.prod.outlook.com ([fe80::5d9e:9ce5:51d1:2021%9]) with mapi id 15.20.5395.014; Fri, 1 Jul 2022 02:21:21 +0000 From: Chaoyong He To: dev@dpdk.org Cc: niklas.soderlund@corigine.com, Chaoyong He , Heinrich Kuhn Subject: [PATCH v4 09/12] net/nfp: add flower ctrl VNIC rxtx logic Date: Fri, 1 Jul 2022 10:20:14 +0800 Message-Id: <1656642017-8992-10-git-send-email-chaoyong.he@corigine.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1656642017-8992-1-git-send-email-chaoyong.he@corigine.com> References: <1656642017-8992-1-git-send-email-chaoyong.he@corigine.com> X-ClientProxiedBy: SG2PR02CA0079.apcprd02.prod.outlook.com (2603:1096:4:90::19) To SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 3242b31b-c979-48d2-9407-08da5b0863a0 X-MS-TrafficTypeDiagnostic: BL3PR13MB5107:EE_ X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: ajo5MxuCATYYbQvCYl/CRX4Z/PaoXXD7d7slm5MJ5fJ91LrVI9bMIR01Aq+eswdCMzkOxS3+G3ucTcEwfeI48Rr88JbA6Y7kzv+Tuv40E7GfiXRRYfIxvPONZSF9kkS4GmRnY73G0HYUir8zZx6lY22QRbYbo/KMbpUiBn8ND5mfX5Mn/KmSEktriqaxTDeaQd1d7tswVtl07FiNTuhW0Zp+FdZ/40bgoYDH/aYKJusPGtBDlO6iyrc/XaYEgZYbLj+xHgTNPZh03BbpbJpLHMFtt54/hljeaZsu8YpD93DerXxRNoU/vGkLwTz4sBLQkKsvi81SG725M4a7zVWAYcjxsANiwixOPbo9SouWEGL1C2tPcbAbOgcnT3dPA8LMocJUBQ11UHjlCv5UYDQ/0LN1IWx83pF0d5xt2E1RjrTMewrJbakU8RwEmO3uW0dlYZ7J9zD4dsBowyRo2lGJRvqxfph/utv+S6nJ/lXSEkGyLWC0he3JDlsfyG4mjptdIZtQOViD1e4e+HpNN324yLFzw2CqcfrkM3GaLn0XGHgyTQfSmP7EFt45CjChOKGwJwc+/jguQ5c7HQ2e6YspPRK0HPyBLpiRIjf1V3qRFNp8TE1VCDvR5rnDxYHVGv4Y+akzUHaXKWrtA9YgKubZBptHE5HkbPh9kNWOY4oer1v+EbEhxl1tEwu2lxvsBXmBAwlDKm8Woc4hVKk7JiN3ESQeXT0Zt/Y3bvQ3qF5nAZ+OqvWcWWLva+LjpRFPaLXKRLCwlh5XX16a3psqcbIuCfCQbQ7g13Mjf5r4/+hanlyMqkkx+whcOe41TeSz0Q68 X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:SJ0PR13MB5545.namprd13.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230016)(4636009)(396003)(366004)(136003)(346002)(376002)(39840400004)(38100700002)(6512007)(38350700002)(6916009)(83380400001)(6486002)(186003)(66574015)(36756003)(26005)(316002)(54906003)(66556008)(66946007)(4326008)(2906002)(8676002)(41300700001)(8936002)(6666004)(2616005)(44832011)(6506007)(478600001)(5660300002)(86362001)(52116002)(66476007)(107886003); DIR:OUT; SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?q?ZkBIqcTNdeL8CukldXZh8T+MB7jQ?= =?utf-8?q?w5A8PY1gb6QTfHamhSoTCpRdWj2mi3TIs+hUntETAIsxJyGtcSqrp0W1YnFu0W2KT?= =?utf-8?q?w0yF5FgunIdaRrVhVARf7MdcLB3RBjCs5xgZhptG0XM7UP/MdrGVz/dEasF4WlD7L?= =?utf-8?q?e0/gsDisYqEnw5dBq+jlD+PxgDB7N4GN/wc3QlqQALlMMQzLAYgJIxWQa3yz37oV7?= =?utf-8?q?Yi1ESgnlKVLiSXrbSZGEU/qoMiN3LNQRMYUGNb/6c075sfzvguypTJEoWES56xUHl?= =?utf-8?q?sunqdvgYkyFUetap7ksbe7warpiF+rRHQAAZPuuqh8X/iWWyB6TwD9jHckLqKFvla?= =?utf-8?q?1Zh/Tyt8cjPCoJv/EG5lZb9me3eY70IeRHpWYGYPyA9nO7D5FyM2GUk2EXZTsy00b?= =?utf-8?q?02Q/oBegjjGQ1atZgp0O+H2uarmcvpFLcKL9jlhJWr6Woq9t1B93FdOlWZK6s7CYu?= =?utf-8?q?Aa5FPSPhHJejyZmdx0sTbcj19cPGqBTmJsAw77jAd5b/d0lONMZEnVmthx/FzSMdn?= =?utf-8?q?OUUizef8QDtAC06iRr2PFCy+rPLTgK4Z7OHa0Wv+25N4snbZHA1tzm0XrVapj6HSh?= =?utf-8?q?Y6+4t0FWKqa7BAq1LUIXevV4G2buSY1q911oHXUDOa3CVwa1yFLym8JWrx6y3ON9z?= =?utf-8?q?IPLHWW9dhzg8R4y/MnchsaUtFzIYawyH5Mpw0lh1hdpAfkldb9uJR6A1BC6KJ/dNO?= =?utf-8?q?mmJoFY0wysYCNDXckgz0OSe04canJsvauQ+xoNatCkTgEduKhSxTVj53eT1JNK8BD?= =?utf-8?q?WgS9RMT5EmBM/hSG35NY5pDq7mQHDBPKbIWOmmDXNO2ubVaoLDu2LCcPJLV0D1SR1?= =?utf-8?q?tFENHrODzv8NeYb59kuM8PoTRiPA9oruGJHV6U+4AJsZSdvITZ/RJnwY84N1kuUhx?= =?utf-8?q?i1MdYBriCSwzx/K79s37JAPSB1WW+pbRBuA+MzP+s+2EbAFStuPY1CUSVqSupbSvF?= =?utf-8?q?BGs1o3RMMDjSEw1R7EauSPcA3zOTj7b4VzFluLfB1r6tawCoMl7vSFmvWyfr/oLMl?= =?utf-8?q?RjUDdTakeqlvitra1HuMvTyxX2k2qimdgwI3o97l7HYkmEtUxELwYZ1zoEYZoAjkY?= =?utf-8?q?XSSrk3uwm1BLEDTRbWdHdt2myj00L47fY8GYilJVZ5Y7soZpbCSMZamk2xoMnXqae?= =?utf-8?q?3gwTr/hKGeThpOleGZ5AorrxRTVPL7FXyX+3pSO7MRvzHJ2iAaIWuw6i/ozm108Nf?= =?utf-8?q?TvpVjiI6aItmThPLnVdVtGHFakjthMYg+bwuY6oWzD4PCrBTD365JjnYZAqOU/yYl?= =?utf-8?q?9czPn+UHwF9M4EYnK1AgVYVBzC9wRnnN2mcgapVkp3hwBIFKK1u3zPEFZtj9Q5o6c?= =?utf-8?q?sX9jWYZlnKXST+6o1ri9yTIwdjfCvrfVLTY+Kl+OCS3EPbgID91MnCFrbagJPuGKg?= =?utf-8?q?NIfKohZ7eNtZewYLqXzOxffc8cl9rxPjHNgt3Zb5TwQxHEvCiXWF4+q1oNOvR4Q3G?= =?utf-8?q?tPLu+1Tdi793ZP8hvo9KyrS23L+ZK5mHVxcXTjo37LlRSu3p+wI21pXemJHGNxCEX?= =?utf-8?q?VXd8BgWdEZS3COsBpNuGbU7tB0PuAVKe7w=3D=3D?= X-OriginatorOrg: corigine.com X-MS-Exchange-CrossTenant-Network-Message-Id: 3242b31b-c979-48d2-9407-08da5b0863a0 X-MS-Exchange-CrossTenant-AuthSource: SJ0PR13MB5545.namprd13.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 01 Jul 2022 02:21:21.6774 (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: KRtluFrKWRPL2kHFoyKoUmqKmVBziTm2vXg+MOsS9zy4J9fwGUjmslUMxhghD/9tEH7FQjqZGptKYIPjkxkQezH5rlltJqe9Gu1fRhLwsHQ= X-MS-Exchange-Transport-CrossTenantHeadersStamped: BL3PR13MB5107 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 a Rx and Tx function for the control vNIC. The logic is mostly identical to the normal Rx and Tx functionality of the NFP PMD. This commit also makes use of the ctrl vNIC service logic to service the ctrl vNIC Rx path. Signed-off-by: Chaoyong He Signed-off-by: Heinrich Kuhn Reviewed-by: Niklas Söderlund --- drivers/net/nfp/flower/nfp_flower.c | 15 ++ drivers/net/nfp/flower/nfp_flower.h | 15 ++ drivers/net/nfp/flower/nfp_flower_ctrl.c | 248 +++++++++++++++++++++++++++++++ drivers/net/nfp/flower/nfp_flower_ctrl.h | 13 ++ drivers/net/nfp/meson.build | 1 + 5 files changed, 292 insertions(+) create mode 100644 drivers/net/nfp/flower/nfp_flower_ctrl.c create mode 100644 drivers/net/nfp/flower/nfp_flower_ctrl.h diff --git a/drivers/net/nfp/flower/nfp_flower.c b/drivers/net/nfp/flower/nfp_flower.c index 6cdec87..cdaa89a 100644 --- a/drivers/net/nfp/flower/nfp_flower.c +++ b/drivers/net/nfp/flower/nfp_flower.c @@ -21,6 +21,7 @@ #include "../nfpcore/nfp_nsp.h" #include "nfp_flower.h" #include "nfp_flower_ovs_compat.h" +#include "nfp_flower_ctrl.h" #define MAX_PKT_BURST 32 #define MEMPOOL_CACHE_SIZE 512 @@ -216,7 +217,21 @@ .link_update = nfp_flower_pf_link_update, }; +static int +nfp_flower_ctrl_vnic_service(void *arg) +{ + struct nfp_app_flower *app_flower = arg; + + nfp_flower_ctrl_vnic_poll(app_flower); + + return 0; +} + static struct rte_service_spec flower_services[NFP_FLOWER_SERVICE_MAX] = { + [NFP_FLOWER_SERVICE_CTRL] = { + .name = "flower_ctrl_vnic_service", + .callback = nfp_flower_ctrl_vnic_service, + }, }; static int diff --git a/drivers/net/nfp/flower/nfp_flower.h b/drivers/net/nfp/flower/nfp_flower.h index f11ef6d..bdc64e3 100644 --- a/drivers/net/nfp/flower/nfp_flower.h +++ b/drivers/net/nfp/flower/nfp_flower.h @@ -7,9 +7,18 @@ #define _NFP_FLOWER_H_ enum nfp_flower_service { + NFP_FLOWER_SERVICE_CTRL, NFP_FLOWER_SERVICE_MAX }; +/* + * Flower fallback and ctrl path always adds and removes + * 8 bytes of prepended data. Tx descriptors must point + * to the correct packet data offset after metadata has + * been added + */ +#define FLOWER_PKT_DATA_OFFSET 8 + /* The flower application's private structure */ struct nfp_app_flower { /* List of rte_service ID's for the flower app */ @@ -29,6 +38,12 @@ struct nfp_app_flower { /* the eth table as reported by firmware */ struct nfp_eth_table *nfp_eth_table; + + /* Ctrl vNIC Rx counter */ + uint64_t ctrl_vnic_rx_count; + + /* Ctrl vNIC Tx counter */ + uint64_t ctrl_vnic_tx_count; }; int nfp_init_app_flower(struct nfp_pf_dev *pf_dev); diff --git a/drivers/net/nfp/flower/nfp_flower_ctrl.c b/drivers/net/nfp/flower/nfp_flower_ctrl.c new file mode 100644 index 0000000..100e808 --- /dev/null +++ b/drivers/net/nfp/flower/nfp_flower_ctrl.c @@ -0,0 +1,248 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright (c) 2022 Corigine, Inc. + * All rights reserved. + */ + +#include +#include + +#include "../nfp_common.h" +#include "../nfp_logs.h" +#include "../nfp_ctrl.h" +#include "../nfp_rxtx.h" +#include "nfp_flower.h" +#include "nfp_flower_ctrl.h" + +#define MAX_PKT_BURST 32 + +static uint16_t +nfp_flower_ctrl_vnic_recv(void *rx_queue, + struct rte_mbuf **rx_pkts, + uint16_t nb_pkts) +{ + struct nfp_net_rxq *rxq; + struct nfp_net_rx_desc *rxds; + struct nfp_net_rx_buff *rxb; + struct nfp_net_hw *hw; + struct rte_mbuf *mb; + struct rte_mbuf *new_mb; + uint64_t dma_addr; + uint16_t avail = 0; + uint16_t nb_hold = 0; + + rxq = rx_queue; + if (unlikely(rxq == NULL)) { + /* + * DPDK just checks the queue is lower than max queues + * enabled. But the queue needs to be configured + */ + PMD_RX_LOG(ERR, "RX Bad queue"); + return -EINVAL; + } + + hw = rxq->hw; + while (avail < nb_pkts) { + rxb = &rxq->rxbufs[rxq->rd_p]; + if (unlikely(rxb == NULL)) { + PMD_RX_LOG(ERR, "rxb does not exist!"); + break; + } + + rxds = &rxq->rxds[rxq->rd_p]; + if ((rxds->rxd.meta_len_dd & PCIE_DESC_RX_DD) == 0) + break; + + /* + * Memory barrier to ensure that we won't do other + * reads before the DD bit. + */ + rte_rmb(); + + /* + * We got a packet. Let's alloc a new mbuf for refilling the + * free descriptor ring as soon as possible + */ + new_mb = rte_pktmbuf_alloc(rxq->mem_pool); + if (unlikely(new_mb == NULL)) { + PMD_RX_LOG(ERR, + "RX mbuf alloc failed port_id=%u queue_id=%u", + rxq->port_id, (unsigned int)rxq->qidx); + nfp_net_mbuf_alloc_failed(rxq); + break; + } + + nb_hold++; + + /* + * Grab the mbuf and refill the descriptor with the + * previously allocated mbuf + */ + mb = rxb->mbuf; + rxb->mbuf = new_mb; + + /* Size of this segment */ + mb->data_len = rxds->rxd.data_len - NFP_DESC_META_LEN(rxds); + /* Size of the whole packet. We just support 1 segment */ + mb->pkt_len = mb->data_len; + + if (unlikely((mb->data_len + hw->rx_offset) > rxq->mbuf_size)) { + /* + * This should not happen and the user has the + * responsibility of avoiding it. But we have + * to give some info about the error + */ + RTE_LOG_DP(ERR, PMD, + "mbuf overflow likely due to the RX offset.\n" + "\t\tYour mbuf size should have extra space for" + " RX offset=%u bytes.\n" + "\t\tCurrently you just have %u bytes available" + " but the received packet is %u bytes long", + hw->rx_offset, + rxq->mbuf_size - hw->rx_offset, + mb->data_len); + return -EINVAL; + } + + /* Filling the received mbuf with packet info */ + if (hw->rx_offset) + mb->data_off = RTE_PKTMBUF_HEADROOM + hw->rx_offset; + else + mb->data_off = RTE_PKTMBUF_HEADROOM + NFP_DESC_META_LEN(rxds); + + /* No scatter mode supported */ + mb->nb_segs = 1; + mb->next = NULL; + mb->port = rxq->port_id; + + rx_pkts[avail++] = mb; + + /* Now resetting and updating the descriptor */ + rxds->vals[0] = 0; + rxds->vals[1] = 0; + dma_addr = rte_cpu_to_le_64(RTE_MBUF_DMA_ADDR_DEFAULT(new_mb)); + rxds->fld.dd = 0; + rxds->fld.dma_addr_hi = (dma_addr >> 32) & 0xff; + rxds->fld.dma_addr_lo = dma_addr & 0xffffffff; + + rxq->rd_p++; + if (unlikely(rxq->rd_p == rxq->rx_count)) /* wrapping?*/ + rxq->rd_p = 0; + } + + if (nb_hold == 0) + return 0; + + 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=%d 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; +} + +uint16_t +nfp_flower_ctrl_vnic_xmit(struct nfp_app_flower *app_flower, + struct rte_mbuf *mbuf) +{ + uint64_t dma_addr; + uint32_t free_descs; + struct rte_mbuf **lmbuf; + struct nfp_net_txq *txq; + struct nfp_net_hw *ctrl_hw; + struct rte_eth_dev *ctrl_dev; + struct nfp_net_nfd3_tx_desc *txds; + + ctrl_hw = app_flower->ctrl_hw; + ctrl_dev = ctrl_hw->eth_dev; + + /* Flower ctrl vNIC only has a single tx queue */ + txq = ctrl_dev->data->tx_queues[0]; + if (unlikely(txq == NULL)) { + /* + * DPDK just checks the queue is lower than max queues + * enabled. But the queue needs to be configured + */ + PMD_TX_LOG(ERROR, "ctrl dev TX Bad queue"); + return -EINVAL; + } + + txds = &txq->txds[txq->wr_p]; + txds->vals[0] = 0; + txds->vals[1] = 0; + txds->vals[2] = 0; + txds->vals[3] = 0; + + if (nfp_net_nfd3_txq_full(txq)) + nfp_net_tx_free_bufs(txq); + + free_descs = nfp_net_nfd3_free_tx_desc(txq); + if (unlikely(free_descs == 0)) { + PMD_TX_LOG(ERROR, "ctrl dev no free descs"); + return -EINVAL; + } + + lmbuf = &txq->txbufs[txq->wr_p].mbuf; + RTE_MBUF_PREFETCH_TO_FREE(*lmbuf); + if (*lmbuf) + rte_pktmbuf_free_seg(*lmbuf); + + *lmbuf = mbuf; + dma_addr = rte_mbuf_data_iova(mbuf); + + txds->data_len = mbuf->pkt_len; + txds->dma_len = txds->data_len; + txds->dma_addr_hi = (dma_addr >> 32) & 0xff; + txds->dma_addr_lo = (dma_addr & 0xffffffff); + txds->offset_eop = FLOWER_PKT_DATA_OFFSET | PCIE_DESC_TX_EOP; + + txq->wr_p++; + if (unlikely(txq->wr_p == txq->tx_count)) /* wrapping?*/ + txq->wr_p = 0; + + rte_wmb(); + nfp_qcp_ptr_add(txq->qcp_q, NFP_QCP_WRITE_PTR, 1); + + app_flower->ctrl_vnic_tx_count++; + + return 0; +} + +void +nfp_flower_ctrl_vnic_poll(struct nfp_app_flower *app_flower) +{ + uint16_t i; + uint16_t count; + struct nfp_net_rxq *rxq; + struct nfp_net_hw *ctrl_hw; + struct rte_eth_dev *ctrl_eth_dev; + struct rte_mbuf *pkts_burst[MAX_PKT_BURST]; + + ctrl_hw = app_flower->ctrl_hw; + ctrl_eth_dev = ctrl_hw->eth_dev; + + /* ctrl vNIC only has a single Rx queue */ + rxq = ctrl_eth_dev->data->rx_queues[0]; + count = nfp_flower_ctrl_vnic_recv(rxq, pkts_burst, MAX_PKT_BURST); + if (count > MAX_PKT_BURST) { + PMD_RX_LOG(ERR, "nfp_net_ctrl_vnic_recv failed!"); + return; + } + + if (count) { + app_flower->ctrl_vnic_rx_count += count; + /* Process cmsgs here, only free for now */ + for (i = 0; i < count; i++) + rte_pktmbuf_free(pkts_burst[i]); + } +} diff --git a/drivers/net/nfp/flower/nfp_flower_ctrl.h b/drivers/net/nfp/flower/nfp_flower_ctrl.h new file mode 100644 index 0000000..74765c9 --- /dev/null +++ b/drivers/net/nfp/flower/nfp_flower_ctrl.h @@ -0,0 +1,13 @@ +/* SPDX-License-Identifier: BSD-3-Clause + * Copyright (c) 2022 Corigine, Inc. + * All rights reserved. + */ + +#ifndef _NFP_FLOWER_CTRL_H_ +#define _NFP_FLOWER_CTRL_H_ + +void nfp_flower_ctrl_vnic_poll(struct nfp_app_flower *app_flower); +uint16_t nfp_flower_ctrl_vnic_xmit(struct nfp_app_flower *app_flower, + struct rte_mbuf *mbuf); + +#endif /* _NFP_FLOWER_CTRL_H_ */ diff --git a/drivers/net/nfp/meson.build b/drivers/net/nfp/meson.build index 7ae3115..8710213 100644 --- a/drivers/net/nfp/meson.build +++ b/drivers/net/nfp/meson.build @@ -7,6 +7,7 @@ if not is_linux or not dpdk_conf.get('RTE_ARCH_64') endif sources = files( 'flower/nfp_flower.c', + 'flower/nfp_flower_ctrl.c', 'nfpcore/nfp_cpp_pcie_ops.c', 'nfpcore/nfp_nsp.c', 'nfpcore/nfp_cppcore.c',