]> git.baikalelectronics.ru Git - kernel.git/commitdiff
net: hns3: fix some mac statistics is always 0 in device version V2
authorGuangbin Huang <huangguangbin2@huawei.com>
Wed, 10 Nov 2021 13:42:54 +0000 (21:42 +0800)
committerDavid S. Miller <davem@davemloft.net>
Wed, 10 Nov 2021 14:20:43 +0000 (14:20 +0000)
When driver queries the register number of mac statistics from firmware,
the old firmware runs in device version V2 only returns number of valid
registers, not include number of three reserved registers among of them.
It cause driver doesn't record the last three data when query mac
statistics.

To fix this problem, driver never query register number in device version
V2 and set it to a fixed value which include three reserved registers.

Fixes: ec37d82b65c0 ("net: hns3: add support pause/pfc durations for mac statistics")
Signed-off-by: Guangbin Huang <huangguangbin2@huawei.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.h

index 21aec4e470cf6532fc357a39733788016afc4815..de9cadf9b9f306fd7fc98284703f9e8a1ee01fa9 100644 (file)
@@ -566,6 +566,16 @@ static int hclge_mac_query_reg_num(struct hclge_dev *hdev, u32 *reg_num)
        struct hclge_desc desc;
        int ret;
 
+       /* Driver needs total register number of both valid registers and
+        * reserved registers, but the old firmware only returns number
+        * of valid registers in device V2. To be compatible with these
+        * devices, driver uses a fixed value.
+        */
+       if (hdev->ae_dev->dev_version == HNAE3_DEVICE_VERSION_V2) {
+               *reg_num = HCLGE_MAC_STATS_MAX_NUM_V1;
+               return 0;
+       }
+
        hclge_cmd_setup_basic_desc(&desc, HCLGE_OPC_QUERY_MAC_REG_NUM, true);
        ret = hclge_cmd_send(&hdev->hw, &desc, 1);
        if (ret) {
index 3c95c957d1e30a454abc8cb9ab123bf185fb6b89..ebba603483a04f1034a70254c25ac8ffe6b1c882 100644 (file)
@@ -404,7 +404,7 @@ struct hclge_tm_info {
 };
 
 /* max number of mac statistics on each version */
-#define HCLGE_MAC_STATS_MAX_NUM_V1             84
+#define HCLGE_MAC_STATS_MAX_NUM_V1             87
 #define HCLGE_MAC_STATS_MAX_NUM_V2             105
 
 struct hclge_comm_stats_str {