get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 133359,
    "url": "http://patchwork.dpdk.org/api/patches/133359/?format=api",
    "web_url": "http://patchwork.dpdk.org/project/dpdk/patch/20231026064324.177531-20-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": "<20231026064324.177531-20-chaoyong.he@corigine.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/20231026064324.177531-20-chaoyong.he@corigine.com",
    "date": "2023-10-26T06:43:18",
    "name": "[v3,19/25] drivers: add the basic framework of vDPA PMD",
    "commit_ref": null,
    "pull_url": null,
    "state": "changes-requested",
    "archived": true,
    "hash": "f073b7175cfa3af7900ccb82dc30e72a7d4e89f6",
    "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/20231026064324.177531-20-chaoyong.he@corigine.com/mbox/",
    "series": [
        {
            "id": 29991,
            "url": "http://patchwork.dpdk.org/api/series/29991/?format=api",
            "web_url": "http://patchwork.dpdk.org/project/dpdk/list/?series=29991",
            "date": "2023-10-26T06:42:59",
            "name": "add the NFP vDPA PMD",
            "version": 3,
            "mbox": "http://patchwork.dpdk.org/series/29991/mbox/"
        }
    ],
    "comments": "http://patchwork.dpdk.org/api/patches/133359/comments/",
    "check": "success",
    "checks": "http://patchwork.dpdk.org/api/patches/133359/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 6382F43204;\n\tThu, 26 Oct 2023 08:47:11 +0200 (CEST)",
            "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id 2C2EF42E35;\n\tThu, 26 Oct 2023 08:44:31 +0200 (CEST)",
            "from NAM10-DM6-obe.outbound.protection.outlook.com\n (mail-dm6nam10on2093.outbound.protection.outlook.com [40.107.93.93])\n by mails.dpdk.org (Postfix) with ESMTP id 5846342E05\n for <dev@dpdk.org>; Thu, 26 Oct 2023 08:44:22 +0200 (CEST)",
            "from SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5)\n by DM4PR13MB5908.namprd13.prod.outlook.com (2603:10b6:8:50::21) with\n Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6933.19; Thu, 26 Oct\n 2023 06:44:20 +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; Thu, 26 Oct 2023\n 06:44:20 +0000"
        ],
        "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;\n b=TlYFXgMS+hYAFqTQxbu+DHQGZhx1CL6GsrEYfIj0+WHu26icMBETivtAMtphvqnVO5TjdNnEiTqbl/b6TomAbQxArvwNM0Mpim2e8BFz74tJeY9WVTstXiRwYv756QQtQvcbb/TNLj/BN0fD69IxZf/shUcqxlVes0+Kp2gLZYAr588DtG1sTknQkbgvQnt2Cb8rcUside7MjgQE4yodW2g9PjI6M7dYtQKLKqlLpV+1sb1D3ZMGiWailjN+wzZ8DP4eXK2gG7+da/9G9DfsEtsqgMbjaV2VlG9JxbrIcp7VULw+MIypV48J4EJCtuwPFEBqIjOU7grE1t3PhVtC+w==",
        "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=yOGvlioRLuuyiF3PvoqM9dx/VgwtqOmWT2SFrI/Pe0E=;\n b=CPpfx50lBltFz9LHLA9ADcDQVufOVkraGMGZz2VURlyncWyJ9LmX+kBDqt0mVzt6qe8xp5Sc/MZ+B/tbIOPGpIlYzPJ3jA1yERpJgtGEiFs949XAwifZj4rO7+g0ZgE6EWW80SgLrlweRwTRxLyulYhtUakd4x9vPB6A7j/SeFdrk1Iv7j2VHLTLYjbppOUstOS+bCa6gbOi/d/l9x3ZozkqktX7HQ1/bWGu4hkj1Cp6qvyxxwDojpjMgiUI4EjlFehgj8QLPesQwFe1eTXmMFWrezxvTP2pGx8gHAmPaDS5c4jE3E9KoQAl8Y5I/Nr4wP3CedFjJEgasZevb3XY3A==",
        "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=yOGvlioRLuuyiF3PvoqM9dx/VgwtqOmWT2SFrI/Pe0E=;\n b=GEJZVVnZQVXKiLXrvFBqIt62L2bGYBWwILyvYR1Wq9E3xsFu8oU1xv7y81sXI9kZ+xPNfE2CTAU2+YknkKZx8kP4WyKo29l2R7Zi5yezK5d5KDaKFv+BQpfMYefdG+dEXAk+cnWYENPw0M5bLyuwfDpbgj19y4hJlBNy8Fi05bg=",
        "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 v3 19/25] drivers: add the basic framework of vDPA PMD",
        "Date": "Thu, 26 Oct 2023 14:43:18 +0800",
        "Message-Id": "<20231026064324.177531-20-chaoyong.he@corigine.com>",
        "X-Mailer": "git-send-email 2.39.1",
        "In-Reply-To": "<20231026064324.177531-1-chaoyong.he@corigine.com>",
        "References": "<20231024022849.3092506-1-chaoyong.he@corigine.com>\n <20231026064324.177531-1-chaoyong.he@corigine.com>",
        "Content-Transfer-Encoding": "8bit",
        "Content-Type": "text/plain",
        "X-ClientProxiedBy": "BYAPR07CA0034.namprd07.prod.outlook.com\n (2603:10b6:a02:bc::47) 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_|DM4PR13MB5908:EE_",
        "X-MS-Office365-Filtering-Correlation-Id": "0a31b275-79dc-4ca4-b311-08dbd5eefbbe",
        "X-MS-Exchange-SenderADCheck": "1",
        "X-MS-Exchange-AntiSpam-Relay": "0",
        "X-Microsoft-Antispam": "BCL:0;",
        "X-Microsoft-Antispam-Message-Info": "\n QPqZclHh5rJmFqUK1/CNwL/caPBSJ2s62mHUP7rPPQ1vaCcBxQxKzAhgQeLWfoPPTmPySeGuw5biWTZbhggZQd8q/I2z2hJjHHn7qjMXWFZCqS2l2CvikzSwbkNJZN36vl+NvZhfc68fO9El1tTYhIrD/KwoOlgZwHXix7sTq+dRSO1RjsMjmKNEfrWbQOLF/NjnjJ78eEartEtQMQhzT6IziEkMZqhTHnEUj4xwpaYBi2hfcd5ZbTKid9k3LewrUtg166OecwtiAeBj7xvYNRyEyFWSaw2B/Z47JEKNCDUhM3E2D3atzv22+eBPlLNUGwaYULt1tQTKUtStRH8bHpRF+qcwleLSGbMsKKrfraakZ8g+O2zVpC2ASh1ke/KMUuh7jfR6ltfHh3t3OJBVNUbDujLNAdBJ2OSvhFqSdcRZbrAgOF0V7dT9m4woO1lLgYINujLQSH18qP4ChJ2vdH+UGi1H55KUdZ0SR8QKrjwuePcuc1QQYALT1GGdWjiwtfO9Oj1oA4T8Wvz/cPTRFr4aDzzhXl5KSvBp7GFqE5RsarucJstC2/GuqhX9n654wmS622cXDyDOi1QwFWCdpiRhPeh+hz4GwTLjTedwNq+JwL4rTp66qiEQQnzilNg5Nc+AeFrZtL2DBc1FnVEO+phghM9EL0fyJqIdrXTC9LU=",
        "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)(136003)(376002)(366004)(396003)(346002)(39840400004)(230922051799003)(186009)(1800799009)(451199024)(64100799003)(26005)(478600001)(1076003)(316002)(6512007)(86362001)(6506007)(6916009)(66946007)(66556008)(38100700002)(66476007)(54906003)(36756003)(38350700005)(2616005)(6486002)(107886003)(44832011)(2906002)(83380400001)(4326008)(8676002)(8936002)(5660300002)(41300700001)(52116002);\n DIR:OUT; SFP:1102;",
        "X-MS-Exchange-AntiSpam-MessageData-ChunkCount": "1",
        "X-MS-Exchange-AntiSpam-MessageData-0": "\n 7JTnNTeFuDLC4LDjEW2LJN1cylE68TWDNR4ki4notrAEP6XYgfPb67vFZhuJMOH16LzR99CbXdU39Hovi1krRaF2fZUKmU2f6BfyN8jEGfiVbnX1GpIH9WDXJZBoLlsri9yhD5ZPzDTCFaTH7VSn5rbInfwwrDkPBnwLmLJxp31N1VdsCN/CLGXb5s00NU20qPB7Amg8LGPCUFtQoXcnEaJpTySdgVOWG5+SqXC+JHudRR3LBnY+Heuy4KRkbTMk7OB2J1B7+Po8UaTy8++TQ/IjuKnFLcsxlpCy04T5cfT+YA1qG5GsxCS0ooMSTpjPXq33d+moMVYfJiwWUR8O0qQe6lx5JXZZRxBj1dkwcIWSJyyoVPfl6IR0tCtAW9XruKw58r85ej0wWe9d9lfbTw4+55uOL5AECI18bnlI7mQjlRIQEFpWL1adeG6TbfFHyk3C0EFdRYEAUcon8ZXNhDsKwvn9UgxdrzFsG8BfkGQoSaUQIFnc/vurBlV9Jn6qZHatuSve9JMRCxBEPPiYVpQYPgxYSl6dAZFfwVBNW0qgYMgmJDvVZUIQ/W9Eg1/CF6PiyGEvqi40nE3J1qPxXjp1zqFR6RMHS4x4XEaTSA+BMFoOJR5oxL6i2YbVUuPT1qdXt7aLl1Dv0ZXgwlBiYNuoViFlD8N+xzgRpBMevSyjddnpwuvj3IbwYg7lSSgna/crmM4xmHncVCqA1S/yP6aB5QRxsOshjEEflGqtjMLKvMuhtCQzWjbJx5uFzPfh0npifsOAUy8Yth2KKX3N/JpmYHf1evSzt7WJ+NH59anhQsbtBrxHFgn7iZU2eelUenR+XBYHxc5eksgWN4f457AjH18gdJGPguRLjKd4tUqC1i/51pLMsPygUOHvbqbyvN4kI0BjDHM+D7wHvIh9ryUdQFYUkXb1iRMOVtQV8qqvaz6uR9VzZ9z03mv8um/qd71f1Qp7zcwAyt/Gq5oDhzdO+Qn7DlXf2f7Snji9UaIYgy3809ZuB7D4m07v3vMYMQPeXg/8RitZLXSzRZjAq5SPvALUTpzZtPaOgTJiwhWOU3qH1i7pBj8MtMPkDiGWhhV1IYl2XdW6EG86mGMEP040qrXaZx3iPRDpYscOpfk2cfMlx1MyHHU8AwaEwL+Ax++47YUQvgZCX7bRLqrVWph+l0X9OY5RYLLdgaiCdcR8HhTAIghPhhKTWpT9IRUnSHIGdcSQnUGXnBUk90nFEhaPO1cLgkj35R+lGcoicOw/4IZwwT7A/75dMI4NU4Hr/hOUYwaEpc3+lsG/YXcXEg0N7JCXMwM7Eu+CisXCXLsMzAvTbVPC/qrVUaypq04ph2VfAnrqTdvNJZuEfO4RuqbXT7TijdQnc7bUNIaHf5xGAE/yTYoDeHnPBKXGtDRqWhP2dnfo8HRCOBzveKCu+S0Wnu0YTIhZ6auj7NJZEc9WhjgulN5Za8e0V5FZq3uLUnqLF2dCRRqChNTMdPCnEADx8woBvgo5A/enZphW67Gvx0SiCjZs1oqoec8vFBl4hcRJswFp4Bev3ADJr2ahe4Tv2exXPIVIGl1MNmmUcGURUK05CWkjB/UNtiXnK9zaYCTAJ4/2kXDDwIl8pkuQPQ==",
        "X-OriginatorOrg": "corigine.com",
        "X-MS-Exchange-CrossTenant-Network-Message-Id": "\n 0a31b275-79dc-4ca4-b311-08dbd5eefbbe",
        "X-MS-Exchange-CrossTenant-AuthSource": "SJ0PR13MB5545.namprd13.prod.outlook.com",
        "X-MS-Exchange-CrossTenant-AuthAs": "Internal",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "26 Oct 2023 06:44:20.8305 (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 bqOoxzVqAtk4cqX/PaQLQOZTXQE2KcjXDcSCbw5XVkktiTXM1fU1KN8sCirrs7twX33KspWos3bHc6fJ/c/EO+rpyglDqcputLKfaLKrnYY=",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "DM4PR13MB5908",
        "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 basic framework of vDPA PMD.\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/common/nfp/nfp_common_pci.c |   1 +\n drivers/common/nfp/nfp_common_pci.h |   1 +\n drivers/vdpa/nfp/meson.build        |   3 +-\n drivers/vdpa/nfp/nfp_vdpa.c         | 153 ++++++++++++++++++++++++++++\n 4 files changed, 157 insertions(+), 1 deletion(-)\n create mode 100644 drivers/vdpa/nfp/nfp_vdpa.c",
    "diff": "diff --git a/drivers/common/nfp/nfp_common_pci.c b/drivers/common/nfp/nfp_common_pci.c\nindex 65f189b05e..723035d0f7 100644\n--- a/drivers/common/nfp/nfp_common_pci.c\n+++ b/drivers/common/nfp/nfp_common_pci.c\n@@ -32,6 +32,7 @@ static const struct {\n \tenum nfp_class drv_class;\n } nfp_classes[] = {\n \t{ .name = \"eth\",      .drv_class = NFP_CLASS_ETH },\n+\t{ .name = \"vdpa\",     .drv_class = NFP_CLASS_VDPA },\n };\n \n static enum nfp_class\ndiff --git a/drivers/common/nfp/nfp_common_pci.h b/drivers/common/nfp/nfp_common_pci.h\nindex 21465fca68..80c027c3a5 100644\n--- a/drivers/common/nfp/nfp_common_pci.h\n+++ b/drivers/common/nfp/nfp_common_pci.h\n@@ -16,6 +16,7 @@ typedef int (nfp_class_driver_remove_t)(struct rte_pci_device *dev);\n \n enum nfp_class {\n \tNFP_CLASS_ETH,\n+\tNFP_CLASS_VDPA,\n \tNFP_CLASS_INVALID,\n };\n \ndiff --git a/drivers/vdpa/nfp/meson.build b/drivers/vdpa/nfp/meson.build\nindex 5eff240055..79a0364917 100644\n--- a/drivers/vdpa/nfp/meson.build\n+++ b/drivers/vdpa/nfp/meson.build\n@@ -7,7 +7,8 @@ if not is_linux or not dpdk_conf.get('RTE_ARCH_64')\n endif\n \n sources = files(\n+        'nfp_vdpa.c',\n         'nfp_vdpa_log.c',\n )\n \n-deps += ['vhost']\n+deps += ['vhost', 'common_nfp']\ndiff --git a/drivers/vdpa/nfp/nfp_vdpa.c b/drivers/vdpa/nfp/nfp_vdpa.c\nnew file mode 100644\nindex 0000000000..ef4ae4946a\n--- /dev/null\n+++ b/drivers/vdpa/nfp/nfp_vdpa.c\n@@ -0,0 +1,153 @@\n+/* SPDX-License-Identifier: BSD-3-Clause\n+ * Copyright (c) 2023 Corigine, Inc.\n+ * All rights reserved.\n+ */\n+\n+#include <pthread.h>\n+\n+#include <nfp_common_pci.h>\n+#include <nfp_dev.h>\n+#include <vdpa_driver.h>\n+\n+#include \"nfp_vdpa_log.h\"\n+\n+#define NFP_VDPA_DRIVER_NAME nfp_vdpa\n+\n+struct nfp_vdpa_dev {\n+\tstruct rte_pci_device *pci_dev;\n+\tstruct rte_vdpa_device *vdev;\n+};\n+\n+struct nfp_vdpa_dev_node {\n+\tTAILQ_ENTRY(nfp_vdpa_dev_node) next;\n+\tstruct nfp_vdpa_dev *device;\n+};\n+\n+TAILQ_HEAD(vdpa_dev_list_head, nfp_vdpa_dev_node);\n+\n+static struct vdpa_dev_list_head vdpa_dev_list =\n+\tTAILQ_HEAD_INITIALIZER(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_pdev(struct rte_pci_device *pdev)\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 (pdev == node->device->pci_dev) {\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+struct rte_vdpa_dev_ops nfp_vdpa_ops = {\n+};\n+\n+static int\n+nfp_vdpa_pci_probe(struct rte_pci_device *pci_dev)\n+{\n+\tstruct nfp_vdpa_dev *device;\n+\tstruct nfp_vdpa_dev_node *node;\n+\n+\tif (rte_eal_process_type() != RTE_PROC_PRIMARY)\n+\t\treturn 0;\n+\n+\tnode = calloc(1, sizeof(*node));\n+\tif (node == NULL)\n+\t\treturn -ENOMEM;\n+\n+\tdevice = calloc(1, sizeof(*device));\n+\tif (device == NULL)\n+\t\tgoto free_node;\n+\n+\tdevice->pci_dev = pci_dev;\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);\n+\t\tgoto free_device;\n+\t}\n+\n+\tnode->device = device;\n+\tpthread_mutex_lock(&vdpa_list_lock);\n+\tTAILQ_INSERT_TAIL(&vdpa_dev_list, node, next);\n+\tpthread_mutex_unlock(&vdpa_list_lock);\n+\n+\treturn 0;\n+\n+free_device:\n+\tfree(device);\n+free_node:\n+\tfree(node);\n+\n+\treturn -1;\n+}\n+\n+static int\n+nfp_vdpa_pci_remove(struct rte_pci_device *pci_dev)\n+{\n+\tstruct nfp_vdpa_dev *device;\n+\tstruct nfp_vdpa_dev_node *node;\n+\n+\tif (rte_eal_process_type() != RTE_PROC_PRIMARY)\n+\t\treturn 0;\n+\n+\tnode = nfp_vdpa_find_node_by_pdev(pci_dev);\n+\tif (node == NULL) {\n+\t\tDRV_VDPA_LOG(ERR, \"Invalid device: %s\", pci_dev->name);\n+\t\treturn -ENODEV;\n+\t}\n+\n+\tdevice = node->device;\n+\n+\tpthread_mutex_lock(&vdpa_list_lock);\n+\tTAILQ_REMOVE(&vdpa_dev_list, node, next);\n+\tpthread_mutex_unlock(&vdpa_list_lock);\n+\n+\trte_vdpa_unregister_device(device->vdev);\n+\n+\tfree(device);\n+\tfree(node);\n+\n+\treturn 0;\n+}\n+\n+static const struct rte_pci_id pci_id_nfp_vdpa_map[] = {\n+\t{\n+\t\tRTE_PCI_DEVICE(PCI_VENDOR_ID_NETRONOME,\n+\t\t\t\tPCI_DEVICE_ID_NFP6000_VF_NIC)\n+\t},\n+\t{\n+\t\t.vendor_id = 0,\n+\t},\n+};\n+\n+static struct nfp_class_driver nfp_vdpa = {\n+\t.drv_class = NFP_CLASS_VDPA,\n+\t.name = RTE_STR(NFP_VDPA_DRIVER_NAME),\n+\t.id_table = pci_id_nfp_vdpa_map,\n+\t.drv_flags =  RTE_PCI_DRV_NEED_MAPPING | RTE_PCI_DRV_INTR_LSC,\n+\t.probe = nfp_vdpa_pci_probe,\n+\t.remove = nfp_vdpa_pci_remove,\n+};\n+\n+RTE_INIT(nfp_vdpa_init)\n+{\n+\tnfp_class_driver_register(&nfp_vdpa);\n+}\n+\n+RTE_PMD_REGISTER_PCI_TABLE(NFP_VDPA_DRIVER_NAME, pci_id_nfp_vdpa_map);\n+RTE_PMD_REGISTER_KMOD_DEP(NFP_VDPA_DRIVER_NAME, \"* vfio-pci\");\n",
    "prefixes": [
        "v3",
        "19/25"
    ]
}