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: c8af2887c941 ("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 21aec4e..de9cadf 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 3c95c95..ebba603 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 {