get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 132882,
    "url": "http://patches.dpdk.org/api/patches/132882/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/20231018074821.1908906-7-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": "<20231018074821.1908906-7-chaoyong.he@corigine.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/20231018074821.1908906-7-chaoyong.he@corigine.com",
    "date": "2023-10-18T07:48:21",
    "name": "[v4,6/6] 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/20231018074821.1908906-7-chaoyong.he@corigine.com/mbox/",
    "series": [
        {
            "id": 29900,
            "url": "http://patches.dpdk.org/api/series/29900/?format=api",
            "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=29900",
            "date": "2023-10-18T07:48:15",
            "name": "Enhance the bond framework to support offload",
            "version": 4,
            "mbox": "http://patches.dpdk.org/series/29900/mbox/"
        }
    ],
    "comments": "http://patches.dpdk.org/api/patches/132882/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/132882/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 3E3E543196;\n\tWed, 18 Oct 2023 09:49:27 +0200 (CEST)",
            "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id 6A0D4427E6;\n\tWed, 18 Oct 2023 09:49:00 +0200 (CEST)",
            "from NAM11-DM6-obe.outbound.protection.outlook.com\n (mail-dm6nam11on2120.outbound.protection.outlook.com [40.107.223.120])\n by mails.dpdk.org (Postfix) with ESMTP id 220E742DE8\n for <dev@dpdk.org>; Wed, 18 Oct 2023 09:48:57 +0200 (CEST)",
            "from SJ0PR13MB5545.namprd13.prod.outlook.com (2603:10b6:a03:424::5)\n by CH0PR13MB5188.namprd13.prod.outlook.com (2603:10b6:610:fd::21)\n with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6907.23; Wed, 18 Oct\n 2023 07:48:55 +0000",
            "from SJ0PR13MB5545.namprd13.prod.outlook.com\n ([fe80::142e:d47c:7320:8a9d]) by SJ0PR13MB5545.namprd13.prod.outlook.com\n ([fe80::142e:d47c:7320:8a9d%4]) with mapi id 15.20.6907.021; Wed, 18 Oct 2023\n 07:48:55 +0000"
        ],
        "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;\n b=QcIL0oRA5T1H2q1wsaBZg8S4FZpS2yQQkN4UJA+1KaZNUZGeVXhMKTsQ+11e3zgFODN9hNcZ3EV08PlkVeP+Is6KaDL16ueXiiGUAZHGAMm0ZALLlEerXKcjTSzq3ht8G4tdLXp2dV+m83if+VJr5Vls+vPzz+a5QzlABELuj23F1RFNaQiFWOzbbFBFq2BMh1fSHtVaoN78vIWXGh/A8XLGVt0BmYvCk6AafK9NdwrSx7KulHK8Y1wL7TrM6jEFK48jKZB0Ufx9voywFx040EUNRuB3ynwfiwO4HfkC4KA+t/+B1PTPWTsURA4G8v0nb/aWIdFqO03F4S5zqgqxTg==",
        "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=iqBxqM2makEu+DZ/jOXbNEWCz7JOyHNFPUS5KbRLp6F1G9021Y6YhYX74qo1RC7h4ftqcV6PiDW14C+LxStyqTmRs0tHlpubNsbAdyqLFp3+y3ZVLUJVSlTI3Fb8a2foobpnG6li5oPe7oYovD6rjZyFJeG6JK/o/sydQ0lrSVZtsu5VB59xAdLTvR6PzvOKRylZreRgzF1KzqsxZc+9nWIamMAN7npU8oFGnuZeTmCWRzmfexBvBnVQyeYd8r67PpgrngKIck9omo9Nixy3x7mZbyvXN0aYR3cptYsKVDSidYgbWXo1fRFi3fjDhsNK6lK6grX3I9qBbOW+vBNnOw==",
        "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=pWOVj5gwQMR3Xo0K7VTOvNCvG8lUarCpyNGIfzAYwidt+IQMYMdPgqEezS5bQ1DBGKVUS76F/CjMTM13cx7JEkdfRmH9ttecEHljduIUYFL4Q/wuQYFs1S3zMNTVgUUW7xvzicdgx2scXJLm/ffzxKgly5el6+oJolZ7MAb+ess=",
        "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 v4 6/6] net/bonding: add commands for bonding port\n notification",
        "Date": "Wed, 18 Oct 2023 15:48:21 +0800",
        "Message-Id": "<20231018074821.1908906-7-chaoyong.he@corigine.com>",
        "X-Mailer": "git-send-email 2.39.1",
        "In-Reply-To": "<20231018074821.1908906-1-chaoyong.he@corigine.com>",
        "References": "<20231008015041.1551165-1-chaoyong.he@corigine.com>\n <20231018074821.1908906-1-chaoyong.he@corigine.com>",
        "Content-Transfer-Encoding": "8bit",
        "Content-Type": "text/plain",
        "X-ClientProxiedBy": "SI2PR02CA0019.apcprd02.prod.outlook.com\n (2603:1096:4:195::13) 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_|CH0PR13MB5188:EE_",
        "X-MS-Office365-Filtering-Correlation-Id": "90d08cde-87cd-4ad4-c492-08dbcfaeade9",
        "X-MS-Exchange-SenderADCheck": "1",
        "X-MS-Exchange-AntiSpam-Relay": "0",
        "X-Microsoft-Antispam": "BCL:0;",
        "X-Microsoft-Antispam-Message-Info": "\n T3piG3WHERSLLycAJpaqW/+e6SCN3xsGt/iS9lDvO1j4phfEtZtWwIQj+hI4x9//gxEVX1FKaDL2spAEZA9oXRPR4GvpczrMjb+hpvpt6Z3ilWCBugsJb2AVUGET23NrzUBGhZi9ppkeTq7LSNlAIPHoyma4razZBIZ7fVOURCftKMlNFsbWNEVxlQBY3ws6Uxc6J62zskds62TwberOARs/3pLOe/SOcrAEgiwKZPAfTnGba7U4uMNUACxqDAWtdIhM3OQE0q/sFqdMo1o5nFMKlzmJhycOoI47Yg8sEafPCmbFRPyHbjaparE9ce34yO43i6zBP4Od64iIncHyCAClf4AnKv+oIuYR58kqIcPx0lkon6IVQIsvInX1AQ0sIgjGnRqJM8kyrYxo7zVOu6z8jrgarZcHobCbEyL8+l6jFphCh/uBCcEtNbFmdPYdLJXg9Lnp6UwY+1Aax+YUr/wU0PqLVM+HvdVN/zNjO+3EE9PLc0Iold6sPSeLMAwVj1xniqWpGfEJtCHfe8hYTRZwRan7370Qz8JEc+0kCV74G4CkT841AQG5155PlA+/s4Sh4ivxhtsXoRoc5eXyDOLLf+KU3jpdinHd9BuIdIYygiPDLYxeWGjh7EBhaWP5PFXYcvl12AX16iA3vsDgdF3OfKmtnQkyAP9n5dC/0kk=",
        "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)(136003)(396003)(346002)(376002)(39830400003)(230922051799003)(64100799003)(451199024)(1800799009)(186009)(86362001)(41300700001)(5660300002)(8936002)(4326008)(8676002)(15650500001)(2906002)(44832011)(36756003)(6486002)(478600001)(107886003)(2616005)(1076003)(26005)(52116002)(6512007)(6666004)(83380400001)(6506007)(38350700005)(54906003)(66476007)(66556008)(66946007)(316002)(6916009)(38100700002);\n DIR:OUT; SFP:1102;",
        "X-MS-Exchange-AntiSpam-MessageData-ChunkCount": "1",
        "X-MS-Exchange-AntiSpam-MessageData-0": "\n 9st8FIfC2CJg3hxZ84PPxl18MBFZ5218YfEutUPNqja1fsJHtOu1YIRmzIabHEEOVyLs+cHy9sbYugZnUCI30KK0ZTDmdUjpt6tdzVYWB8jot57v5jfoXuvWqVurr5rATNddsrb35nMTPLfaqtiqXzdyTlGys0+USsduPtfOdtUsRhtbWi09UH9Az3KV+MuLHsIO9+V00mQzuKdsf5WOGEgBhTp9m0jOSdGAEJw/N7yvb0epYhiD4D+6Tl1/MOqI2j1rJWg/XC+h8mePW9VpRvztVa4NS9Bhh7HCILAf+Ub60UU8epwevyxwiuiNb4FmXjAiBoKoEkEnlv3EWJuP0ojqjky2gySY2uasWqX+LmEy5GetwAGSNTuEk24Cnlgknh+Lym5qd/lwaFAqZDyocusnL1hdKBAABIMfEHBiZlkOfSnPD2COj6rn/6PhVLJgBBbzh76PFxMMz166WoqPv4UU1FSwqQu45NuegKV4zfwhr7TqByOSvFViApfJ7J26JDSDHTlT9E599FdPOkafP770slPrMb7mXpN0iTPgxSjgAW2TAaAM4OQ024x+Omon5AJavI5dLamYU517+mPqDHQ5AaA6pkIE0pMG4IFLDxSRLOqKgT3N3pnkjJyxwfeIO/0qqGIKHT92os/fz55MX7WOmhS1kxPi+zc4Y+0kkBHeBaSRyeIP6ih1iXk+3WSJc4/iS9h72wAlAztOxo+QwjEF96ycGmou6zk0IY2AmnZjucXAzvCFfTW9gbi1pDrqc2EE3fZb0DCWeFqSl8HfsNJ+sunjQ7ZZ4XSktOldIT5zmiVCpL7I2i/EiF/Ot0C1452ySkVy8wHIpp/W9DItQ934mDFQfH4XfN3W2u/GsNS8vImc8bJKz8jHV8u8WBvxiCLEwccpvSUWhbBsK4COH8y6UPKrwOOzb/g3+F2/MkNecxVZZXDeBW1cWu8ayFAO7cSAjjadZq7N7FTsPCWvVBv9u9CsR5V0Yr9pNiAtd2clApTTHEhuFo9Fmd/xlRZs8g8M/Q+OvxXksjOBUBFb4O1aATSflfPBPzuRe6xQVH/gGIjvAEW/gxwtPK3Rac2bpLAZ7alGPVf13j/K2GiAsf8q3wUXoA4X/nMCwGeKM45MX82Gbz/atC5ABQwaUDkvn2tbMMorviR7dlLHRLC03e590ZVLbdvqNi2lif/Y5KFQELItE6wFZnWHCN+B9/vYRSswubQktxuySy5gkH4o52Eu+vUMD2qtQjDsUsGAmZFE++CzJ19HZJ7pF/GQ0+nRe74OBjOZU1N08vvSUg/gZ5NO3QppK6HjyJrAVJMffX9dkQPDBGm0jaYBsf3foXV8+q9OwYK89GHcHZXBD9kT1zRmfb5Eykmtl+pRozJmvlJ9NatxdiWqhtPrB67mVuYRj9DW89Lb/3dweF+rNjKpYMD3e31JJTuslfJrdPTUOL8fmw19SeXQbjWSj4lQux/DHjVgdf+8GgjpBdRYTP8TPNWsWfEMv6rEwWvdfewnfwXfYlzT8CKTqjrNvYxiSVsZgxMU0qHYl3qyjh80DVTzdSUhQd65QD+nAvat4gKAYQpB73J/LxV4ektOEWdZKcPNSU3R+nEv0nKP1ECwcZbF5w==",
        "X-OriginatorOrg": "corigine.com",
        "X-MS-Exchange-CrossTenant-Network-Message-Id": "\n 90d08cde-87cd-4ad4-c492-08dbcfaeade9",
        "X-MS-Exchange-CrossTenant-AuthSource": "SJ0PR13MB5545.namprd13.prod.outlook.com",
        "X-MS-Exchange-CrossTenant-AuthAs": "Internal",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "18 Oct 2023 07:48:55.3616 (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 ze7cvcv4VyOGfjxz9TAWL21aoiS3IBv2b4l1GhjW4kwsKPFT2fXkjfjpe+F6/bAYmyybzfke5r1JCP9EmLGFLeUZjLX+y9WMXL6LCK60pd8=",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "CH0PR13MB5188",
        "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": [
        "v4",
        "6/6"
    ]
}