get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

GET /api/patches/133464/?format=api
HTTP 200 OK
Allow: GET, PUT, PATCH, HEAD, OPTIONS
Content-Type: application/json
Vary: Accept

{
    "id": 133464,
    "url": "http://patches.dpdk.org/api/patches/133464/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/20231027030001.602639-22-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": "<20231027030001.602639-22-chaoyong.he@corigine.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/20231027030001.602639-22-chaoyong.he@corigine.com",
    "date": "2023-10-27T02:59:58",
    "name": "[v4,21/24] vdpa/nfp: add hardware init",
    "commit_ref": null,
    "pull_url": null,
    "state": "accepted",
    "archived": true,
    "hash": "e3fc6ac3efdc98479446def6cb8fd4e2c6b94145",
    "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/20231027030001.602639-22-chaoyong.he@corigine.com/mbox/",
    "series": [
        {
            "id": 30016,
            "url": "http://patches.dpdk.org/api/series/30016/?format=api",
            "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=30016",
            "date": "2023-10-27T02:59:37",
            "name": "add the NFP vDPA PMD",
            "version": 4,
            "mbox": "http://patches.dpdk.org/series/30016/mbox/"
        }
    ],
    "comments": "http://patches.dpdk.org/api/patches/133464/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/133464/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 82A074320F;\n\tFri, 27 Oct 2023 05:04:10 +0200 (CEST)",
            "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id 0720342EA4;\n\tFri, 27 Oct 2023 05:01:22 +0200 (CEST)",
            "from NAM04-DM6-obe.outbound.protection.outlook.com\n (mail-dm6nam04on2116.outbound.protection.outlook.com [40.107.102.116])\n by mails.dpdk.org (Postfix) with ESMTP id 5814442E25\n for <dev@dpdk.org>; Fri, 27 Oct 2023 05:01:07 +0200 (CEST)",
            "from SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5)\n by SA0PR13MB4048.namprd13.prod.outlook.com (2603:10b6:806:97::13)\n with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6933.24; Fri, 27 Oct\n 2023 03:01:05 +0000",
            "from SJ0PR13MB5545.namprd13.prod.outlook.com\n ([fe80::45b3:d83c:cff2:4a1b]) by SJ0PR13MB5545.namprd13.prod.outlook.com\n ([fe80::45b3:d83c:cff2:4a1b%6]) with mapi id 15.20.6933.022; Fri, 27 Oct 2023\n 03:01:05 +0000"
        ],
        "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;\n b=TotJ5jqu00NJUQWSvDhJcCrYyV4eFH4/DJAbds66T0n7TSDC3vz7MNfd7dU1KAYRkS1++DpE8pYK/pnQ+5sfXc+NgS4KnHReK7lU7wvGU1KyXk44l0NyfXJmHI8JnNScSe/Fo3R5asC6OtBdPya8SyhCVKCuTtl2+4kzKVgmYlHEKyoPIDA+KIwDjCizAj9g7LtjL7JDte7m04PzFDolorwrtBpF+nHqs4+xcnrBZE3vdQNwTW++GNn+PjBP41u2rPGvH3iDGNe2aTEHHKMhEUkTesW8t1UCBxeHCvGSZa+25KEukyG5aICktyZiL5+1DkpLLC6zm7Bars93hHMbjw==",
        "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=//vcj9C4dCYeyhEFcez77fR7dZTUeDRee4UCLmkkU5I=;\n b=WG6P/XvbqUPZVxvMlQShq2qo14pd7B3FLqavbz3xM5c1WKYuZXmpleD4A4zcziD2knP8f2+yYzr/Yi1tqmNGdLo8tPFgOUkSrJU+cXz8nKoI++RCueNuth1Tpkf5Hr5q90Cnv8WkP4kzJxXk1vobGNaFzIEXZpgcPKFK1gtXuTb3rXN8Xim6m8oQvSxkGqrMRb44Fvk90wS+TwbAj2DM6vLFQMgso005MOiwMYw4GEWgm+pVEKaf/4QkC2FMJwOuUp5dI7Ijn0Ws1bidnS6K1wwR9452VtKsSZG+VcgD0Sc8qfdiCA220p8GL6crVWLeCk03LFGIQpkmbum0UvkmeA==",
        "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=//vcj9C4dCYeyhEFcez77fR7dZTUeDRee4UCLmkkU5I=;\n b=J/cNgc7KsOE/l0t7MFrlrxWkLbBzRgTmQewPkepadlqeVniv6bGk7CvPat7aGr2I4XPJBwSRabe/LkSl6HI68yQO9GhxxU4ZhqnYH+hN5z0hetn0PamG09KjyKw2L99fXDc+MJsnvsOXhW2rD8mYPXIPu0U0/PrI/W1m2zrpAs8=",
        "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 v4 21/24] vdpa/nfp: add hardware init",
        "Date": "Fri, 27 Oct 2023 10:59:58 +0800",
        "Message-Id": "<20231027030001.602639-22-chaoyong.he@corigine.com>",
        "X-Mailer": "git-send-email 2.39.1",
        "In-Reply-To": "<20231027030001.602639-1-chaoyong.he@corigine.com>",
        "References": "<20231026064324.177531-1-chaoyong.he@corigine.com>\n <20231027030001.602639-1-chaoyong.he@corigine.com>",
        "Content-Transfer-Encoding": "8bit",
        "Content-Type": "text/plain",
        "X-ClientProxiedBy": "BYAPR08CA0065.namprd08.prod.outlook.com\n (2603:10b6:a03:117::42) 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_|SA0PR13MB4048:EE_",
        "X-MS-Office365-Filtering-Correlation-Id": "8d5dbfdf-80b7-4e9c-de19-08dbd698f616",
        "X-MS-Exchange-SenderADCheck": "1",
        "X-MS-Exchange-AntiSpam-Relay": "0",
        "X-Microsoft-Antispam": "BCL:0;",
        "X-Microsoft-Antispam-Message-Info": "\n 3n6bJt3lbLmSJFliod9Df8c0oKJ0B0kYixkak4YE5dU5FvE7VZrT3ojxq6C5Hlzano0OiKxRwC0trK2gDU554PcTgQLYfASE+x5ypdKENJsDTXYW6rvFZoJoHOAPkPmaxfFf6+ejesT7MZJBCjS2szfLQnmOVndQMRFpDLowbE+NSDKCuwDffmxX59d1VaNPEPwtPu5zeq3FuSr+ESdFnV/URjJVUwqTZK+5w/ELSm5tvC12zjib/GUuDjE/yy1jBxHvZmkOwMgtbaZ+Cu42ppKhyW2/wgkPlp4yVZxwglicJbA5SpOBbo9BIX1aDCGKTRj1UoD9xK873I1nuaArGuXcM3UZYNne2d//G7sIxGKqzFuyIQswKCOzHeM+Ra61CNhoOBWhgyAt2pFTup8F64BeqIo3HFrreqh+oMX9R0IAym0+pzzywK09m6KkXUdPyYlNWcBuvkhFML710Sk+ahmc/RzpQirhvh3/37XlzAmaeLdrayKwEpidefZ9f8wtgzGmL4XadGyZmzWRvG0gLbovZ9ILmkWSQT5SfNZEhbkfpA7lQ1GrWr9VqATd3VKSxbzzHAza1y/6cabk7QehKu2thyjP2qevi1NWW1Dyt/t50Ag1rJJYbB9EbkP99lcry97R/rO+xC3DAFykBOEV4TVlnIzR9ER8EJWjjO/0JGs=",
        "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)(376002)(396003)(39840400004)(366004)(346002)(136003)(230922051799003)(64100799003)(186009)(1800799009)(451199024)(6512007)(6666004)(52116002)(6506007)(6486002)(86362001)(36756003)(478600001)(38100700002)(2906002)(6916009)(41300700001)(83380400001)(1076003)(107886003)(26005)(2616005)(38350700005)(66946007)(316002)(66556008)(66476007)(4326008)(8936002)(8676002)(44832011)(5660300002)(54906003);\n DIR:OUT; SFP:1102;",
        "X-MS-Exchange-AntiSpam-MessageData-ChunkCount": "1",
        "X-MS-Exchange-AntiSpam-MessageData-0": "\n cY2LNlMJoU1Tgz9OjeNCCo1l9RvoL9+pSm57ctkbF5dlblzAJFNDAzWtENeoiMOi39ZWr21hkRO2+XzaIgcVBhIPE3hfwYz9S9C8lARxg/3yYUlG5CiTh2KFjuQOlgTx7iD8DUwsfC/aTSLkod8xJ+TcgEbFNowQbcRg6AL5QtnOB6gUjDTVrDc7eUvhsltGWkQXtVWKNe/le/oXZMfjMfqB1qYmrJWU55bh2Gtky5de4pA1LVMd9OEuFsWvCLT/qi5isZYkWLWrtCaUREcH19ttvUxReLjWnht01gzkKNrNBDr9ujjBk42C3/nwQYOwFhxO1bFG0T+7LAuD/R2jAv2VgNYbZpuVaPnCfGyKiE+hkr0KFq60SoTCsImreKMN5pymL3Zu+40Ag1fLolcDEZ6ZAU1gNELmQQkiEVg191+rGRKuxF6QNVjuD7rKVVGuv7ReIgf6I1sAMWDBTxwGZYcw2Bt8++/8s5ex5zFAL3UJ22eDIoKAEysF8F7w+bJEk+NbGR50LZL9a9/I4LIFf5Exy0QbEgY+Phz3ZipEgapIOjt8BwnU1trD+EJnvp4zVBBRct+Ltcd5bwgilsz/FjociMFsYm3fUqzKrhYH9H8VPmM6raF3NqlU0h3Dun/vHWalbMK7TxmVNYXZC9iH+NU9FHkP9TBjnNQbufvKLtHp61ZESJs4VlW9CRkD7CCUlrC+M8blJybiDz7B5GxcTxnutwrcuuZsU5PhWmsIpoR3lVEYEfDuyW7V/9BOlprIdKiXa1QYiT30OmTWatbF0XQDQ9dgJC/CrKQnhekQlBI5kcoOcWINtTrYIiiOWvzt5DriRPcYqMnzE0FHZYMXRCHX45N+lQdTapgHzoKEDLtZ7lgGtztsRKjpdziK65tA9o2HRwprImBZCIN1i/WMlD7SMp3Xax2+B/wxhOV9x6ZNDxfemVIEHyvYLdWDWAvaBBuJww2J6NWHVhgGSbig3F9wwG9TU01qSgF0tcqu3aKISsEUZGYnlCVRm7dePjjugvVoeFrMdwSLT1X9aP0c18gUHU/QXPRb2F6Xh3A3QDfTdboBVk68uA51vP/t39n/PnqTB2mirNyVF2//aNm5Jwe/xwhXttiNY0BRw+mXA7akgFpaJeWAOhzrsKKqfqOnaYeQvOVIDmmGubjUWhcAZSKdYWx5QBzoTxDzq2xjK4itrYzziweblZSVUnqYstq9njsjMGNPg3t7qGdGkyD3SHYMCGhmKkq22heXljIOVvnXENzrZ2CuJpv8O2CISIydm96sEfZZR0ailGScaHhTQeTep+rHd0YZZv0GFnxe8sz0xAt6a5UVCk23D5WIDesHPK7dfmDnu9tRV5GdOtwqEGusPRj1AQ0XaEtK59F1NNLRct1lAnJvtZaMe8mt4ZkX/BOvPA+zFd8i7BKyAaDrA0Ms/NLCis5TN1ujgvTLhYU4f8WQoJzvAWdt7F124Xll0JyoPRsnAoVWVAwFe4UbWg50ujuu1zqEi+/uy4KssxatTCU17ou2HpnZPDNCB0s1q5SNCFVISYgLkxaAFSPsGlrp3e5/hIX34DliM5X97op3lDz7BhsEYUiCf221M7fKFLh4Mbi/UjhwQHwSLn004w==",
        "X-OriginatorOrg": "corigine.com",
        "X-MS-Exchange-CrossTenant-Network-Message-Id": "\n 8d5dbfdf-80b7-4e9c-de19-08dbd698f616",
        "X-MS-Exchange-CrossTenant-AuthSource": "SJ0PR13MB5545.namprd13.prod.outlook.com",
        "X-MS-Exchange-CrossTenant-AuthAs": "Internal",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "27 Oct 2023 03:01:05.8236 (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 8a/JM8WN2Aky/lOAaiR9fVpqqZCc4vszGpN21NzgNmhssPzgRMXO/1e8FxwNmYi60nFXbqYqOeqSBvkbt7I9RoKkUMjs4aa6grqVaEi2J1w=",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "SA0PR13MB4048",
        "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 79a0364917..258f3eaaa0 100644\n--- a/drivers/vdpa/nfp/meson.build\n+++ b/drivers/vdpa/nfp/meson.build\n@@ -8,6 +8,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": [
        "v4",
        "21/24"
    ]
}