989 lines
38 KiB
Diff
989 lines
38 KiB
Diff
From 69f914597fdb37f7bb74a96e56af0e34c86de375 Mon Sep 17 00:00:00 2001
|
|
From: Jie Wang <wangjie125@huawei.com>
|
|
Date: Wed, 12 Jan 2022 15:16:53 +0800
|
|
Subject: [PATCH 247/283] net: hns3: refactor PF cmdq resource APIs with new
|
|
common APIs
|
|
|
|
mainline inclusion
|
|
from mainline-v5.17-rc1
|
|
commit d3c69a8812c22d84eb12f1a60f91889a63a5fc51
|
|
category: feature
|
|
bugzilla: https://gitee.com/src-openeuler/kernel/issues/I8EN49
|
|
CVE: NA
|
|
|
|
Reference: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=d3c69a8812c22d84eb12f1a60f91889a63a5fc51
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
This patch uses common cmdq resource allocate/free/query APIs to replace
|
|
the old APIs in PF cmdq module and deletes the old cmdq resource APIs.
|
|
Still we kept hclge_cmd_setup_basic_desc name as a seam API to avoid too
|
|
many meaningless replacement.
|
|
|
|
Signed-off-by: Jie Wang <wangjie125@huawei.com>
|
|
Signed-off-by: Guangbin Huang <huangguangbin2@huawei.com>
|
|
Signed-off-by: David S. Miller <davem@davemloft.net>
|
|
Reviewed-by: Jian Shen <shenjian15@huawei.com>
|
|
Reviewed-by: Yue Haibing <yuehaibing@huawei.com>
|
|
Signed-off-by: Zheng Zengkai <zhengzengkai@huawei.com>
|
|
Signed-off-by: Xiaodong Li <lixiaodong67@huawei.com>
|
|
|
|
Conflicts:
|
|
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.c
|
|
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.h
|
|
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
|
|
---
|
|
.../hisilicon/hns3/hns3_cae/hns3_cae_cmd.c | 10 +-
|
|
.../hisilicon/hns3/hns3_cae/hns3_cae_fd.c | 2 +-
|
|
.../hns3/hns3_cae/hns3_cae_hilink_param.c | 12 +-
|
|
.../hisilicon/hns3/hns3_cae/hns3_cae_port.c | 4 +-
|
|
.../hisilicon/hns3/hns3_cae/hns3_cae_qos.c | 16 +-
|
|
.../hisilicon/hns3/hns3_cae/hns3_cae_xsfp.c | 4 +-
|
|
.../hns3/hns3_common/hclge_comm_cmd.c | 2 +-
|
|
.../hisilicon/hns3/hns3pf/hclge_cmd.c | 216 ++----------------
|
|
.../hisilicon/hns3/hns3pf/hclge_cmd.h | 64 +-----
|
|
.../hisilicon/hns3/hns3pf/hclge_debugfs.c | 14 +-
|
|
.../hisilicon/hns3/hns3pf/hclge_err.c | 25 +-
|
|
.../hisilicon/hns3/hns3pf/hclge_main.c | 54 ++---
|
|
12 files changed, 89 insertions(+), 334 deletions(-)
|
|
|
|
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_cmd.c b/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_cmd.c
|
|
index 203ee3135f9d..d26dbfc36c9b 100644
|
|
--- a/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_cmd.c
|
|
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_cmd.c
|
|
@@ -137,11 +137,11 @@ static int hns3_cae_cmd_check_retval(struct hclge_hw *hw,
|
|
|
|
void hns3_cae_cmd_reuse_desc(struct hclge_desc *desc, bool is_read)
|
|
{
|
|
- desc->flag = cpu_to_le16(HCLGE_CMD_FLAG_NO_INTR | HCLGE_CMD_FLAG_IN);
|
|
+ desc->flag = cpu_to_le16(HCLGE_COMM_CMD_FLAG_NO_INTR | HCLGE_COMM_CMD_FLAG_IN);
|
|
if (is_read)
|
|
- desc->flag |= cpu_to_le16(HCLGE_CMD_FLAG_WR);
|
|
+ desc->flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_WR);
|
|
else
|
|
- desc->flag &= cpu_to_le16(~HCLGE_CMD_FLAG_WR);
|
|
+ desc->flag &= cpu_to_le16(~HCLGE_COMM_CMD_FLAG_WR);
|
|
}
|
|
|
|
void hns3_cae_cmd_setup_basic_desc(struct hclge_desc *desc,
|
|
@@ -149,10 +149,10 @@ void hns3_cae_cmd_setup_basic_desc(struct hclge_desc *desc,
|
|
{
|
|
memset((void *)desc, 0, sizeof(struct hclge_desc));
|
|
desc->opcode = cpu_to_le16(opcode);
|
|
- desc->flag = cpu_to_le16(HCLGE_CMD_FLAG_NO_INTR | HCLGE_CMD_FLAG_IN);
|
|
+ desc->flag = cpu_to_le16(HCLGE_COMM_CMD_FLAG_NO_INTR | HCLGE_COMM_CMD_FLAG_IN);
|
|
|
|
if (is_read)
|
|
- desc->flag |= cpu_to_le16(HCLGE_CMD_FLAG_WR);
|
|
+ desc->flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_WR);
|
|
}
|
|
|
|
/**
|
|
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_fd.c b/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_fd.c
|
|
index 21e034153808..2a1b26fbd81b 100644
|
|
--- a/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_fd.c
|
|
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_fd.c
|
|
@@ -171,7 +171,7 @@ static int hns3_cae_send_tcam_op_cmd(struct hclge_dev *hdev, u8 *buf_in,
|
|
hns3_cae_cmd_setup_basic_desc(pdesc, HCLGE_OPC_FD_TCAM_OP,
|
|
param->is_read ? true : false);
|
|
if (i < HNS3_CAE_FD_TCAM_BD_NUM - 1)
|
|
- pdesc->flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ pdesc->flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
}
|
|
|
|
req1 = (struct hclge_fd_tcam_config_1_cmd *)desc[0].data;
|
|
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_hilink_param.c b/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_hilink_param.c
|
|
index 6aa003ff0a2c..696f31759ee7 100644
|
|
--- a/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_hilink_param.c
|
|
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_hilink_param.c
|
|
@@ -39,10 +39,10 @@ static int hns3_get_hilink_ctle(struct hclge_dev *hdev,
|
|
ctle_desc[0].data[0] = lane_start | (lane_len << 4);
|
|
|
|
if (i < HILINK_PARAM_CMD_BD_LEN - 1)
|
|
- ctle_desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ ctle_desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
else
|
|
ctle_desc[i].flag &=
|
|
- ~(cpu_to_le16(HCLGE_CMD_FLAG_NEXT));
|
|
+ ~(cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT));
|
|
}
|
|
|
|
ret = hns3_cae_cmd_send(hdev, ctle_desc, HILINK_PARAM_CMD_BD_LEN);
|
|
@@ -91,9 +91,9 @@ static int hns3_get_hilink_dfe(struct hclge_dev *hdev,
|
|
dfe_desc[0].data[0] = lane_start | (lane_len << 4);
|
|
|
|
if (i < HILINK_PARAM_CMD_BD_LEN - 1)
|
|
- dfe_desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ dfe_desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
else
|
|
- dfe_desc[i].flag &= ~(cpu_to_le16(HCLGE_CMD_FLAG_NEXT));
|
|
+ dfe_desc[i].flag &= ~(cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT));
|
|
}
|
|
|
|
ret = hns3_cae_cmd_send(hdev, dfe_desc, HILINK_PARAM_CMD_BD_LEN);
|
|
@@ -138,9 +138,9 @@ static int hns3_get_hilink_ffe(struct hclge_dev *hdev,
|
|
ffe_desc[0].data[0] = lane_start | (lane_len << 4);
|
|
|
|
if (i < HILINK_PARAM_CMD_BD_LEN - 1)
|
|
- ffe_desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ ffe_desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
else
|
|
- ffe_desc[i].flag &= ~(cpu_to_le16(HCLGE_CMD_FLAG_NEXT));
|
|
+ ffe_desc[i].flag &= ~(cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT));
|
|
}
|
|
|
|
ret = hns3_cae_cmd_send(hdev, ffe_desc, HILINK_PARAM_CMD_BD_LEN);
|
|
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_port.c b/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_port.c
|
|
index 9af8d019b655..2df2f6a3b158 100644
|
|
--- a/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_port.c
|
|
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_port.c
|
|
@@ -102,10 +102,10 @@ int hns3_get_port_info(const struct hns3_nic_priv *net_priv,
|
|
hns3_cae_cmd_setup_basic_desc(&port_desc[i],
|
|
HCLGE_OPC_DUMP_PORT_INFO, true);
|
|
if (i < bd_num - 1)
|
|
- port_desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ port_desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
else
|
|
port_desc[i].flag &=
|
|
- ~(cpu_to_le16(HCLGE_CMD_FLAG_NEXT));
|
|
+ ~(cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT));
|
|
}
|
|
|
|
ret = hns3_cae_cmd_send(hdev, port_desc, bd_num);
|
|
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_qos.c b/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_qos.c
|
|
index 4bbe8bbcfe03..9778ac07a5f4 100644
|
|
--- a/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_qos.c
|
|
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_qos.c
|
|
@@ -34,9 +34,9 @@ int hns3_cmd_rx_priv_wl_config(struct hclge_dev *hdev, u16 tc,
|
|
req = (struct hclge_rx_priv_wl_buf *)desc[i].data;
|
|
/* The first descriptor set the NEXT bit to 1 */
|
|
if (i == 0)
|
|
- desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
else
|
|
- desc[i].flag &= ~cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag &= ~cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
|
|
for (j = 0; j < HCLGE_TC_NUM_ONE_DESC; j++) {
|
|
idx = i * HCLGE_TC_NUM_ONE_DESC + j;
|
|
@@ -107,9 +107,9 @@ int hns3_cmd_common_thrd_config(struct hclge_dev *hdev, u16 tc,
|
|
req = (struct hclge_rx_com_thrd *)desc[i].data;
|
|
|
|
if (i == 0)
|
|
- desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
else
|
|
- desc[i].flag &= ~cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag &= ~cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
|
|
for (j = 0; j < HCLGE_TC_NUM_ONE_DESC; j++) {
|
|
idx = i * HCLGE_TC_NUM_ONE_DESC + j;
|
|
@@ -353,9 +353,9 @@ int hns3_cae_show_comm_thres(const struct hns3_nic_priv *net_priv,
|
|
HCLGE_OPC_RX_COM_THRD_ALLOC,
|
|
true);
|
|
if (i == 0)
|
|
- desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
else
|
|
- desc[i].flag &= ~cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag &= ~cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
}
|
|
|
|
status = hns3_cae_cmd_send(hdev, desc, HNS3_CAE_THRD_ALLOC_BD_NUM);
|
|
@@ -404,9 +404,9 @@ int hns3_cae_show_rx_priv_wl(const struct hns3_nic_priv *net_priv,
|
|
HCLGE_OPC_RX_PRIV_WL_ALLOC,
|
|
true);
|
|
if (i == 0)
|
|
- desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
else
|
|
- desc[i].flag &= ~cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag &= ~cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
}
|
|
|
|
status = hns3_cae_cmd_send(hdev, desc, HNS3_CAE_WL_ALLOC_BD_NUM);
|
|
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_xsfp.c b/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_xsfp.c
|
|
index d6295d9e7427..71a4bd22c4ba 100644
|
|
--- a/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_xsfp.c
|
|
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3_cae/hns3_cae_xsfp.c
|
|
@@ -57,9 +57,9 @@ static int _hns3_get_sfpinfo(struct hnae3_handle *handle, u8 *buff,
|
|
desc[0].data[0] = offset | (size << 16);
|
|
|
|
if (i < HCLGE_SFP_INFO_LEN - 1)
|
|
- desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
else
|
|
- desc[i].flag &= ~(cpu_to_le16(HCLGE_CMD_FLAG_NEXT));
|
|
+ desc[i].flag &= ~(cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT));
|
|
}
|
|
|
|
ret = hns3_cae_cmd_send(hdev, desc, HCLGE_SFP_INFO_LEN);
|
|
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3_common/hclge_comm_cmd.c b/drivers/net/ethernet/hisilicon/hns3/hns3_common/hclge_comm_cmd.c
|
|
index c96620269037..67c084f7dce0 100644
|
|
--- a/drivers/net/ethernet/hisilicon/hns3/hns3_common/hclge_comm_cmd.c
|
|
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3_common/hclge_comm_cmd.c
|
|
@@ -77,7 +77,7 @@ static int hclge_comm_alloc_cmd_desc(struct hclge_comm_cmq_ring *ring)
|
|
{
|
|
int size = ring->desc_num * sizeof(struct hclge_desc);
|
|
|
|
- ring->desc = dma_alloc_coherent(&ring->pdev->dev,
|
|
+ ring->desc = dma_zalloc_coherent(&ring->pdev->dev,
|
|
size, &ring->desc_dma_addr, GFP_KERNEL);
|
|
if (!ring->desc)
|
|
return -ENOMEM;
|
|
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.c b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.c
|
|
index dc73c90605dc..3e06eba7a90c 100644
|
|
--- a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.c
|
|
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.c
|
|
@@ -12,100 +12,6 @@
|
|
#include "hnae3.h"
|
|
#include "hclge_main.h"
|
|
|
|
-static int hclge_alloc_cmd_desc(struct hclge_comm_cmq_ring *ring)
|
|
-{
|
|
- int size = ring->desc_num * sizeof(struct hclge_desc);
|
|
-
|
|
- ring->desc = dma_zalloc_coherent(cmq_ring_to_dev(ring),
|
|
- size, &ring->desc_dma_addr,
|
|
- GFP_KERNEL);
|
|
- if (!ring->desc)
|
|
- return -ENOMEM;
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static void hclge_free_cmd_desc(struct hclge_comm_cmq_ring *ring)
|
|
-{
|
|
- int size = ring->desc_num * sizeof(struct hclge_desc);
|
|
-
|
|
- if (ring->desc) {
|
|
- dma_free_coherent(&ring->pdev->dev, size,
|
|
- ring->desc, ring->desc_dma_addr);
|
|
- ring->desc = NULL;
|
|
- }
|
|
-}
|
|
-
|
|
-static int hclge_alloc_cmd_queue(struct hclge_dev *hdev, int ring_type)
|
|
-{
|
|
- struct hclge_hw *hw = &hdev->hw;
|
|
- struct hclge_comm_cmq_ring *ring =
|
|
- (ring_type == HCLGE_TYPE_CSQ) ? &hw->hw.cmq.csq :
|
|
- &hw->hw.cmq.crq;
|
|
- int ret;
|
|
-
|
|
- ring->ring_type = ring_type;
|
|
- ring->pdev = hdev->pdev;
|
|
-
|
|
- ret = hclge_alloc_cmd_desc(ring);
|
|
- if (ret) {
|
|
- dev_err(&hdev->pdev->dev, "descriptor %s alloc error %d\n",
|
|
- (ring_type == HCLGE_TYPE_CSQ) ? "CSQ" : "CRQ", ret);
|
|
- return ret;
|
|
- }
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-void hclge_cmd_reuse_desc(struct hclge_desc *desc, bool is_read)
|
|
-{
|
|
- desc->flag = cpu_to_le16(HCLGE_CMD_FLAG_NO_INTR | HCLGE_CMD_FLAG_IN);
|
|
- if (is_read)
|
|
- desc->flag |= cpu_to_le16(HCLGE_CMD_FLAG_WR);
|
|
- else
|
|
- desc->flag &= cpu_to_le16(~HCLGE_CMD_FLAG_WR);
|
|
-}
|
|
-
|
|
-void hclge_cmd_setup_basic_desc(struct hclge_desc *desc,
|
|
- enum hclge_opcode_type opcode, bool is_read)
|
|
-{
|
|
- memset((void *)desc, 0, sizeof(struct hclge_desc));
|
|
- desc->opcode = cpu_to_le16(opcode);
|
|
- desc->flag = cpu_to_le16(HCLGE_CMD_FLAG_NO_INTR | HCLGE_CMD_FLAG_IN);
|
|
-
|
|
- if (is_read)
|
|
- desc->flag |= cpu_to_le16(HCLGE_CMD_FLAG_WR);
|
|
-}
|
|
-
|
|
-static void hclge_cmd_config_regs(struct hclge_hw *hw,
|
|
- struct hclge_comm_cmq_ring *ring)
|
|
-{
|
|
- dma_addr_t dma = ring->desc_dma_addr;
|
|
- u32 reg_val;
|
|
-
|
|
- if (ring->ring_type == HCLGE_TYPE_CSQ) {
|
|
- hclge_write_dev(hw, HCLGE_NIC_CSQ_BASEADDR_L_REG,
|
|
- lower_32_bits(dma));
|
|
- hclge_write_dev(hw, HCLGE_NIC_CSQ_BASEADDR_H_REG,
|
|
- upper_32_bits(dma));
|
|
- reg_val = hclge_read_dev(hw, HCLGE_NIC_CSQ_DEPTH_REG);
|
|
- reg_val &= HCLGE_NIC_SW_RST_RDY;
|
|
- reg_val |= ring->desc_num >> HCLGE_NIC_CMQ_DESC_NUM_S;
|
|
- hclge_write_dev(hw, HCLGE_NIC_CSQ_DEPTH_REG, reg_val);
|
|
- hclge_write_dev(hw, HCLGE_NIC_CSQ_HEAD_REG, 0);
|
|
- hclge_write_dev(hw, HCLGE_NIC_CSQ_TAIL_REG, 0);
|
|
- } else {
|
|
- hclge_write_dev(hw, HCLGE_NIC_CRQ_BASEADDR_L_REG,
|
|
- lower_32_bits(dma));
|
|
- hclge_write_dev(hw, HCLGE_NIC_CRQ_BASEADDR_H_REG,
|
|
- upper_32_bits(dma));
|
|
- hclge_write_dev(hw, HCLGE_NIC_CRQ_DEPTH_REG,
|
|
- ring->desc_num >> HCLGE_NIC_CMQ_DESC_NUM_S);
|
|
- hclge_write_dev(hw, HCLGE_NIC_CRQ_HEAD_REG, 0);
|
|
- hclge_write_dev(hw, HCLGE_NIC_CRQ_TAIL_REG, 0);
|
|
- }
|
|
-}
|
|
-
|
|
static void hclge_cmd_clear_regs(struct hclge_hw *hw)
|
|
{
|
|
hclge_write_dev(hw, HCLGE_NIC_CSQ_BASEADDR_L_REG, 0);
|
|
@@ -120,12 +26,6 @@ static void hclge_cmd_clear_regs(struct hclge_hw *hw)
|
|
hclge_write_dev(hw, HCLGE_NIC_CRQ_TAIL_REG, 0);
|
|
}
|
|
|
|
-static void hclge_cmd_init_regs(struct hclge_hw *hw)
|
|
-{
|
|
- hclge_cmd_config_regs(hw, &hw->hw.cmq.csq);
|
|
- hclge_cmd_config_regs(hw, &hw->hw.cmq.crq);
|
|
-}
|
|
-
|
|
/**
|
|
* hclge_cmd_send - send command to command queue
|
|
* @hw: pointer to the hw struct
|
|
@@ -140,74 +40,6 @@ int hclge_cmd_send(struct hclge_hw *hw, struct hclge_desc *desc, int num)
|
|
return hclge_comm_cmd_send(&hw->hw, desc, num);
|
|
}
|
|
|
|
-static void hclge_set_default_capability(struct hclge_dev *hdev)
|
|
-{
|
|
- struct hnae3_ae_dev *ae_dev = pci_get_drvdata(hdev->pdev);
|
|
-
|
|
- set_bit(HNAE3_DEV_SUPPORT_FD_B, ae_dev->caps);
|
|
- set_bit(HNAE3_DEV_SUPPORT_GRO_B, ae_dev->caps);
|
|
- set_bit(HNAE3_DEV_SUPPORT_FEC_B, ae_dev->caps);
|
|
-}
|
|
-
|
|
-static const struct hclge_caps_bit_map hclge_cmd_caps_bit_map0[] = {
|
|
- {HCLGE_CAP_UDP_GSO_B, HNAE3_DEV_SUPPORT_UDP_GSO_B},
|
|
- {HCLGE_CAP_PTP_B, HNAE3_DEV_SUPPORT_PTP_B},
|
|
- {HCLGE_CAP_INT_QL_B, HNAE3_DEV_SUPPORT_INT_QL_B},
|
|
- {HCLGE_CAP_TQP_TXRX_INDEP_B, HNAE3_DEV_SUPPORT_TQP_TXRX_INDEP_B},
|
|
- {HCLGE_CAP_HW_TX_CSUM_B, HNAE3_DEV_SUPPORT_HW_TX_CSUM_B},
|
|
- {HCLGE_CAP_UDP_TUNNEL_CSUM_B, HNAE3_DEV_SUPPORT_UDP_TUNNEL_CSUM_B},
|
|
- {HCLGE_CAP_FD_FORWARD_TC_B, HNAE3_DEV_SUPPORT_FD_FORWARD_TC_B},
|
|
- {HCLGE_CAP_FEC_B, HNAE3_DEV_SUPPORT_FEC_B},
|
|
- {HCLGE_CAP_PAUSE_B, HNAE3_DEV_SUPPORT_PAUSE_B},
|
|
- {HCLGE_CAP_PHY_IMP_B, HNAE3_DEV_SUPPORT_PHY_IMP_B},
|
|
- {HCLGE_CAP_RAS_IMP_B, HNAE3_DEV_SUPPORT_RAS_IMP_B},
|
|
- {HCLGE_CAP_RXD_ADV_LAYOUT_B, HNAE3_DEV_SUPPORT_RXD_ADV_LAYOUT_B},
|
|
- {HCLGE_CAP_PORT_VLAN_BYPASS_B, HNAE3_DEV_SUPPORT_PORT_VLAN_BYPASS_B},
|
|
- {HCLGE_CAP_PORT_VLAN_BYPASS_B, HNAE3_DEV_SUPPORT_VLAN_FLTR_MDF_B},
|
|
-};
|
|
-
|
|
-static void hclge_parse_capability(struct hclge_dev *hdev,
|
|
- struct hclge_query_version_cmd *cmd)
|
|
-{
|
|
- struct hnae3_ae_dev *ae_dev = pci_get_drvdata(hdev->pdev);
|
|
- u32 caps, i;
|
|
-
|
|
- caps = __le32_to_cpu(cmd->caps[0]);
|
|
- for (i = 0; i < ARRAY_SIZE(hclge_cmd_caps_bit_map0); i++)
|
|
- if (hnae3_get_bit(caps, hclge_cmd_caps_bit_map0[i].imp_bit))
|
|
- set_bit(hclge_cmd_caps_bit_map0[i].local_bit,
|
|
- ae_dev->caps);
|
|
-}
|
|
-
|
|
-static enum hclge_comm_cmd_status
|
|
-hclge_cmd_query_version_and_capability(struct hclge_dev *hdev)
|
|
-{
|
|
- struct hnae3_ae_dev *ae_dev = pci_get_drvdata(hdev->pdev);
|
|
- struct hclge_query_version_cmd *resp;
|
|
- struct hclge_desc desc;
|
|
- int ret;
|
|
-
|
|
- hclge_cmd_setup_basic_desc(&desc, HCLGE_OPC_QUERY_FW_VER, 1);
|
|
- resp = (struct hclge_query_version_cmd *)desc.data;
|
|
-
|
|
- ret = hclge_cmd_send(&hdev->hw, &desc, 1);
|
|
- if (ret)
|
|
- return ret;
|
|
-
|
|
- hdev->fw_version = le32_to_cpu(resp->firmware);
|
|
-
|
|
- ae_dev->dev_version = le32_to_cpu(resp->hardware) <<
|
|
- HNAE3_PCI_REVISION_BIT_SIZE;
|
|
- ae_dev->dev_version |= hdev->pdev->revision;
|
|
-
|
|
- if (ae_dev->dev_version >= HNAE3_DEVICE_VERSION_V2)
|
|
- hclge_set_default_capability(hdev);
|
|
-
|
|
- hclge_parse_capability(hdev, resp);
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
int hclge_cmd_queue_init(struct hclge_dev *hdev)
|
|
{
|
|
struct hclge_comm_cmq *cmdq = &hdev->hw.hw.cmq;
|
|
@@ -233,14 +65,14 @@ int hclge_cmd_queue_init(struct hclge_dev *hdev)
|
|
cmdq->tx_timeout = HCLGE_CMDQ_TX_TIMEOUT;
|
|
|
|
/* Setup queue rings */
|
|
- ret = hclge_alloc_cmd_queue(hdev, HCLGE_TYPE_CSQ);
|
|
+ ret = hclge_comm_alloc_cmd_queue(&hdev->hw.hw, HCLGE_COMM_TYPE_CSQ);
|
|
if (ret) {
|
|
dev_err(&hdev->pdev->dev,
|
|
"CSQ ring setup error %d\n", ret);
|
|
return ret;
|
|
}
|
|
|
|
- ret = hclge_alloc_cmd_queue(hdev, HCLGE_TYPE_CRQ);
|
|
+ ret = hclge_comm_alloc_cmd_queue(&hdev->hw.hw, HCLGE_COMM_TYPE_CRQ);
|
|
if (ret) {
|
|
dev_err(&hdev->pdev->dev,
|
|
"CRQ ring setup error %d\n", ret);
|
|
@@ -249,35 +81,10 @@ int hclge_cmd_queue_init(struct hclge_dev *hdev)
|
|
|
|
return 0;
|
|
err_csq:
|
|
- hclge_free_cmd_desc(&hdev->hw.hw.cmq.csq);
|
|
+ hclge_comm_free_cmd_desc(&hdev->hw.hw.cmq.csq);
|
|
return ret;
|
|
}
|
|
|
|
-/* ask the firmware to enable some features, driver can work without it. */
|
|
-static int hclge_firmware_compat_config(struct hclge_dev *hdev, bool en)
|
|
-{
|
|
- struct hclge_firmware_compat_cmd *req;
|
|
- struct hclge_desc desc;
|
|
- u32 compat = 0;
|
|
-
|
|
- hclge_cmd_setup_basic_desc(&desc, HCLGE_OPC_IMP_COMPAT_CFG, false);
|
|
-
|
|
- if (en) {
|
|
- req = (struct hclge_firmware_compat_cmd *)desc.data;
|
|
-
|
|
- hnae3_set_bit(compat, HCLGE_LINK_EVENT_REPORT_EN_B, 1);
|
|
- hnae3_set_bit(compat, HCLGE_NCSI_ERROR_REPORT_EN_B, 1);
|
|
- if (hnae3_dev_phy_imp_supported(hdev))
|
|
- hnae3_set_bit(compat, HCLGE_PHY_IMP_EN_B, 1);
|
|
- hnae3_set_bit(compat, HCLGE_MAC_STATS_EXT_EN_B, 1);
|
|
- hnae3_set_bit(compat, HCLGE_SYNC_RX_RING_HEAD_EN_B, 1);
|
|
-
|
|
- req->compat = cpu_to_le32(compat);
|
|
- }
|
|
-
|
|
- return hclge_cmd_send(&hdev->hw, &desc, 1);
|
|
-}
|
|
-
|
|
int hclge_cmd_init(struct hclge_dev *hdev)
|
|
{
|
|
struct hclge_comm_cmq *cmdq = &hdev->hw.hw.cmq;
|
|
@@ -291,7 +98,7 @@ int hclge_cmd_init(struct hclge_dev *hdev)
|
|
cmdq->crq.next_to_clean = 0;
|
|
cmdq->crq.next_to_use = 0;
|
|
|
|
- hclge_cmd_init_regs(&hdev->hw);
|
|
+ hclge_comm_cmd_init_regs(&hdev->hw.hw);
|
|
|
|
spin_unlock(&cmdq->crq.lock);
|
|
spin_unlock_bh(&cmdq->csq.lock);
|
|
@@ -310,7 +117,10 @@ int hclge_cmd_init(struct hclge_dev *hdev)
|
|
}
|
|
|
|
/* get version and device capabilities */
|
|
- ret = hclge_cmd_query_version_and_capability(hdev);
|
|
+ ret = hclge_comm_cmd_query_version_and_capability(hdev->ae_dev,
|
|
+ &hdev->hw.hw,
|
|
+ &hdev->fw_version,
|
|
+ true);
|
|
if (ret) {
|
|
dev_err(&hdev->pdev->dev,
|
|
"failed to query version and capabilities, ret = %d\n",
|
|
@@ -331,7 +141,8 @@ int hclge_cmd_init(struct hclge_dev *hdev)
|
|
/* ask the firmware to enable some features, driver can work without
|
|
* it.
|
|
*/
|
|
- ret = hclge_firmware_compat_config(hdev, true);
|
|
+ ret = hclge_comm_firmware_compat_config(hdev->ae_dev,
|
|
+ &hdev->hw.hw, true);
|
|
if (ret)
|
|
dev_warn(&hdev->pdev->dev,
|
|
"Firmware compatible features not enabled(%d).\n",
|
|
@@ -351,7 +162,8 @@ void hclge_cmd_uninit(struct hclge_dev *hdev)
|
|
|
|
cmdq->csq.pdev = hdev->pdev;
|
|
|
|
- hclge_firmware_compat_config(hdev, false);
|
|
+ hclge_comm_firmware_compat_config(hdev->ae_dev, &hdev->hw.hw,
|
|
+ false);
|
|
|
|
set_bit(HCLGE_COMM_STATE_CMD_DISABLE, &hdev->hw.hw.comm_state);
|
|
/* wait to ensure that the firmware completes the possible left
|
|
@@ -364,6 +176,6 @@ void hclge_cmd_uninit(struct hclge_dev *hdev)
|
|
spin_unlock(&cmdq->crq.lock);
|
|
spin_unlock_bh(&cmdq->csq.lock);
|
|
|
|
- hclge_free_cmd_desc(&cmdq->csq);
|
|
- hclge_free_cmd_desc(&cmdq->crq);
|
|
+ hclge_comm_free_cmd_desc(&cmdq->csq);
|
|
+ hclge_comm_free_cmd_desc(&cmdq->crq);
|
|
}
|
|
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.h b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.h
|
|
index c2b23b31690e..1262d708a9ff 100644
|
|
--- a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.h
|
|
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_cmd.h
|
|
@@ -23,12 +23,9 @@ struct hclge_misc_vector {
|
|
char name[HNAE3_INT_NAME_LEN];
|
|
};
|
|
|
|
-#define HCLGE_CMD_FLAG_IN BIT(0)
|
|
-#define HCLGE_CMD_FLAG_OUT BIT(1)
|
|
-#define HCLGE_CMD_FLAG_NEXT BIT(2)
|
|
-#define HCLGE_CMD_FLAG_WR BIT(3)
|
|
-#define HCLGE_CMD_FLAG_NO_INTR BIT(4)
|
|
-#define HCLGE_CMD_FLAG_ERR_INTR BIT(5)
|
|
+#define hclge_cmd_setup_basic_desc(desc, opcode, is_read) \
|
|
+ hclge_comm_cmd_setup_basic_desc(desc, (enum hclge_comm_opcode_type)opcode, \
|
|
+ is_read)
|
|
|
|
#define HCLGE_TQP_REG_OFFSET 0x80000
|
|
#define HCLGE_TQP_REG_SIZE 0x200
|
|
@@ -96,34 +93,6 @@ struct hclge_rx_priv_buff_cmd {
|
|
u8 rsv[6];
|
|
};
|
|
|
|
-enum HCLGE_CAP_BITS {
|
|
- HCLGE_CAP_UDP_GSO_B,
|
|
- HCLGE_CAP_QB_B,
|
|
- HCLGE_CAP_FD_FORWARD_TC_B,
|
|
- HCLGE_CAP_PTP_B,
|
|
- HCLGE_CAP_INT_QL_B,
|
|
- HCLGE_CAP_HW_TX_CSUM_B,
|
|
- HCLGE_CAP_TX_PUSH_B,
|
|
- HCLGE_CAP_PHY_IMP_B,
|
|
- HCLGE_CAP_TQP_TXRX_INDEP_B,
|
|
- HCLGE_CAP_HW_PAD_B,
|
|
- HCLGE_CAP_STASH_B,
|
|
- HCLGE_CAP_UDP_TUNNEL_CSUM_B,
|
|
- HCLGE_CAP_RAS_IMP_B = 12,
|
|
- HCLGE_CAP_FEC_B = 13,
|
|
- HCLGE_CAP_PAUSE_B = 14,
|
|
- HCLGE_CAP_RXD_ADV_LAYOUT_B = 15,
|
|
- HCLGE_CAP_PORT_VLAN_BYPASS_B = 17,
|
|
-};
|
|
-
|
|
-#define HCLGE_QUERY_CAP_LENGTH 3
|
|
-struct hclge_query_version_cmd {
|
|
- __le32 firmware;
|
|
- __le32 hardware;
|
|
- __le32 rsv;
|
|
- __le32 caps[HCLGE_QUERY_CAP_LENGTH]; /* capabilities of device */
|
|
-};
|
|
-
|
|
#define HCLGE_RX_PRIV_EN_B 15
|
|
#define HCLGE_TC_NUM_ONE_DESC 4
|
|
struct hclge_priv_wl {
|
|
@@ -747,13 +716,6 @@ struct hclge_common_lb_cmd {
|
|
#define HCLGE_DEFAULT_NON_DCB_DV 0x7800 /* 30K byte */
|
|
#define HCLGE_NON_DCB_ADDITIONAL_BUF 0x1400 /* 5120 byte */
|
|
|
|
-#define HCLGE_TYPE_CRQ 0
|
|
-#define HCLGE_TYPE_CSQ 1
|
|
-
|
|
-/* this bit indicates that the driver is ready for hardware reset */
|
|
-#define HCLGE_NIC_SW_RST_RDY_B 16
|
|
-#define HCLGE_NIC_SW_RST_RDY BIT(HCLGE_NIC_SW_RST_RDY_B)
|
|
-
|
|
#define HCLGE_NIC_CMQ_DESC_NUM 1024
|
|
#define HCLGE_NIC_CMQ_DESC_NUM_S 3
|
|
|
|
@@ -894,16 +856,6 @@ struct hclge_query_ppu_pf_other_int_dfx_cmd {
|
|
u8 rsv[4];
|
|
};
|
|
|
|
-#define HCLGE_LINK_EVENT_REPORT_EN_B 0
|
|
-#define HCLGE_NCSI_ERROR_REPORT_EN_B 1
|
|
-#define HCLGE_PHY_IMP_EN_B 2
|
|
-#define HCLGE_MAC_STATS_EXT_EN_B 3
|
|
-#define HCLGE_SYNC_RX_RING_HEAD_EN_B 4
|
|
-struct hclge_firmware_compat_cmd {
|
|
- __le32 compat;
|
|
- u8 rsv[20];
|
|
-};
|
|
-
|
|
#define HCLGE_SFP_INFO_CMD_NUM 6
|
|
#define HCLGE_SFP_INFO_BD0_LEN 20
|
|
#define HCLGE_SFP_INFO_BDX_LEN 24
|
|
@@ -989,12 +941,6 @@ struct hclge_phy_reg_cmd {
|
|
u8 rsv2[12];
|
|
};
|
|
|
|
-/* capabilities bits map between imp firmware and local driver */
|
|
-struct hclge_caps_bit_map {
|
|
- u16 imp_bit;
|
|
- u16 local_bit;
|
|
-};
|
|
-
|
|
int hclge_cmd_init(struct hclge_dev *hdev);
|
|
enum HCLGE_WOL_MODE {
|
|
HCLGE_WOL_PHY = BIT(0),
|
|
@@ -1022,10 +968,6 @@ struct hclge_query_wol_supported_cmd {
|
|
|
|
struct hclge_hw;
|
|
int hclge_cmd_send(struct hclge_hw *hw, struct hclge_desc *desc, int num);
|
|
-void hclge_cmd_setup_basic_desc(struct hclge_desc *desc,
|
|
- enum hclge_opcode_type opcode, bool is_read);
|
|
-void hclge_cmd_reuse_desc(struct hclge_desc *desc, bool is_read);
|
|
-
|
|
enum hclge_comm_cmd_status hclge_cmd_mdio_write(struct hclge_hw *hw,
|
|
struct hclge_desc *desc);
|
|
enum hclge_comm_cmd_status hclge_cmd_mdio_read(struct hclge_hw *hw,
|
|
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_debugfs.c b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_debugfs.c
|
|
index 087079070353..407ba8d9a10c 100644
|
|
--- a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_debugfs.c
|
|
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_debugfs.c
|
|
@@ -165,7 +165,7 @@ static int hclge_dbg_cmd_send(struct hclge_dev *hdev,
|
|
desc->data[0] = cpu_to_le32(index);
|
|
|
|
for (i = 1; i < bd_num; i++) {
|
|
- desc->flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc->flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
desc++;
|
|
hclge_cmd_setup_basic_desc(desc, cmd, true);
|
|
}
|
|
@@ -1259,7 +1259,7 @@ static int hclge_dbg_dump_rx_priv_wl_buf_cfg(struct hclge_dev *hdev, char *buf,
|
|
int i, ret;
|
|
|
|
hclge_cmd_setup_basic_desc(&desc[0], HCLGE_OPC_RX_PRIV_WL_ALLOC, true);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[1], HCLGE_OPC_RX_PRIV_WL_ALLOC, true);
|
|
ret = hclge_cmd_send(&hdev->hw, desc, 2);
|
|
if (ret) {
|
|
@@ -1295,7 +1295,7 @@ static int hclge_dbg_dump_rx_common_threshold_cfg(struct hclge_dev *hdev,
|
|
int i, ret;
|
|
|
|
hclge_cmd_setup_basic_desc(&desc[0], HCLGE_OPC_RX_COM_THRD_ALLOC, true);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[1], HCLGE_OPC_RX_COM_THRD_ALLOC, true);
|
|
ret = hclge_cmd_send(&hdev->hw, desc, 2);
|
|
if (ret) {
|
|
@@ -1397,10 +1397,10 @@ static int hclge_dbg_dump_mac_table(struct hclge_dev *hdev, char *buf, int len)
|
|
|
|
hclge_cmd_setup_basic_desc(&desc[0], HCLGE_PPP_MAC_VLAN_IDX_RD,
|
|
true);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[1], HCLGE_PPP_MAC_VLAN_IDX_RD,
|
|
true);
|
|
- desc[1].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[1].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[2], HCLGE_PPP_MAC_VLAN_IDX_RD,
|
|
true);
|
|
|
|
@@ -1555,9 +1555,9 @@ static int hclge_dbg_fd_tcam_read(struct hclge_dev *hdev, bool sel_x,
|
|
u32 *req;
|
|
|
|
hclge_cmd_setup_basic_desc(&desc[0], HCLGE_OPC_FD_TCAM_OP, true);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[1], HCLGE_OPC_FD_TCAM_OP, true);
|
|
- desc[1].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[1].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[2], HCLGE_OPC_FD_TCAM_OP, true);
|
|
|
|
req1 = (struct hclge_fd_tcam_config_1_cmd *)desc[0].data;
|
|
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_err.c b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_err.c
|
|
index 5733f7c25bde..68b53d4020f7 100644
|
|
--- a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_err.c
|
|
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_err.c
|
|
@@ -1399,7 +1399,7 @@ static int hclge_config_common_hw_err_int(struct hclge_dev *hdev, bool en)
|
|
|
|
/* configure common error interrupts */
|
|
hclge_cmd_setup_basic_desc(&desc[0], HCLGE_COMMON_ECC_INT_CFG, false);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[1], HCLGE_COMMON_ECC_INT_CFG, false);
|
|
|
|
if (en) {
|
|
@@ -1498,7 +1498,7 @@ static int hclge_config_ppp_error_interrupt(struct hclge_dev *hdev, u32 cmd,
|
|
|
|
/* configure PPP error interrupts */
|
|
hclge_cmd_setup_basic_desc(&desc[0], cmd, false);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[1], cmd, false);
|
|
|
|
if (cmd == HCLGE_PPP_CMD0_INT_CMD) {
|
|
@@ -1630,7 +1630,7 @@ static int hclge_config_ppu_error_interrupts(struct hclge_dev *hdev, u32 cmd,
|
|
/* configure PPU error interrupts */
|
|
if (cmd == HCLGE_PPU_MPF_ECC_INT_CMD) {
|
|
hclge_cmd_setup_basic_desc(&desc[0], cmd, false);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[1], cmd, false);
|
|
if (en) {
|
|
desc[0].data[0] =
|
|
@@ -1715,7 +1715,7 @@ static int hclge_config_ssu_hw_err_int(struct hclge_dev *hdev, bool en)
|
|
|
|
/* configure SSU ecc error interrupts */
|
|
hclge_cmd_setup_basic_desc(&desc[0], HCLGE_SSU_ECC_INT_CMD, false);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[1], HCLGE_SSU_ECC_INT_CMD, false);
|
|
if (en) {
|
|
desc[0].data[0] = cpu_to_le32(HCLGE_SSU_1BIT_ECC_ERR_INT_EN);
|
|
@@ -1737,7 +1737,7 @@ static int hclge_config_ssu_hw_err_int(struct hclge_dev *hdev, bool en)
|
|
|
|
/* configure SSU common error interrupts */
|
|
hclge_cmd_setup_basic_desc(&desc[0], HCLGE_SSU_COMMON_INT_CMD, false);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[1], HCLGE_SSU_COMMON_INT_CMD, false);
|
|
|
|
if (en) {
|
|
@@ -1960,7 +1960,7 @@ static int hclge_handle_mpf_ras_error(struct hclge_dev *hdev,
|
|
&ae_dev->hw_err_reset_req);
|
|
|
|
/* clear all main PF RAS errors */
|
|
- hclge_cmd_reuse_desc(&desc[0], false);
|
|
+ hclge_comm_cmd_reuse_desc(&desc[0], false);
|
|
ret = hclge_cmd_send(&hdev->hw, &desc[0], num);
|
|
if (ret)
|
|
dev_err(dev, "clear all mpf ras int cmd failed (%d)\n", ret);
|
|
@@ -2033,7 +2033,7 @@ static int hclge_handle_pf_ras_error(struct hclge_dev *hdev,
|
|
}
|
|
|
|
/* clear all PF RAS errors */
|
|
- hclge_cmd_reuse_desc(&desc[0], false);
|
|
+ hclge_comm_cmd_reuse_desc(&desc[0], false);
|
|
ret = hclge_cmd_send(&hdev->hw, &desc[0], num);
|
|
if (ret)
|
|
dev_err(dev, "clear all pf ras int cmd failed (%d)\n", ret);
|
|
@@ -2084,8 +2084,8 @@ static int hclge_log_rocee_axi_error(struct hclge_dev *hdev)
|
|
true);
|
|
hclge_cmd_setup_basic_desc(&desc[2], HCLGE_QUERY_ROCEE_AXI_RAS_INFO_CMD,
|
|
true);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
- desc[1].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
+ desc[1].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
|
|
ret = hclge_cmd_send(&hdev->hw, &desc[0], 3);
|
|
if (ret) {
|
|
@@ -2116,7 +2116,7 @@ static int hclge_log_rocee_ecc_error(struct hclge_dev *hdev)
|
|
|
|
ret = hclge_cmd_query_error(hdev, &desc[0],
|
|
HCLGE_QUERY_ROCEE_ECC_RAS_INFO_CMD,
|
|
- HCLGE_CMD_FLAG_NEXT);
|
|
+ HCLGE_COMM_CMD_FLAG_NEXT);
|
|
if (ret) {
|
|
dev_err(dev, "failed(%d) to query ROCEE ECC error sts\n", ret);
|
|
return ret;
|
|
@@ -2232,7 +2232,7 @@ hclge_log_and_clear_rocee_ras_error(struct hclge_dev *hdev)
|
|
}
|
|
|
|
/* clear error status */
|
|
- hclge_cmd_reuse_desc(&desc[0], false);
|
|
+ hclge_comm_cmd_reuse_desc(&desc[0], false);
|
|
ret = hclge_cmd_send(&hdev->hw, &desc[0], 1);
|
|
if (ret) {
|
|
dev_err(dev, "failed(%d) to clear ROCEE RAS error\n", ret);
|
|
@@ -2405,7 +2405,8 @@ static int hclge_clear_hw_msix_error(struct hclge_dev *hdev,
|
|
else
|
|
desc[0].opcode = cpu_to_le16(HCLGE_QUERY_CLEAR_ALL_PF_MSIX_INT);
|
|
|
|
- desc[0].flag = cpu_to_le16(HCLGE_CMD_FLAG_NO_INTR | HCLGE_CMD_FLAG_IN);
|
|
+ desc[0].flag = cpu_to_le16(HCLGE_COMM_CMD_FLAG_NO_INTR |
|
|
+ HCLGE_COMM_CMD_FLAG_IN);
|
|
|
|
return hclge_cmd_send(&hdev->hw, &desc[0], bd_num);
|
|
}
|
|
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
|
|
index f680f58451db..7a218cd6c37c 100644
|
|
--- a/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
|
|
+++ b/drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
|
|
@@ -1581,7 +1581,7 @@ static int hclge_query_dev_specs(struct hclge_dev *hdev)
|
|
for (i = 0; i < HCLGE_QUERY_DEV_SPECS_BD_NUM - 1; i++) {
|
|
hclge_cmd_setup_basic_desc(&desc[i], HCLGE_OPC_QUERY_DEV_SPECS,
|
|
true);
|
|
- desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
}
|
|
hclge_cmd_setup_basic_desc(&desc[i], HCLGE_OPC_QUERY_DEV_SPECS, true);
|
|
|
|
@@ -2432,9 +2432,9 @@ static int hclge_rx_priv_wl_config(struct hclge_dev *hdev,
|
|
|
|
/* The first descriptor set the NEXT bit to 1 */
|
|
if (i == 0)
|
|
- desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
else
|
|
- desc[i].flag &= ~cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag &= ~cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
|
|
for (j = 0; j < HCLGE_TC_NUM_ONE_DESC; j++) {
|
|
u32 idx = i * HCLGE_TC_NUM_ONE_DESC + j;
|
|
@@ -2477,9 +2477,9 @@ static int hclge_common_thrd_config(struct hclge_dev *hdev,
|
|
|
|
/* The first descriptor set the NEXT bit to 1 */
|
|
if (i == 0)
|
|
- desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
else
|
|
- desc[i].flag &= ~cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag &= ~cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
|
|
for (j = 0; j < HCLGE_TC_NUM_ONE_DESC; j++) {
|
|
tc = &s_buf->tc_thrd[i * HCLGE_TC_NUM_ONE_DESC + j];
|
|
@@ -3424,7 +3424,7 @@ static int hclge_get_phy_link_ksettings(struct hnae3_handle *handle,
|
|
|
|
hclge_cmd_setup_basic_desc(&desc[0], HCLGE_OPC_PHY_LINK_KSETTING,
|
|
true);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[1], HCLGE_OPC_PHY_LINK_KSETTING,
|
|
true);
|
|
|
|
@@ -3481,7 +3481,7 @@ hclge_set_phy_link_ksettings(struct hnae3_handle *handle,
|
|
|
|
hclge_cmd_setup_basic_desc(&desc[0], HCLGE_OPC_PHY_LINK_KSETTING,
|
|
false);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[1], HCLGE_OPC_PHY_LINK_KSETTING,
|
|
false);
|
|
|
|
@@ -4071,7 +4071,7 @@ static void hclge_func_reset_sync_vf(struct hclge_dev *hdev)
|
|
return;
|
|
}
|
|
msleep(HCLGE_PF_RESET_SYNC_TIME);
|
|
- hclge_cmd_reuse_desc(&desc, true);
|
|
+ hclge_comm_cmd_reuse_desc(&desc, true);
|
|
} while (cnt++ < HCLGE_PF_RESET_SYNC_CNT);
|
|
|
|
dev_warn(&hdev->pdev->dev, "sync with VF timeout!\n");
|
|
@@ -4230,9 +4230,9 @@ static void hclge_reset_handshake(struct hclge_dev *hdev, bool enable)
|
|
|
|
reg_val = hclge_read_dev(&hdev->hw, HCLGE_NIC_CSQ_DEPTH_REG);
|
|
if (enable)
|
|
- reg_val |= HCLGE_NIC_SW_RST_RDY;
|
|
+ reg_val |= HCLGE_COMM_NIC_SW_RST_RDY;
|
|
else
|
|
- reg_val &= ~HCLGE_NIC_SW_RST_RDY;
|
|
+ reg_val &= ~HCLGE_COMM_NIC_SW_RST_RDY;
|
|
|
|
hclge_write_dev(&hdev->hw, HCLGE_NIC_CSQ_DEPTH_REG, reg_val);
|
|
}
|
|
@@ -5971,9 +5971,9 @@ static int hclge_fd_tcam_config(struct hclge_dev *hdev, u8 stage, bool sel_x,
|
|
int ret;
|
|
|
|
hclge_cmd_setup_basic_desc(&desc[0], HCLGE_OPC_FD_TCAM_OP, false);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[1], HCLGE_OPC_FD_TCAM_OP, false);
|
|
- desc[1].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[1].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[2], HCLGE_OPC_FD_TCAM_OP, false);
|
|
|
|
req1 = (struct hclge_fd_tcam_config_1_cmd *)desc[0].data;
|
|
@@ -7774,7 +7774,7 @@ static int hclge_config_switch_param(struct hclge_dev *hdev, int vfid,
|
|
}
|
|
|
|
/* modify and write new config parameter */
|
|
- hclge_cmd_reuse_desc(&desc, false);
|
|
+ hclge_comm_cmd_reuse_desc(&desc, false);
|
|
req->switch_param = (req->switch_param & param_mask) | switch_param;
|
|
req->param_mask = param_mask;
|
|
|
|
@@ -7870,7 +7870,7 @@ static int hclge_set_app_loopback(struct hclge_dev *hdev, bool en)
|
|
/* 3 Config mac work mode with loopback flag
|
|
* and its original configure parameters
|
|
*/
|
|
- hclge_cmd_reuse_desc(&desc, false);
|
|
+ hclge_comm_cmd_reuse_desc(&desc, false);
|
|
ret = hclge_cmd_send(&hdev->hw, &desc, 1);
|
|
if (ret)
|
|
dev_err(&hdev->pdev->dev,
|
|
@@ -8448,10 +8448,10 @@ hclge_lookup_mc_mac_vlan_tbl(struct hclge_vport *vport,
|
|
int ret;
|
|
|
|
hclge_cmd_setup_basic_desc(&desc[0], HCLGE_OPC_MAC_VLAN_ADD, true);
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
memcpy(desc[0].data, req, sizeof(struct hclge_mac_vlan_tbl_entry_cmd));
|
|
hclge_cmd_setup_basic_desc(&desc[1], HCLGE_OPC_MAC_VLAN_ADD, true);
|
|
- desc[1].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[1].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
hclge_cmd_setup_basic_desc(&desc[2], HCLGE_OPC_MAC_VLAN_ADD, true);
|
|
|
|
ret = hclge_cmd_send(&hdev->hw, desc, 3);
|
|
@@ -8495,12 +8495,12 @@ static int hclge_add_mac_vlan_tbl(struct hclge_vport *vport,
|
|
resp_code,
|
|
HCLGE_MAC_VLAN_ADD);
|
|
} else {
|
|
- hclge_cmd_reuse_desc(&mc_desc[0], false);
|
|
- mc_desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
- hclge_cmd_reuse_desc(&mc_desc[1], false);
|
|
- mc_desc[1].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
- hclge_cmd_reuse_desc(&mc_desc[2], false);
|
|
- mc_desc[2].flag &= cpu_to_le16(~HCLGE_CMD_FLAG_NEXT);
|
|
+ hclge_comm_cmd_reuse_desc(&mc_desc[0], false);
|
|
+ mc_desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
+ hclge_comm_cmd_reuse_desc(&mc_desc[1], false);
|
|
+ mc_desc[1].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
+ hclge_comm_cmd_reuse_desc(&mc_desc[2], false);
|
|
+ mc_desc[2].flag &= cpu_to_le16(~HCLGE_COMM_CMD_FLAG_NEXT);
|
|
memcpy(mc_desc[0].data, req,
|
|
sizeof(struct hclge_mac_vlan_tbl_entry_cmd));
|
|
ret = hclge_cmd_send(&hdev->hw, mc_desc, 3);
|
|
@@ -9549,7 +9549,7 @@ static int hclge_set_vlan_filter_ctrl(struct hclge_dev *hdev, u8 vlan_type,
|
|
}
|
|
|
|
/* modify and write new config parameter */
|
|
- hclge_cmd_reuse_desc(&desc, false);
|
|
+ hclge_comm_cmd_reuse_desc(&desc, false);
|
|
req->vlan_fe = filter_en ?
|
|
(req->vlan_fe | fe_type) : (req->vlan_fe & ~fe_type);
|
|
|
|
@@ -9672,7 +9672,7 @@ static int hclge_set_vf_vlan_filter_cmd(struct hclge_dev *hdev, u16 vfid,
|
|
hclge_cmd_setup_basic_desc(&desc[1],
|
|
HCLGE_OPC_VLAN_FILTER_VF_CFG, false);
|
|
|
|
- desc[0].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[0].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
|
|
vf_byte_off = vfid / 8;
|
|
vf_byte_val = 1 << (vfid % 8);
|
|
@@ -12638,7 +12638,7 @@ int hclge_query_bd_num_cmd_send(struct hclge_dev *hdev, struct hclge_desc *desc)
|
|
for (i = 0; i < HCLGE_GET_DFX_REG_TYPE_CNT - 1; i++) {
|
|
hclge_cmd_setup_basic_desc(&desc[i], HCLGE_OPC_DFX_BD_NUM,
|
|
true);
|
|
- desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
}
|
|
|
|
/* initialize the last command BD */
|
|
@@ -12682,7 +12682,7 @@ static int hclge_dfx_reg_cmd_send(struct hclge_dev *hdev,
|
|
|
|
hclge_cmd_setup_basic_desc(desc, cmd, true);
|
|
for (i = 0; i < bd_num - 1; i++) {
|
|
- desc->flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc->flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
desc++;
|
|
hclge_cmd_setup_basic_desc(desc, cmd, true);
|
|
}
|
|
@@ -13124,7 +13124,7 @@ static u16 hclge_get_sfp_eeprom_info(struct hclge_dev *hdev, u32 offset,
|
|
|
|
/* bd0~bd4 need next flag */
|
|
if (i < HCLGE_SFP_INFO_CMD_NUM - 1)
|
|
- desc[i].flag |= cpu_to_le16(HCLGE_CMD_FLAG_NEXT);
|
|
+ desc[i].flag |= cpu_to_le16(HCLGE_COMM_CMD_FLAG_NEXT);
|
|
}
|
|
|
|
/* setup bd0, this bd contains offset and read length. */
|
|
--
|
|
2.34.1
|
|
|