net: hns3: always assume no drop TC for performance reason
authorYunsheng Lin <linyunsheng@huawei.com>
Sun, 14 Apr 2019 01:47:41 +0000 (09:47 +0800)
committerDavid S. Miller <davem@davemloft.net>
Sun, 14 Apr 2019 20:47:35 +0000 (13:47 -0700)
Currently RX shared buffer' threshold size for speific TC is
set to smaller value when the TC's PFC is not enabled, which may
cause performance problem because hardware may not have enough
hardware buffer when PFC is not enabled.

This patch sets the same threshold size for all TC no matter if
the specific TC's PFC is enabled.

Signed-off-by: Yunsheng Lin <linyunsheng@huawei.com>
Signed-off-by: Peng Li <lipeng321@huawei.com>
Signed-off-by: Huazhong Tan <tanhuazhong@huawei.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c

index 0d1cd3f5eafd04f4f7fd56f85d1dd9581b57de84..7e7cdad6d987a87ef29a8726952b3ba219db4b4b 100644 (file)
@@ -1432,17 +1432,6 @@ static int hclge_get_tc_num(struct hclge_dev *hdev)
        return cnt;
 }
 
-static int hclge_get_pfc_enalbe_num(struct hclge_dev *hdev)
-{
-       int i, cnt = 0;
-
-       for (i = 0; i < HCLGE_MAX_TC_NUM; i++)
-               if (hdev->hw_tc_map & BIT(i) &&
-                   hdev->tm_info.hw_pfc_map & BIT(i))
-                       cnt++;
-       return cnt;
-}
-
 /* Get the number of pfc enabled TCs, which have private buffer */
 static int hclge_get_pfc_priv_num(struct hclge_dev *hdev,
                                  struct hclge_pkt_buf_alloc *buf_alloc)
@@ -1507,13 +1496,11 @@ static bool  hclge_is_rx_buf_ok(struct hclge_dev *hdev,
                                u32 rx_all)
 {
        u32 shared_buf_min, shared_buf_tc, shared_std;
-       int tc_num, pfc_enable_num;
+       int tc_num = hclge_get_tc_num(hdev);
        u32 shared_buf, aligned_mps;
        u32 rx_priv;
        int i;
 
-       tc_num = hclge_get_tc_num(hdev);
-       pfc_enable_num = hclge_get_pfc_enalbe_num(hdev);
        aligned_mps = roundup(hdev->mps, HCLGE_BUF_SIZE_UNIT);
 
        if (hnae3_dev_dcb_supported(hdev))
@@ -1522,9 +1509,7 @@ static bool  hclge_is_rx_buf_ok(struct hclge_dev *hdev,
                shared_buf_min = aligned_mps + HCLGE_NON_DCB_ADDITIONAL_BUF
                                        + hdev->dv_buf_size;
 
-       shared_buf_tc = pfc_enable_num * aligned_mps +
-                       (tc_num - pfc_enable_num) * aligned_mps / 2 +
-                       aligned_mps;
+       shared_buf_tc = tc_num * aligned_mps + aligned_mps;
        shared_std = roundup(max_t(u32, shared_buf_min, shared_buf_tc),
                             HCLGE_BUF_SIZE_UNIT);
 
@@ -1546,14 +1531,8 @@ static bool  hclge_is_rx_buf_ok(struct hclge_dev *hdev,
        }
 
        for (i = 0; i < HCLGE_MAX_TC_NUM; i++) {
-               if ((hdev->hw_tc_map & BIT(i)) &&
-                   (hdev->tm_info.hw_pfc_map & BIT(i))) {
-                       buf_alloc->s_buf.tc_thrd[i].low = aligned_mps;
-                       buf_alloc->s_buf.tc_thrd[i].high = 2 * aligned_mps;
-               } else {
-                       buf_alloc->s_buf.tc_thrd[i].low = 0;
-                       buf_alloc->s_buf.tc_thrd[i].high = aligned_mps;
-               }
+               buf_alloc->s_buf.tc_thrd[i].low = aligned_mps;
+               buf_alloc->s_buf.tc_thrd[i].high = 2 * aligned_mps;
        }
 
        return true;