Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/132714/?format=api
http://patches.dpdk.org/api/patches/132714/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/patch/20231017054545.1692509-25-chaoyong.he@corigine.com/", "project": { "id": 1, "url": "http://patches.dpdk.org/api/projects/1/?format=api", "name": "DPDK", "link_name": "dpdk", "list_id": "dev.dpdk.org", "list_email": "dev@dpdk.org", "web_url": "http://core.dpdk.org", "scm_url": "git://dpdk.org/dpdk", "webscm_url": "http://git.dpdk.org/dpdk", "list_archive_url": "https://inbox.dpdk.org/dev", "list_archive_url_format": "https://inbox.dpdk.org/dev/{}", "commit_url_format": "" }, "msgid": "<20231017054545.1692509-25-chaoyong.he@corigine.com>", "list_archive_url": "https://inbox.dpdk.org/dev/20231017054545.1692509-25-chaoyong.he@corigine.com", "date": "2023-10-17T05:45:44", "name": "[24/25] vdpa/nfp: add nfp vDPA device operations", "commit_ref": null, "pull_url": null, "state": "superseded", "archived": true, "hash": "773e318386799ab1ea10fb86a94c62e501bf81b8", "submitter": { "id": 2554, "url": "http://patches.dpdk.org/api/people/2554/?format=api", "name": "Chaoyong He", "email": "chaoyong.he@corigine.com" }, "delegate": { "id": 319, "url": "http://patches.dpdk.org/api/users/319/?format=api", "username": "fyigit", "first_name": "Ferruh", "last_name": "Yigit", "email": "ferruh.yigit@amd.com" }, "mbox": "http://patches.dpdk.org/project/dpdk/patch/20231017054545.1692509-25-chaoyong.he@corigine.com/mbox/", "series": [ { "id": 29865, "url": "http://patches.dpdk.org/api/series/29865/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=29865", "date": "2023-10-17T05:45:20", "name": "add the NFP vDPA PMD", "version": 1, "mbox": "http://patches.dpdk.org/series/29865/mbox/" } ], "comments": "http://patches.dpdk.org/api/patches/132714/comments/", "check": "warning", "checks": "http://patches.dpdk.org/api/patches/132714/checks/", "tags": {}, "related": [], "headers": { "Return-Path": "<dev-bounces@dpdk.org>", "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])\n\tby inbox.dpdk.org (Postfix) with ESMTP id ABE2D43186;\n\tTue, 17 Oct 2023 07:49:13 +0200 (CEST)", "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id 539DD42D91;\n\tTue, 17 Oct 2023 07:47:29 +0200 (CEST)", "from NAM10-MW2-obe.outbound.protection.outlook.com\n (mail-mw2nam10on2122.outbound.protection.outlook.com [40.107.94.122])\n by mails.dpdk.org (Postfix) with ESMTP id 9F70342DA3\n for <dev@dpdk.org>; Tue, 17 Oct 2023 07:47:27 +0200 (CEST)", "from PH0PR13MB5568.namprd13.prod.outlook.com (2603:10b6:510:12b::16)\n by SJ0PR13MB5272.namprd13.prod.outlook.com (2603:10b6:a03:3e3::21)\n with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6863.46; Tue, 17 Oct\n 2023 05:47:25 +0000", "from PH0PR13MB5568.namprd13.prod.outlook.com\n ([fe80::b070:92e1:931e:fee7]) by PH0PR13MB5568.namprd13.prod.outlook.com\n ([fe80::b070:92e1:931e:fee7%4]) with mapi id 15.20.6863.047; Tue, 17 Oct 2023\n 05:47:25 +0000" ], "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;\n b=R9IADCnUMl8Ep/BNo7ZV1bvgKSolWoxgmql++eZO+nkmNaQ2hXKxVjte5wtrmTQY96DqUI/M2aom6FMGsYZouixGZRg68QZSHVkVx7gxTToay1sPCECTz/fEYAp4lN4/6NKF2sbR7tLOQfzQdfk/MufLy+fVDtK77yYJDotaZ7AeZte2M2l2AV/Re4MSVqlsuUPZ1YEQ5M0MihUn31d/+pWtPqCKbTtU6C95Wcbq2yYCGx49rXMg0xK/v0Z3qDjxWjjZSL/oUN/rWAmPf4oLgIKAriyEPwjwdOuAE4jRK4zo+A9muwXRloEXNJUL8/LvDM05qVi2S7/pYx3DX2LwCA==", "ARC-Message-Signature": "i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com;\n s=arcselector9901;\n 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;\n bh=s6/uD0XlZ5EznMcVag8a7+X3NNWpa++VHqzaMZ/6RM0=;\n b=jp/IbnmqzIvk52yltbdROut5ctfCT326G4EVKeQ/7wi5964vdCEGiO1phJCZSbm8qe3pb2Mpimm+CmfX8oVKBrz17R3jYhU5enXU8uRZlbND89OcLcnzi1mKX1pVz3RFkZzjYexIqdEwmKYF2nmuQd7hn2IIeD0VBISFx0RJ4glvg71sZbgt363ScF1yyOifwuUgwzd45wrcmILvoTxzH0UKg1BwB5EJ5gwvexEcCwiEkcOyh71n/V42LME/YF0r0GajBmviOZ4BXcdm1L7TVpggB/twoiWo956BN+M7LPNPBrPCNNW0W2vdWMnIRKfUQQDg8w+onQA5wPZERswc9w==", "ARC-Authentication-Results": "i=1; mx.microsoft.com 1; spf=pass\n smtp.mailfrom=corigine.com; dmarc=pass action=none header.from=corigine.com;\n dkim=pass header.d=corigine.com; arc=none", "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=corigine.onmicrosoft.com; s=selector2-corigine-onmicrosoft-com;\n h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck;\n bh=s6/uD0XlZ5EznMcVag8a7+X3NNWpa++VHqzaMZ/6RM0=;\n b=BVt4BLLACpOJFTogzS+U3lTZIjPxMyMpr1n7yTvTyObxnEK00pq4U7o1LgxZYqDW0WJM32o+0PkZyIg8ycIYKVgM5BVOgttxfvWX8J9kIWRORbMGVGiGuQiE3HUO9AjPLdqVLDuLeKvF7XIGg0b1m7d7QajO4RxzJ2hs9HphqLc=", "Authentication-Results": "dkim=none (message not signed)\n header.d=none;dmarc=none action=none header.from=corigine.com;", "From": "Chaoyong He <chaoyong.he@corigine.com>", "To": "dev@dpdk.org", "Cc": "oss-drivers@corigine.com, Chaoyong He <chaoyong.he@corigine.com>,\n Shujing Dong <shujing.dong@corigine.com>, Long Wu <long.wu@corigine.com>,\n Peng Zhang <peng.zhang@corigine.com>", "Subject": "[PATCH 24/25] vdpa/nfp: add nfp vDPA device operations", "Date": "Tue, 17 Oct 2023 13:45:44 +0800", "Message-Id": "<20231017054545.1692509-25-chaoyong.he@corigine.com>", "X-Mailer": "git-send-email 2.39.1", "In-Reply-To": "<20231017054545.1692509-1-chaoyong.he@corigine.com>", "References": "<20231017054545.1692509-1-chaoyong.he@corigine.com>", "Content-Transfer-Encoding": "8bit", "Content-Type": "text/plain", "X-ClientProxiedBy": "PH7PR17CA0069.namprd17.prod.outlook.com\n (2603:10b6:510:325::29) To PH0PR13MB5568.namprd13.prod.outlook.com\n (2603:10b6:510:12b::16)", "MIME-Version": "1.0", "X-MS-PublicTrafficType": "Email", "X-MS-TrafficTypeDiagnostic": "PH0PR13MB5568:EE_|SJ0PR13MB5272:EE_", "X-MS-Office365-Filtering-Correlation-Id": "18186f39-2a8e-4339-8b90-08dbced48a0b", "X-MS-Exchange-SenderADCheck": "1", "X-MS-Exchange-AntiSpam-Relay": "0", "X-Microsoft-Antispam": "BCL:0;", "X-Microsoft-Antispam-Message-Info": "\n MjOJ6K0c5dmhNG5+/7N7kwGrVv9Khw01mD225eKgZ3DoAshPmJzSwxpi0bNLRtFE4IacPqN7MnmfHNdZcVYSdjZ58t92pPxcfHP1Kz6pqs1C5WNY59TTo2YTD7Ps5FleCZzZO52tY1QDxyUKQD7Hra/gNi4um/bMTYGhX+ltiBJ2Z1h/A7OnHLyHgH5/Qk/+qzh1nK4fwNQkyHa9W4cuZYlYbfFgx+3vCZIzRfuaCOY6S/+bMsU3ud+VjxnIlghH+sns++T2EAl8LxoPvwiKVOxGUxFl0tCmKoTQ39OjNSudNHhdEDaQPa1ZMVXtC1cQD/qEnFZUAatKgWHxzCrjg86805dG798LZguETbTD+jKUC4L7TFPfKpKEaAL12YSzO/FQ5bnOefRWEpabVq/6fXW4cvSQmBl7jdDUTufQtKAF3ec96gyIdRcmOob6mjtbzevhDcYWJT0w1gktOzt177WNiTtaU9s4JK7x8xhJmjekf/8+NOrUsKzNK8XsdUDa4krjEeZHI/LVrTm2edGdjuMUpd0MdhYNoc/P0+w5Yn4GGUPjoyQfccaF3pSVsw/WA1tpKp5QfcJrV6Rgjwj8hh7swzrjW0XL4H8tAgoceoGivxTVmbPDek3kERIMZ0+D7xiF4+z4z7Rlmn/0sWKa7xRueuHypplIqrGgn38PNsU=", "X-Forefront-Antispam-Report": "CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:;\n IPV:NLI; SFV:NSPM; H:PH0PR13MB5568.namprd13.prod.outlook.com; PTR:; CAT:NONE;\n SFS:(13230031)(366004)(136003)(376002)(346002)(396003)(39830400003)(230922051799003)(451199024)(64100799003)(1800799009)(186009)(38350700005)(6916009)(66476007)(6666004)(66556008)(66946007)(6486002)(86362001)(54906003)(2616005)(83380400001)(478600001)(6512007)(38100700002)(316002)(1076003)(52116002)(26005)(107886003)(5660300002)(6506007)(2906002)(4326008)(8676002)(36756003)(44832011)(41300700001)(8936002);\n DIR:OUT; SFP:1102;", "X-MS-Exchange-AntiSpam-MessageData-ChunkCount": "1", "X-MS-Exchange-AntiSpam-MessageData-0": "\n wYnL/RiK74f87xD6JA/bwRMeZ6aOeRL0fPhXmo1doeLC961PKMa/wyUwUN0jA5RQSXZtNyp99LEw+nnpsb++B3OotVoJa57bIggocO+2R8vvsPnxSL0pukevIFREIKPi51uTR/l7PFEAH0+mnMO7jmmmyoDWI7fiBye9xRS4U7Ib7Cra5fBQ+Pkd4KdWYTVYOVIe3+PU4UuZKRHCPEE9fZ7TvL9QQC8EAHkUPdEh2r5XSfTHW0ibbomdeWAGpWQwTRhy87w2cf+8wzqLeI3OpMfeHvCGSJpRMRuLLhlXrmJsDYqNPbr+Wk8eLunNe9M5xUTwQg8K/c6LVLfBvMEA46W+thbSXBJuyXUcI9Xdg5ekoK+e9JAqpKiUb3TIJBLQfnj4SYkPTmPbuclERoaCB60V3GiGYIYgnPsjL1jB0xgWyiMTKNvDAz0tENvblV1MQw7uHzceeMKcYVSbRDpnOZgZYksH+QbFK7ryr5LQpwTIkBLqK0n/TQiZurfvwXloFac1rXkSvsFAKHOEuPPkWfJXs906y1Ub3eOUCF15C6UjEMyFSKAjfwvnDMTbF9a6U0VlqeA4E0xd2SCgjWsNsuZxEWc6krdpb8N7mhpWJnNHQra5rDUbT5wpXYVvhdQRJtRj2Vd1S9k/G4PtrIGKKLd/HjNTBbBHjtQr9cOG/2iwU9LmIcVjtgKgbjdxVSA2N2H47BgwIfbMdRzf3XAtimuntSogD2KwgoMYqx+lS6zBvorzdTb4EMKlwc4jwdEysK7cWdI1nIT9DqiIvNktQN8nRaPhGZYfJWUYlZE51E5AejF2S+964UBSF8+BU24KB6QMBeIqK9uViEnv5LPgoc4v4pAbvaeUhHW5LJOGO3Jnkzl+0l+Fh/VBoIVCOaZxxaDqZVHjUjmcqul6jgaAaDUKwdd3pZswb0EPgsNjqKUe1NcccH94FehcOwmjHWUvmzBovG+3E1VstJ4VURUU2oGpGPsdy5Ly3N+Z/M5Ozg6K3XjWWoL3hgOVkBHO/kuOIVEG/4vFIHvFqSddf0UpQtc34WWbPnr7lBQi6DjLb+AE8IZOT1KE1V+gmpOk2S6lt4zvZhObyHeM11jBpNc/0/URDwVBUOdscEPilfiBYs2L2QDxyD6+yz+FNh5vIxwDPjhdNhPRH+OPMBRGtHmC0B9e/CY+epcaS9r49x0nO0JF6a3CerE7WjOcm3MklBwg+KryTq50ezzEtnVARtJbMclk8E4HSHiJKU04ZWYIquTXqSJvJXaUt1Z6EjA8MhoEWAq0VH945AGzYycdoLMYSu25Pj/liqIdCTdZVnRrSdZaDWNvnUz4dxmlLuAfPxguoM6GxzfTVvo0jiDNi0xfbzEKOEWu+aJ6UoiQeWJJ8SCd+dMwu98s11VSGESk4H/3FeVMTImfOdjjyn0nz0/3gNvSy+tlO88SXtLKPWojkYY27gHuQH9W2+t/ggEanEk3lq+ZS1dK5eAhw93pd80QxRkT2ErWwJldCLqSDnnOt2ZnJSI6LlD9A5INrtRlkkuQH68kbgZsPNA0gbJkwt8kQUM5RtZpDKgtzoBSqGRWIf79hkPepaRKqOEoLwVwCtnrSnV+SvAU/4itMm+gaa6DRg==", "X-OriginatorOrg": "corigine.com", "X-MS-Exchange-CrossTenant-Network-Message-Id": "\n 18186f39-2a8e-4339-8b90-08dbced48a0b", "X-MS-Exchange-CrossTenant-AuthSource": "PH0PR13MB5568.namprd13.prod.outlook.com", "X-MS-Exchange-CrossTenant-AuthAs": "Internal", "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "17 Oct 2023 05:47:25.6827 (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": "\n V2m1tgjiOq0+nVPBg6qj/LNHicBnCoEgOHvwGwU34SvJmx6l2gHEpDET6KJxJRgIPjQY9zvWSXPhTYq3bYtBNKHog8UvCiDy23izc1OC7kM=", "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "SJ0PR13MB5272", "X-BeenThere": "dev@dpdk.org", "X-Mailman-Version": "2.1.29", "Precedence": "list", "List-Id": "DPDK patches and discussions <dev.dpdk.org>", "List-Unsubscribe": "<https://mails.dpdk.org/options/dev>,\n <mailto:dev-request@dpdk.org?subject=unsubscribe>", "List-Archive": "<http://mails.dpdk.org/archives/dev/>", "List-Post": "<mailto:dev@dpdk.org>", "List-Help": "<mailto:dev-request@dpdk.org?subject=help>", "List-Subscribe": "<https://mails.dpdk.org/listinfo/dev>,\n <mailto:dev-request@dpdk.org?subject=subscribe>", "Errors-To": "dev-bounces@dpdk.org" }, "content": "Implement the corresponding nfp vDPA opetation functions.\n\nSigned-off-by: Shujing Dong <shujing.dong@corigine.com>\nSigned-off-by: Chaoyong He <chaoyong.he@corigine.com>\nReviewed-by: Long Wu <long.wu@corigine.com>\nReviewed-by: Peng Zhang <peng.zhang@corigine.com>\n---\n drivers/vdpa/nfp/nfp_vdpa.c | 213 ++++++++++++++++++++++++++++++++++++\n 1 file changed, 213 insertions(+)", "diff": "diff --git a/drivers/vdpa/nfp/nfp_vdpa.c b/drivers/vdpa/nfp/nfp_vdpa.c\nindex 01a59e2cfd..860b5cce63 100644\n--- a/drivers/vdpa/nfp/nfp_vdpa.c\n+++ b/drivers/vdpa/nfp/nfp_vdpa.c\n@@ -57,6 +57,29 @@ static struct vdpa_dev_list_head vdpa_dev_list =\n \n static pthread_mutex_t vdpa_list_lock = PTHREAD_MUTEX_INITIALIZER;\n \n+static struct nfp_vdpa_dev_node *\n+nfp_vdpa_find_node_by_vdev(struct rte_vdpa_device *vdev)\n+{\n+\tbool found = false;\n+\tstruct nfp_vdpa_dev_node *node;\n+\n+\tpthread_mutex_lock(&vdpa_list_lock);\n+\n+\tTAILQ_FOREACH(node, &vdpa_dev_list, next) {\n+\t\tif (vdev == node->device->vdev) {\n+\t\t\tfound = true;\n+\t\t\tbreak;\n+\t\t}\n+\t}\n+\n+\tpthread_mutex_unlock(&vdpa_list_lock);\n+\n+\tif (found)\n+\t\treturn node;\n+\n+\treturn NULL;\n+}\n+\n static struct nfp_vdpa_dev_node *\n nfp_vdpa_find_node_by_pdev(struct rte_pci_device *pdev)\n {\n@@ -575,7 +598,197 @@ update_datapath(struct nfp_vdpa_dev *device)\n \treturn ret;\n }\n \n+static int\n+nfp_vdpa_dev_config(int vid)\n+{\n+\tint ret;\n+\tstruct nfp_vdpa_dev *device;\n+\tstruct rte_vdpa_device *vdev;\n+\tstruct nfp_vdpa_dev_node *node;\n+\n+\tvdev = rte_vhost_get_vdpa_device(vid);\n+\tnode = nfp_vdpa_find_node_by_vdev(vdev);\n+\tif (node == NULL) {\n+\t\tDRV_VDPA_LOG(ERR, \"Invalid vDPA device: %p\", vdev);\n+\t\treturn -ENODEV;\n+\t}\n+\n+\tdevice = node->device;\n+\tdevice->vid = vid;\n+\t__atomic_store_n(&device->dev_attached, 1, __ATOMIC_RELAXED);\n+\tupdate_datapath(device);\n+\n+\tret = rte_vhost_host_notifier_ctrl(vid, RTE_VHOST_QUEUE_ALL, true);\n+\tif (ret != 0)\n+\t\tDRV_VDPA_LOG(INFO, \"vDPA (%s): software relay is used.\",\n+\t\t\t\tvdev->device->name);\n+\n+\treturn 0;\n+}\n+\n+static int\n+nfp_vdpa_dev_close(int vid)\n+{\n+\tstruct nfp_vdpa_dev *device;\n+\tstruct rte_vdpa_device *vdev;\n+\tstruct nfp_vdpa_dev_node *node;\n+\n+\tvdev = rte_vhost_get_vdpa_device(vid);\n+\tnode = nfp_vdpa_find_node_by_vdev(vdev);\n+\tif (node == NULL) {\n+\t\tDRV_VDPA_LOG(ERR, \"Invalid vDPA device: %p\", vdev);\n+\t\treturn -ENODEV;\n+\t}\n+\n+\tdevice = node->device;\n+\t__atomic_store_n(&device->dev_attached, 0, __ATOMIC_RELAXED);\n+\tupdate_datapath(device);\n+\n+\treturn 0;\n+}\n+\n+static int\n+nfp_vdpa_get_vfio_group_fd(int vid)\n+{\n+\tstruct rte_vdpa_device *vdev;\n+\tstruct nfp_vdpa_dev_node *node;\n+\n+\tvdev = rte_vhost_get_vdpa_device(vid);\n+\tnode = nfp_vdpa_find_node_by_vdev(vdev);\n+\tif (node == NULL) {\n+\t\tDRV_VDPA_LOG(ERR, \"Invalid vDPA device: %p\", vdev);\n+\t\treturn -ENODEV;\n+\t}\n+\n+\treturn node->device->vfio_group_fd;\n+}\n+\n+static int\n+nfp_vdpa_get_vfio_device_fd(int vid)\n+{\n+\tstruct rte_vdpa_device *vdev;\n+\tstruct nfp_vdpa_dev_node *node;\n+\n+\tvdev = rte_vhost_get_vdpa_device(vid);\n+\tnode = nfp_vdpa_find_node_by_vdev(vdev);\n+\tif (node == NULL) {\n+\t\tDRV_VDPA_LOG(ERR, \"Invalid vDPA device: %p\", vdev);\n+\t\treturn -ENODEV;\n+\t}\n+\n+\treturn node->device->vfio_dev_fd;\n+}\n+\n+static int\n+nfp_vdpa_get_notify_area(int vid,\n+\t\tint qid,\n+\t\tuint64_t *offset,\n+\t\tuint64_t *size)\n+{\n+\tint ret;\n+\tstruct nfp_vdpa_dev *device;\n+\tstruct rte_vdpa_device *vdev;\n+\tstruct nfp_vdpa_dev_node *node;\n+\tstruct vfio_region_info region = {\n+\t\t.argsz = sizeof(region)\n+\t};\n+\n+\tvdev = rte_vhost_get_vdpa_device(vid);\n+\tnode = nfp_vdpa_find_node_by_vdev(vdev);\n+\tif (node == NULL) {\n+\t\tDRV_VDPA_LOG(ERR, \"Invalid vDPA device: %p\", vdev);\n+\t\treturn -ENODEV;\n+\t}\n+\n+\tdevice = node->device;\n+\tregion.index = device->hw.notify_region;\n+\n+\tret = ioctl(device->vfio_dev_fd, VFIO_DEVICE_GET_REGION_INFO, ®ion);\n+\tif (ret != 0) {\n+\t\tDRV_VDPA_LOG(ERR, \"Get not get device region info.\");\n+\t\treturn -EIO;\n+\t}\n+\n+\t*offset = nfp_vdpa_get_queue_notify_offset(&device->hw, qid) + region.offset;\n+\t*size = NFP_VDPA_NOTIFY_ADDR_INTERVAL;\n+\n+\treturn 0;\n+}\n+\n+static int\n+nfp_vdpa_get_queue_num(struct rte_vdpa_device *vdev,\n+\t\tuint32_t *queue_num)\n+{\n+\tstruct nfp_vdpa_dev_node *node;\n+\n+\tnode = nfp_vdpa_find_node_by_vdev(vdev);\n+\tif (node == NULL) {\n+\t\tDRV_VDPA_LOG(ERR, \"Invalid vDPA device: %p\", vdev);\n+\t\treturn -ENODEV;\n+\t}\n+\n+\t*queue_num = node->device->max_queues;\n+\n+\treturn 0;\n+}\n+\n+static int\n+nfp_vdpa_get_vdpa_features(struct rte_vdpa_device *vdev,\n+\t\tuint64_t *features)\n+{\n+\tstruct nfp_vdpa_dev_node *node;\n+\n+\tnode = nfp_vdpa_find_node_by_vdev(vdev);\n+\tif (node == NULL) {\n+\t\tDRV_VDPA_LOG(ERR, \"Invalid vDPA device: %p\", vdev);\n+\t\treturn -ENODEV;\n+\t}\n+\n+\t*features = node->device->hw.features;\n+\n+\treturn 0;\n+}\n+\n+static int\n+nfp_vdpa_get_protocol_features(struct rte_vdpa_device *vdev __rte_unused,\n+\t\tuint64_t *features)\n+{\n+\t*features = 1ULL << VHOST_USER_PROTOCOL_F_LOG_SHMFD |\n+\t\t\t1ULL << VHOST_USER_PROTOCOL_F_REPLY_ACK |\n+\t\t\t1ULL << VHOST_USER_PROTOCOL_F_BACKEND_REQ |\n+\t\t\t1ULL << VHOST_USER_PROTOCOL_F_BACKEND_SEND_FD |\n+\t\t\t1ULL << VHOST_USER_PROTOCOL_F_HOST_NOTIFIER;\n+\n+\treturn 0;\n+}\n+\n+static int\n+nfp_vdpa_set_features(int32_t vid)\n+{\n+\tDRV_VDPA_LOG(DEBUG, \"Start vid=%d\", vid);\n+\treturn 0;\n+}\n+\n+static int\n+nfp_vdpa_set_vring_state(int vid,\n+\t\tint vring,\n+\t\tint state)\n+{\n+\tDRV_VDPA_LOG(DEBUG, \"Start vid=%d, vring=%d, state=%d\", vid, vring, state);\n+\treturn 0;\n+}\n+\n struct rte_vdpa_dev_ops nfp_vdpa_ops = {\n+\t.get_queue_num = nfp_vdpa_get_queue_num,\n+\t.get_features = nfp_vdpa_get_vdpa_features,\n+\t.get_protocol_features = nfp_vdpa_get_protocol_features,\n+\t.dev_conf = nfp_vdpa_dev_config,\n+\t.dev_close = nfp_vdpa_dev_close,\n+\t.set_vring_state = nfp_vdpa_set_vring_state,\n+\t.set_features = nfp_vdpa_set_features,\n+\t.get_vfio_group_fd = nfp_vdpa_get_vfio_group_fd,\n+\t.get_vfio_device_fd = nfp_vdpa_get_vfio_device_fd,\n+\t.get_notify_area = nfp_vdpa_get_notify_area,\n };\n \n static int\n", "prefixes": [ "24/25" ] }{ "id": 132714, "url": "