Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/43943/?format=api
http://patches.dpdk.org/api/patches/43943/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/patch/1535526966-32456-5-git-send-email-arybchenko@solarflare.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": "<1535526966-32456-5-git-send-email-arybchenko@solarflare.com>", "list_archive_url": "https://inbox.dpdk.org/dev/1535526966-32456-5-git-send-email-arybchenko@solarflare.com", "date": "2018-08-29T07:16:06", "name": "[4/4] net/failsafe: add Tx queue start and stop functions", "commit_ref": null, "pull_url": null, "state": "superseded", "archived": true, "hash": "289cb55959af0ec0138e550c4dfd9f800191b037", "submitter": { "id": 607, "url": "http://patches.dpdk.org/api/people/607/?format=api", "name": "Andrew Rybchenko", "email": "arybchenko@solarflare.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/1535526966-32456-5-git-send-email-arybchenko@solarflare.com/mbox/", "series": [ { "id": 1082, "url": "http://patches.dpdk.org/api/series/1082/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=1082", "date": "2018-08-29T07:16:03", "name": "net/failsafe: support deferred queue start", "version": 1, "mbox": "http://patches.dpdk.org/series/1082/mbox/" } ], "comments": "http://patches.dpdk.org/api/patches/43943/comments/", "check": "success", "checks": "http://patches.dpdk.org/api/patches/43943/checks/", "tags": {}, "related": [], "headers": { "Return-Path": "<dev-bounces@dpdk.org>", "X-Original-To": "patchwork@dpdk.org", "Delivered-To": "patchwork@dpdk.org", "Received": [ "from [92.243.14.124] (localhost [127.0.0.1])\n\tby dpdk.org (Postfix) with ESMTP id 9F3814F91;\n\tWed, 29 Aug 2018 09:17:00 +0200 (CEST)", "from dispatch1-us1.ppe-hosted.com (dispatch1-us1.ppe-hosted.com\n\t[67.231.154.164]) by dpdk.org (Postfix) with ESMTP id DCA8E4C74\n\tfor <dev@dpdk.org>; Wed, 29 Aug 2018 09:16:52 +0200 (CEST)", "from webmail.solarflare.com (webmail.solarflare.com\n\t[12.187.104.26])\n\t(using TLSv1.2 with cipher ECDHE-RSA-AES256-SHA384 (256/256 bits))\n\t(No client certificate requested)\n\tby mx1-us3.ppe-hosted.com (Proofpoint Essentials ESMTP Server) with\n\tESMTPS id DF0FA980067; Wed, 29 Aug 2018 07:16:51 +0000 (UTC)", "from ocex03.SolarFlarecom.com (10.20.40.36) by\n\tocex03.SolarFlarecom.com (10.20.40.36) with Microsoft SMTP Server\n\t(TLS) id 15.0.1395.4; Wed, 29 Aug 2018 00:16:49 -0700", "from opal.uk.solarflarecom.com (10.17.10.1) by\n\tocex03.SolarFlarecom.com (10.20.40.36) with Microsoft SMTP Server\n\t(TLS) id\n\t15.0.1395.4 via Frontend Transport; Wed, 29 Aug 2018 00:16:49 -0700", "from ukv-loginhost.uk.solarflarecom.com\n\t(ukv-loginhost.uk.solarflarecom.com [10.17.10.39])\n\tby opal.uk.solarflarecom.com (8.13.8/8.13.8) with ESMTP id\n\tw7T7GlHk013135; Wed, 29 Aug 2018 08:16:47 +0100", "from ukv-loginhost.uk.solarflarecom.com (localhost [127.0.0.1])\n\tby ukv-loginhost.uk.solarflarecom.com (Postfix) with ESMTP id\n\t9CBCE1626D1; Wed, 29 Aug 2018 08:16:47 +0100 (BST)" ], "X-Virus-Scanned": "Proofpoint Essentials engine", "From": "Andrew Rybchenko <arybchenko@solarflare.com>", "To": "Gaetan Rivet <gaetan.rivet@6wind.com>", "CC": "<dev@dpdk.org>, Ian Dolzhansky <Ian.Dolzhansky@oktetlabs.ru>", "Date": "Wed, 29 Aug 2018 08:16:06 +0100", "Message-ID": "<1535526966-32456-5-git-send-email-arybchenko@solarflare.com>", "X-Mailer": "git-send-email 1.8.3.1", "In-Reply-To": "<1535526966-32456-1-git-send-email-arybchenko@solarflare.com>", "References": "<1535526966-32456-1-git-send-email-arybchenko@solarflare.com>", "MIME-Version": "1.0", "Content-Type": "text/plain", "X-TM-AS-Product-Ver": "SMEX-12.5.0.1300-8.5.1010-24060.005", "X-TM-AS-Result": "No-1.648200-4.000000-10", "X-TMASE-MatchedRID": "YoejGZvC3lcfL4EtCqmd9B+WEMjoO9WWTJDl9FKHbrkYSjzp7efq+iH3\n\tfZSwSQ1slTrfppylHpBLArWPJqBt4kIjaJSsaV6quIwLnB3Aqp24vBuE2X0HlW0eIjMMK3PpC0W\n\tclmp83Ya19P7rPMjNlrEpXFJOdxjJESUQs9x1RCfzh2yKdnl7WB1BLI8ZvqYIBWVBTXPjgu1576\n\tmy5IxjunI7bYqYmsn6U3N+3UpXmSBD22D6nfxmiYdlc1JaOB1TfS0Ip2eEHnyTitjWv6+zCBe9C\n\tQaLe2PPjoczmuoPCq1l3lMxN5s7vPwULVcl7nD8Z3kT+lFQ/SCW++3e57Fe43c9ziMX/cIMMxNU\n\tb9o1KkXimPTo7p2eRBWgYV8vAfnST0Rpv/a+xeiF15h6/oibNbKsWJ44GuEGPNxau39/BitFwHZ\n\tmk+dWMm4j0wYb2y4WlExlQIQeRG0=", "X-TM-AS-User-Approved-Sender": "No", "X-TM-AS-User-Blocked-Sender": "No", "X-TMASE-Result": "10--1.648200-4.000000", "X-TMASE-Version": "SMEX-12.5.0.1300-8.5.1010-24060.005", "X-MDID": "1535527012-lwhTUdU3OqJR", "Subject": "[dpdk-dev] [PATCH 4/4] net/failsafe: add Tx queue start and stop\n\tfunctions", "X-BeenThere": "dev@dpdk.org", "X-Mailman-Version": "2.1.15", "Precedence": "list", "List-Id": "DPDK patches and discussions <dev.dpdk.org>", "List-Unsubscribe": "<https://mails.dpdk.org/options/dev>,\n\t<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\t<mailto:dev-request@dpdk.org?subject=subscribe>", "Errors-To": "dev-bounces@dpdk.org", "Sender": "\"dev\" <dev-bounces@dpdk.org>" }, "content": "From: Ian Dolzhansky <Ian.Dolzhansky@oktetlabs.ru>\n\nSupport Tx queue deferred start.\n\nSigned-off-by: Ian Dolzhansky <Ian.Dolzhansky@oktetlabs.ru>\nSigned-off-by: Andrew Rybchenko <arybchenko@solarflare.com>\n---\n doc/guides/nics/features/failsafe.ini | 2 +-\n doc/guides/rel_notes/release_18_11.rst | 4 +-\n drivers/net/failsafe/failsafe_ether.c | 44 +++++++++++++++\n drivers/net/failsafe/failsafe_ops.c | 77 ++++++++++++++++++++++++--\n 4 files changed, 120 insertions(+), 7 deletions(-)", "diff": "diff --git a/doc/guides/nics/features/failsafe.ini b/doc/guides/nics/features/failsafe.ini\nindex 712c0b7f7..74eae4a62 100644\n--- a/doc/guides/nics/features/failsafe.ini\n+++ b/doc/guides/nics/features/failsafe.ini\n@@ -7,7 +7,7 @@\n Link status = Y\n Link status event = Y\n Rx interrupt = Y\n-Queue start/stop = P\n+Queue start/stop = Y\n MTU update = Y\n Jumbo frame = Y\n Promiscuous mode = Y\ndiff --git a/doc/guides/rel_notes/release_18_11.rst b/doc/guides/rel_notes/release_18_11.rst\nindex 882ef8ac6..ad08a204f 100644\n--- a/doc/guides/rel_notes/release_18_11.rst\n+++ b/doc/guides/rel_notes/release_18_11.rst\n@@ -58,8 +58,8 @@ New Features\n \n Updated the failsafe driver including the following changes:\n \n- * Support for Rx queues start and stop.\n- * Support for Rx queues deferred start.\n+ * Support for Rx and Tx queues start and stop.\n+ * Support for Rx and Tx queues deferred start.\n \n * **Added ability to switch queue deferred start flag on testpmd app.**\n \ndiff --git a/drivers/net/failsafe/failsafe_ether.c b/drivers/net/failsafe/failsafe_ether.c\nindex 305deed63..191f95f14 100644\n--- a/drivers/net/failsafe/failsafe_ether.c\n+++ b/drivers/net/failsafe/failsafe_ether.c\n@@ -407,6 +407,47 @@ failsafe_eth_dev_rx_queues_sync(struct rte_eth_dev *dev)\n \treturn 0;\n }\n \n+static int\n+failsafe_eth_dev_tx_queues_sync(struct rte_eth_dev *dev)\n+{\n+\tstruct txq *txq;\n+\tint ret;\n+\tuint16_t i;\n+\n+\tfor (i = 0; i < dev->data->nb_tx_queues; i++) {\n+\t\ttxq = dev->data->tx_queues[i];\n+\n+\t\tif (txq->info.conf.tx_deferred_start &&\n+\t\t dev->data->tx_queue_state[i] ==\n+\t\t\t\t\t\tRTE_ETH_QUEUE_STATE_STARTED) {\n+\t\t\t/*\n+\t\t\t * The subdevice Tx queue does not launch on device\n+\t\t\t * start if deferred start flag is set. It needs to be\n+\t\t\t * started manually in case an appropriate failsafe Tx\n+\t\t\t * queue has been started earlier.\n+\t\t\t */\n+\t\t\tret = dev->dev_ops->tx_queue_start(dev, i);\n+\t\t\tif (ret) {\n+\t\t\t\tERROR(\"Could not synchronize Tx queue %d\", i);\n+\t\t\t\treturn ret;\n+\t\t\t}\n+\t\t} else if (dev->data->tx_queue_state[i] ==\n+\t\t\t\t\t\tRTE_ETH_QUEUE_STATE_STOPPED) {\n+\t\t\t/*\n+\t\t\t * The subdevice Tx queue needs to be stopped manually\n+\t\t\t * in case an appropriate failsafe Tx queue has been\n+\t\t\t * stopped earlier.\n+\t\t\t */\n+\t\t\tret = dev->dev_ops->tx_queue_stop(dev, i);\n+\t\t\tif (ret) {\n+\t\t\t\tERROR(\"Could not synchronize Tx queue %d\", i);\n+\t\t\t\treturn ret;\n+\t\t\t}\n+\t\t}\n+\t}\n+\treturn 0;\n+}\n+\n int\n failsafe_eth_dev_state_sync(struct rte_eth_dev *dev)\n {\n@@ -466,6 +507,9 @@ failsafe_eth_dev_state_sync(struct rte_eth_dev *dev)\n \tif (ret)\n \t\tgoto err_remove;\n \tret = failsafe_eth_dev_rx_queues_sync(dev);\n+\tif (ret)\n+\t\tgoto err_remove;\n+\tret = failsafe_eth_dev_tx_queues_sync(dev);\n \tif (ret)\n \t\tgoto err_remove;\n \treturn 0;\ndiff --git a/drivers/net/failsafe/failsafe_ops.c b/drivers/net/failsafe/failsafe_ops.c\nindex 412d522cf..4d30eb22d 100644\n--- a/drivers/net/failsafe/failsafe_ops.c\n+++ b/drivers/net/failsafe/failsafe_ops.c\n@@ -174,6 +174,7 @@ static void\n fs_set_queues_state_start(struct rte_eth_dev *dev)\n {\n \tstruct rxq *rxq;\n+\tstruct txq *txq;\n \tuint16_t i;\n \n \tfor (i = 0; i < dev->data->nb_rx_queues; i++) {\n@@ -182,6 +183,12 @@ fs_set_queues_state_start(struct rte_eth_dev *dev)\n \t\t\tdev->data->rx_queue_state[i] =\n \t\t\t\t\t\tRTE_ETH_QUEUE_STATE_STARTED;\n \t}\n+\tfor (i = 0; i < dev->data->nb_tx_queues; i++) {\n+\t\ttxq = dev->data->tx_queues[i];\n+\t\tif (!txq->info.conf.tx_deferred_start)\n+\t\t\tdev->data->tx_queue_state[i] =\n+\t\t\t\t\t\tRTE_ETH_QUEUE_STATE_STARTED;\n+\t}\n }\n \n static int\n@@ -234,6 +241,8 @@ fs_set_queues_state_stop(struct rte_eth_dev *dev)\n \n \tfor (i = 0; i < dev->data->nb_rx_queues; i++)\n \t\tdev->data->rx_queue_state[i] = RTE_ETH_QUEUE_STATE_STOPPED;\n+\tfor (i = 0; i < dev->data->nb_tx_queues; i++)\n+\t\tdev->data->tx_queue_state[i] = RTE_ETH_QUEUE_STATE_STOPPED;\n }\n \n static void\n@@ -586,12 +595,17 @@ fs_tx_queue_setup(struct rte_eth_dev *dev,\n \tuint8_t i;\n \tint ret;\n \n+\tfs_lock(dev, 0);\n \tif (tx_conf->tx_deferred_start) {\n-\t\tERROR(\"Tx queue deferred start is not supported\");\n-\t\treturn -EINVAL;\n+\t\tFOREACH_SUBDEV_STATE(sdev, i, dev, DEV_PROBED) {\n+\t\t\tif (SUBOPS(sdev, tx_queue_start) == NULL) {\n+\t\t\t\tERROR(\"Tx queue deferred start is not \"\n+\t\t\t\t\t\"supported for subdevice %d\", i);\n+\t\t\t\tfs_unlock(dev, 0);\n+\t\t\t\treturn -EINVAL;\n+\t\t\t}\n+\t\t}\n \t}\n-\n-\tfs_lock(dev, 0);\n \ttxq = dev->data->tx_queues[tx_queue_id];\n \tif (txq != NULL) {\n \t\tfs_tx_queue_release(txq);\n@@ -631,6 +645,59 @@ fs_tx_queue_setup(struct rte_eth_dev *dev,\n \treturn ret;\n }\n \n+static int\n+fs_tx_queue_stop(struct rte_eth_dev *dev, uint16_t tx_queue_id)\n+{\n+\tstruct sub_device *sdev;\n+\tuint8_t i;\n+\tint ret;\n+\tint err = 0;\n+\tbool failure = true;\n+\n+\tfs_lock(dev, 0);\n+\tFOREACH_SUBDEV_STATE(sdev, i, dev, DEV_ACTIVE) {\n+\t\tuint16_t port_id = ETH(sdev)->data->port_id;\n+\n+\t\tret = rte_eth_dev_tx_queue_stop(port_id, tx_queue_id);\n+\t\tret = fs_err(sdev, ret);\n+\t\tif (ret) {\n+\t\t\tERROR(\"Tx queue stop failed for subdevice %d\", i);\n+\t\t\terr = ret;\n+\t\t} else {\n+\t\t\tfailure = false;\n+\t\t}\n+\t}\n+\tdev->data->tx_queue_state[tx_queue_id] = RTE_ETH_QUEUE_STATE_STOPPED;\n+\tfs_unlock(dev, 0);\n+\t/* Return 0 in case of at least one successful queue stop */\n+\treturn (failure) ? err : 0;\n+}\n+\n+static int\n+fs_tx_queue_start(struct rte_eth_dev *dev, uint16_t tx_queue_id)\n+{\n+\tstruct sub_device *sdev;\n+\tuint8_t i;\n+\tint ret;\n+\n+\tfs_lock(dev, 0);\n+\tFOREACH_SUBDEV_STATE(sdev, i, dev, DEV_ACTIVE) {\n+\t\tuint16_t port_id = ETH(sdev)->data->port_id;\n+\n+\t\tret = rte_eth_dev_tx_queue_start(port_id, tx_queue_id);\n+\t\tret = fs_err(sdev, ret);\n+\t\tif (ret) {\n+\t\t\tERROR(\"Tx queue start failed for subdevice %d\", i);\n+\t\t\tfs_tx_queue_stop(dev, tx_queue_id);\n+\t\t\tfs_unlock(dev, 0);\n+\t\t\treturn ret;\n+\t\t}\n+\t}\n+\tdev->data->tx_queue_state[tx_queue_id] = RTE_ETH_QUEUE_STATE_STARTED;\n+\tfs_unlock(dev, 0);\n+\treturn 0;\n+}\n+\n static void\n fs_dev_free_queues(struct rte_eth_dev *dev)\n {\n@@ -1122,7 +1189,9 @@ const struct eth_dev_ops failsafe_ops = {\n \t.rx_queue_setup = fs_rx_queue_setup,\n \t.tx_queue_setup = fs_tx_queue_setup,\n \t.rx_queue_start = fs_rx_queue_start,\n+\t.tx_queue_start = fs_tx_queue_start,\n \t.rx_queue_stop = fs_rx_queue_stop,\n+\t.tx_queue_stop = fs_tx_queue_stop,\n \t.rx_queue_release = fs_rx_queue_release,\n \t.tx_queue_release = fs_tx_queue_release,\n \t.rx_queue_intr_enable = fs_rx_intr_enable,\n", "prefixes": [ "4/4" ] }{ "id": 43943, "url": "