提交 7b6859fb 编写于 作者: M Mintz, Yuval 提交者: David S. Miller

qed: Utilize FW 8.20.0.0

This pushes qed [and as result, all qed* drivers] into using 8.20.0.0
firmware. The changes are mostly contained in qed with minor changes
to qedi due to some HSI changes.

Content-wise, the firmware contains fixes to various issues exposed
since the release of the previous firmware, including:
 - Corrects iSCSI fast retransmit when data digest is enabled.
 - Stop draining packets when receiving several consecutive PFCs.
 - Prevent possible assertion when consecutively opening/closing
   many connections.
 - Prevent possible assertion due to too long BDQ fetch time.

In addition, the new firmware would allow us to later add iWARP support
in qed and qedr.

Changes from previous version
-----------------------------
 - V2: Fix warning in qed_debug.c
Signed-off-by: NChad Dupuis <Chad.Dupuis@cavium.com>
Signed-off-by: NRam Amrani <Ram.Amrani@cavium.com>
Signed-off-by: NTomer Tayar <Tomer.Tayar@cavium.com>
Signed-off-by: NManish Rangankar <Manish.Rangankar@cavium.com>
Signed-off-by: NYuval Mintz <Yuval.Mintz@cavium.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 b17b8a20
...@@ -54,7 +54,7 @@ extern const struct qed_common_ops qed_common_ops_pass; ...@@ -54,7 +54,7 @@ extern const struct qed_common_ops qed_common_ops_pass;
#define QED_MAJOR_VERSION 8 #define QED_MAJOR_VERSION 8
#define QED_MINOR_VERSION 10 #define QED_MINOR_VERSION 10
#define QED_REVISION_VERSION 10 #define QED_REVISION_VERSION 11
#define QED_ENGINEERING_VERSION 21 #define QED_ENGINEERING_VERSION 21
#define QED_VERSION \ #define QED_VERSION \
......
...@@ -944,17 +944,18 @@ void qed_dcbx_set_pf_update_params(struct qed_dcbx_results *p_src, ...@@ -944,17 +944,18 @@ void qed_dcbx_set_pf_update_params(struct qed_dcbx_results *p_src,
p_dest->pf_id = p_src->pf_id; p_dest->pf_id = p_src->pf_id;
update_flag = p_src->arr[DCBX_PROTOCOL_FCOE].update; update_flag = p_src->arr[DCBX_PROTOCOL_FCOE].update;
p_dest->update_fcoe_dcb_data_flag = update_flag; p_dest->update_fcoe_dcb_data_mode = update_flag;
update_flag = p_src->arr[DCBX_PROTOCOL_ROCE].update; update_flag = p_src->arr[DCBX_PROTOCOL_ROCE].update;
p_dest->update_roce_dcb_data_flag = update_flag; p_dest->update_roce_dcb_data_mode = update_flag;
update_flag = p_src->arr[DCBX_PROTOCOL_ROCE_V2].update; update_flag = p_src->arr[DCBX_PROTOCOL_ROCE_V2].update;
p_dest->update_roce_dcb_data_flag = update_flag; p_dest->update_rroce_dcb_data_mode = update_flag;
update_flag = p_src->arr[DCBX_PROTOCOL_ISCSI].update; update_flag = p_src->arr[DCBX_PROTOCOL_ISCSI].update;
p_dest->update_iscsi_dcb_data_flag = update_flag; p_dest->update_iscsi_dcb_data_mode = update_flag;
update_flag = p_src->arr[DCBX_PROTOCOL_ETH].update; update_flag = p_src->arr[DCBX_PROTOCOL_ETH].update;
p_dest->update_eth_dcb_data_flag = update_flag; p_dest->update_eth_dcb_data_mode = update_flag;
p_dcb_data = &p_dest->fcoe_dcb_data; p_dcb_data = &p_dest->fcoe_dcb_data;
qed_dcbx_update_protocol_data(p_dcb_data, p_src, DCBX_PROTOCOL_FCOE); qed_dcbx_update_protocol_data(p_dcb_data, p_src, DCBX_PROTOCOL_FCOE);
......
...@@ -20,6 +20,9 @@ enum qed_dbg_features { ...@@ -20,6 +20,9 @@ enum qed_dbg_features {
DBG_FEATURE_NUM DBG_FEATURE_NUM
}; };
/* Forward Declaration */
struct qed_dev;
int qed_dbg_grc(struct qed_dev *cdev, void *buffer, u32 *num_dumped_bytes); int qed_dbg_grc(struct qed_dev *cdev, void *buffer, u32 *num_dumped_bytes);
int qed_dbg_grc_size(struct qed_dev *cdev); int qed_dbg_grc_size(struct qed_dev *cdev);
int qed_dbg_idle_chk(struct qed_dev *cdev, void *buffer, int qed_dbg_idle_chk(struct qed_dev *cdev, void *buffer,
......
...@@ -375,7 +375,6 @@ static int qed_sp_iscsi_conn_offload(struct qed_hwfn *p_hwfn, ...@@ -375,7 +375,6 @@ static int qed_sp_iscsi_conn_offload(struct qed_hwfn *p_hwfn,
p_tcp->ss_thresh = cpu_to_le32(p_conn->ss_thresh); p_tcp->ss_thresh = cpu_to_le32(p_conn->ss_thresh);
p_tcp->srtt = cpu_to_le16(p_conn->srtt); p_tcp->srtt = cpu_to_le16(p_conn->srtt);
p_tcp->rtt_var = cpu_to_le16(p_conn->rtt_var); p_tcp->rtt_var = cpu_to_le16(p_conn->rtt_var);
p_tcp->ts_time = cpu_to_le32(p_conn->ts_time);
p_tcp->ts_recent = cpu_to_le32(p_conn->ts_recent); p_tcp->ts_recent = cpu_to_le32(p_conn->ts_recent);
p_tcp->ts_recent_age = cpu_to_le32(p_conn->ts_recent_age); p_tcp->ts_recent_age = cpu_to_le32(p_conn->ts_recent_age);
p_tcp->total_rt = cpu_to_le32(p_conn->total_rt); p_tcp->total_rt = cpu_to_le32(p_conn->total_rt);
...@@ -400,8 +399,6 @@ static int qed_sp_iscsi_conn_offload(struct qed_hwfn *p_hwfn, ...@@ -400,8 +399,6 @@ static int qed_sp_iscsi_conn_offload(struct qed_hwfn *p_hwfn,
p_tcp->mss = cpu_to_le16(p_conn->mss); p_tcp->mss = cpu_to_le16(p_conn->mss);
p_tcp->snd_wnd_scale = p_conn->snd_wnd_scale; p_tcp->snd_wnd_scale = p_conn->snd_wnd_scale;
p_tcp->rcv_wnd_scale = p_conn->rcv_wnd_scale; p_tcp->rcv_wnd_scale = p_conn->rcv_wnd_scale;
dval = p_conn->ts_ticks_per_second;
p_tcp->ts_ticks_per_second = cpu_to_le32(dval);
wval = p_conn->da_timeout_value; wval = p_conn->da_timeout_value;
p_tcp->da_timeout_value = cpu_to_le16(wval); p_tcp->da_timeout_value = cpu_to_le16(wval);
p_tcp->ack_frequency = p_conn->ack_frequency; p_tcp->ack_frequency = p_conn->ack_frequency;
......
...@@ -592,15 +592,15 @@ ...@@ -592,15 +592,15 @@
#define QM_REG_WFQPFWEIGHT 0x2f4e80UL #define QM_REG_WFQPFWEIGHT 0x2f4e80UL
#define QM_REG_WFQVPWEIGHT 0x2fa000UL #define QM_REG_WFQVPWEIGHT 0x2fa000UL
#define PGLCS_REG_DBG_SELECT \ #define PGLCS_REG_DBG_SELECT_K2 \
0x001d14UL 0x001d14UL
#define PGLCS_REG_DBG_DWORD_ENABLE \ #define PGLCS_REG_DBG_DWORD_ENABLE_K2 \
0x001d18UL 0x001d18UL
#define PGLCS_REG_DBG_SHIFT \ #define PGLCS_REG_DBG_SHIFT_K2 \
0x001d1cUL 0x001d1cUL
#define PGLCS_REG_DBG_FORCE_VALID \ #define PGLCS_REG_DBG_FORCE_VALID_K2 \
0x001d20UL 0x001d20UL
#define PGLCS_REG_DBG_FORCE_FRAME \ #define PGLCS_REG_DBG_FORCE_FRAME_K2 \
0x001d24UL 0x001d24UL
#define MISC_REG_RESET_PL_PDA_VMAIN_1 \ #define MISC_REG_RESET_PL_PDA_VMAIN_1 \
0x008070UL 0x008070UL
...@@ -612,7 +612,7 @@ ...@@ -612,7 +612,7 @@
0x009050UL 0x009050UL
#define MISCS_REG_RESET_PL_HV \ #define MISCS_REG_RESET_PL_HV \
0x009060UL 0x009060UL
#define MISCS_REG_RESET_PL_HV_2 \ #define MISCS_REG_RESET_PL_HV_2_K2 \
0x009150UL 0x009150UL
#define DMAE_REG_DBG_SELECT \ #define DMAE_REG_DBG_SELECT \
0x00c510UL 0x00c510UL
...@@ -644,15 +644,15 @@ ...@@ -644,15 +644,15 @@
0x0500b0UL 0x0500b0UL
#define GRC_REG_DBG_FORCE_FRAME \ #define GRC_REG_DBG_FORCE_FRAME \
0x0500b4UL 0x0500b4UL
#define UMAC_REG_DBG_SELECT \ #define UMAC_REG_DBG_SELECT_K2 \
0x051094UL 0x051094UL
#define UMAC_REG_DBG_DWORD_ENABLE \ #define UMAC_REG_DBG_DWORD_ENABLE_K2 \
0x051098UL 0x051098UL
#define UMAC_REG_DBG_SHIFT \ #define UMAC_REG_DBG_SHIFT_K2 \
0x05109cUL 0x05109cUL
#define UMAC_REG_DBG_FORCE_VALID \ #define UMAC_REG_DBG_FORCE_VALID_K2 \
0x0510a0UL 0x0510a0UL
#define UMAC_REG_DBG_FORCE_FRAME \ #define UMAC_REG_DBG_FORCE_FRAME_K2 \
0x0510a4UL 0x0510a4UL
#define MCP2_REG_DBG_SELECT \ #define MCP2_REG_DBG_SELECT \
0x052400UL 0x052400UL
...@@ -924,15 +924,15 @@ ...@@ -924,15 +924,15 @@
0x4c160cUL 0x4c160cUL
#define XYLD_REG_DBG_FORCE_FRAME \ #define XYLD_REG_DBG_FORCE_FRAME \
0x4c1610UL 0x4c1610UL
#define YULD_REG_DBG_SELECT \ #define YULD_REG_DBG_SELECT_BB_K2 \
0x4c9600UL 0x4c9600UL
#define YULD_REG_DBG_DWORD_ENABLE \ #define YULD_REG_DBG_DWORD_ENABLE_BB_K2 \
0x4c9604UL 0x4c9604UL
#define YULD_REG_DBG_SHIFT \ #define YULD_REG_DBG_SHIFT_BB_K2 \
0x4c9608UL 0x4c9608UL
#define YULD_REG_DBG_FORCE_VALID \ #define YULD_REG_DBG_FORCE_VALID_BB_K2 \
0x4c960cUL 0x4c960cUL
#define YULD_REG_DBG_FORCE_FRAME \ #define YULD_REG_DBG_FORCE_FRAME_BB_K2 \
0x4c9610UL 0x4c9610UL
#define TMLD_REG_DBG_SELECT \ #define TMLD_REG_DBG_SELECT \
0x4d1600UL 0x4d1600UL
...@@ -994,35 +994,35 @@ ...@@ -994,35 +994,35 @@
0x580710UL 0x580710UL
#define CDU_REG_DBG_FORCE_FRAME \ #define CDU_REG_DBG_FORCE_FRAME \
0x580714UL 0x580714UL
#define WOL_REG_DBG_SELECT \ #define WOL_REG_DBG_SELECT_K2 \
0x600140UL 0x600140UL
#define WOL_REG_DBG_DWORD_ENABLE \ #define WOL_REG_DBG_DWORD_ENABLE_K2 \
0x600144UL 0x600144UL
#define WOL_REG_DBG_SHIFT \ #define WOL_REG_DBG_SHIFT_K2 \
0x600148UL 0x600148UL
#define WOL_REG_DBG_FORCE_VALID \ #define WOL_REG_DBG_FORCE_VALID_K2 \
0x60014cUL 0x60014cUL
#define WOL_REG_DBG_FORCE_FRAME \ #define WOL_REG_DBG_FORCE_FRAME_K2 \
0x600150UL 0x600150UL
#define BMBN_REG_DBG_SELECT \ #define BMBN_REG_DBG_SELECT_K2 \
0x610140UL 0x610140UL
#define BMBN_REG_DBG_DWORD_ENABLE \ #define BMBN_REG_DBG_DWORD_ENABLE_K2 \
0x610144UL 0x610144UL
#define BMBN_REG_DBG_SHIFT \ #define BMBN_REG_DBG_SHIFT_K2 \
0x610148UL 0x610148UL
#define BMBN_REG_DBG_FORCE_VALID \ #define BMBN_REG_DBG_FORCE_VALID_K2 \
0x61014cUL 0x61014cUL
#define BMBN_REG_DBG_FORCE_FRAME \ #define BMBN_REG_DBG_FORCE_FRAME_K2 \
0x610150UL 0x610150UL
#define NWM_REG_DBG_SELECT \ #define NWM_REG_DBG_SELECT_K2 \
0x8000ecUL 0x8000ecUL
#define NWM_REG_DBG_DWORD_ENABLE \ #define NWM_REG_DBG_DWORD_ENABLE_K2 \
0x8000f0UL 0x8000f0UL
#define NWM_REG_DBG_SHIFT \ #define NWM_REG_DBG_SHIFT_K2 \
0x8000f4UL 0x8000f4UL
#define NWM_REG_DBG_FORCE_VALID \ #define NWM_REG_DBG_FORCE_VALID_K2 \
0x8000f8UL 0x8000f8UL
#define NWM_REG_DBG_FORCE_FRAME \ #define NWM_REG_DBG_FORCE_FRAME_K2\
0x8000fcUL 0x8000fcUL
#define PBF_REG_DBG_SELECT \ #define PBF_REG_DBG_SELECT \
0xd80060UL 0xd80060UL
...@@ -1244,35 +1244,35 @@ ...@@ -1244,35 +1244,35 @@
0x1901534UL 0x1901534UL
#define USEM_REG_DBG_FORCE_FRAME \ #define USEM_REG_DBG_FORCE_FRAME \
0x1901538UL 0x1901538UL
#define NWS_REG_DBG_SELECT \ #define NWS_REG_DBG_SELECT_K2 \
0x700128UL 0x700128UL
#define NWS_REG_DBG_DWORD_ENABLE \ #define NWS_REG_DBG_DWORD_ENABLE_K2 \
0x70012cUL 0x70012cUL
#define NWS_REG_DBG_SHIFT \ #define NWS_REG_DBG_SHIFT_K2 \
0x700130UL 0x700130UL
#define NWS_REG_DBG_FORCE_VALID \ #define NWS_REG_DBG_FORCE_VALID_K2 \
0x700134UL 0x700134UL
#define NWS_REG_DBG_FORCE_FRAME \ #define NWS_REG_DBG_FORCE_FRAME_K2 \
0x700138UL 0x700138UL
#define MS_REG_DBG_SELECT \ #define MS_REG_DBG_SELECT_K2 \
0x6a0228UL 0x6a0228UL
#define MS_REG_DBG_DWORD_ENABLE \ #define MS_REG_DBG_DWORD_ENABLE_K2 \
0x6a022cUL 0x6a022cUL
#define MS_REG_DBG_SHIFT \ #define MS_REG_DBG_SHIFT_K2 \
0x6a0230UL 0x6a0230UL
#define MS_REG_DBG_FORCE_VALID \ #define MS_REG_DBG_FORCE_VALID_K2 \
0x6a0234UL 0x6a0234UL
#define MS_REG_DBG_FORCE_FRAME \ #define MS_REG_DBG_FORCE_FRAME_K2 \
0x6a0238UL 0x6a0238UL
#define PCIE_REG_DBG_COMMON_SELECT \ #define PCIE_REG_DBG_COMMON_SELECT_K2 \
0x054398UL 0x054398UL
#define PCIE_REG_DBG_COMMON_DWORD_ENABLE \ #define PCIE_REG_DBG_COMMON_DWORD_ENABLE_K2 \
0x05439cUL 0x05439cUL
#define PCIE_REG_DBG_COMMON_SHIFT \ #define PCIE_REG_DBG_COMMON_SHIFT_K2 \
0x0543a0UL 0x0543a0UL
#define PCIE_REG_DBG_COMMON_FORCE_VALID \ #define PCIE_REG_DBG_COMMON_FORCE_VALID_K2 \
0x0543a4UL 0x0543a4UL
#define PCIE_REG_DBG_COMMON_FORCE_FRAME \ #define PCIE_REG_DBG_COMMON_FORCE_FRAME_K2 \
0x0543a8UL 0x0543a8UL
#define MISC_REG_RESET_PL_UA \ #define MISC_REG_RESET_PL_UA \
0x008050UL 0x008050UL
...@@ -1328,85 +1328,85 @@ ...@@ -1328,85 +1328,85 @@
0x128170cUL 0x128170cUL
#define UCM_REG_SM_TASK_CTX \ #define UCM_REG_SM_TASK_CTX \
0x1281710UL 0x1281710UL
#define XSEM_REG_SLOW_DBG_EMPTY \ #define XSEM_REG_SLOW_DBG_EMPTY_BB_K2 \
0x1401140UL 0x1401140UL
#define XSEM_REG_SYNC_DBG_EMPTY \ #define XSEM_REG_SYNC_DBG_EMPTY \
0x1401160UL 0x1401160UL
#define XSEM_REG_SLOW_DBG_ACTIVE \ #define XSEM_REG_SLOW_DBG_ACTIVE_BB_K2 \
0x1401400UL 0x1401400UL
#define XSEM_REG_SLOW_DBG_MODE \ #define XSEM_REG_SLOW_DBG_MODE_BB_K2 \
0x1401404UL 0x1401404UL
#define XSEM_REG_DBG_FRAME_MODE \ #define XSEM_REG_DBG_FRAME_MODE_BB_K2 \
0x1401408UL 0x1401408UL
#define XSEM_REG_DBG_MODE1_CFG \ #define XSEM_REG_DBG_MODE1_CFG_BB_K2 \
0x1401420UL 0x1401420UL
#define XSEM_REG_FAST_MEMORY \ #define XSEM_REG_FAST_MEMORY \
0x1440000UL 0x1440000UL
#define YSEM_REG_SYNC_DBG_EMPTY \ #define YSEM_REG_SYNC_DBG_EMPTY \
0x1501160UL 0x1501160UL
#define YSEM_REG_SLOW_DBG_ACTIVE \ #define YSEM_REG_SLOW_DBG_ACTIVE_BB_K2 \
0x1501400UL 0x1501400UL
#define YSEM_REG_SLOW_DBG_MODE \ #define YSEM_REG_SLOW_DBG_MODE_BB_K2 \
0x1501404UL 0x1501404UL
#define YSEM_REG_DBG_FRAME_MODE \ #define YSEM_REG_DBG_FRAME_MODE_BB_K2 \
0x1501408UL 0x1501408UL
#define YSEM_REG_DBG_MODE1_CFG \ #define YSEM_REG_DBG_MODE1_CFG_BB_K2 \
0x1501420UL 0x1501420UL
#define YSEM_REG_FAST_MEMORY \ #define YSEM_REG_FAST_MEMORY \
0x1540000UL 0x1540000UL
#define PSEM_REG_SLOW_DBG_EMPTY \ #define PSEM_REG_SLOW_DBG_EMPTY_BB_K2 \
0x1601140UL 0x1601140UL
#define PSEM_REG_SYNC_DBG_EMPTY \ #define PSEM_REG_SYNC_DBG_EMPTY \
0x1601160UL 0x1601160UL
#define PSEM_REG_SLOW_DBG_ACTIVE \ #define PSEM_REG_SLOW_DBG_ACTIVE_BB_K2 \
0x1601400UL 0x1601400UL
#define PSEM_REG_SLOW_DBG_MODE \ #define PSEM_REG_SLOW_DBG_MODE_BB_K2 \
0x1601404UL 0x1601404UL
#define PSEM_REG_DBG_FRAME_MODE \ #define PSEM_REG_DBG_FRAME_MODE_BB_K2 \
0x1601408UL 0x1601408UL
#define PSEM_REG_DBG_MODE1_CFG \ #define PSEM_REG_DBG_MODE1_CFG_BB_K2 \
0x1601420UL 0x1601420UL
#define PSEM_REG_FAST_MEMORY \ #define PSEM_REG_FAST_MEMORY \
0x1640000UL 0x1640000UL
#define TSEM_REG_SLOW_DBG_EMPTY \ #define TSEM_REG_SLOW_DBG_EMPTY_BB_K2 \
0x1701140UL 0x1701140UL
#define TSEM_REG_SYNC_DBG_EMPTY \ #define TSEM_REG_SYNC_DBG_EMPTY \
0x1701160UL 0x1701160UL
#define TSEM_REG_SLOW_DBG_ACTIVE \ #define TSEM_REG_SLOW_DBG_ACTIVE_BB_K2 \
0x1701400UL 0x1701400UL
#define TSEM_REG_SLOW_DBG_MODE \ #define TSEM_REG_SLOW_DBG_MODE_BB_K2 \
0x1701404UL 0x1701404UL
#define TSEM_REG_DBG_FRAME_MODE \ #define TSEM_REG_DBG_FRAME_MODE_BB_K2 \
0x1701408UL 0x1701408UL
#define TSEM_REG_DBG_MODE1_CFG \ #define TSEM_REG_DBG_MODE1_CFG_BB_K2 \
0x1701420UL 0x1701420UL
#define TSEM_REG_FAST_MEMORY \ #define TSEM_REG_FAST_MEMORY \
0x1740000UL 0x1740000UL
#define MSEM_REG_SLOW_DBG_EMPTY \ #define MSEM_REG_SLOW_DBG_EMPTY_BB_K2 \
0x1801140UL 0x1801140UL
#define MSEM_REG_SYNC_DBG_EMPTY \ #define MSEM_REG_SYNC_DBG_EMPTY \
0x1801160UL 0x1801160UL
#define MSEM_REG_SLOW_DBG_ACTIVE \ #define MSEM_REG_SLOW_DBG_ACTIVE_BB_K2 \
0x1801400UL 0x1801400UL
#define MSEM_REG_SLOW_DBG_MODE \ #define MSEM_REG_SLOW_DBG_MODE_BB_K2 \
0x1801404UL 0x1801404UL
#define MSEM_REG_DBG_FRAME_MODE \ #define MSEM_REG_DBG_FRAME_MODE_BB_K2 \
0x1801408UL 0x1801408UL
#define MSEM_REG_DBG_MODE1_CFG \ #define MSEM_REG_DBG_MODE1_CFG_BB_K2 \
0x1801420UL 0x1801420UL
#define MSEM_REG_FAST_MEMORY \ #define MSEM_REG_FAST_MEMORY \
0x1840000UL 0x1840000UL
#define USEM_REG_SLOW_DBG_EMPTY \ #define USEM_REG_SLOW_DBG_EMPTY_BB_K2 \
0x1901140UL 0x1901140UL
#define USEM_REG_SYNC_DBG_EMPTY \ #define USEM_REG_SYNC_DBG_EMPTY \
0x1901160UL 0x1901160UL
#define USEM_REG_SLOW_DBG_ACTIVE \ #define USEM_REG_SLOW_DBG_ACTIVE_BB_K2 \
0x1901400UL 0x1901400UL
#define USEM_REG_SLOW_DBG_MODE \ #define USEM_REG_SLOW_DBG_MODE_BB_K2 \
0x1901404UL 0x1901404UL
#define USEM_REG_DBG_FRAME_MODE \ #define USEM_REG_DBG_FRAME_MODE_BB_K2 \
0x1901408UL 0x1901408UL
#define USEM_REG_DBG_MODE1_CFG \ #define USEM_REG_DBG_MODE1_CFG_BB_K2 \
0x1901420UL 0x1901420UL
#define USEM_REG_FAST_MEMORY \ #define USEM_REG_FAST_MEMORY \
0x1940000UL 0x1940000UL
...@@ -1430,7 +1430,7 @@ ...@@ -1430,7 +1430,7 @@
0x340800UL 0x340800UL
#define BRB_REG_BIG_RAM_DATA \ #define BRB_REG_BIG_RAM_DATA \
0x341500UL 0x341500UL
#define SEM_FAST_REG_STALL_0 \ #define SEM_FAST_REG_STALL_0_BB_K2 \
0x000488UL 0x000488UL
#define SEM_FAST_REG_STALLED \ #define SEM_FAST_REG_STALLED \
0x000494UL 0x000494UL
...@@ -1480,37 +1480,37 @@ ...@@ -1480,37 +1480,37 @@
4 4
#define MISC_REG_BLOCK_256B_EN \ #define MISC_REG_BLOCK_256B_EN \
0x008c14UL 0x008c14UL
#define NWS_REG_NWS_CMU \ #define NWS_REG_NWS_CMU_K2 \
0x720000UL 0x720000UL
#define PHY_NW_IP_REG_PHY0_TOP_TBUS_ADDR_7_0 \ #define PHY_NW_IP_REG_PHY0_TOP_TBUS_ADDR_7_0_K2 \
0x000680UL 0x000680UL
#define PHY_NW_IP_REG_PHY0_TOP_TBUS_ADDR_15_8 \ #define PHY_NW_IP_REG_PHY0_TOP_TBUS_ADDR_15_8_K2 \
0x000684UL 0x000684UL
#define PHY_NW_IP_REG_PHY0_TOP_TBUS_DATA_7_0 \ #define PHY_NW_IP_REG_PHY0_TOP_TBUS_DATA_7_0_K2 \
0x0006c0UL 0x0006c0UL
#define PHY_NW_IP_REG_PHY0_TOP_TBUS_DATA_11_8 \ #define PHY_NW_IP_REG_PHY0_TOP_TBUS_DATA_11_8_K2 \
0x0006c4UL 0x0006c4UL
#define MS_REG_MS_CMU \ #define MS_REG_MS_CMU_K2 \
0x6a4000UL 0x6a4000UL
#define PHY_SGMII_IP_REG_AHB_CMU_CSR_0_X130 \ #define PHY_SGMII_IP_REG_AHB_CMU_CSR_0_X130_K2 \
0x000208UL 0x000208UL
#define PHY_SGMII_IP_REG_AHB_CMU_CSR_0_X132 \ #define PHY_SGMII_IP_REG_AHB_CMU_CSR_0_X131_K2 \
0x000210UL
#define PHY_SGMII_IP_REG_AHB_CMU_CSR_0_X131 \
0x00020cUL 0x00020cUL
#define PHY_SGMII_IP_REG_AHB_CMU_CSR_0_X133 \ #define PHY_SGMII_IP_REG_AHB_CMU_CSR_0_X132_K2 \
0x000210UL
#define PHY_SGMII_IP_REG_AHB_CMU_CSR_0_X133_K2 \
0x000214UL 0x000214UL
#define PHY_PCIE_IP_REG_AHB_CMU_CSR_0_X130 \ #define PHY_PCIE_IP_REG_AHB_CMU_CSR_0_X130_K2 \
0x000208UL 0x000208UL
#define PHY_PCIE_IP_REG_AHB_CMU_CSR_0_X131 \ #define PHY_PCIE_IP_REG_AHB_CMU_CSR_0_X131_K2 \
0x00020cUL 0x00020cUL
#define PHY_PCIE_IP_REG_AHB_CMU_CSR_0_X132 \ #define PHY_PCIE_IP_REG_AHB_CMU_CSR_0_X132_K2 \
0x000210UL 0x000210UL
#define PHY_PCIE_IP_REG_AHB_CMU_CSR_0_X133 \ #define PHY_PCIE_IP_REG_AHB_CMU_CSR_0_X133_K2 \
0x000214UL 0x000214UL
#define PHY_PCIE_REG_PHY0 \ #define PHY_PCIE_REG_PHY0_K2 \
0x620000UL 0x620000UL
#define PHY_PCIE_REG_PHY1 \ #define PHY_PCIE_REG_PHY1_K2 \
0x624000UL 0x624000UL
#define NIG_REG_ROCE_DUPLICATE_TO_HOST 0x5088f0UL #define NIG_REG_ROCE_DUPLICATE_TO_HOST 0x5088f0UL
#define PRS_REG_LIGHT_L2_ETHERTYPE_EN 0x1f0968UL #define PRS_REG_LIGHT_L2_ETHERTYPE_EN 0x1f0968UL
......
...@@ -2431,10 +2431,6 @@ qed_rdma_register_tid(void *rdma_cxt, ...@@ -2431,10 +2431,6 @@ qed_rdma_register_tid(void *rdma_cxt,
RDMA_REGISTER_TID_RAMROD_DATA_PAGE_SIZE_LOG, RDMA_REGISTER_TID_RAMROD_DATA_PAGE_SIZE_LOG,
params->page_size_log - 12); params->page_size_log - 12);
SET_FIELD(p_ramrod->flags,
RDMA_REGISTER_TID_RAMROD_DATA_MAX_ID,
p_hwfn->p_rdma_info->last_tid);
SET_FIELD(p_ramrod->flags, SET_FIELD(p_ramrod->flags,
RDMA_REGISTER_TID_RAMROD_DATA_REMOTE_READ, RDMA_REGISTER_TID_RAMROD_DATA_REMOTE_READ,
params->remote_read); params->remote_read);
......
...@@ -185,22 +185,20 @@ static void qed_set_tunn_ports(struct qed_tunnel_info *p_tun, ...@@ -185,22 +185,20 @@ static void qed_set_tunn_ports(struct qed_tunnel_info *p_tun,
} }
static void static void
__qed_set_ramrod_tunnel_param(u8 *p_tunn_cls, u8 *p_enable_tx_clas, __qed_set_ramrod_tunnel_param(u8 *p_tunn_cls,
struct qed_tunn_update_type *tun_type) struct qed_tunn_update_type *tun_type)
{ {
*p_tunn_cls = tun_type->tun_cls; *p_tunn_cls = tun_type->tun_cls;
if (tun_type->b_mode_enabled)
*p_enable_tx_clas = 1;
} }
static void static void
qed_set_ramrod_tunnel_param(u8 *p_tunn_cls, u8 *p_enable_tx_clas, qed_set_ramrod_tunnel_param(u8 *p_tunn_cls,
struct qed_tunn_update_type *tun_type, struct qed_tunn_update_type *tun_type,
u8 *p_update_port, __le16 *p_port, u8 *p_update_port,
__le16 *p_port,
struct qed_tunn_update_udp_port *p_udp_port) struct qed_tunn_update_udp_port *p_udp_port)
{ {
__qed_set_ramrod_tunnel_param(p_tunn_cls, p_enable_tx_clas, tun_type); __qed_set_ramrod_tunnel_param(p_tunn_cls, tun_type);
if (p_udp_port->b_update_port) { if (p_udp_port->b_update_port) {
*p_update_port = 1; *p_update_port = 1;
*p_port = cpu_to_le16(p_udp_port->port); *p_port = cpu_to_le16(p_udp_port->port);
...@@ -219,33 +217,27 @@ qed_tunn_set_pf_update_params(struct qed_hwfn *p_hwfn, ...@@ -219,33 +217,27 @@ qed_tunn_set_pf_update_params(struct qed_hwfn *p_hwfn,
qed_set_tunn_ports(p_tun, p_src); qed_set_tunn_ports(p_tun, p_src);
qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_vxlan, qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_vxlan,
&p_tunn_cfg->tx_enable_vxlan,
&p_tun->vxlan, &p_tun->vxlan,
&p_tunn_cfg->set_vxlan_udp_port_flg, &p_tunn_cfg->set_vxlan_udp_port_flg,
&p_tunn_cfg->vxlan_udp_port, &p_tunn_cfg->vxlan_udp_port,
&p_tun->vxlan_port); &p_tun->vxlan_port);
qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_l2geneve, qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_l2geneve,
&p_tunn_cfg->tx_enable_l2geneve,
&p_tun->l2_geneve, &p_tun->l2_geneve,
&p_tunn_cfg->set_geneve_udp_port_flg, &p_tunn_cfg->set_geneve_udp_port_flg,
&p_tunn_cfg->geneve_udp_port, &p_tunn_cfg->geneve_udp_port,
&p_tun->geneve_port); &p_tun->geneve_port);
__qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_ipgeneve, __qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_ipgeneve,
&p_tunn_cfg->tx_enable_ipgeneve,
&p_tun->ip_geneve); &p_tun->ip_geneve);
__qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_l2gre, __qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_l2gre,
&p_tunn_cfg->tx_enable_l2gre,
&p_tun->l2_gre); &p_tun->l2_gre);
__qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_ipgre, __qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_ipgre,
&p_tunn_cfg->tx_enable_ipgre,
&p_tun->ip_gre); &p_tun->ip_gre);
p_tunn_cfg->update_rx_pf_clss = p_tun->b_update_rx_cls; p_tunn_cfg->update_rx_pf_clss = p_tun->b_update_rx_cls;
p_tunn_cfg->update_tx_pf_clss = p_tun->b_update_tx_cls;
} }
static void qed_set_hw_tunn_mode(struct qed_hwfn *p_hwfn, static void qed_set_hw_tunn_mode(struct qed_hwfn *p_hwfn,
...@@ -289,29 +281,24 @@ qed_tunn_set_pf_start_params(struct qed_hwfn *p_hwfn, ...@@ -289,29 +281,24 @@ qed_tunn_set_pf_start_params(struct qed_hwfn *p_hwfn,
qed_set_tunn_ports(p_tun, p_src); qed_set_tunn_ports(p_tun, p_src);
qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_vxlan, qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_vxlan,
&p_tunn_cfg->tx_enable_vxlan,
&p_tun->vxlan, &p_tun->vxlan,
&p_tunn_cfg->set_vxlan_udp_port_flg, &p_tunn_cfg->set_vxlan_udp_port_flg,
&p_tunn_cfg->vxlan_udp_port, &p_tunn_cfg->vxlan_udp_port,
&p_tun->vxlan_port); &p_tun->vxlan_port);
qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_l2geneve, qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_l2geneve,
&p_tunn_cfg->tx_enable_l2geneve,
&p_tun->l2_geneve, &p_tun->l2_geneve,
&p_tunn_cfg->set_geneve_udp_port_flg, &p_tunn_cfg->set_geneve_udp_port_flg,
&p_tunn_cfg->geneve_udp_port, &p_tunn_cfg->geneve_udp_port,
&p_tun->geneve_port); &p_tun->geneve_port);
__qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_ipgeneve, __qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_ipgeneve,
&p_tunn_cfg->tx_enable_ipgeneve,
&p_tun->ip_geneve); &p_tun->ip_geneve);
__qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_l2gre, __qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_l2gre,
&p_tunn_cfg->tx_enable_l2gre,
&p_tun->l2_gre); &p_tun->l2_gre);
__qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_ipgre, __qed_set_ramrod_tunnel_param(&p_tunn_cfg->tunnel_clss_ipgre,
&p_tunn_cfg->tx_enable_ipgre,
&p_tun->ip_gre); &p_tun->ip_gre);
} }
......
...@@ -2099,14 +2099,16 @@ int qedi_iscsi_send_ioreq(struct iscsi_task *task) ...@@ -2099,14 +2099,16 @@ int qedi_iscsi_send_ioreq(struct iscsi_task *task)
/* Update header info */ /* Update header info */
SET_FIELD(cmd_pdu_header.flags_attr, ISCSI_CMD_HDR_ATTR, SET_FIELD(cmd_pdu_header.flags_attr, ISCSI_CMD_HDR_ATTR,
ISCSI_ATTR_SIMPLE); ISCSI_ATTR_SIMPLE);
if (sc->sc_data_direction == DMA_TO_DEVICE) { if (hdr->cdb[0] != TEST_UNIT_READY) {
SET_FIELD(cmd_pdu_header.flags_attr, if (sc->sc_data_direction == DMA_TO_DEVICE) {
ISCSI_CMD_HDR_WRITE, 1); SET_FIELD(cmd_pdu_header.flags_attr,
task_type = ISCSI_TASK_TYPE_INITIATOR_WRITE; ISCSI_CMD_HDR_WRITE, 1);
} else { task_type = ISCSI_TASK_TYPE_INITIATOR_WRITE;
SET_FIELD(cmd_pdu_header.flags_attr, } else {
ISCSI_CMD_HDR_READ, 1); SET_FIELD(cmd_pdu_header.flags_attr,
task_type = ISCSI_TASK_TYPE_INITIATOR_READ; ISCSI_CMD_HDR_READ, 1);
task_type = ISCSI_TASK_TYPE_INITIATOR_READ;
}
} }
cmd_pdu_header.lun.lo = be32_to_cpu(scsi_lun[0]); cmd_pdu_header.lun.lo = be32_to_cpu(scsi_lun[0]);
...@@ -2117,7 +2119,7 @@ int qedi_iscsi_send_ioreq(struct iscsi_task *task) ...@@ -2117,7 +2119,7 @@ int qedi_iscsi_send_ioreq(struct iscsi_task *task)
cmd_pdu_header.expected_transfer_length = cpu_to_be32(hdr->data_length); cmd_pdu_header.expected_transfer_length = cpu_to_be32(hdr->data_length);
cmd_pdu_header.hdr_second_dword = ntoh24(hdr->dlength); cmd_pdu_header.hdr_second_dword = ntoh24(hdr->dlength);
cmd_pdu_header.cmd_sn = be32_to_cpu(hdr->cmdsn); cmd_pdu_header.cmd_sn = be32_to_cpu(hdr->cmdsn);
cmd_pdu_header.opcode = hdr->opcode; cmd_pdu_header.hdr_first_byte = hdr->opcode;
qedi_cpy_scsi_cdb(sc, (u32 *)cmd_pdu_header.cdb); qedi_cpy_scsi_cdb(sc, (u32 *)cmd_pdu_header.cdb);
/* Fill tx AHS and rx buffer */ /* Fill tx AHS and rx buffer */
......
...@@ -578,7 +578,8 @@ int init_initiator_rw_iscsi_task(struct iscsi_task_params *task_params, ...@@ -578,7 +578,8 @@ int init_initiator_rw_iscsi_task(struct iscsi_task_params *task_params,
(struct iscsi_common_hdr *)cmd_header, (struct iscsi_common_hdr *)cmd_header,
tx_sgl_params, cmd_params, tx_sgl_params, cmd_params,
dif_task_params); dif_task_params);
else if (GET_FIELD(cmd_header->flags_attr, ISCSI_CMD_HDR_READ)) else if (GET_FIELD(cmd_header->flags_attr, ISCSI_CMD_HDR_READ) ||
(task_params->rx_io_size == 0 && task_params->tx_io_size == 0))
return init_rw_iscsi_task(task_params, return init_rw_iscsi_task(task_params,
ISCSI_TASK_TYPE_INITIATOR_READ, ISCSI_TASK_TYPE_INITIATOR_READ,
conn_params, conn_params,
......
...@@ -1461,9 +1461,6 @@ static const struct { ...@@ -1461,9 +1461,6 @@ static const struct {
{ ISCSI_CONN_ERROR_OUT_OF_SGES_ERROR, { ISCSI_CONN_ERROR_OUT_OF_SGES_ERROR,
"out of sge error" "out of sge error"
}, },
{ ISCSI_CONN_ERROR_TCP_SEG_PROC_IP_OPTIONS_ERROR,
"tcp seg ip options error"
},
{ ISCSI_CONN_ERROR_TCP_IP_FRAGMENT_ERROR, { ISCSI_CONN_ERROR_TCP_IP_FRAGMENT_ERROR,
"tcp ip fragment error" "tcp ip fragment error"
}, },
......
此差异已折叠。
...@@ -75,7 +75,8 @@ ...@@ -75,7 +75,8 @@
(ETH_NUM_STATISTIC_COUNTERS - 3 * MAX_NUM_VFS / 4) (ETH_NUM_STATISTIC_COUNTERS - 3 * MAX_NUM_VFS / 4)
/* Maximum number of buffers, used for RX packet placement */ /* Maximum number of buffers, used for RX packet placement */
#define ETH_RX_MAX_BUFF_PER_PKT 5 #define ETH_RX_MAX_BUFF_PER_PKT 5
#define ETH_RX_BD_THRESHOLD 12
/* num of MAC/VLAN filters */ /* num of MAC/VLAN filters */
#define ETH_NUM_MAC_FILTERS 512 #define ETH_NUM_MAC_FILTERS 512
......
...@@ -13,7 +13,6 @@ ...@@ -13,7 +13,6 @@
/*********************/ /*********************/
#define FC_ABTS_REPLY_MAX_PAYLOAD_LEN 12 #define FC_ABTS_REPLY_MAX_PAYLOAD_LEN 12
#define FCOE_MAX_SIZE_FCP_DATA_SUPER (8600)
struct fcoe_abts_pkt { struct fcoe_abts_pkt {
__le32 abts_rsp_fc_payload_lo; __le32 abts_rsp_fc_payload_lo;
......
此差异已折叠。
...@@ -42,7 +42,7 @@ ...@@ -42,7 +42,7 @@
#define RDMA_MAX_SGE_PER_SQ_WQE (4) #define RDMA_MAX_SGE_PER_SQ_WQE (4)
#define RDMA_MAX_SGE_PER_RQ_WQE (4) #define RDMA_MAX_SGE_PER_RQ_WQE (4)
#define RDMA_MAX_DATA_SIZE_IN_WQE (0x7FFFFFFF) #define RDMA_MAX_DATA_SIZE_IN_WQE (0x80000000)
#define RDMA_REQ_RD_ATOMIC_ELM_SIZE (0x50) #define RDMA_REQ_RD_ATOMIC_ELM_SIZE (0x50)
#define RDMA_RESP_RD_ATOMIC_ELM_SIZE (0x20) #define RDMA_RESP_RD_ATOMIC_ELM_SIZE (0x20)
......
此差异已折叠。
此差异已折叠。
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册