get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 116089,
    "url": "http://patches.dpdk.org/api/patches/116089/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/1662626702-17254-7-git-send-email-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": "<1662626702-17254-7-git-send-email-chaoyong.he@corigine.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/1662626702-17254-7-git-send-email-chaoyong.he@corigine.com",
    "date": "2022-09-08T08:44:56",
    "name": "[v8,06/12] net/nfp: add flower PF related routines",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "8ed9907f70f0e08307f7d34d753218d5030bef61",
    "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/1662626702-17254-7-git-send-email-chaoyong.he@corigine.com/mbox/",
    "series": [
        {
            "id": 24607,
            "url": "http://patches.dpdk.org/api/series/24607/?format=api",
            "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=24607",
            "date": "2022-09-08T08:44:50",
            "name": "preparation for the rte_flow offload of nfp PMD",
            "version": 8,
            "mbox": "http://patches.dpdk.org/series/24607/mbox/"
        }
    ],
    "comments": "http://patches.dpdk.org/api/patches/116089/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/116089/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 18F11A0548;\n\tThu,  8 Sep 2022 10:46:12 +0200 (CEST)",
            "from [217.70.189.124] (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id 5A73E42B79;\n\tThu,  8 Sep 2022 10:45:41 +0200 (CEST)",
            "from NAM11-DM6-obe.outbound.protection.outlook.com\n (mail-dm6nam11on2138.outbound.protection.outlook.com [40.107.223.138])\n by mails.dpdk.org (Postfix) with ESMTP id EE8A142B75\n for <dev@dpdk.org>; Thu,  8 Sep 2022 10:45:39 +0200 (CEST)",
            "from SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5)\n by MW4PR13MB5940.namprd13.prod.outlook.com (2603:10b6:303:1b8::10)\n with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5588.3; Thu, 8 Sep\n 2022 08:45:38 +0000",
            "from SJ0PR13MB5545.namprd13.prod.outlook.com\n ([fe80::402d:6abc:83a8:2431]) by SJ0PR13MB5545.namprd13.prod.outlook.com\n ([fe80::402d:6abc:83a8:2431%6]) with mapi id 15.20.5612.009; Thu, 8 Sep 2022\n 08:45:38 +0000"
        ],
        "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;\n b=Id+5uBmR2cZ1R1DxDLjD58OOcBZZ5Hxjz9YTzw7cM/sSRTH0GIKkbaa2Eef0x86lJccRxg+33nLTt4xBEpqLGifUBw3zg6JEwUsvxToP567OexFmcMWGB92BcDSq6xUIcgV5rtly0Oj+B+LYnr8TrvysWmGooHeaaVx8cdMIT4L3ENoXhX7lYiSM8zSKxOXvGdgcye3CW6P7AxfdMAlN1xE6lK5cXuC/QKQpJ5iNVzlSOLLSNxPOemMbmkmO12wfbId74Kw6kywmCqbcCtt8jqB7xo2wJuDl60czO3mNr9CNiZh/qrxWuKtGT+/uo/ih57c79Al3E9DBR/MqhfXGFg==",
        "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=ia8i+f2eKqE3RGc44L6jT68QzZQ1Yr1/rh885dhrU1A=;\n b=e4UaSfBH6Y5MWF1UM9xOnvWa0tl5fVWv+k1zTlGYe4FdVBqoDAR25YnUJay/W25OTNCyxVgl62dWmDbb3jQ9np78I6P+Ztc76aki4kRRh7Pn4c/cHuo1eKKu82N1Ga/osvdgeHfujO5L1yvHORjvkOEWmznPS+e12/ib6LYIJllwltYCfVV6W4yL4mF4vmYJYKAY8qBBTFyXWj8Tw4gZQGdZLwYkbEiTEH49DPnqLLxRdlpWs8VAqZyW0kO/doOJHqvrsXSn/sm+vbssGXa59czyTs5rA6q0WYneRZOwwu4F3VpENwgc6axY00b6X5fJ7K0LA+kBOSeSdTf8bKIbFQ==",
        "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=ia8i+f2eKqE3RGc44L6jT68QzZQ1Yr1/rh885dhrU1A=;\n b=wD7UEvOKnQDd9iNO51mLC2CJQCKvaywHt30hQ+21TLsWV+rzFxQvkZIHVjXyBfG1xK4zN/IWzFoHMuiLwUsVuaNj6VOXGNddL6M8hXCZOnENwD8vnCV9vs/RvLGKsrrVo1dKV810RJ3N1idwnxtSFU/PxBMxp2Re3QP8ZEt3ZEw=",
        "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, niklas.soderlund@corigine.com,\n Chaoyong He <chaoyong.he@corigine.com>",
        "Subject": "[PATCH v8 06/12] net/nfp: add flower PF related routines",
        "Date": "Thu,  8 Sep 2022 16:44:56 +0800",
        "Message-Id": "<1662626702-17254-7-git-send-email-chaoyong.he@corigine.com>",
        "X-Mailer": "git-send-email 1.8.3.1",
        "In-Reply-To": "<1662626702-17254-1-git-send-email-chaoyong.he@corigine.com>",
        "References": "<1662626702-17254-1-git-send-email-chaoyong.he@corigine.com>",
        "Content-Type": "text/plain; charset=UTF-8",
        "Content-Transfer-Encoding": "8bit",
        "X-ClientProxiedBy": "SI2PR01CA0023.apcprd01.prod.exchangelabs.com\n (2603:1096:4:192::17) 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_|MW4PR13MB5940:EE_",
        "X-MS-Office365-Filtering-Correlation-Id": "9ff966bc-e2db-4914-e1de-08da917680d1",
        "X-MS-Exchange-SenderADCheck": "1",
        "X-MS-Exchange-AntiSpam-Relay": "0",
        "X-Microsoft-Antispam": "BCL:0;",
        "X-Microsoft-Antispam-Message-Info": "\n fHL3evxpK+C/DoLPcLt1VDjhjRozW+9ukRZ4mMmLhdHcjfa2Z/CdIrcN75snooMh/eoHJYIPmzRmtyFBWO5aMeW76cH2n1ltJO6IP3HXci3aAP7sDWb72TejFy1orhInczCHehmkIUzJrOhKHiW67SBrCaz/8JLhsEDNXmUWifgMPKB8iB0OjNzaOJJ0exs+VyZW9n2VoJenD+UCJFlTXrFfR/ZG9SIH6pd8VlJwEKjfZ4dK/R5rvf5tkzwT6UnfoHzCxA2o4JPq4B6FI9PYZLU0RBo8wUrSBYAiXLVDSYUxEAuqOsecMD58mns47eVZEMtP4WC+VehSL/hBNl/AZPhZSKRM1oOLWy6Oz3wtUS4f23SAoZy8N2A9HkfmPysjXDiEUxMAOYXmRwPuVhraedawDESLu+dkgiq24XzbhIMmYsOIsvbcLd+edsOeQHKubAHu93KQSX3ZZ6kfCCoqJSjRJdbgZ68tYXpwaPhi5l+D3wbmIBibAD4YawnW0tsf3N2qzwUDQv8PQ/k1iP3cUksxcE/BiNCzy/zUe9F/rLuqVrNpKxMdtBDIAQSiESQyybaZcrlHU7P+CBg1uX1AsRrCNfawoJrN8/uWcWMDrijs35lMn7mUku6YR49bpyQoNRvgwAmRln4uTvv3keh42yEbJtgvGzjNP0rO1JlpxaJenuJe4MInxRNXjnPKbhbHVquQoz7m/E77nFcTwOyEqgBdE8r5EW39P28Zew4tkWEnb0R3he7rdqdWKMhD0HzG7w92QbLkP+rpw1/Z30ZMZw==",
        "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:(13230016)(4636009)(396003)(366004)(39840400004)(346002)(376002)(136003)(107886003)(44832011)(2616005)(41300700001)(6916009)(38350700002)(83380400001)(66574015)(26005)(6512007)(186003)(36756003)(38100700002)(4326008)(2906002)(6506007)(316002)(66946007)(478600001)(86362001)(5660300002)(66476007)(52116002)(6486002)(6666004)(8936002)(8676002)(66556008);\n DIR:OUT; SFP:1102;",
        "X-MS-Exchange-AntiSpam-MessageData-ChunkCount": "1",
        "X-MS-Exchange-AntiSpam-MessageData-0": "=?utf-8?q?K6hSipEy+rQTdEF5+x1yQQ9VHdLM?=\n\t=?utf-8?q?AG67j9o8nlZ5cUsC6vjGexQx3RlhlfWmAnQXbyhBLCzuWdDmiFkiT3Ug3rqCiLTZ/?=\n\t=?utf-8?q?1LQgBR8JaAppXD1wUGfSp70dQV3xGeTwc1jZWmgN/DNhejh/STHry7ersUh/4nydt?=\n\t=?utf-8?q?d81DmY94ikYqOaZcRtbi1SueKd2uFR7NEXq0yxxVKAJZcSEOT9r+Hd7zQHVAqiatb?=\n\t=?utf-8?q?qFCziNFrimiOAHg9fUB0agXFIE0dMtSUMbIlJd43P5P6CFC+Pn64MKyZtzUZxSiVv?=\n\t=?utf-8?q?Y5jXDD3z9/dXbF8l0+Rsom8gFyJcYdhXUgMtCZGFYHFR/v6wIX72JsPqx3Zh0xtar?=\n\t=?utf-8?q?ZgYZy6x0iM6BZNI8BhYHxkWMgfk48PhCKqGEwVez/Jc/sDpbf/bf4bv7pXWfkxm7A?=\n\t=?utf-8?q?ZOGIZexTKbXupLLiuacc1j9EUCsiRWwOI34qS4JArTgX/D1vMTqRKH0zrgN/9/8gd?=\n\t=?utf-8?q?bD9JCXjbJB8nVkWynB4TcWK9QyizG7jKZk/XUGaXTHXl9o4hxipkRMWH0vJJ1viKn?=\n\t=?utf-8?q?IX9YRtigB0nd0maLPoZ/EhpkfmQ5x8dq+zsxgv294MU6cvgZIE3bJkCqWpsq+RRs2?=\n\t=?utf-8?q?HXbE7iqtPrfExUfxJpsgmV+FUDe7Cc8kA724gn72YSMK1+WhhVWXfNl7VNOOt0Hmt?=\n\t=?utf-8?q?J8esOnSUuMuKlGeFpJ37Mk0XW+PNoNrNInkHVDCYkHKI8u3VWDaHKHRWixjINiBBx?=\n\t=?utf-8?q?89Svadl+GzRahzB7+xJ/oWEzk0071ORHPcn6xmiJKp49Al1aO09vJf3SQZakjhQmo?=\n\t=?utf-8?q?Vcf8FwNU3Ho1zRXauB1iSRdQ8x9IEdE0031mT0wq79sOgi6xptFWPsDPYyjaW7lbO?=\n\t=?utf-8?q?3W6PbCmClS971iV5Dn/6V21LvyQ9mKALjUwhYkoiNDrGb0VD7QCKVEJyerxYcuPK7?=\n\t=?utf-8?q?ZgOmMQL3/E8NP5lTcxnr9UxucWRMBFZDUkUmdpkarPA31cdOYUlou/BJDCDXKEpGz?=\n\t=?utf-8?q?ryIF8dKKjdQ7F1L9amFuI+rAZbBlRqG+/PsHlOQwlTykV58o0HMhuAMbFJQt7cIBS?=\n\t=?utf-8?q?4TBlYZ9DDGmvQHG66LAJFuisVdkCXMyF8ZFbwaYpVgUNVS0jyfGoxd5FlxiwULZDE?=\n\t=?utf-8?q?QwCbfSayPYoabOOd2rfiI+Qg96F6FDmdyRePsuHe1jgb3ZcH6bRId/3tV4k9Auy4w?=\n\t=?utf-8?q?opfAHnwbCtqSJBgVL9U5v+vMr8KPvT7CkEz2dw4K63uBRbD3fcG+hcBmLgbqK/UND?=\n\t=?utf-8?q?elo6MphAmkcUrjnwoSth77hqF8eZi2otKzgpPRw1JJXAMcengqja6K5CfmRHZOP8h?=\n\t=?utf-8?q?IIF0pvQPP8IQxwiFIOd82u3EBE2QeEXzzILA9DiO3ASQHOmGBblZNopYcM17jjsaT?=\n\t=?utf-8?q?EauH1kQB5oT7U2MyKiekTmk+t8J8R7CR6fF8+QkC8OrGRZ7jwRBvt9XKLEKvNmIaj?=\n\t=?utf-8?q?LkO0OBAb4KPvsl2A2IMooIN2Hb0/PgVs8xxtKvfe+gebix43pDn+8lbikya/Q9NjJ?=\n\t=?utf-8?q?PAb/8Avm73mi39/C5winRM96WWhbMe1m3zW2sg0/r2CGnk/O2ymskSE4JelljaEIv?=\n\t=?utf-8?q?G/d0reCndND4Z95xTvwFj1U8YBS7tHIlWA=3D=3D?=",
        "X-OriginatorOrg": "corigine.com",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "MW4PR13MB5940",
        "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": "Adds the start/stop/close routine of the flower PF vNIC.\nAnd we reuse the configure/link_update routine.\n\nSigned-off-by: Chaoyong He <chaoyong.he@corigine.com>\nReviewed-by: Niklas Söderlund <niklas.soderlund@corigine.com>\n---\n drivers/net/nfp/flower/nfp_flower.c | 185 ++++++++++++++++++++++++++++++++++++\n 1 file changed, 185 insertions(+)",
    "diff": "diff --git a/drivers/net/nfp/flower/nfp_flower.c b/drivers/net/nfp/flower/nfp_flower.c\nindex ad0dff1..e0c0ab3 100644\n--- a/drivers/net/nfp/flower/nfp_flower.c\n+++ b/drivers/net/nfp/flower/nfp_flower.c\n@@ -6,6 +6,7 @@\n #include <rte_common.h>\n #include <rte_service_component.h>\n #include <rte_malloc.h>\n+#include <rte_alarm.h>\n #include <ethdev_pci.h>\n #include <ethdev_driver.h>\n \n@@ -40,8 +41,168 @@\n \t.tx_free_thresh = DEFAULT_TX_FREE_THRESH,\n };\n \n+static int\n+nfp_flower_pf_start(struct rte_eth_dev *dev)\n+{\n+\tint ret;\n+\tuint32_t new_ctrl;\n+\tuint32_t update = 0;\n+\tstruct nfp_net_hw *hw;\n+\n+\thw = NFP_NET_DEV_PRIVATE_TO_HW(dev->data->dev_private);\n+\n+\t/* Disabling queues just in case... */\n+\tnfp_net_disable_queues(dev);\n+\n+\t/* Enabling the required queues in the device */\n+\tnfp_net_enable_queues(dev);\n+\n+\tnew_ctrl = nfp_check_offloads(dev);\n+\n+\t/* Writing configuration parameters in the device */\n+\tnfp_net_params_setup(hw);\n+\n+\tnfp_net_rss_config_default(dev);\n+\tupdate |= NFP_NET_CFG_UPDATE_RSS;\n+\n+\tif (hw->cap & NFP_NET_CFG_CTRL_RSS2)\n+\t\tnew_ctrl |= NFP_NET_CFG_CTRL_RSS2;\n+\telse\n+\t\tnew_ctrl |= NFP_NET_CFG_CTRL_RSS;\n+\n+\t/* Enable device */\n+\tnew_ctrl |= NFP_NET_CFG_CTRL_ENABLE;\n+\n+\tupdate |= NFP_NET_CFG_UPDATE_GEN | NFP_NET_CFG_UPDATE_RING;\n+\n+\tif (hw->cap & NFP_NET_CFG_CTRL_RINGCFG)\n+\t\tnew_ctrl |= NFP_NET_CFG_CTRL_RINGCFG;\n+\n+\tnn_cfg_writel(hw, NFP_NET_CFG_CTRL, new_ctrl);\n+\n+\t/* If an error when reconfig we avoid to change hw state */\n+\tret = nfp_net_reconfig(hw, new_ctrl, update);\n+\tif (ret != 0) {\n+\t\tPMD_INIT_LOG(ERR, \"Failed to reconfig PF vnic\");\n+\t\treturn -EIO;\n+\t}\n+\n+\thw->ctrl = new_ctrl;\n+\n+\t/* Setup the freelist ring */\n+\tret = nfp_net_rx_freelist_setup(dev);\n+\tif (ret != 0) {\n+\t\tPMD_INIT_LOG(ERR, \"Error with flower PF vNIC freelist setup\");\n+\t\treturn -EIO;\n+\t}\n+\n+\treturn 0;\n+}\n+\n+/* Stop device: disable rx and tx functions to allow for reconfiguring. */\n+static int\n+nfp_flower_pf_stop(struct rte_eth_dev *dev)\n+{\n+\tuint16_t i;\n+\tstruct nfp_net_hw *hw;\n+\tstruct nfp_net_txq *this_tx_q;\n+\tstruct nfp_net_rxq *this_rx_q;\n+\n+\thw = NFP_NET_DEV_PRIVATE_TO_HW(dev->data->dev_private);\n+\n+\tnfp_net_disable_queues(dev);\n+\n+\t/* Clear queues */\n+\tfor (i = 0; i < dev->data->nb_tx_queues; i++) {\n+\t\tthis_tx_q = (struct nfp_net_txq *)dev->data->tx_queues[i];\n+\t\tnfp_net_reset_tx_queue(this_tx_q);\n+\t}\n+\n+\tfor (i = 0; i < dev->data->nb_rx_queues; i++) {\n+\t\tthis_rx_q = (struct nfp_net_rxq *)dev->data->rx_queues[i];\n+\t\tnfp_net_reset_rx_queue(this_rx_q);\n+\t}\n+\n+\tif (rte_eal_process_type() == RTE_PROC_PRIMARY)\n+\t\t/* Configure the physical port down */\n+\t\tnfp_eth_set_configured(hw->cpp, hw->nfp_idx, 0);\n+\telse\n+\t\tnfp_eth_set_configured(dev->process_private, hw->nfp_idx, 0);\n+\n+\treturn 0;\n+}\n+\n+/* Reset and stop device. The device can not be restarted. */\n+static int\n+nfp_flower_pf_close(struct rte_eth_dev *dev)\n+{\n+\tuint16_t i;\n+\tstruct nfp_net_hw *hw;\n+\tstruct nfp_pf_dev *pf_dev;\n+\tstruct nfp_net_txq *this_tx_q;\n+\tstruct nfp_net_rxq *this_rx_q;\n+\tstruct rte_pci_device *pci_dev;\n+\tstruct nfp_app_fw_flower *app_fw_flower;\n+\n+\tif (rte_eal_process_type() != RTE_PROC_PRIMARY)\n+\t\treturn 0;\n+\n+\tpf_dev = NFP_NET_DEV_PRIVATE_TO_PF(dev->data->dev_private);\n+\thw = NFP_NET_DEV_PRIVATE_TO_HW(dev->data->dev_private);\n+\tpci_dev = RTE_ETH_DEV_TO_PCI(dev);\n+\tapp_fw_flower = NFP_PRIV_TO_APP_FW_FLOWER(pf_dev->app_fw_priv);\n+\n+\t/*\n+\t * We assume that the DPDK application is stopping all the\n+\t * threads/queues before calling the device close function.\n+\t */\n+\tnfp_net_disable_queues(dev);\n+\n+\t/* Clear queues */\n+\tfor (i = 0; i < dev->data->nb_tx_queues; i++) {\n+\t\tthis_tx_q = (struct nfp_net_txq *)dev->data->tx_queues[i];\n+\t\tnfp_net_reset_tx_queue(this_tx_q);\n+\t}\n+\n+\tfor (i = 0; i < dev->data->nb_rx_queues; i++) {\n+\t\tthis_rx_q = (struct nfp_net_rxq *)dev->data->rx_queues[i];\n+\t\tnfp_net_reset_rx_queue(this_rx_q);\n+\t}\n+\n+\t/* Cancel possible impending LSC work here before releasing the port*/\n+\trte_eal_alarm_cancel(nfp_net_dev_interrupt_delayed_handler, (void *)dev);\n+\n+\tnn_cfg_writeb(hw, NFP_NET_CFG_LSC, 0xff);\n+\n+\trte_eth_dev_release_port(dev);\n+\n+\t/* Now it is safe to free all PF resources */\n+\tPMD_DRV_LOG(INFO, \"Freeing PF resources\");\n+\tnfp_cpp_area_free(pf_dev->ctrl_area);\n+\tnfp_cpp_area_free(pf_dev->hwqueues_area);\n+\tfree(pf_dev->hwinfo);\n+\tfree(pf_dev->sym_tbl);\n+\tnfp_cpp_free(pf_dev->cpp);\n+\trte_free(app_fw_flower);\n+\trte_free(pf_dev);\n+\n+\trte_intr_disable(pci_dev->intr_handle);\n+\n+\t/* unregister callback func from eal lib */\n+\trte_intr_callback_unregister(pci_dev->intr_handle,\n+\t\t\tnfp_net_dev_interrupt_handler, (void *)dev);\n+\n+\treturn 0;\n+}\n+\n static const struct eth_dev_ops nfp_flower_pf_vnic_ops = {\n \t.dev_infos_get          = nfp_net_infos_get,\n+\t.link_update            = nfp_net_link_update,\n+\t.dev_configure          = nfp_net_configure,\n+\n+\t.dev_start              = nfp_flower_pf_start,\n+\t.dev_stop               = nfp_flower_pf_stop,\n+\t.dev_close              = nfp_flower_pf_close,\n };\n \n static void\n@@ -310,6 +471,24 @@\n }\n \n static int\n+nfp_flower_start_pf_vnic(struct nfp_net_hw *hw)\n+{\n+\tint ret;\n+\tuint16_t port_id;\n+\n+\tport_id = hw->eth_dev->data->port_id;\n+\n+\t/* Start the device */\n+\tret = rte_eth_dev_start(port_id);\n+\tif (ret != 0) {\n+\t\tPMD_INIT_LOG(ERR, \"Could not start PF device %d\", port_id);\n+\t\treturn ret;\n+\t}\n+\n+\treturn 0;\n+}\n+\n+static int\n nfp_flower_pf_vnic_service(void *arg)\n {\n \tint ret;\n@@ -321,6 +500,12 @@\n \t\tgoto pf_vnic_cleanup;\n \t}\n \n+\tret = nfp_flower_start_pf_vnic(app_fw_flower->pf_hw);\n+\tif (ret != 0) {\n+\t\tPMD_DRV_LOG(ERR, \"Could not start flower PF vNIC\");\n+\t\tgoto pf_vnic_cleanup;\n+\t}\n+\n \treturn 0;\n \n pf_vnic_cleanup:\n",
    "prefixes": [
        "v8",
        "06/12"
    ]
}