Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/133226/?format=api
http://patchwork.dpdk.org/api/patches/133226/?format=api", "web_url": "http://patchwork.dpdk.org/project/dpdk/patch/20231024022849.3092506-22-chaoyong.he@corigine.com/", "project": { "id": 1, "url": "http://patchwork.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": "<20231024022849.3092506-22-chaoyong.he@corigine.com>", "list_archive_url": "https://inbox.dpdk.org/dev/20231024022849.3092506-22-chaoyong.he@corigine.com", "date": "2023-10-24T02:28:45", "name": "[v2,21/25] vdpa/nfp: add the hardware init logic", "commit_ref": null, "pull_url": null, "state": "changes-requested", "archived": true, "hash": "e3fc6ac3efdc98479446def6cb8fd4e2c6b94145", "submitter": { "id": 2554, "url": "http://patchwork.dpdk.org/api/people/2554/?format=api", "name": "Chaoyong He", "email": "chaoyong.he@corigine.com" }, "delegate": { "id": 319, "url": "http://patchwork.dpdk.org/api/users/319/?format=api", "username": "fyigit", "first_name": "Ferruh", "last_name": "Yigit", "email": "ferruh.yigit@amd.com" }, "mbox": "http://patchwork.dpdk.org/project/dpdk/patch/20231024022849.3092506-22-chaoyong.he@corigine.com/mbox/", "series": [ { "id": 29961, "url": "http://patchwork.dpdk.org/api/series/29961/?format=api", "web_url": "http://patchwork.dpdk.org/project/dpdk/list/?series=29961", "date": "2023-10-24T02:28:24", "name": "add the NFP vDPA PMD", "version": 2, "mbox": "http://patchwork.dpdk.org/series/29961/mbox/" } ], "comments": "http://patchwork.dpdk.org/api/patches/133226/comments/", "check": "success", "checks": "http://patchwork.dpdk.org/api/patches/133226/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 25576431EB;\n\tTue, 24 Oct 2023 04:32:43 +0200 (CEST)", "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id BB89742DD7;\n\tTue, 24 Oct 2023 04:30:24 +0200 (CEST)", "from NAM11-DM6-obe.outbound.protection.outlook.com\n (mail-dm6nam11on2102.outbound.protection.outlook.com [40.107.223.102])\n by mails.dpdk.org (Postfix) with ESMTP id B9B7442D96\n for <dev@dpdk.org>; Tue, 24 Oct 2023 04:30:18 +0200 (CEST)", "from SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5)\n by PH8PR13MB6182.namprd13.prod.outlook.com (2603:10b6:510:259::13)\n with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6907.21; Tue, 24 Oct\n 2023 02:30:17 +0000", "from SJ0PR13MB5545.namprd13.prod.outlook.com\n ([fe80::142e:d47c:7320:8a9d]) by SJ0PR13MB5545.namprd13.prod.outlook.com\n ([fe80::142e:d47c:7320:8a9d%4]) with mapi id 15.20.6907.021; Tue, 24 Oct 2023\n 02:30:17 +0000" ], "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;\n b=kCNz/woAamIc3qzby2aI/nRDvIJg3f1O8raB5P8NnOXvV+tr7wB5kEVtLWCM3BdUE/59EJjZzOLdRKWhvqFwI1G9ulXGlLIsJndv4rK7ZL0Zn2pc7MbC0NJ4tvWHxRHkWt/jqpVCV5L0ULj2s512quDjB+AEtw0o6d9DVxqjWn7OH/Qu45k+JmK+4zUyjJUKyTUzYc/yoHmqbqGqa/47FajowH7Gv1yNt/umT0ffOlXd0jDqzsoRe0ZpXkDhh32H7ECdGZl+IOLKfhBkCMdvSxnxmTg67PoC/CEvU+8tWAHbmxVnX8K7cZumgBTwlod8FNWy3hlZF5CX7IA3jtw2NQ==", "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=ueD306333BC6aL/GrzldxBPxOnMsxU/MlgBa+o8r1+8=;\n b=U1MK/2djTn9uGtZxmJAkkHjpD6AZqA36YPcjq2wzPtIOGH/DlsSFpyYXsRRT/5Z7n1JcZwXJfi9DcAYv8EJqEQ90PuV32f2RI3tYPv6zGLQVm53NNv4h8HDbdh64Cq4p9+sQrmX0IQmnnYv2/zoo6yxF2Z2+pd9eZqxu5QEg0PAJwr9pxzQ62QOjG7PTJYU8OhuWWqXwUxaXAxFk7SkeCPP+7tznxx2CMVF9LCd9TWVUyzZPF5swgIwn+FrFgm72B39nxDdBkok87XYj6M3cR0wnuOgMM6CL501svN4DWgiZc9DhI573rgvJe2WIycCASTawwXLkmqAAfnwSmOPkFg==", "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=ueD306333BC6aL/GrzldxBPxOnMsxU/MlgBa+o8r1+8=;\n b=BVpRKKPNEdRIzV2hUTXmcFffG5mAWrgNc1vnKLEJAQyO1De0zSyUiBhzXuCHK0mYpyt/qnr8NK07c4ZvBsQUfE29uzWB/tmfQhUTQmP9MqH14/ke4cMx+pfchYgtRik5DoEqGVKcVTcfMswibMO5H8fBBlr31JL46mFjkVlFCx4=", "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 v2 21/25] vdpa/nfp: add the hardware init logic", "Date": "Tue, 24 Oct 2023 10:28:45 +0800", "Message-Id": "<20231024022849.3092506-22-chaoyong.he@corigine.com>", "X-Mailer": "git-send-email 2.39.1", "In-Reply-To": "<20231024022849.3092506-1-chaoyong.he@corigine.com>", "References": "<20231017054545.1692509-1-chaoyong.he@corigine.com>\n <20231024022849.3092506-1-chaoyong.he@corigine.com>", "Content-Transfer-Encoding": "8bit", "Content-Type": "text/plain", "X-ClientProxiedBy": "BYAPR04CA0015.namprd04.prod.outlook.com\n (2603:10b6:a03:40::28) To SJ0PR13MB5545.namprd13.prod.outlook.com\n (2603:10b6:a03:424::5)", "MIME-Version": "1.0", "X-MS-PublicTrafficType": "Email", "X-MS-TrafficTypeDiagnostic": "SJ0PR13MB5545:EE_|PH8PR13MB6182:EE_", "X-MS-Office365-Filtering-Correlation-Id": "c3ac0de1-7dd7-4c43-2bf2-08dbd43928eb", "X-MS-Exchange-SenderADCheck": "1", "X-MS-Exchange-AntiSpam-Relay": "0", "X-Microsoft-Antispam": "BCL:0;", "X-Microsoft-Antispam-Message-Info": "\n YDlcE0Ac0s/8t/TxNeiq//WiyFO/ThhfRo2Lfx9W6cmaJNzLs5eSuU/Do9+rcX87EZMGgH66iCVxImq4Juqha34lwkQJF6vk2eoVLYZwWIWuzdEv5RicxTbnDaBZSqeHc5W/n4RREBjWJSCD+6lHDSepm91VsMV2ylyx3ZmNrnSWhT4qvymkXB9E19Ffj6TOUD8dOkiyVam2ouB+Dj0g0ROzxBaaSGJDi5v58mAV3rE5KsnXfmbLYso/gANYvDQxgP+YzghDVhq774XEva9EFD53CTeCv4LGgiYCFQYYd1AACBeb/91R+i4Wm63YukLF5Z2fnQFJZKvbgHcTHDb859dqzODIHV3c6hKQqMup7jXdT2ZTEbBz6+MdyURPowoI1FWKp1afciq2jDSaXZIAp0BCI6z/T5Gtg415sB6/Q4ijVKnkshAixi4vwCCZQx0qEeLKVrxlf27VBvX/bmi6RCJF6VWc6Y7nA0z+XXCQMqHHItf2L/QrZwIF1HcphOLJ7xrIryqIaapMV0fnVUaaV85QZLkZO4w3HxYcpdgLUjFsVFHQdGHwWbFD+JYIfyJyWcGJvy53u0OJkIFXF9rmLUI+KBV67Ta7rpEn2Wqye4MRccnPqOMRDPY2qirkycQy/E6EaJGQiJCPN4gCnJVVdb4G8+nc+KgrxZ4RfgweWMg=", "X-Forefront-Antispam-Report": "CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:;\n IPV:NLI; SFV:NSPM; H:SJ0PR13MB5545.namprd13.prod.outlook.com; PTR:; CAT:NONE;\n SFS:(13230031)(366004)(396003)(376002)(39830400003)(346002)(136003)(230922051799003)(1800799009)(64100799003)(186009)(451199024)(86362001)(66946007)(316002)(2906002)(54906003)(66476007)(6916009)(66556008)(5660300002)(8936002)(44832011)(8676002)(4326008)(36756003)(41300700001)(2616005)(38100700002)(478600001)(1076003)(52116002)(6506007)(107886003)(6666004)(38350700005)(6512007)(26005)(83380400001)(6486002);\n DIR:OUT; SFP:1102;", "X-MS-Exchange-AntiSpam-MessageData-ChunkCount": "1", "X-MS-Exchange-AntiSpam-MessageData-0": "\n UShskndJgAsWe4Xw5vWndfA1f0DFdj6g8aBM+4AZO3lOho+j8YbJDN9ngIjxvxHFOJsNefqBQsnhwx/elsAFYxsBl+ZxNaNrU3P6Gg9kg99uRfuQgLQWQ4GelcyeIxkbmKy74DU+GM9bVZE0jbg/uPBCCu3AhIvuPix9jL5baXKSuaBYsQ2rvCfRum5tmt7O0ZC/Ngysu4N+sJswS7WYdy/XLylPxPeohqpYbjexX3wnHs8eL0mWTogE0dGaQoBKMOt6I5DxAlpLw59WoM9xWW6+V42ydTbidSOwSD3WhiU+cGabanvTo4+kGD6bf6AkNmIxvg5QKOfawjbfNk6+4C4IQNhj6PZvME1Wj8bN4mGhaZ8SJnGQGXR9XWeCnWOY8mor+lu3DuHi5kHbnU3E/+mfNIAH4+tyoZpsm/FtT/ya1F/+0zmBgNcSsm4LURzlPOk7Ie/GHL/XXIfMiISVAz0IB7+kbKjoui69ZA1buY+RKHIVaryxDXpmQCNhA78KTMTO2BS5SGBz88mBGSZlqvsUrfsX3jeq0UPFlK9xk5QO8ZmGg0sFH+wuE2HO3eeinPjYM+WssILG2dN96ttVAPQNVXs8MFjJbTT4W/0oCbEzSuA0sCOvJWpOcYecIbE7jA+mo9aOguS2npY6K58hmrQM3eoLNjHwdCSvxFgx/FjwXCJg/ox56+5/j8P7DFKvX1oN0jx3YnFmncPURTGPm+ci33mN56t44RZahdi2I7E0qIgKUMDwSd804B2KNQkTbH7uj6N2Y1QdvWRQTlEw8Cs5llsBHrnzGkGwphHee0FD0nmjzPphKj7dLxdEtn+hhyZtKsQwAhUbAgL5PIz3OnL66q0N6xBBfGpKUmCN9jQIpYe9uYSFA+BDJXrVXSU2ikvxc7fi0RNzeQ2+JBnOsN7gtR5myLAKbWVjNQ2aTLSXc10bHBsbU8meLcNCIbVFFKLb+sG4oz7oED6Ia4Y1MTb6ysVI6052SgLGQ1VHMMxbaA6Ojgq0AbEAmhqs2ajkAUqCLsAWRcWTOb8iffZa9jgWEBzzsj8JaCNozeWTF5RJavtz2eRgrPpIHVqK0kBKSw0PJbQbDupZ2fDUT4OgaEY7F5RovldLZwZT9joVp26s7jC2D0g/2JgOscCStOUka2XvTmjsQCcizyWjCzfLIsg1xsixgtgiFXr+s+R8pdM2fzr4iADEDhFehc0iyxjI/4nmaIDH8ZYdL+jUtQfI48NKWuO80czeHFATQdxrKvt3E5oV0xcB3o0cwcx/Vw7kslXRjtyPJnA7B5SToVzcTGwj5M8jG2ylwv/5o1XStt6OvGKBNtTT5B6jkw9YVZCXkicpqaxXrgYI8JKGbmpQVMW41PPvH9r82zSbPUBqmHxqI67adOF24sbXj10Y9IhO1ya2y/NAV72UiQYIz+XbVgYTx/qMwDu2AKX4I8EbbgVOPKyXVidZS4vtGncOn06weSnPsjG7r7SJt76KSpNWIa/bAYLscSzd8QDA6tP0uh6nGCzkxrajSS+IxvdMOzj4wdk7kvL1Woq6I9408+B6TAluAjoUTIob361MWpI+obSFBoyJCoc2+7ZCES0Wpaq4Rl/GE8+dMmbnM0yXWJ5HeQ==", "X-OriginatorOrg": "corigine.com", "X-MS-Exchange-CrossTenant-Network-Message-Id": "\n c3ac0de1-7dd7-4c43-2bf2-08dbd43928eb", "X-MS-Exchange-CrossTenant-AuthSource": "SJ0PR13MB5545.namprd13.prod.outlook.com", "X-MS-Exchange-CrossTenant-AuthAs": "Internal", "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "24 Oct 2023 02:30:17.0832 (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 l5bfy0aJayBWc8YML4pGfvckq4JlcKbQaVCgoO5R1k/+KcnMXSPxQ9oXq8lcYJgbnda2cx7J14B9dYiAD6vf36rGfQZLQ0oZf2FgCv9JmKo=", "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "PH8PR13MB6182", "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": "Add the hardware initialize logic.\n\nSigned-off-by: Chaoyong He <chaoyong.he@corigine.com>\nSigned-off-by: Shujing Dong <shujing.dong@corigine.com>\nReviewed-by: Long Wu <long.wu@corigine.com>\nReviewed-by: Peng Zhang <peng.zhang@corigine.com>\n---\n drivers/vdpa/nfp/meson.build | 1 +\n drivers/vdpa/nfp/nfp_vdpa.c | 10 ++++++\n drivers/vdpa/nfp/nfp_vdpa_core.c | 54 ++++++++++++++++++++++++++++++++\n drivers/vdpa/nfp/nfp_vdpa_core.h | 32 +++++++++++++++++++\n 4 files changed, 97 insertions(+)\n create mode 100644 drivers/vdpa/nfp/nfp_vdpa_core.c\n create mode 100644 drivers/vdpa/nfp/nfp_vdpa_core.h", "diff": "diff --git a/drivers/vdpa/nfp/meson.build b/drivers/vdpa/nfp/meson.build\nindex e1cc244578..27eb1a6276 100644\n--- a/drivers/vdpa/nfp/meson.build\n+++ b/drivers/vdpa/nfp/meson.build\n@@ -13,6 +13,7 @@ endif\n \n sources = files(\n 'nfp_vdpa.c',\n+ 'nfp_vdpa_core.c',\n 'nfp_vdpa_log.c',\n )\n \ndiff --git a/drivers/vdpa/nfp/nfp_vdpa.c b/drivers/vdpa/nfp/nfp_vdpa.c\nindex 824b0d681a..00d8f7e007 100644\n--- a/drivers/vdpa/nfp/nfp_vdpa.c\n+++ b/drivers/vdpa/nfp/nfp_vdpa.c\n@@ -10,6 +10,7 @@\n #include <rte_vfio.h>\n #include <vdpa_driver.h>\n \n+#include \"nfp_vdpa_core.h\"\n #include \"nfp_vdpa_log.h\"\n \n #define NFP_VDPA_DRIVER_NAME nfp_vdpa\n@@ -17,11 +18,14 @@\n struct nfp_vdpa_dev {\n \tstruct rte_pci_device *pci_dev;\n \tstruct rte_vdpa_device *vdev;\n+\tstruct nfp_vdpa_hw hw;\n \n \tint vfio_container_fd;\n \tint vfio_group_fd;\n \tint vfio_dev_fd;\n \tint iommu_group;\n+\n+\tuint16_t max_queues;\n };\n \n struct nfp_vdpa_dev_node {\n@@ -135,6 +139,12 @@ nfp_vdpa_pci_probe(struct rte_pci_device *pci_dev)\n \tif (ret != 0)\n \t\tgoto free_device;\n \n+\tret = nfp_vdpa_hw_init(&device->hw, pci_dev);\n+\tif (ret != 0)\n+\t\tgoto vfio_teardown;\n+\n+\tdevice->max_queues = NFP_VDPA_MAX_QUEUES;\n+\n \tdevice->vdev = rte_vdpa_register_device(&pci_dev->device, &nfp_vdpa_ops);\n \tif (device->vdev == NULL) {\n \t\tDRV_VDPA_LOG(ERR, \"Failed to register device %s\", pci_dev->name);\ndiff --git a/drivers/vdpa/nfp/nfp_vdpa_core.c b/drivers/vdpa/nfp/nfp_vdpa_core.c\nnew file mode 100644\nindex 0000000000..a7e15fa88a\n--- /dev/null\n+++ b/drivers/vdpa/nfp/nfp_vdpa_core.c\n@@ -0,0 +1,54 @@\n+/* SPDX-License-Identifier: BSD-3-Clause\n+ * Copyright (c) 2023 Corigine, Inc.\n+ * All rights reserved.\n+ */\n+\n+#include \"nfp_vdpa_core.h\"\n+\n+#include <rte_vhost.h>\n+\n+#include \"nfp_vdpa_log.h\"\n+\n+/* Available and used descs are in same order */\n+#ifndef VIRTIO_F_IN_ORDER\n+#define VIRTIO_F_IN_ORDER 35\n+#endif\n+\n+int\n+nfp_vdpa_hw_init(struct nfp_vdpa_hw *vdpa_hw,\n+\t\tstruct rte_pci_device *pci_dev)\n+{\n+\tuint32_t queue;\n+\tstruct nfp_hw *hw;\n+\tuint8_t *notify_base;\n+\n+\thw = &vdpa_hw->super;\n+\thw->ctrl_bar = pci_dev->mem_resource[0].addr;\n+\tif (hw->ctrl_bar == NULL) {\n+\t\tDRV_CORE_LOG(ERR, \"hw->ctrl_bar is NULL. BAR0 not configured.\");\n+\t\treturn -ENODEV;\n+\t}\n+\n+\tnotify_base = hw->ctrl_bar + NFP_VDPA_NOTIFY_ADDR_BASE;\n+\tfor (queue = 0; queue < NFP_VDPA_MAX_QUEUES; queue++) {\n+\t\tuint32_t idx = queue * 2;\n+\n+\t\t/* RX */\n+\t\tvdpa_hw->notify_addr[idx] = notify_base;\n+\t\tnotify_base += NFP_VDPA_NOTIFY_ADDR_INTERVAL;\n+\t\t/* TX */\n+\t\tvdpa_hw->notify_addr[idx + 1] = notify_base;\n+\t\tnotify_base += NFP_VDPA_NOTIFY_ADDR_INTERVAL;\n+\n+\t\tvdpa_hw->notify_region = queue;\n+\t\tDRV_CORE_LOG(DEBUG, \"notify_addr[%d] at %p, notify_addr[%d] at %p\",\n+\t\t\t\tidx, vdpa_hw->notify_addr[idx],\n+\t\t\t\tidx + 1, vdpa_hw->notify_addr[idx + 1]);\n+\t}\n+\n+\tvdpa_hw->features = (1ULL << VIRTIO_F_VERSION_1) |\n+\t\t\t(1ULL << VIRTIO_F_IN_ORDER) |\n+\t\t\t(1ULL << VHOST_USER_F_PROTOCOL_FEATURES);\n+\n+\treturn 0;\n+}\ndiff --git a/drivers/vdpa/nfp/nfp_vdpa_core.h b/drivers/vdpa/nfp/nfp_vdpa_core.h\nnew file mode 100644\nindex 0000000000..c9403e0ea4\n--- /dev/null\n+++ b/drivers/vdpa/nfp/nfp_vdpa_core.h\n@@ -0,0 +1,32 @@\n+/* SPDX-License-Identifier: BSD-3-Clause\n+ * Copyright (c) 2023 Corigine, Inc.\n+ * All rights reserved.\n+ */\n+\n+#ifndef __NFP_VDPA_CORE_H__\n+#define __NFP_VDPA_CORE_H__\n+\n+#include <bus_pci_driver.h>\n+#include <nfp_common.h>\n+#include <rte_ether.h>\n+\n+#define NFP_VDPA_MAX_QUEUES 1\n+\n+#define NFP_VDPA_NOTIFY_ADDR_BASE 0x4000\n+#define NFP_VDPA_NOTIFY_ADDR_INTERVAL 0x1000\n+\n+struct nfp_vdpa_hw {\n+\tstruct nfp_hw super;\n+\n+\tuint64_t features;\n+\tuint64_t req_features;\n+\n+\tuint8_t *notify_addr[NFP_VDPA_MAX_QUEUES * 2];\n+\n+\tuint8_t mac_addr[RTE_ETHER_ADDR_LEN];\n+\tuint8_t notify_region;\n+};\n+\n+int nfp_vdpa_hw_init(struct nfp_vdpa_hw *vdpa_hw, struct rte_pci_device *dev);\n+\n+#endif /* __NFP_VDPA_CORE_H__ */\n", "prefixes": [ "v2", "21/25" ] }{ "id": 133226, "url": "