get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 11759,
    "url": "https://patches.dpdk.org/api/patches/11759/?format=api",
    "web_url": "https://patches.dpdk.org/project/dpdk/patch/1458955640-22951-9-git-send-email-marcdevel@gmail.com/",
    "project": {
        "id": 1,
        "url": "https://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": "<1458955640-22951-9-git-send-email-marcdevel@gmail.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/1458955640-22951-9-git-send-email-marcdevel@gmail.com",
    "date": "2016-03-26T01:27:20",
    "name": "[dpdk-dev,v13,8/8] ethdev: add 100G link speed",
    "commit_ref": null,
    "pull_url": null,
    "state": "changes-requested",
    "archived": true,
    "hash": "940366606f1f33c2ebc1d216ece0fd34e3b6692a",
    "submitter": {
        "id": 314,
        "url": "https://patches.dpdk.org/api/people/314/?format=api",
        "name": "Marc Sune",
        "email": "marcdevel@gmail.com"
    },
    "delegate": null,
    "mbox": "https://patches.dpdk.org/project/dpdk/patch/1458955640-22951-9-git-send-email-marcdevel@gmail.com/mbox/",
    "series": [],
    "comments": "https://patches.dpdk.org/api/patches/11759/comments/",
    "check": "pending",
    "checks": "https://patches.dpdk.org/api/patches/11759/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 [IPv6:::1])\n\tby dpdk.org (Postfix) with ESMTP id E0FEB684E;\n\tSat, 26 Mar 2016 02:28:31 +0100 (CET)",
            "from mail-wm0-f66.google.com (mail-wm0-f66.google.com\n\t[74.125.82.66]) by dpdk.org (Postfix) with ESMTP id 84F695AA9\n\tfor <dev@dpdk.org>; Sat, 26 Mar 2016 02:28:11 +0100 (CET)",
            "by mail-wm0-f66.google.com with SMTP id 139so1258462wmn.2\n\tfor <dev@dpdk.org>; Fri, 25 Mar 2016 18:28:11 -0700 (PDT)",
            "from localhost.localdomain (28.red-88-23-79.staticip.rima-tde.net.\n\t[88.23.79.28]) by smtp.gmail.com with ESMTPSA id\n\thh8sm14070113wjc.42.2016.03.25.18.28.10\n\t(version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128);\n\tFri, 25 Mar 2016 18:28:10 -0700 (PDT)"
        ],
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113;\n\th=from:to:cc:subject:date:message-id:in-reply-to:references;\n\tbh=971jY9nUIe9BiDC6Ccz1fAYo/BvprBRoO2o692AxSow=;\n\tb=NclJdmmMECEWatt/XQ/8YXacM9erq8XkUZG/D9H2qCRZaD6HMYOwlknL2SBDvisfDl\n\tVEyW7dgT71Rv8OMsj0NYcM41OH9XozBktb7T6uUKDej5TYhBBqU6ou+gbYkO2feNjpwg\n\tuzFcoVn4nUwV69ad4/0gbQ9h04w2ce+k3VdomXP42+8M5qbdsHLEkWFaMaBAdSRHPg/L\n\tubcIb9DHw0QODk4YEY8oUUBSHSZdnRRRvgJAk/othoXcKyASVlExiT3PFnKKyChhSq4j\n\tIwDkZvsUrcdPVxG5YWhToS6BzzUb3ZK7A4qNIp92vqpgAxBayCscNrevHuCGeKvOp7af\n\tkeFw==",
        "X-Google-DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n\td=1e100.net; s=20130820;\n\th=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to\n\t:references;\n\tbh=971jY9nUIe9BiDC6Ccz1fAYo/BvprBRoO2o692AxSow=;\n\tb=VT/pBAjIzn8WnjlQuWq8vingBf6qlpVIt+NdzLtdZ5ps2S59n+dKErkiqfzXpwAv3N\n\tP/eN4FyUy4EwHdGRi2WhP8Y9X/BoZ3IQSa93M5bSRGk0vz1yDg4jA+Wcd0nJeIR1DCeB\n\tYskup7zGzpSouPcNzrqfy4jnMrxUk8P0olNhvgnVBuzQ++28E+Kk94ToVUt8zgB7f7vb\n\tm2HQ2ljzw3x7LEN+jW/iv0a62EPcc3R6iw3elLflhTsdPaHFTGGk4knE45S+vbW2emzZ\n\tvaqzTEx04De7jonbuPqowK2MinXdQpHaIS88vYgn4gol6bFpKtg9TTNx2cTSui7Rqq6Q\n\tZ6FQ==",
        "X-Gm-Message-State": "AD7BkJJSJkJyZp320cMfgKuUW5VEVCo632h7OfUaJFuwWImxPCfSJmDnlQppKPA7dFmAhQ==",
        "X-Received": "by 10.194.242.202 with SMTP id ws10mr17638210wjc.3.1458955691357;\n\tFri, 25 Mar 2016 18:28:11 -0700 (PDT)",
        "From": "Marc Sune <marcdevel@gmail.com>",
        "To": "Thomas Monjalon <thomas.monjalon@6wind.com>,\n\t\"Xu, Qian Q\" <qian.q.xu@intel.com>, \"Xing,\n\tBeilei\" <beilei.xing@intel.com>, \"dev@dpdk.org\" <dev@dpdk.org>,\n\t\"Ananyev, Konstantin\" <konstantin.ananyev@intel.com>,\n\t\"Lu, Wenzhuo\" <wenzhuo.lu@intel.com>,\n\t\"Richardson, Bruce\" <bruce.richardson@intel.com>,\n\t\"Glynn, Michael J\" <michael.j.glynn@intel.com>",
        "Cc": "Marc Sune <marcdevel@gmail.com>",
        "Date": "Sat, 26 Mar 2016 02:27:20 +0100",
        "Message-Id": "<1458955640-22951-9-git-send-email-marcdevel@gmail.com>",
        "X-Mailer": "git-send-email 2.1.4",
        "In-Reply-To": "<1458955640-22951-1-git-send-email-marcdevel@gmail.com>",
        "References": "<1458934950-23333-1-git-send-email-thomas.monjalon@6wind.com>\n\t<1458955640-22951-1-git-send-email-marcdevel@gmail.com>",
        "Subject": "[dpdk-dev] [PATCH v13 8/8] ethdev: add 100G link speed",
        "X-BeenThere": "dev@dpdk.org",
        "X-Mailman-Version": "2.1.15",
        "Precedence": "list",
        "List-Id": "patches and discussions about DPDK <dev.dpdk.org>",
        "List-Unsubscribe": "<http://dpdk.org/ml/options/dev>,\n\t<mailto:dev-request@dpdk.org?subject=unsubscribe>",
        "List-Archive": "<http://dpdk.org/ml/archives/dev/>",
        "List-Post": "<mailto:dev@dpdk.org>",
        "List-Help": "<mailto:dev-request@dpdk.org?subject=help>",
        "List-Subscribe": "<http://dpdk.org/ml/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: Thomas Monjalon <thomas.monjalon@6wind.com>\n\nThe link speed configuration is now done with bitmaps so 100G speed\nrequires only a new bit flag.\nThe actual link speed is a number so its size must be increased from\n16-bit to 32-bit.\n\nSigned-off-by: Marc Sune <marcdevel@gmail.com>\nSigned-off-by: Thomas Monjalon <thomas.monjalon@6wind.com>\nTested-by: Nelio Laranjeiro <nelio.laranjeiro@6wind.com>\nTested-by: Matej Vido <vido@cesnet.cz>\n---\n app/test-pmd/cmdline.c                      | 12 +++++++-----\n doc/guides/nics/szedata2.rst                |  6 ------\n doc/guides/rel_notes/release_16_04.rst      |  5 +++++\n doc/guides/testpmd_app_ug/testpmd_funcs.rst |  2 +-\n drivers/net/ena/ena_ethdev.c                |  3 ++-\n drivers/net/fm10k/fm10k_ethdev.c            |  2 +-\n drivers/net/mlx5/mlx5_ethdev.c              |  3 ++-\n drivers/net/nfp/nfp_net.c                   |  2 +-\n drivers/net/szedata2/rte_eth_szedata2.c     |  9 ++-------\n lib/librte_ether/rte_ethdev.c               |  2 ++\n lib/librte_ether/rte_ethdev.h               |  4 +++-\n 11 files changed, 26 insertions(+), 24 deletions(-)",
    "diff": "diff --git a/app/test-pmd/cmdline.c b/app/test-pmd/cmdline.c\nindex 741cac3..c5b9479 100644\n--- a/app/test-pmd/cmdline.c\n+++ b/app/test-pmd/cmdline.c\n@@ -549,7 +549,7 @@ static void cmd_help_long_parsed(void *parsed_result,\n \t\t\t\"    Detach physical or virtual dev by port_id\\n\\n\"\n \n \t\t\t\"port config (port_id|all)\"\n-\t\t\t\" speed (10|100|1000|10000|40000|auto)\"\n+\t\t\t\" speed (10|100|1000|10000|40000|100000|auto)\"\n \t\t\t\" duplex (half|full|auto)\\n\"\n \t\t\t\"    Set speed and duplex for all ports or port_id\\n\\n\"\n \n@@ -1022,6 +1022,8 @@ parse_and_check_speed_duplex(char *speedstr, char *duplexstr, uint32_t *speed)\n \t\t\t*speed = ETH_LINK_SPEED_10G;\n \t\t} else if (!strcmp(speedstr, \"40000\")) {\n \t\t\t*speed = ETH_LINK_SPEED_40G;\n+\t\t} else if (!strcmp(speedstr, \"100000\")) {\n+\t\t\t*speed = ETH_LINK_SPEED_100G;\n \t\t} else if (!strcmp(speedstr, \"auto\")) {\n \t\t\t*speed = ETH_LINK_SPEED_AUTONEG;\n \t\t} else {\n@@ -1069,7 +1071,7 @@ cmdline_parse_token_string_t cmd_config_speed_all_item1 =\n \tTOKEN_STRING_INITIALIZER(struct cmd_config_speed_all, item1, \"speed\");\n cmdline_parse_token_string_t cmd_config_speed_all_value1 =\n \tTOKEN_STRING_INITIALIZER(struct cmd_config_speed_all, value1,\n-\t\t\t\t\t\t\"10#100#1000#10000#40000#auto\");\n+\t\t\t\t\t\t\"10#100#1000#10000#40000#100000#auto\");\n cmdline_parse_token_string_t cmd_config_speed_all_item2 =\n \tTOKEN_STRING_INITIALIZER(struct cmd_config_speed_all, item2, \"duplex\");\n cmdline_parse_token_string_t cmd_config_speed_all_value2 =\n@@ -1079,7 +1081,7 @@ cmdline_parse_token_string_t cmd_config_speed_all_value2 =\n cmdline_parse_inst_t cmd_config_speed_all = {\n \t.f = cmd_config_speed_all_parsed,\n \t.data = NULL,\n-\t.help_str = \"port config all speed 10|100|1000|10000|40000|auto duplex \"\n+\t.help_str = \"port config all speed 10|100|1000|10000|40000|100000|auto duplex \"\n \t\t\t\t\t\t\t\"half|full|auto\",\n \t.tokens = {\n \t\t(void *)&cmd_config_speed_all_port,\n@@ -1143,7 +1145,7 @@ cmdline_parse_token_string_t cmd_config_speed_specific_item1 =\n \t\t\t\t\t\t\t\t\"speed\");\n cmdline_parse_token_string_t cmd_config_speed_specific_value1 =\n \tTOKEN_STRING_INITIALIZER(struct cmd_config_speed_specific, value1,\n-\t\t\t\t\t\t\"10#100#1000#10000#40000#auto\");\n+\t\t\t\t\t\t\"10#100#1000#10000#40000#100000#auto\");\n cmdline_parse_token_string_t cmd_config_speed_specific_item2 =\n \tTOKEN_STRING_INITIALIZER(struct cmd_config_speed_specific, item2,\n \t\t\t\t\t\t\t\t\"duplex\");\n@@ -1154,7 +1156,7 @@ cmdline_parse_token_string_t cmd_config_speed_specific_value2 =\n cmdline_parse_inst_t cmd_config_speed_specific = {\n \t.f = cmd_config_speed_specific_parsed,\n \t.data = NULL,\n-\t.help_str = \"port config X speed 10|100|1000|10000|40000|auto duplex \"\n+\t.help_str = \"port config X speed 10|100|1000|10000|40000|100000|auto duplex \"\n \t\t\t\t\t\t\t\"half|full|auto\",\n \t.tokens = {\n \t\t(void *)&cmd_config_speed_specific_port,\ndiff --git a/doc/guides/nics/szedata2.rst b/doc/guides/nics/szedata2.rst\nindex 77c15b3..741b400 100644\n--- a/doc/guides/nics/szedata2.rst\n+++ b/doc/guides/nics/szedata2.rst\n@@ -148,9 +148,3 @@ Example output:\n      TX threshold registers: pthresh=0 hthresh=0 wthresh=0\n      TX RS bit threshold=0 - TXQ flags=0x0\n    testpmd>\n-\n-.. note::\n-\n-   Link speed API currently supports speeds up to 40 Gbps.\n-   Therefore there is used 10G constant for 100 Gbps cards until the link speed\n-   API is not changed.\ndiff --git a/doc/guides/rel_notes/release_16_04.rst b/doc/guides/rel_notes/release_16_04.rst\nindex c891a55..a0fc02d 100644\n--- a/doc/guides/rel_notes/release_16_04.rst\n+++ b/doc/guides/rel_notes/release_16_04.rst\n@@ -320,6 +320,11 @@ EAL\n Drivers\n ~~~~~~~\n \n+* **ethdev: Fixed overflow for 100Gbps.**\n+\n+  100Gbps in Mbps (100000) was exceeding 16-bit max value of ``link_speed``\n+  in ``rte_eth_link``.\n+\n * **ethdev: Fixed byte order consistency between fdir flow and mask.**\n \n   Fixed issue in ethdev library that the structure for setting\ndiff --git a/doc/guides/testpmd_app_ug/testpmd_funcs.rst b/doc/guides/testpmd_app_ug/testpmd_funcs.rst\nindex 94fba6a..aed5e47 100644\n--- a/doc/guides/testpmd_app_ug/testpmd_funcs.rst\n+++ b/doc/guides/testpmd_app_ug/testpmd_funcs.rst\n@@ -1155,7 +1155,7 @@ port config - speed\n \n Set the speed and duplex mode for all ports or a specific port::\n \n-   testpmd> port config (port_id|all) speed (10|100|1000|10000|auto) \\\n+   testpmd> port config (port_id|all) speed (10|100|1000|10000|40000|100000|auto) \\\n             duplex (half|full|auto)\n \n port config - queues/descriptors\ndiff --git a/drivers/net/ena/ena_ethdev.c b/drivers/net/ena/ena_ethdev.c\nindex 4e403af..02af67a 100644\n--- a/drivers/net/ena/ena_ethdev.c\n+++ b/drivers/net/ena/ena_ethdev.c\n@@ -1177,7 +1177,8 @@ static void ena_infos_get(struct rte_eth_dev *dev,\n \t\t\tETH_LINK_SPEED_10G  |\n \t\t\tETH_LINK_SPEED_25G  |\n \t\t\tETH_LINK_SPEED_40G  |\n-\t\t\tETH_LINK_SPEED_50G;\n+\t\t\tETH_LINK_SPEED_50G  |\n+\t\t\tETH_LINK_SPEED_100G;\n \n \t/* Get supported features from HW */\n \trc = ena_com_get_dev_attr_feat(ena_dev, &feat);\ndiff --git a/drivers/net/fm10k/fm10k_ethdev.c b/drivers/net/fm10k/fm10k_ethdev.c\nindex 85ad0df..953d9c1 100644\n--- a/drivers/net/fm10k/fm10k_ethdev.c\n+++ b/drivers/net/fm10k/fm10k_ethdev.c\n@@ -1413,7 +1413,7 @@ fm10k_dev_infos_get(struct rte_eth_dev *dev,\n \n \tdev_info->speed_capa = ETH_LINK_SPEED_1G | ETH_LINK_SPEED_2_5G |\n \t\t\tETH_LINK_SPEED_10G | ETH_LINK_SPEED_25G |\n-\t\t\tETH_LINK_SPEED_40G;\n+\t\t\tETH_LINK_SPEED_40G | ETH_LINK_SPEED_100G;\n }\n \n #ifdef RTE_LIBRTE_FM10K_RX_OLFLAGS_ENABLE\ndiff --git a/drivers/net/mlx5/mlx5_ethdev.c b/drivers/net/mlx5/mlx5_ethdev.c\nindex beecc63..36b369e 100644\n--- a/drivers/net/mlx5/mlx5_ethdev.c\n+++ b/drivers/net/mlx5/mlx5_ethdev.c\n@@ -566,7 +566,8 @@ mlx5_dev_infos_get(struct rte_eth_dev *dev, struct rte_eth_dev_info *info)\n \t\t\tETH_LINK_SPEED_25G |\n \t\t\tETH_LINK_SPEED_40G |\n \t\t\tETH_LINK_SPEED_50G |\n-\t\t\tETH_LINK_SPEED_56G;\n+\t\t\tETH_LINK_SPEED_56G |\n+\t\t\tETH_LINK_SPEED_100G;\n \tpriv_unlock(priv);\n }\n \ndiff --git a/drivers/net/nfp/nfp_net.c b/drivers/net/nfp/nfp_net.c\nindex bdeb21f..4e909e0 100644\n--- a/drivers/net/nfp/nfp_net.c\n+++ b/drivers/net/nfp/nfp_net.c\n@@ -1062,7 +1062,7 @@ nfp_net_infos_get(struct rte_eth_dev *dev, struct rte_eth_dev_info *dev_info)\n \tdev_info->reta_size = NFP_NET_CFG_RSS_ITBL_SZ;\n \tdev_info->hash_key_size = NFP_NET_CFG_RSS_KEY_SZ;\n \n-\tdev_info->speed_capa = ETH_LINK_SPEED_50G;\n+\tdev_info->speed_capa = ETH_LINK_SPEED_50G | ETH_LINK_SPEED_100G;\n }\n \n static const uint32_t *\ndiff --git a/drivers/net/szedata2/rte_eth_szedata2.c b/drivers/net/szedata2/rte_eth_szedata2.c\nindex ee97a4e..78c43b0 100644\n--- a/drivers/net/szedata2/rte_eth_szedata2.c\n+++ b/drivers/net/szedata2/rte_eth_szedata2.c\n@@ -1036,6 +1036,7 @@ eth_dev_info(struct rte_eth_dev *dev,\n \tdev_info->max_rx_queues = internals->max_rx_queues;\n \tdev_info->max_tx_queues = internals->max_tx_queues;\n \tdev_info->min_rx_bufsize = 0;\n+\tdev_info->speed_capa = ETH_LINK_SPEED_100G;\n }\n \n static void\n@@ -1155,13 +1156,7 @@ eth_link_update(struct rte_eth_dev *dev,\n \t\tlink.link_speed = ETH_SPEED_NUM_40G;\n \t\tbreak;\n \tcase SZEDATA2_LINK_SPEED_100G:\n-\t\t/*\n-\t\t * TODO\n-\t\t * If link_speed value from rte_eth_link structure\n-\t\t * will be changed to support 100Gbps speed change\n-\t\t * this value to 100G.\n-\t\t */\n-\t\tlink.link_speed = ETH_SPEED_NUM_10G;\n+\t\tlink.link_speed = ETH_SPEED_NUM_100G;\n \t\tbreak;\n \tdefault:\n \t\tlink.link_speed = ETH_SPEED_NUM_10G;\ndiff --git a/lib/librte_ether/rte_ethdev.c b/lib/librte_ether/rte_ethdev.c\nindex 695b475..fd49b26 100644\n--- a/lib/librte_ether/rte_ethdev.c\n+++ b/lib/librte_ether/rte_ethdev.c\n@@ -892,6 +892,8 @@ rte_eth_speed_bitflag(uint32_t speed, int duplex)\n \t\treturn ETH_LINK_SPEED_50G;\n \tcase ETH_SPEED_NUM_56G:\n \t\treturn ETH_LINK_SPEED_56G;\n+\tcase ETH_SPEED_NUM_100G:\n+\t\treturn ETH_LINK_SPEED_100G;\n \tdefault:\n \t\treturn 0;\n \t}\ndiff --git a/lib/librte_ether/rte_ethdev.h b/lib/librte_ether/rte_ethdev.h\nindex 0b436d9..fb247a7 100644\n--- a/lib/librte_ether/rte_ethdev.h\n+++ b/lib/librte_ether/rte_ethdev.h\n@@ -259,6 +259,7 @@ struct rte_eth_stats {\n #define ETH_LINK_SPEED_40G      (1 << 11)  /**<  40 Gbps */\n #define ETH_LINK_SPEED_50G      (1 << 12)  /**<  50 Gbps */\n #define ETH_LINK_SPEED_56G      (1 << 13)  /**<  56 Gbps */\n+#define ETH_LINK_SPEED_100G     (1 << 14)  /**< 100 Gbps */\n \n /**\n  * Ethernet numeric link speeds in Mbps\n@@ -275,12 +276,13 @@ struct rte_eth_stats {\n #define ETH_SPEED_NUM_40G      40000 /**<  40 Gbps */\n #define ETH_SPEED_NUM_50G      50000 /**<  50 Gbps */\n #define ETH_SPEED_NUM_56G      56000 /**<  56 Gbps */\n+#define ETH_SPEED_NUM_100G    100000 /**< 100 Gbps */\n \n /**\n  * A structure used to retrieve link-level information of an Ethernet port.\n  */\n struct rte_eth_link {\n-\tuint16_t link_speed;        /**< ETH_SPEED_NUM_ */\n+\tuint32_t link_speed;        /**< ETH_SPEED_NUM_ */\n \tuint16_t link_duplex  : 1;  /**< ETH_LINK_[HALF/FULL]_DUPLEX */\n \tuint16_t link_autoneg : 1;  /**< ETH_LINK_SPEED_[AUTONEG/FIXED] */\n \tuint16_t link_status  : 1;  /**< ETH_LINK_[DOWN/UP] */\n",
    "prefixes": [
        "dpdk-dev",
        "v13",
        "8/8"
    ]
}