get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 133467,
    "url": "http://patches.dpdk.org/api/patches/133467/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/20231027030001.602639-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": "<20231027030001.602639-25-chaoyong.he@corigine.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/20231027030001.602639-25-chaoyong.he@corigine.com",
    "date": "2023-10-27T03:00:01",
    "name": "[v4,24/24] vdpa/nfp: add device operations",
    "commit_ref": null,
    "pull_url": null,
    "state": "accepted",
    "archived": true,
    "hash": "69cd68f4a7900bb110083a35d2076acc3d0844f1",
    "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-25-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/133467/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/133467/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 59C724320F;\n\tFri, 27 Oct 2023 05:04:43 +0200 (CEST)",
            "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id 8FEAC42E95;\n\tFri, 27 Oct 2023 05:01:34 +0200 (CEST)",
            "from NAM04-DM6-obe.outbound.protection.outlook.com\n (mail-dm6nam04on2093.outbound.protection.outlook.com [40.107.102.93])\n by mails.dpdk.org (Postfix) with ESMTP id 0C8E342E5A\n for <dev@dpdk.org>; Fri, 27 Oct 2023 05:01:14 +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:12 +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:12 +0000"
        ],
        "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;\n b=lD98fyfz9BOzJps8x3zODg/58Z01/vwIqkaZzBfy1eNkqpECrBJZu5naLuIXTKCRMC/RxLo9wzgBpu96OH+Upkwq2Ytq4wPSe+NNH9wMrXn7Q4FNg5hQvgq1JsqkPlgBCWNciIO/QObhanhWwPB3+L24Fip7DC8aNfaTx/+SOStTTGEu0HnBGc3WZoIeq7l/keynbl/TrcKrA8kpVT0rjeeid7D3r6uMwuGxZBZw4shfvMfnENEiog3MHedVjPFluZnkAaDUW2UzHccFOoBTYgAZ49mJN3isoGAN8tAQypcqLJDIu7l0nrWphA23oOZpUfdkY2uU5TSzJ9fsrqZQGw==",
        "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=zs3+5JTfr5a7DpPcAx9Hen1IISiYu2wPu83zcbKT8Pg=;\n b=Ln2Q7LZprlKKQBN3vWFK2vY8PkaUwkbgVi3K/UT/f8Mz0cxn7t86BTUsaEvwo58pm3O7FOsAVf/hJX7zAssyCp/yDNkAvZBnNTCMTPP47EzzY8I9zf9EoGE7w6l0hPrw0AUhYH3EP8ccgFeYOK3j9AMUcakpHxHI3M4Q5tOU90CxpEOV/ZR06oZvY+Hem/KjuC8YGKbc/f/GSPSpcW5rIoYwtV5gUyBaWdqKssPg+YMt25EbQRHvKIEm0jleMgbvHObRuCrtE6h9wQaPkDHkP3tlo/mzj7dLdmlqvxyYMVqAejPU5IRAJ3rLVSzGJs1+Nfsmq9qjWnnJxBPoQSuLkg==",
        "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=zs3+5JTfr5a7DpPcAx9Hen1IISiYu2wPu83zcbKT8Pg=;\n b=uush6V9R4yPX0SIRLhmuY8hTPDvv2jLMgDCH2258ftKkP43MZbiWP0oMUMBpINZF3nzG1fRjgDV9ndupHaSYeN7A7KG9wjjJnnisk0vZC5t7XzOzRI38WLTnHeXJpaCCIvE3MvrZ1vbwXpMTHUs86a5h53RQ+IuuYhbKE8WZ9jU=",
        "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 24/24] vdpa/nfp: add device operations",
        "Date": "Fri, 27 Oct 2023 11:00:01 +0800",
        "Message-Id": "<20231027030001.602639-25-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": "aef199c3-e08a-4e58-2600-08dbd698fa0c",
        "X-MS-Exchange-SenderADCheck": "1",
        "X-MS-Exchange-AntiSpam-Relay": "0",
        "X-Microsoft-Antispam": "BCL:0;",
        "X-Microsoft-Antispam-Message-Info": "\n McrXvi3E/zOQukbjw4xPWVx2uVbDloFB2HjSN2PjvINWWb5tez6zRWPl90o+c7bbwB64Y3kug3F3dMq20170Qmphqxa/oRaaCuFaFttIK/l6G0bp/79Hs2uQ8VoS+d+TFxTk6+QuvA9XkkE1pp1zqEwuv4g5WsGlY1zszOV2FzFvL4T6Qa/KuQ5+pzBkXsooNcportI5RS3hqGRYyMyDBkvvk9rIQvt+LOjPlIAuY6aijy9803WmdI5Nv27G4yrdbBinasC6t09qa+ylrt9E6ptHf96pp3WNai+LMc7dJ0TbGeGwZcS83LAW/SDv9famDwmBs31MDWK99CZsnPNvoLnDabhqhHyYnttYb5old0SBt6iUzIwzpZGrMs8HikdswxoBfYzTF24dV9/0Xsk6M/I5i1F9rNWTIrCV7MjNhtMcoFA0nbFK0jex+B39U65LWwBI7pxznN/fggo/i+74LSU3dmqG6fzY7VWvCnU2zHUGMQ3+SP6aFZegw6z5R3PKvzj1PsHtOZxhNes5u2lgFdBZRzqwVA9tk042Hgvuiouh9PMAMg/uziuZrQM8b0XTDqJX6O4yjQ98C+W/UC0CDUmhPe8EpST1xQ9DPNRnOJezFr5ZC0gb1bPKLlbz9zKnFzf1Dpu49u6LrceSFGHMfjnhtbQ+QVpnMdpkEfUz1ak=",
        "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 lyi6Sw0xcMe6SCiVC0dOZ/myM3B2KLd4ZhqmUVh4finAc9c1+Pn7zZMToxS5zQg++YZVkk/e19Am/NQC2jRxqiDYWLsQOGiqZs+mKM0V9AalaLU2+pjzNF6hLQHrI5wMHxz+LBCBlT/yVAJYRMtwefNpZL6/zMdLrY4mJ2CPBsW5Jf7Mefs8108SjIi7i/NulQ2KPkE59Uv0t63eBjKGG3IcOreJzc6HVVzl/zb0IzEB8RJ+rbUBlC+JzxxbqkQso4gPHGxdlp1OkhjoswyB0Kx9xo3DWhpXJMTYIx0GAJ7ty73YURLziZkITudPj7Gxkx/q+lznCYh8b0htuvbWbdEKZgJOjR1yWAyIwvKUB8jGqB1Rx4b2FevftCj68DyzlSYml9kRbUs/DRVf797rl8cf+KqHy4llVaHdMLdPGnC9YlQiTbLZAxpbu/NizHRRhMCD5vVI/Ou7QAUNL5VDJSbTmWsu5jCVhofzseE/iv14G3FeNWr0VXKU3YRvQJbUy5k+7EMaM1jSkLFpc3mNts0mOzp+0rBzLCkDVTAI36/jDg+VtTpb9cM4EMFB9Jug7QfngcjfHfiCkQaSV3XNd+RAx+e4snoo0D8ujStnDpjMESH0D008Il75nyZfVSXMDFtJEMBmZ9DEKkaZP2hP2wM0UoG561OcpeQkgkXWuBZVL6xKyNCJm4NLnuxMEBsGeyL9DI9xeQCAxiwtyIBV3PuhJ2orVqfcLCeHmjHhYDRGoEwCz3mZItMNHOe23cVJoSGr+9Zxn9rH/Q6S9zwh97RK6DewPTlsZTBd5VViZFP08xDqGA6gXzPVNAUi3nKCGFFV1K4U7G0v3NDj3hHMLpgWGy1DK85jgD5P2s4R/6135joI2qaJJYzStfP2t67YOAWeQJktjfgumFrHs4m3pTAXy8FdXWdVx+xSmrBePmRFEdRL68vOuPF7aMZoyYPaXKPzDq26KzvsxZxfQRNe/9hQOCKrOEYuC6eRDRVUaRW+13O0N8zr+nHHCfeXaALXXLSuuVtDJQc8TG0q54Yt/z57XqN2wEh1SXdeA0kSqRQmJgUuulUnG5NpMWfGhwiKYsYllbpf5OeIzs1hxhNR+Au2T1YTK1JU+PWpPqXpPHZ3pFRKEeIgQHghRpKIiU+0L7/360x1qXBnTVAj+4jTWS/EwiAUhp6kTVhGu3zBNVNuq/Bz2lc74OUr0qqEVxFUjEZ0nbpckTc5z261PT+GHIAHj1KZ/sfPEIZVqT8eXmrX7V8a64dUDX8o2j1HkLFNxQQBoRuGLwWScKmL8+Ou0uvci7JpF+vnpsSq3m0QckngwVCfJZ9Y+3rjUYl3/XTyb/yKO8h+Nnsa3Ght5nDSmgpgd2seDwQ8ds1RxdKH6pMI1dzrDcob/lXlSdgSSigRYPpVv2j6D7Kh1EWF/6RBT9JGXg9FpQCBiv9+C8IX/QuplYsyvwB0VaDBl+LotKjyPdnLbMkWyyNAK4IYVHo9Y3LeQv8ijLg6ZITAkN0GrTzUtOi78iTG0ieuNZ4GuRguYUc4xCk5B6Y2x26/Dc5rd6jgTVi+pKKyYhXcGc4KJfT+L8LKXa1yluoVCnzJKsVN4SRGp0USnx2+YS2OaCKdmQ==",
        "X-OriginatorOrg": "corigine.com",
        "X-MS-Exchange-CrossTenant-Network-Message-Id": "\n aef199c3-e08a-4e58-2600-08dbd698fa0c",
        "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:12.4232 (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 R4TgzP6UsDQSlsWp4zEoLNk5aHOdxHIsQsAudE08PzPhjxwXOB4Hj/pUTvnLkW4YSGiPiwgWrbI8E56GPRPD366mEgsgEOoMZmrpDaKxGME=",
        "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": "Implement the corresponding nfp vDPA operation 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 c104588663..a1d1dc4f73 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@@ -578,7 +601,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+\trte_atomic_store_explicit(&device->dev_attached, 1, rte_memory_order_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+\trte_atomic_store_explicit(&device->dev_attached, 0, rte_memory_order_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, &region);\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": [
        "v4",
        "24/24"
    ]
}