Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp2320133pxu; Sat, 28 Nov 2020 10:03:01 -0800 (PST) X-Google-Smtp-Source: ABdhPJyAWzONNtMmsdA71jhGNTC8sjm/bI1YmVd7cISVm1KNtOc1PtzC/NVWhBjxRoFobUSCtJZ5 X-Received: by 2002:aa7:c701:: with SMTP id i1mr6117437edq.191.1606586581756; Sat, 28 Nov 2020 10:03:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1606586581; cv=none; d=google.com; s=arc-20160816; b=OpTWjrG+oHI1Aid1/NtsfZx+MDHh+xmkTW64IgxCdIUfh/UEirebAIw0aZK/fDxujX /3ZZhUiLy79P8L9HQ0RzVhvbI7vJ3Lc4/+zfdhNi2tCwvBW75AqZ/D13RDEaBeLzjlkB ircbMccoJJM3D36qRhsCHMIJGX0+G9V7ZeiypyK1rwH0f/rOAtQMRPCdCeAAYRoyCoT9 3P0j+vRCksPvvJQIiy5DdR+B7T3z6eLJNQ+8ytAHxyKmIKdnndBaw8AF43MQfOoJMy1z j5FHVKlcqtaGxW5aMd/Rg+tfnaWfXP1isfRRRV4I77MTAdF20t1cVUqe77boe1144hM2 3iGQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from; bh=TyllC65A1/C85DM3LRVlXBCAHGVtABZIMP7BeoWjppE=; b=FVGEsTYl1lZ7txPv0Yaa3thT6S8F6hvaQE/vyEc2GbOatiL6ovOxhUum2lxrp3XLfE URQEVuhLcu6dVfI0H2eiI4nLHBZaHUUR8qUkRB0+7OfGEojbtGdyrFRWPzG/k2cIEt05 +jzZ/115hSyqUruQywJ2l8qlbqxibJWSK/rk0ZrEnK/fA4VlewK6rpylaINrPXRUjKDb WEk68HhFgsZ9d77L8Y2I8+5YQkcWFgKldaVUdeQKVj6MVabGQEiAM79M8NS/adgeGcsq 8lq2oOsTaW4yZRH8zUzD46kWXit+pv6eJaZHIi00p+rrIx/fjv4QGn/JdoZ30D1wTB+Z oIKw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id o23si3138304ejb.346.2020.11.28.10.02.38; Sat, 28 Nov 2020 10:03:01 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732167AbgK1Rzy (ORCPT + 99 others); Sat, 28 Nov 2020 12:55:54 -0500 Received: from szxga06-in.huawei.com ([45.249.212.32]:8451 "EHLO szxga06-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731497AbgK1ENK (ORCPT ); Fri, 27 Nov 2020 23:13:10 -0500 Received: from DGGEMS407-HUB.china.huawei.com (unknown [172.30.72.59]) by szxga06-in.huawei.com (SkyGuard) with ESMTP id 4CjcxS4JFTzhhhN; Sat, 28 Nov 2020 11:51:40 +0800 (CST) Received: from localhost.localdomain (10.69.192.56) by DGGEMS407-HUB.china.huawei.com (10.3.19.207) with Microsoft SMTP Server id 14.3.487.0; Sat, 28 Nov 2020 11:51:49 +0800 From: Huazhong Tan To: CC: , , , , , , Yonglong Liu , Huazhong Tan Subject: [PATCH V2 net-next 7/7] net: hns3: keep MAC pause mode when multiple TCs are enabled Date: Sat, 28 Nov 2020 11:51:50 +0800 Message-ID: <1606535510-44346-8-git-send-email-tanhuazhong@huawei.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1606535510-44346-1-git-send-email-tanhuazhong@huawei.com> References: <1606535510-44346-1-git-send-email-tanhuazhong@huawei.com> MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.69.192.56] X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Yonglong Liu Bellow HNAE3_DEVICE_VERSION_V3, MAC pause mode just support one TC, when enabled multiple TCs, force enable PFC mode. HNAE3_DEVICE_VERSION_V3 can support MAC pause mode on multiple TCs, so when enable multiple TCs, just keep MAC pause mode, and enable PFC mode just according to the user settings. Signed-off-by: Yonglong Liu Signed-off-by: Huazhong Tan --- .../net/ethernet/hisilicon/hns3/hns3pf/hclge_tm.c | 23 +++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_tm.c b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_tm.c index 54767b0..b1026cd 100644 --- a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_tm.c +++ b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_tm.c @@ -715,7 +715,7 @@ static void hclge_tm_pg_info_init(struct hclge_dev *hdev) } } -static void hclge_pfc_info_init(struct hclge_dev *hdev) +static void hclge_update_fc_mode_by_dcb_flag(struct hclge_dev *hdev) { if (!(hdev->flag & HCLGE_FLAG_DCB_ENABLE)) { if (hdev->fc_mode_last_time == HCLGE_FC_PFC) @@ -733,6 +733,27 @@ static void hclge_pfc_info_init(struct hclge_dev *hdev) } } +static void hclge_update_fc_mode(struct hclge_dev *hdev) +{ + if (!hdev->tm_info.pfc_en) { + hdev->tm_info.fc_mode = hdev->fc_mode_last_time; + return; + } + + if (hdev->tm_info.fc_mode != HCLGE_FC_PFC) { + hdev->fc_mode_last_time = hdev->tm_info.fc_mode; + hdev->tm_info.fc_mode = HCLGE_FC_PFC; + } +} + +static void hclge_pfc_info_init(struct hclge_dev *hdev) +{ + if (hdev->ae_dev->dev_version >= HNAE3_DEVICE_VERSION_V3) + hclge_update_fc_mode(hdev); + else + hclge_update_fc_mode_by_dcb_flag(hdev); +} + static void hclge_tm_schd_info_init(struct hclge_dev *hdev) { hclge_tm_pg_info_init(hdev); -- 2.7.4