From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id 5CC13A0093; Mon, 7 Nov 2022 03:18:13 +0100 (CET) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 3C8DC40156; Mon, 7 Nov 2022 03:18:13 +0100 (CET) Received: from szxga03-in.huawei.com (szxga03-in.huawei.com [45.249.212.189]) by mails.dpdk.org (Postfix) with ESMTP id 606704003F for ; Mon, 7 Nov 2022 03:18:11 +0100 (CET) Received: from dggemv704-chm.china.huawei.com (unknown [172.30.72.56]) by szxga03-in.huawei.com (SkyGuard) with ESMTP id 4N5FDn6VjkzJnVX; Mon, 7 Nov 2022 10:15:05 +0800 (CST) Received: from kwepemm600004.china.huawei.com (7.193.23.242) by dggemv704-chm.china.huawei.com (10.3.19.47) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Mon, 7 Nov 2022 10:18:04 +0800 Received: from localhost.localdomain (10.69.192.56) by kwepemm600004.china.huawei.com (7.193.23.242) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Mon, 7 Nov 2022 10:18:04 +0800 From: Huisong Li To: CC: , , <3chas3@gmail.com>, , , , Subject: [PATCH V5] app/testpmd: update bond port configurations when add slave Date: Mon, 7 Nov 2022 10:18:34 +0800 Message-ID: <20221107021834.20694-1-lihuisong@huawei.com> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20221028035331.49406-1-lihuisong@huawei.com> References: <20221028035331.49406-1-lihuisong@huawei.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-Originating-IP: [10.69.192.56] X-ClientProxiedBy: dggems705-chm.china.huawei.com (10.3.19.182) To kwepemm600004.china.huawei.com (7.193.23.242) X-CFilter-Loop: Reflected X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Some capabilities (like, rx_offload_capa and tx_offload_capa) of bonding device in dev_info is zero when no slave is added. And its capability will be updated when add a new slave device. The capability to update dynamically may introduce some problems if not handled properly. For example, the reconfig() is called to initialize bonding port configurations when create a bonding device. The global tx_mode is assigned to dev_conf.txmode. The DEV_TX_OFFLOAD_MBUF_FAST_FREE which is the default value of global tx_mode.offloads in testpmd is removed from bonding device configuration because of zero rx_offload_capa. As a result, this offload isn't set to bonding device. Generally, port configurations of bonding device must be within the intersection of the capability of all slave devices. If use original port configurations, the removed capabilities because of adding a new slave may cause failure when re-initialize bonding device. So port configurations of bonding device need to be updated because of the added and removed capabilities. In addition, this also helps to ensure consistency between testpmd and bonding device. Signed-off-by: Huisong Li Reviewed-by: Min Hu (Connor) --- - v5: fix unrecognized email address - v4: resolve applying failure on dpdk-next-net/main - v3: fix code comment - v2: fix a spelling error in commit log --- app/test-pmd/testpmd.c | 40 +++++++++++++++++++++++++++ app/test-pmd/testpmd.h | 3 +- drivers/net/bonding/bonding_testpmd.c | 2 ++ 3 files changed, 44 insertions(+), 1 deletion(-) diff --git a/app/test-pmd/testpmd.c b/app/test-pmd/testpmd.c index bf589c4e8d..7381dfd9e5 100644 --- a/app/test-pmd/testpmd.c +++ b/app/test-pmd/testpmd.c @@ -2801,6 +2801,41 @@ fill_xstats_display_info(void) fill_xstats_display_info_for_port(pi); } +/* + * Some capabilities (like, rx_offload_capa and tx_offload_capa) of bonding + * device in dev_info is zero when no slave is added. And its capability + * will be updated when add a new slave device. So adding a slave device need + * to update the port configurations of bonding device. + */ +static void +update_bonding_port_dev_conf(portid_t bond_pid) +{ +#ifdef RTE_NET_BOND + struct rte_port *port = &ports[bond_pid]; + uint16_t i; + int ret; + + ret = eth_dev_info_get_print_err(bond_pid, &port->dev_info); + if (ret != 0) { + fprintf(stderr, "Failed to get dev info for port = %u\n", + bond_pid); + return; + } + + if (port->dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_MBUF_FAST_FREE) + port->dev_conf.txmode.offloads |= + RTE_ETH_TX_OFFLOAD_MBUF_FAST_FREE; + /* Apply Tx offloads configuration */ + for (i = 0; i < port->dev_info.max_tx_queues; i++) + port->txq[i].conf.offloads = port->dev_conf.txmode.offloads; + + port->dev_conf.rx_adv_conf.rss_conf.rss_hf &= + port->dev_info.flow_type_rss_offloads; +#else + RTE_SET_USED(bond_pid); +#endif +} + int start_port(portid_t pid) { @@ -2865,6 +2900,11 @@ start_port(portid_t pid) return -1; } + if (port->bond_flag == 1 && port->update_conf == 1) { + update_bonding_port_dev_conf(pi); + port->update_conf = 0; + } + /* configure port */ diag = eth_dev_configure_mp(pi, nb_rxq + nb_hairpinq, nb_txq + nb_hairpinq, diff --git a/app/test-pmd/testpmd.h b/app/test-pmd/testpmd.h index 93fdb9d331..8b5a3cdb30 100644 --- a/app/test-pmd/testpmd.h +++ b/app/test-pmd/testpmd.h @@ -317,7 +317,8 @@ struct rte_port { uint32_t queue_sz; /**< size of a queue for flow rules */ uint8_t slave_flag : 1, /**< bonding slave port */ bond_flag : 1, /**< port is bond device */ - fwd_mac_swap : 1; /**< swap packet MAC before forward */ + fwd_mac_swap : 1, /**< swap packet MAC before forward */ + update_conf : 1; /**< need to update bonding device configuration */ struct port_template *pattern_templ_list; /**< Pattern templates. */ struct port_template *actions_templ_list; /**< Actions templates. */ struct port_table *table_list; /**< Flow tables. */ diff --git a/drivers/net/bonding/bonding_testpmd.c b/drivers/net/bonding/bonding_testpmd.c index 3941f4cf23..9529e16fb6 100644 --- a/drivers/net/bonding/bonding_testpmd.c +++ b/drivers/net/bonding/bonding_testpmd.c @@ -625,6 +625,7 @@ static void cmd_add_bonding_slave_parsed(void *parsed_result, slave_port_id, master_port_id); return; } + ports[master_port_id].update_conf = 1; init_port_config(); set_port_slave_flag(slave_port_id); } @@ -762,6 +763,7 @@ static void cmd_create_bonded_device_parsed(void *parsed_result, fprintf(stderr, "Failed to enable promiscuous mode for port %u: %s - ignore\n", port_id, rte_strerror(-ret)); + ports[port_id].update_conf = 1; ports[port_id].bond_flag = 1; ports[port_id].need_setup = 0; ports[port_id].port_status = RTE_PORT_STOPPED; -- 2.33.0