summaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
authorYunsheng Lin <linyunsheng@huawei.com>2017-09-20 06:52:54 -0400
committerDavid S. Miller <davem@davemloft.net>2017-09-20 19:15:39 -0400
commitb8c8bf47da5576657370798da6f18a8cb0245d5b (patch)
tree32989bf175e0e99691c9fd4bc47237dc7dc359de /drivers/net
parentbb1fe9ea6371e075d3d1448cd3ff6441d31307be (diff)
net: hns3: Fix for rx_priv_buf_alloc not setting rx shared buffer
rx_priv_buf_alloc is used to tell hardware how much buffer is used for rx direction, right now only the private buffer is assigned. For ae_dev that doesn't support DCB, private rx buffer is assigned to zero, only shared rx buffer is used. So not setting the shared rx buffer cause dropping of packet in SSU. Fixes: 46a3df9f9718 ("net: hns3: Add HNS3 Acceleration Engine & Compatibility Layer Support") Signed-off-by: Yunsheng Lin <linyunsheng@huawei.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.h3
-rw-r--r--drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c4
2 files changed, 6 insertions, 1 deletions
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.h b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.h
index 30e2ad5ac0da..758cf3948131 100644
--- a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.h
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.h
@@ -270,7 +270,8 @@ struct hclge_tx_buff_alloc {
270 270
271struct hclge_rx_priv_buff { 271struct hclge_rx_priv_buff {
272 __le16 buf_num[HCLGE_TC_NUM]; 272 __le16 buf_num[HCLGE_TC_NUM];
273 u8 rsv[8]; 273 __le16 shared_buf;
274 u8 rsv[6];
274}; 275};
275 276
276struct hclge_query_version { 277struct hclge_query_version {
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
index a7d8fb1e15f6..e313552bb23d 100644
--- a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
@@ -1622,6 +1622,10 @@ static int hclge_rx_priv_buf_alloc(struct hclge_dev *hdev)
1622 cpu_to_le16(true << HCLGE_TC0_PRI_BUF_EN_B); 1622 cpu_to_le16(true << HCLGE_TC0_PRI_BUF_EN_B);
1623 } 1623 }
1624 1624
1625 req->shared_buf =
1626 cpu_to_le16((hdev->s_buf.buf_size >> HCLGE_BUF_UNIT_S) |
1627 (1 << HCLGE_TC0_PRI_BUF_EN_B));
1628
1625 ret = hclge_cmd_send(&hdev->hw, &desc, 1); 1629 ret = hclge_cmd_send(&hdev->hw, &desc, 1);
1626 if (ret) { 1630 if (ret) {
1627 dev_err(&hdev->pdev->dev, 1631 dev_err(&hdev->pdev->dev,