net: hns3: code optimization for hclge_rx_buffer_calc
authorYunsheng Lin <linyunsheng@huawei.com>
Sat, 2 Feb 2019 14:39:29 +0000 (22:39 +0800)
committerDavid S. Miller <davem@davemloft.net>
Sat, 2 Feb 2019 16:24:08 +0000 (08:24 -0800)
There are four steps to calcuate the rx private buffer, each step
can be done in a function to avoid code duplication and aid code
readability.

This patch adds three separate functions do the job. Also, the
function name more or less make the comment redundant, so remove
some obvious comment.

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 9630bbce5932dbb3dec9d0e0ae61bc0960157490..be7d82502f5fd8e0aef46ab45cb019c77403ab01 100644 (file)
@@ -1520,66 +1520,15 @@ static int hclge_tx_buffer_calc(struct hclge_dev *hdev,
        return 0;
 }
 
-/* hclge_rx_buffer_calc: calculate the rx private buffer size for all TCs
- * @hdev: pointer to struct hclge_dev
- * @buf_alloc: pointer to buffer calculation data
- * @return: 0: calculate sucessful, negative: fail
- */
-static int hclge_rx_buffer_calc(struct hclge_dev *hdev,
-                               struct hclge_pkt_buf_alloc *buf_alloc)
+static bool hclge_rx_buf_calc_all(struct hclge_dev *hdev, bool max,
+                                 struct hclge_pkt_buf_alloc *buf_alloc)
 {
-       u32 rx_all = hdev->pkt_buf_size, aligned_mps;
-       int no_pfc_priv_num, pfc_priv_num;
-       struct hclge_priv_buf *priv;
+       u32 rx_all = hdev->pkt_buf_size - hclge_get_tx_buff_alloced(buf_alloc);
+       u32 aligned_mps = round_up(hdev->mps, HCLGE_BUF_SIZE_UNIT);
        int i;
 
-       aligned_mps = round_up(hdev->mps, HCLGE_BUF_SIZE_UNIT);
-       rx_all -= hclge_get_tx_buff_alloced(buf_alloc);
-
-       /* When DCB is not supported, rx private
-        * buffer is not allocated.
-        */
-       if (!hnae3_dev_dcb_supported(hdev)) {
-               if (!hclge_is_rx_buf_ok(hdev, buf_alloc, rx_all))
-                       return -ENOMEM;
-
-               return 0;
-       }
-
-       /* step 1, try to alloc private buffer for all enabled tc */
-       for (i = 0; i < HCLGE_MAX_TC_NUM; i++) {
-               priv = &buf_alloc->priv_buf[i];
-               if (hdev->hw_tc_map & BIT(i)) {
-                       priv->enable = 1;
-                       if (hdev->tm_info.hw_pfc_map & BIT(i)) {
-                               priv->wl.low = aligned_mps;
-                               priv->wl.high =
-                                       roundup(priv->wl.low + aligned_mps,
-                                               HCLGE_BUF_SIZE_UNIT);
-                               priv->buf_size = priv->wl.high +
-                                       hdev->dv_buf_size;
-                       } else {
-                               priv->wl.low = 0;
-                               priv->wl.high = 2 * aligned_mps;
-                               priv->buf_size = priv->wl.high +
-                                               hdev->dv_buf_size;
-                       }
-               } else {
-                       priv->enable = 0;
-                       priv->wl.low = 0;
-                       priv->wl.high = 0;
-                       priv->buf_size = 0;
-               }
-       }
-
-       if (hclge_is_rx_buf_ok(hdev, buf_alloc, rx_all))
-               return 0;
-
-       /* step 2, try to decrease the buffer size of
-        * no pfc TC's private buffer
-        */
        for (i = 0; i < HCLGE_MAX_TC_NUM; i++) {
-               priv = &buf_alloc->priv_buf[i];
+               struct hclge_priv_buf *priv = &buf_alloc->priv_buf[i];
 
                priv->enable = 0;
                priv->wl.low = 0;
@@ -1592,28 +1541,30 @@ static int hclge_rx_buffer_calc(struct hclge_dev *hdev,
                priv->enable = 1;
 
                if (hdev->tm_info.hw_pfc_map & BIT(i)) {
-                       priv->wl.low = 256;
-                       priv->wl.high = priv->wl.low + aligned_mps;
-                       priv->buf_size = priv->wl.high + hdev->dv_buf_size;
+                       priv->wl.low = max ? aligned_mps : 256;
+                       priv->wl.high = roundup(priv->wl.low + aligned_mps,
+                                               HCLGE_BUF_SIZE_UNIT);
                } else {
                        priv->wl.low = 0;
-                       priv->wl.high = aligned_mps;
-                       priv->buf_size = priv->wl.high + hdev->dv_buf_size;
+                       priv->wl.high = max ? (aligned_mps * 2) : aligned_mps;
                }
+
+               priv->buf_size = priv->wl.high + hdev->dv_buf_size;
        }
 
-       if (hclge_is_rx_buf_ok(hdev, buf_alloc, rx_all))
-               return 0;
+       return hclge_is_rx_buf_ok(hdev, buf_alloc, rx_all);
+}
 
-       /* step 3, try to reduce the number of pfc disabled TCs,
-        * which have private buffer
-        */
-       /* get the total no pfc enable TC number, which have private buffer */
-       no_pfc_priv_num = hclge_get_no_pfc_priv_num(hdev, buf_alloc);
+static bool hclge_drop_nopfc_buf_till_fit(struct hclge_dev *hdev,
+                                         struct hclge_pkt_buf_alloc *buf_alloc)
+{
+       u32 rx_all = hdev->pkt_buf_size - hclge_get_tx_buff_alloced(buf_alloc);
+       int no_pfc_priv_num = hclge_get_no_pfc_priv_num(hdev, buf_alloc);
+       int i;
 
        /* let the last to be cleared first */
        for (i = HCLGE_MAX_TC_NUM - 1; i >= 0; i--) {
-               priv = &buf_alloc->priv_buf[i];
+               struct hclge_priv_buf *priv = &buf_alloc->priv_buf[i];
 
                if (hdev->hw_tc_map & BIT(i) &&
                    !(hdev->tm_info.hw_pfc_map & BIT(i))) {
@@ -1630,17 +1581,19 @@ static int hclge_rx_buffer_calc(struct hclge_dev *hdev,
                        break;
        }
 
-       if (hclge_is_rx_buf_ok(hdev, buf_alloc, rx_all))
-               return 0;
+       return hclge_is_rx_buf_ok(hdev, buf_alloc, rx_all);
+}
 
-       /* step 4, try to reduce the number of pfc enabled TCs
-        * which have private buffer.
-        */
-       pfc_priv_num = hclge_get_pfc_priv_num(hdev, buf_alloc);
+static bool hclge_drop_pfc_buf_till_fit(struct hclge_dev *hdev,
+                                       struct hclge_pkt_buf_alloc *buf_alloc)
+{
+       u32 rx_all = hdev->pkt_buf_size - hclge_get_tx_buff_alloced(buf_alloc);
+       int pfc_priv_num = hclge_get_pfc_priv_num(hdev, buf_alloc);
+       int i;
 
        /* let the last to be cleared first */
        for (i = HCLGE_MAX_TC_NUM - 1; i >= 0; i--) {
-               priv = &buf_alloc->priv_buf[i];
+               struct hclge_priv_buf *priv = &buf_alloc->priv_buf[i];
 
                if (hdev->hw_tc_map & BIT(i) &&
                    hdev->tm_info.hw_pfc_map & BIT(i)) {
@@ -1656,7 +1609,40 @@ static int hclge_rx_buffer_calc(struct hclge_dev *hdev,
                    pfc_priv_num == 0)
                        break;
        }
-       if (hclge_is_rx_buf_ok(hdev, buf_alloc, rx_all))
+
+       return hclge_is_rx_buf_ok(hdev, buf_alloc, rx_all);
+}
+
+/* hclge_rx_buffer_calc: calculate the rx private buffer size for all TCs
+ * @hdev: pointer to struct hclge_dev
+ * @buf_alloc: pointer to buffer calculation data
+ * @return: 0: calculate sucessful, negative: fail
+ */
+static int hclge_rx_buffer_calc(struct hclge_dev *hdev,
+                               struct hclge_pkt_buf_alloc *buf_alloc)
+{
+       /* When DCB is not supported, rx private buffer is not allocated. */
+       if (!hnae3_dev_dcb_supported(hdev)) {
+               u32 rx_all = hdev->pkt_buf_size;
+
+               rx_all -= hclge_get_tx_buff_alloced(buf_alloc);
+               if (!hclge_is_rx_buf_ok(hdev, buf_alloc, rx_all))
+                       return -ENOMEM;
+
+               return 0;
+       }
+
+       if (hclge_rx_buf_calc_all(hdev, true, buf_alloc))
+               return 0;
+
+       /* try to decrease the buffer size */
+       if (hclge_rx_buf_calc_all(hdev, false, buf_alloc))
+               return 0;
+
+       if (hclge_drop_nopfc_buf_till_fit(hdev, buf_alloc))
+               return 0;
+
+       if (hclge_drop_pfc_buf_till_fit(hdev, buf_alloc))
                return 0;
 
        return -ENOMEM;