Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/132328/?format=api
http://patches.dpdk.org/api/patches/132328/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/patch/20231005024012.1279810-9-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": "<20231005024012.1279810-9-chaoyong.he@corigine.com>", "list_archive_url": "https://inbox.dpdk.org/dev/20231005024012.1279810-9-chaoyong.he@corigine.com", "date": "2023-10-05T02:40:12", "name": "[8/8] net/bonding: add commands for bonding port notification", "commit_ref": null, "pull_url": null, "state": "superseded", "archived": true, "hash": "58b5fc1c67fd9d99fab7441c9ff42219e9fd5a3c", "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/20231005024012.1279810-9-chaoyong.he@corigine.com/mbox/", "series": [ { "id": 29740, "url": "http://patches.dpdk.org/api/series/29740/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=29740", "date": "2023-10-05T02:40:04", "name": "Enhance the bond framework to support offload", "version": 1, "mbox": "http://patches.dpdk.org/series/29740/mbox/" } ], "comments": "http://patches.dpdk.org/api/patches/132328/comments/", "check": "fail", "checks": "http://patches.dpdk.org/api/patches/132328/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 289BE426BB;\n\tThu, 5 Oct 2023 04:41:34 +0200 (CEST)", "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id CED1040A67;\n\tThu, 5 Oct 2023 04:40:53 +0200 (CEST)", "from NAM11-BN8-obe.outbound.protection.outlook.com\n (mail-bn8nam11on2100.outbound.protection.outlook.com [40.107.236.100])\n by mails.dpdk.org (Postfix) with ESMTP id 30EDD4067C\n for <dev@dpdk.org>; Thu, 5 Oct 2023 04:40:52 +0200 (CEST)", "from SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5)\n by PH0PR13MB4780.namprd13.prod.outlook.com (2603:10b6:510:79::7) with\n Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6838.28; Thu, 5 Oct\n 2023 02:40:50 +0000", "from SJ0PR13MB5545.namprd13.prod.outlook.com\n ([fe80::28c0:63e2:ecd1:9314]) by SJ0PR13MB5545.namprd13.prod.outlook.com\n ([fe80::28c0:63e2:ecd1:9314%4]) with mapi id 15.20.6813.027; Thu, 5 Oct 2023\n 02:40:50 +0000" ], "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;\n b=fLjb9uieTBkf6A+L1iC9bmhoPsVKXdyrvaJ5Kf0txCgxuborWHS747qOZARwqXx+GN1NP4ek0Ce+gXAq+nYdWcbIfS6ZwZY/PcvLfsvAKeYAGrCll0Nn6uMFgTQqh0JGkILqgt7VSKo0Vqe1FCAjJMMo3+qTwDcTrPD32D17GdsbSTrsi5ve8a9WpKtf38i++Xa6V+5RqXKa79RH/HL3izJVyLkkhfCc3tW7Io8dC9jTPEP7M7ZOB8BysWREVWKJQatOqgyur3ZaenHFZCegI8A0mRsgiO/52LCK5QixwGgT7UhPu0RvZQeUN/st87jy5+PjiYO3mCtfTT0tuqxDhw==", "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=r2uSKdjD8aUYDsFnQ6gOb3ZDt2NvVI3Te+OojzDVCUo=;\n b=YWo3ro+S5sW9WE5gQ9mG6jXAy2tNe40WcdY9Ojc5s/PylWmFYBKh4nXOQaJscezEPud6DbQtvWXKJ8LJUIkXQd/eKO805iLz7rJY/rFrD3BmZ1qCrD15ZD2VL4SiDJnL+o7kuDYJssIolBKLVr4Of/m3VQJiwnIghEYWRAxfHYjukCaKbU1+hOgmpOgJKhXJ2nu+QJatpc99mx1/t+GRnNv0TGGHZ+hbSmwDATOTkv6C3Em9i22sOc8rrFZCGxW7n+OSdXIe0n4HfRmhQZbn/a+tlmoX4N1esDk91g127KOPWrlDwNocfb/WaqLiPxXzTYww87PWOgANnmupDt0rMQ==", "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=r2uSKdjD8aUYDsFnQ6gOb3ZDt2NvVI3Te+OojzDVCUo=;\n b=B3PXd0FwXtsYOC2G2hv0ctJb7KMCsTFcbZSHoVSr7ooiA3z9HjDYNwTc/RVbeVFjX/a4wsioNenMyC1tlk1LuxxvWqL1QZeXI4T2YMOU13InXxho9YQKkKdaOnHm9aLhL9Rw1M2woyvitMJftr4RksKqDrtfkJx2c0ih9yjwYIU=", "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, Long Wu <long.wu@corigine.com>,\n James Hershaw <james.hershaw@corigine.com>,\n Chaoyong He <chaoyong.he@corigine.com>", "Subject": "[PATCH 8/8] net/bonding: add commands for bonding port notification", "Date": "Thu, 5 Oct 2023 10:40:12 +0800", "Message-Id": "<20231005024012.1279810-9-chaoyong.he@corigine.com>", "X-Mailer": "git-send-email 2.39.1", "In-Reply-To": "<20231005024012.1279810-1-chaoyong.he@corigine.com>", "References": "<20231005024012.1279810-1-chaoyong.he@corigine.com>", "Content-Transfer-Encoding": "8bit", "Content-Type": "text/plain", "X-ClientProxiedBy": "PH0PR07CA0064.namprd07.prod.outlook.com\n (2603:10b6:510:f::9) 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_|PH0PR13MB4780:EE_", "X-MS-Office365-Filtering-Correlation-Id": "eba5cdad-9b5b-496d-b212-08dbc54c7cd1", "X-MS-Exchange-SenderADCheck": "1", "X-MS-Exchange-AntiSpam-Relay": "0", "X-Microsoft-Antispam": "BCL:0;", "X-Microsoft-Antispam-Message-Info": "\n fouIA2tNTQDnjcFB4Yox5f+rbs95DCQAoEouhpH8xlYijNf5mxBwOo4PBtL3jf0YgjfX389wXheLEUCY7hEUftbPg6Z4Sls0g4v8CzQwjmIXUe5Udxy4gGfg/G3TmAvxrWFqoSizlB3RxhRsb44lnFaycPHp+a5yNrm88Mw2t5QZCQuh+y8LF8PXzRWBa9YsdUe03YBkhZTji8hM3mm5kubrYfQBPsxpeAX80MpTu8L25b1Uk1Tv5dpwc6EoukyCiu+XEKDS9sraOILaVUnwN6H2fySEeM4mfaGFsonKnEjoQCdQQa5MA3c5OpbjrV6z/VGTnQ6vv+stNkggdqBsHbhunHhELuTbeYeLp8yOxDML8Xwe0eP+Z9pwB5O296LSLVZgNQ8WFyULpWwnHNusx2sentCStVOlHTsmkMB8lX3hMUyMPJgUOQuPWhlmGSm1yevwY+/qCU7n/ktwzrS9ROYyDTRnYOTysxWxpsco4rDov94JxREetSYHOgw4Kr1sSePJXSQRZHPelLCPkjrgahZEmL/1GRg0f4meEkJPGc3nXCREe7IdROxO+GFawRkrcgkJ3OytTUqqGnRvDVr3szU4PMyjUlSfgWBbLKUevcerLaMep280DJHkIs2Rrxgj0EzrThgSGjpHoeaL79oft6V0mHNzkNo0QOX24JDsFPw=", "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)(366004)(376002)(346002)(136003)(39830400003)(396003)(230922051799003)(451199024)(186009)(1800799009)(64100799003)(8676002)(107886003)(2616005)(66476007)(4326008)(38100700002)(54906003)(316002)(478600001)(8936002)(66556008)(66946007)(38350700002)(2906002)(6916009)(86362001)(41300700001)(6486002)(15650500001)(6506007)(5660300002)(52116002)(83380400001)(6512007)(1076003)(6666004)(26005)(44832011)(36756003);\n DIR:OUT; SFP:1102;", "X-MS-Exchange-AntiSpam-MessageData-ChunkCount": "1", "X-MS-Exchange-AntiSpam-MessageData-0": "\n Rr56CcqFykaTxNS6hLnaP8hAVgCJDTBdOr/vnLJK6Je0RsiP4vx78XiSX6J9UDebJiJ8Jv/ntRA8KM9LdSf+vaYLag02L/MIoTygL467g3saX1OiV6Ec4f1cKh6jr0TNR1yrrBqfUqhdsFcWO3IarwesXBxsR4NY/IxQSk3ZyiVUHi8VQJpFwH2IUULLvZY14RaR4nW0lkNAywQzLAqkqQROTgqNi2yD6Ks88Ik9Uwj/grhffL4eH9vaQBqnE5GxRvTBdIrRs5AWViZBq29Xjhr5bL7ckkzohWjocpse++VJakIHYITj4RZzY8Z2k+mesCPodqcxhequb17IbOEmoIwY3NHgJC1gvQF7/qMQgxIf3qs2D0gg/I0oFoSLTVXynOaBBsImvS7HnZ2yWDpN0xTphgeOR3LMiJwNBZFPyv19y3mzn4uJGRx4iJ1mt2TMNL5CktgB8+O6elhxGsTg15BYRzdYDe9PgiyyjuuW/Mih4+JyHd0weIXS6U2iI8CScTlGO1U03zW3my643crt+cxVsi56evnfyPIWVa/FcSZMP+KPF5g+QbHq4rRsRJ9xGB/7+0g6CC4lxgRtQlPmAMi96ZgsHdh9pa3Ke1i+USHxCmO9Ow6ysBwNGUPAQW7MrhnjylSgPXQuAmqSwGSY0EhJC98UEugXuiydJ0+WYrBYw3zn+p455ksr7bqKISRcXkUIm0oqSAGneQHFQzgtYcWspeWkV9DddUaowc0P32/hZV6dwfCQ8SjvSgXwQsdxT/bEyg0+7jf1jb7XAc7NhhZQ2yNsvMsJkxN5UkNtf+01CYx0L2KSsEZrKP8lkbdMLiiu9EhRefbDGqSRhM7fJpqZ7Eby5OqhCwB5Y5mT0YeNAawKRzpg64+I9DWHHNBPaVZoHbnyVi+ewU4AVfPKYCrR9y7ZywRKBCKVYpRQN2bbr/4SzirnWF2UQyeMa1ez+3C2oITDkzLK7xqpYYHpgNZ1gJ5SP6hObvSUWN04sFt82rSjTlf0WZ62TgWLUbVH97VdQAgyOSwyGAA3ujoKXa1/Dh70nvHKH2XjaCVugwLvJ/w+iixFqLnt6c2sVp5p7VKdBzZEblqOSh9fYsCcioUwCNV6kOUEhtlHREq0xTko9EaQsjfFcLBvubE5zFaeUg7wEpQOjV82IR5u0419o8l5/yWGgx0s8F9K4w58YkGpK9Cef1C1t1oSoHsxMRPDliyWdR0nUQTXYB79EpB92fD9k/VlMlm4VMPEIy2cpfv8lTVPI3KB8HDFl6pbrR9/eeqkrVxBqM8UJI3UhEwz0xQMUitKwKvtjazH66slnlVXbbcDwgqVffBAfcrueCtpy00rofmIFhW78SyZ0Olv28j6vrCyuik5oXjJvi6XqDRkWGoHNV4rz8+CqZv8K20XcJfDiCr1eiIn6362gXnXzPCSdSK8/A3ohYy7jSathOrxi0YeQFd7nVSFWxOpGkAuEoxOYB6Va1bvq4l+3CAMkFq5ngJY1CyVbDY0i3SMYUB8QcCS4ntEQGg1Fv8lw2gweAum2X83V7AIv59PpGLZM4Ts/aA+2oLuvWB/s/E1/Qx86yFZNH3Q+JFp5AB6GjjuOM9P6bm26tL6ZGvs94vpRw==", "X-OriginatorOrg": "corigine.com", "X-MS-Exchange-CrossTenant-Network-Message-Id": "\n eba5cdad-9b5b-496d-b212-08dbc54c7cd1", "X-MS-Exchange-CrossTenant-AuthSource": "SJ0PR13MB5545.namprd13.prod.outlook.com", "X-MS-Exchange-CrossTenant-AuthAs": "Internal", "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "05 Oct 2023 02:40:50.8017 (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 o8qwxXQdlGEJbu8ZKuQxUmi9xPEWcheRKBQJ/UwBT7ZCf2WU3edU1Njom8kxEuCQy/FGd9iZaAH23yZjRoyaYIicyySI4S2Qe2RD1ZW89t4=", "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "PH0PR13MB4780", "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": "From: Long Wu <long.wu@corigine.com>\n\nAdd some commands to support bonding port notification in\ndpdk-testpmd.\n\n1. We can enable the notification by command:\n\"set bonding notify_member (port_id) (enable|disable)\"\n\n2. If member port hardware try to create the bonding port after\nnotification we can get the status by command:\n\"get bonding member hardware create (member_port_id) (bonding_port_id)\"\n\nSigned-off-by: Long Wu <long.wu@corigine.com>\nReviewed-by: James Hershaw <james.hershaw@corigine.com>\nReviewed-by: Chaoyong He <chaoyong.he@corigine.com>\n---\n .../link_bonding_poll_mode_drv_lib.rst | 19 +++\n drivers/net/bonding/bonding_testpmd.c | 128 ++++++++++++++++++\n 2 files changed, 147 insertions(+)", "diff": "diff --git a/doc/guides/prog_guide/link_bonding_poll_mode_drv_lib.rst b/doc/guides/prog_guide/link_bonding_poll_mode_drv_lib.rst\nindex 60717a3587..9f6443ebd8 100644\n--- a/doc/guides/prog_guide/link_bonding_poll_mode_drv_lib.rst\n+++ b/doc/guides/prog_guide/link_bonding_poll_mode_drv_lib.rst\n@@ -637,3 +637,22 @@ in balance mode with a transmission policy of layer 2+3::\n Members (3): [1 3 4]\n Active Members (3): [1 3 4]\n Primary: [3]\n+\n+set bonding notify_member\n+~~~~~~~~~~~~~~~~~~~~~~~~~\n+\n+Set the notify member flag of bonding port::\n+\n+ testpmd> set bonding notify_member (port_id) (enable|disable)\n+\n+This command just set the flag of notification.\n+If we enable it, bonding PMD will notify member ports when its some\n+configurations changed. So member ports can do some private things, maybe hardware\n+bonding creation and etc.\n+\n+get bonding member hardware create\n+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n+\n+Get the status of member port hardware creating the bonding port::\n+\n+ testpmd> get bonding member hardware create (member_port_id) (bonding_port_id)\ndiff --git a/drivers/net/bonding/bonding_testpmd.c b/drivers/net/bonding/bonding_testpmd.c\nindex 8fcd6cadd0..da7d9cc58f 100644\n--- a/drivers/net/bonding/bonding_testpmd.c\n+++ b/drivers/net/bonding/bonding_testpmd.c\n@@ -692,6 +692,124 @@ static cmdline_parse_inst_t cmd_set_bonding_agg_mode_policy = {\n \t}\n };\n \n+struct cmd_set_bonding_notify_member_result {\n+\tcmdline_fixed_string_t set;\n+\tcmdline_fixed_string_t bonding;\n+\tcmdline_fixed_string_t notify_member;\n+\tuint16_t port_num;\n+\tcmdline_fixed_string_t mode;\n+};\n+\n+static void\n+cmd_set_bonding_notify_member_parsed(void *parsed_result,\n+\t__rte_unused struct cmdline *cl, __rte_unused void *data)\n+{\n+\tstruct cmd_set_bonding_notify_member_result *res = parsed_result;\n+\tbool notify_member = false;\n+\n+\tif (strcmp(res->notify_member, \"enable\") == 0)\n+\t\tnotify_member = true;\n+\telse if (strcmp(res->notify_member, \"disable\") == 0)\n+\t\tnotify_member = false;\n+\n+\trte_eth_bond_notify_member_flag_set(res->port_num, notify_member);\n+}\n+\n+static cmdline_parse_token_string_t cmd_set_bonding_notify_member_set =\n+\tTOKEN_STRING_INITIALIZER(struct cmd_set_bonding_notify_member_result,\n+\t\tset, \"set\");\n+static cmdline_parse_token_string_t cmd_set_bonding_notify_member_bonding =\n+\tTOKEN_STRING_INITIALIZER(struct cmd_set_bonding_notify_member_result,\n+\t\tbonding, \"bonding\");\n+static cmdline_parse_token_string_t cmd_set_bonding_notify_member =\n+\tTOKEN_STRING_INITIALIZER(struct cmd_set_bonding_notify_member_result,\n+\t\tnotify_member, \"notify_member\");\n+static cmdline_parse_token_num_t cmd_set_bonding_notify_member_portnum =\n+\tTOKEN_NUM_INITIALIZER(struct cmd_set_bonding_notify_member_result,\n+\t\tport_num, RTE_UINT16);\n+static cmdline_parse_token_string_t cmd_set_bonding_notify_member_mode_string =\n+\tTOKEN_STRING_INITIALIZER(struct cmd_set_bonding_notify_member_result,\n+\t\tmode, \"enable#disable\");\n+\n+static cmdline_parse_inst_t cmd_set_bonding_notify_member_ports = {\n+\t.f = cmd_set_bonding_notify_member_parsed,\n+\t.data = NULL,\n+\t.help_str = \"set bonding notify_member (port_id) (enable|disable)\",\n+\t.tokens = {\n+\t\t(void *)&cmd_set_bonding_notify_member_set,\n+\t\t(void *)&cmd_set_bonding_notify_member_bonding,\n+\t\t(void *)&cmd_set_bonding_notify_member,\n+\t\t(void *)&cmd_set_bonding_notify_member_portnum,\n+\t\t(void *)&cmd_set_bonding_notify_member_mode_string,\n+\t\tNULL\n+\t}\n+};\n+\n+struct cmd_get_bonding_member_hw_create_result {\n+\tcmdline_fixed_string_t get;\n+\tcmdline_fixed_string_t bonding;\n+\tcmdline_fixed_string_t member;\n+\tcmdline_fixed_string_t hardware;\n+\tcmdline_fixed_string_t create;\n+\tuint16_t member_port_id;\n+\tuint16_t bonding_port_id;\n+};\n+\n+static void\n+cmd_get_bonding_member_hw_create_parsed(void *parsed_result,\n+\t__rte_unused struct cmdline *cl, __rte_unused void *data)\n+{\n+\tstruct cmd_get_bonding_member_hw_create_result *res = parsed_result;\n+\tint ret;\n+\n+\tret = rte_eth_bond_hw_create_get(res->bonding_port_id, res->member_port_id);\n+\tif (ret == 0)\n+\t\tprintf(\"Member port %u hardware creates bonding port %u successfully\\n\",\n+\t\t\tres->member_port_id, res->bonding_port_id);\n+\telse\n+\t\tprintf(\"Failed to get status of member port %u hardware creating\"\n+\t\t\t\" bonding port %u, %d\\n\",\n+\t\t\tres->member_port_id, res->bonding_port_id, ret);\n+}\n+\n+static cmdline_parse_token_string_t cmd_get_bonding_member_hw_create_get =\n+\tTOKEN_STRING_INITIALIZER(struct cmd_get_bonding_member_hw_create_result,\n+\t\tget, \"get\");\n+static cmdline_parse_token_string_t cmd_get_bonding_member_hw_create_bonding =\n+\tTOKEN_STRING_INITIALIZER(struct cmd_get_bonding_member_hw_create_result,\n+\t\tbonding, \"bonding\");\n+static cmdline_parse_token_string_t cmd_get_bonding_member_hw_create_member =\n+\tTOKEN_STRING_INITIALIZER(struct cmd_get_bonding_member_hw_create_result,\n+\t\tmember, \"member\");\n+static cmdline_parse_token_string_t cmd_get_bonding_member_hw_create_hardware =\n+\tTOKEN_STRING_INITIALIZER(struct cmd_get_bonding_member_hw_create_result,\n+\t\tcreate, \"hardware\");\n+static cmdline_parse_token_string_t cmd_get_bonding_member_hw_create_create =\n+\tTOKEN_STRING_INITIALIZER(struct cmd_get_bonding_member_hw_create_result,\n+\t\tcreate, \"create\");\n+static cmdline_parse_token_num_t cmd_get_bonding_member_hw_create_memberportid =\n+\tTOKEN_NUM_INITIALIZER(struct cmd_get_bonding_member_hw_create_result,\n+\t\tmember_port_id, RTE_UINT16);\n+static cmdline_parse_token_num_t cmd_get_bonding_member_hw_create_bondingportid =\n+\tTOKEN_NUM_INITIALIZER(struct cmd_get_bonding_member_hw_create_result,\n+\t\tbonding_port_id, RTE_UINT16);\n+\n+static cmdline_parse_inst_t cmd_get_member_hw_create_bonding = {\n+\t.f = cmd_get_bonding_member_hw_create_parsed,\n+\t.data = NULL,\n+\t.help_str = \"get bonding member hardware create (member_port_id) (bonding_port_id)\",\n+\t.tokens = {\n+\t\t(void *)&cmd_get_bonding_member_hw_create_get,\n+\t\t(void *)&cmd_get_bonding_member_hw_create_bonding,\n+\t\t(void *)&cmd_get_bonding_member_hw_create_member,\n+\t\t(void *)&cmd_get_bonding_member_hw_create_hardware,\n+\t\t(void *)&cmd_get_bonding_member_hw_create_create,\n+\t\t(void *)&cmd_get_bonding_member_hw_create_memberportid,\n+\t\t(void *)&cmd_get_bonding_member_hw_create_bondingportid,\n+\t\tNULL\n+\t}\n+};\n+\n static struct testpmd_driver_commands bonding_cmds = {\n \t.commands = {\n \t{\n@@ -749,6 +867,16 @@ static struct testpmd_driver_commands bonding_cmds = {\n \t\t\"set bonding mode IEEE802.3AD aggregator policy (port_id) (agg_name)\\n\"\n \t\t\"\tSet Aggregation mode for IEEE802.3AD (mode 4)\\n\",\n \t},\n+\t{\n+\t\t&cmd_set_bonding_notify_member_ports,\n+\t\t\"set bonding notify_member (port_id) (enable|disable)\\n\"\n+\t\t\"\tEnable/disable the notify member flag of bonding port\\n\",\n+\t},\n+\t{\n+\t\t&cmd_get_member_hw_create_bonding,\n+\t\t\"get bonding member hardware create (member_port_id) (bonding_port_id)\\n\"\n+\t\t\"\tGet the status of member port hardware creating the bonding port\\n\",\n+\t},\n \t{ NULL, NULL },\n \t},\n };\n", "prefixes": [ "8/8" ] }{ "id": 132328, "url": "