mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-11-24 07:00:52 +07:00
Merge branch 'qed-warnings-cleanup'
Alexander Lobakin says: ==================== net: qed/qede: W=1 C=1 warnings cleanup This set cleans qed/qede build log under W=1 C=1 with GCC 8 and sparse 0.6.2. The only thing left is "context imbalance -- unexpected unlock" in one of the source files, which will be issued later during the refactoring cycles. The biggest part is handling the endianness warnings. The current code often just assumes that both host and device operate in LE, which is obviously incorrect (despite the fact that it's true for x86 platforms), and makes sparse {s,m}ad. The rest of the series is mostly random non-functional fixes here-and-there. ==================== Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
commit
1eafa7369f
@ -73,8 +73,8 @@ union type1_task_context {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct src_ent {
|
struct src_ent {
|
||||||
u8 opaque[56];
|
__u8 opaque[56];
|
||||||
u64 next;
|
__be64 next;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define CDUT_SEG_ALIGNMET 3 /* in 4k chunks */
|
#define CDUT_SEG_ALIGNMET 3 /* in 4k chunks */
|
||||||
@ -2170,12 +2170,14 @@ qed_cxt_dynamic_ilt_alloc(struct qed_hwfn *p_hwfn,
|
|||||||
enum qed_cxt_elem_type elem_type, u32 iid)
|
enum qed_cxt_elem_type elem_type, u32 iid)
|
||||||
{
|
{
|
||||||
u32 reg_offset, shadow_line, elem_size, hw_p_size, elems_per_p, line;
|
u32 reg_offset, shadow_line, elem_size, hw_p_size, elems_per_p, line;
|
||||||
|
struct tdif_task_context *tdif_context;
|
||||||
struct qed_ilt_client_cfg *p_cli;
|
struct qed_ilt_client_cfg *p_cli;
|
||||||
struct qed_ilt_cli_blk *p_blk;
|
struct qed_ilt_cli_blk *p_blk;
|
||||||
struct qed_ptt *p_ptt;
|
struct qed_ptt *p_ptt;
|
||||||
dma_addr_t p_phys;
|
dma_addr_t p_phys;
|
||||||
u64 ilt_hw_entry;
|
u64 ilt_hw_entry;
|
||||||
void *p_virt;
|
void *p_virt;
|
||||||
|
u32 flags1;
|
||||||
int rc = 0;
|
int rc = 0;
|
||||||
|
|
||||||
switch (elem_type) {
|
switch (elem_type) {
|
||||||
@ -2252,8 +2254,12 @@ qed_cxt_dynamic_ilt_alloc(struct qed_hwfn *p_hwfn,
|
|||||||
|
|
||||||
for (elem_i = 0; elem_i < elems_per_p; elem_i++) {
|
for (elem_i = 0; elem_i < elems_per_p; elem_i++) {
|
||||||
elem = (union type1_task_context *)elem_start;
|
elem = (union type1_task_context *)elem_start;
|
||||||
SET_FIELD(elem->roce_ctx.tdif_context.flags1,
|
tdif_context = &elem->roce_ctx.tdif_context;
|
||||||
TDIF_TASK_CONTEXT_REF_TAG_MASK, 0xf);
|
|
||||||
|
flags1 = le32_to_cpu(tdif_context->flags1);
|
||||||
|
SET_FIELD(flags1, TDIF_TASK_CONTEXT_REF_TAG_MASK, 0xf);
|
||||||
|
tdif_context->flags1 = cpu_to_le32(flags1);
|
||||||
|
|
||||||
elem_start += TYPE1_TASK_CXT_SIZE(p_hwfn);
|
elem_start += TYPE1_TASK_CXT_SIZE(p_hwfn);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -547,7 +547,8 @@ qed_dcbx_get_ets_data(struct qed_hwfn *p_hwfn,
|
|||||||
struct dcbx_ets_feature *p_ets,
|
struct dcbx_ets_feature *p_ets,
|
||||||
struct qed_dcbx_params *p_params)
|
struct qed_dcbx_params *p_params)
|
||||||
{
|
{
|
||||||
u32 bw_map[2], tsa_map[2], pri_map;
|
__be32 bw_map[2], tsa_map[2];
|
||||||
|
u32 pri_map;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
p_params->ets_willing = QED_MFW_GET_FIELD(p_ets->flags,
|
p_params->ets_willing = QED_MFW_GET_FIELD(p_ets->flags,
|
||||||
@ -573,11 +574,10 @@ qed_dcbx_get_ets_data(struct qed_hwfn *p_hwfn,
|
|||||||
/* 8 bit tsa and bw data corresponding to each of the 8 TC's are
|
/* 8 bit tsa and bw data corresponding to each of the 8 TC's are
|
||||||
* encoded in a type u32 array of size 2.
|
* encoded in a type u32 array of size 2.
|
||||||
*/
|
*/
|
||||||
bw_map[0] = be32_to_cpu(p_ets->tc_bw_tbl[0]);
|
cpu_to_be32_array(bw_map, p_ets->tc_bw_tbl, 2);
|
||||||
bw_map[1] = be32_to_cpu(p_ets->tc_bw_tbl[1]);
|
cpu_to_be32_array(tsa_map, p_ets->tc_tsa_tbl, 2);
|
||||||
tsa_map[0] = be32_to_cpu(p_ets->tc_tsa_tbl[0]);
|
|
||||||
tsa_map[1] = be32_to_cpu(p_ets->tc_tsa_tbl[1]);
|
|
||||||
pri_map = p_ets->pri_tc_tbl[0];
|
pri_map = p_ets->pri_tc_tbl[0];
|
||||||
|
|
||||||
for (i = 0; i < QED_MAX_PFC_PRIORITIES; i++) {
|
for (i = 0; i < QED_MAX_PFC_PRIORITIES; i++) {
|
||||||
p_params->ets_tc_bw_tbl[i] = ((u8 *)bw_map)[i];
|
p_params->ets_tc_bw_tbl[i] = ((u8 *)bw_map)[i];
|
||||||
p_params->ets_tc_tsa_tbl[i] = ((u8 *)tsa_map)[i];
|
p_params->ets_tc_tsa_tbl[i] = ((u8 *)tsa_map)[i];
|
||||||
@ -1054,7 +1054,7 @@ qed_dcbx_set_ets_data(struct qed_hwfn *p_hwfn,
|
|||||||
struct dcbx_ets_feature *p_ets,
|
struct dcbx_ets_feature *p_ets,
|
||||||
struct qed_dcbx_params *p_params)
|
struct qed_dcbx_params *p_params)
|
||||||
{
|
{
|
||||||
u8 *bw_map, *tsa_map;
|
__be32 bw_map[2], tsa_map[2];
|
||||||
u32 val;
|
u32 val;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
@ -1076,22 +1076,21 @@ qed_dcbx_set_ets_data(struct qed_hwfn *p_hwfn,
|
|||||||
p_ets->flags &= ~DCBX_ETS_MAX_TCS_MASK;
|
p_ets->flags &= ~DCBX_ETS_MAX_TCS_MASK;
|
||||||
p_ets->flags |= (u32)p_params->max_ets_tc << DCBX_ETS_MAX_TCS_SHIFT;
|
p_ets->flags |= (u32)p_params->max_ets_tc << DCBX_ETS_MAX_TCS_SHIFT;
|
||||||
|
|
||||||
bw_map = (u8 *)&p_ets->tc_bw_tbl[0];
|
|
||||||
tsa_map = (u8 *)&p_ets->tc_tsa_tbl[0];
|
|
||||||
p_ets->pri_tc_tbl[0] = 0;
|
p_ets->pri_tc_tbl[0] = 0;
|
||||||
|
|
||||||
for (i = 0; i < QED_MAX_PFC_PRIORITIES; i++) {
|
for (i = 0; i < QED_MAX_PFC_PRIORITIES; i++) {
|
||||||
bw_map[i] = p_params->ets_tc_bw_tbl[i];
|
((u8 *)bw_map)[i] = p_params->ets_tc_bw_tbl[i];
|
||||||
tsa_map[i] = p_params->ets_tc_tsa_tbl[i];
|
((u8 *)tsa_map)[i] = p_params->ets_tc_tsa_tbl[i];
|
||||||
|
|
||||||
/* Copy the priority value to the corresponding 4 bits in the
|
/* Copy the priority value to the corresponding 4 bits in the
|
||||||
* traffic class table.
|
* traffic class table.
|
||||||
*/
|
*/
|
||||||
val = (((u32)p_params->ets_pri_tc_tbl[i]) << ((7 - i) * 4));
|
val = (((u32)p_params->ets_pri_tc_tbl[i]) << ((7 - i) * 4));
|
||||||
p_ets->pri_tc_tbl[0] |= val;
|
p_ets->pri_tc_tbl[0] |= val;
|
||||||
}
|
}
|
||||||
for (i = 0; i < 2; i++) {
|
|
||||||
p_ets->tc_bw_tbl[i] = cpu_to_be32(p_ets->tc_bw_tbl[i]);
|
be32_to_cpu_array(p_ets->tc_bw_tbl, bw_map, 2);
|
||||||
p_ets->tc_tsa_tbl[i] = cpu_to_be32(p_ets->tc_tsa_tbl[i]);
|
be32_to_cpu_array(p_ets->tc_tsa_tbl, tsa_map, 2);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -81,6 +81,8 @@ struct qed_dcbx_mib_meta_data {
|
|||||||
u32 addr;
|
u32 addr;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
extern const struct qed_eth_dcbnl_ops qed_dcbnl_ops_pass;
|
||||||
|
|
||||||
#ifdef CONFIG_DCB
|
#ifdef CONFIG_DCB
|
||||||
int qed_dcbx_get_config_params(struct qed_hwfn *, struct qed_dcbx_set *);
|
int qed_dcbx_get_config_params(struct qed_hwfn *, struct qed_dcbx_set *);
|
||||||
|
|
||||||
|
@ -972,7 +972,7 @@ static void qed_read_storm_fw_info(struct qed_hwfn *p_hwfn,
|
|||||||
{
|
{
|
||||||
struct storm_defs *storm = &s_storm_defs[storm_id];
|
struct storm_defs *storm = &s_storm_defs[storm_id];
|
||||||
struct fw_info_location fw_info_location;
|
struct fw_info_location fw_info_location;
|
||||||
u32 addr, i, *dest;
|
u32 addr, i, size, *dest;
|
||||||
|
|
||||||
memset(&fw_info_location, 0, sizeof(fw_info_location));
|
memset(&fw_info_location, 0, sizeof(fw_info_location));
|
||||||
memset(fw_info, 0, sizeof(*fw_info));
|
memset(fw_info, 0, sizeof(*fw_info));
|
||||||
@ -985,20 +985,29 @@ static void qed_read_storm_fw_info(struct qed_hwfn *p_hwfn,
|
|||||||
sizeof(fw_info_location);
|
sizeof(fw_info_location);
|
||||||
|
|
||||||
dest = (u32 *)&fw_info_location;
|
dest = (u32 *)&fw_info_location;
|
||||||
|
size = BYTES_TO_DWORDS(sizeof(fw_info_location));
|
||||||
|
|
||||||
for (i = 0; i < BYTES_TO_DWORDS(sizeof(fw_info_location));
|
for (i = 0; i < size; i++, addr += BYTES_IN_DWORD)
|
||||||
i++, addr += BYTES_IN_DWORD)
|
|
||||||
dest[i] = qed_rd(p_hwfn, p_ptt, addr);
|
dest[i] = qed_rd(p_hwfn, p_ptt, addr);
|
||||||
|
|
||||||
|
/* qed_rq() fetches data in CPU byteorder. Swap it back to
|
||||||
|
* the device's to get right structure layout.
|
||||||
|
*/
|
||||||
|
cpu_to_le32_array(dest, size);
|
||||||
|
|
||||||
/* Read FW version info from Storm RAM */
|
/* Read FW version info from Storm RAM */
|
||||||
if (fw_info_location.size > 0 && fw_info_location.size <=
|
size = le32_to_cpu(fw_info_location.size);
|
||||||
sizeof(*fw_info)) {
|
if (!size || size > sizeof(*fw_info))
|
||||||
addr = fw_info_location.grc_addr;
|
return;
|
||||||
dest = (u32 *)fw_info;
|
|
||||||
for (i = 0; i < BYTES_TO_DWORDS(fw_info_location.size);
|
addr = le32_to_cpu(fw_info_location.grc_addr);
|
||||||
i++, addr += BYTES_IN_DWORD)
|
dest = (u32 *)fw_info;
|
||||||
dest[i] = qed_rd(p_hwfn, p_ptt, addr);
|
size = BYTES_TO_DWORDS(size);
|
||||||
}
|
|
||||||
|
for (i = 0; i < size; i++, addr += BYTES_IN_DWORD)
|
||||||
|
dest[i] = qed_rd(p_hwfn, p_ptt, addr);
|
||||||
|
|
||||||
|
cpu_to_le32_array(dest, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Dumps the specified string to the specified buffer.
|
/* Dumps the specified string to the specified buffer.
|
||||||
@ -1122,9 +1131,8 @@ static u32 qed_dump_fw_ver_param(struct qed_hwfn *p_hwfn,
|
|||||||
dump, "fw-version", fw_ver_str);
|
dump, "fw-version", fw_ver_str);
|
||||||
offset += qed_dump_str_param(dump_buf + offset,
|
offset += qed_dump_str_param(dump_buf + offset,
|
||||||
dump, "fw-image", fw_img_str);
|
dump, "fw-image", fw_img_str);
|
||||||
offset += qed_dump_num_param(dump_buf + offset,
|
offset += qed_dump_num_param(dump_buf + offset, dump, "fw-timestamp",
|
||||||
dump,
|
le32_to_cpu(fw_info.ver.timestamp));
|
||||||
"fw-timestamp", fw_info.ver.timestamp);
|
|
||||||
|
|
||||||
return offset;
|
return offset;
|
||||||
}
|
}
|
||||||
@ -4441,9 +4449,11 @@ static u32 qed_fw_asserts_dump(struct qed_hwfn *p_hwfn,
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
addr = le16_to_cpu(asserts->section_ram_line_offset);
|
||||||
fw_asserts_section_addr = storm->sem_fast_mem_addr +
|
fw_asserts_section_addr = storm->sem_fast_mem_addr +
|
||||||
SEM_FAST_REG_INT_RAM +
|
SEM_FAST_REG_INT_RAM +
|
||||||
RAM_LINES_TO_BYTES(asserts->section_ram_line_offset);
|
RAM_LINES_TO_BYTES(addr);
|
||||||
|
|
||||||
next_list_idx_addr = fw_asserts_section_addr +
|
next_list_idx_addr = fw_asserts_section_addr +
|
||||||
DWORDS_TO_BYTES(asserts->list_next_index_dword_offset);
|
DWORDS_TO_BYTES(asserts->list_next_index_dword_offset);
|
||||||
next_list_idx = qed_rd(p_hwfn, p_ptt, next_list_idx_addr);
|
next_list_idx = qed_rd(p_hwfn, p_ptt, next_list_idx_addr);
|
||||||
@ -7651,8 +7661,7 @@ static int qed_dbg_nvm_image(struct qed_dev *cdev, void *buffer,
|
|||||||
{
|
{
|
||||||
struct qed_hwfn *p_hwfn =
|
struct qed_hwfn *p_hwfn =
|
||||||
&cdev->hwfns[cdev->engine_for_debug];
|
&cdev->hwfns[cdev->engine_for_debug];
|
||||||
u32 len_rounded, i;
|
u32 len_rounded;
|
||||||
__be32 val;
|
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
*num_dumped_bytes = 0;
|
*num_dumped_bytes = 0;
|
||||||
@ -7671,10 +7680,9 @@ static int qed_dbg_nvm_image(struct qed_dev *cdev, void *buffer,
|
|||||||
|
|
||||||
/* QED_NVM_IMAGE_NVM_META image is not swapped like other images */
|
/* QED_NVM_IMAGE_NVM_META image is not swapped like other images */
|
||||||
if (image_id != QED_NVM_IMAGE_NVM_META)
|
if (image_id != QED_NVM_IMAGE_NVM_META)
|
||||||
for (i = 0; i < len_rounded; i += 4) {
|
cpu_to_be32_array((__force __be32 *)buffer,
|
||||||
val = cpu_to_be32(*(u32 *)(buffer + i));
|
(const u32 *)buffer,
|
||||||
*(u32 *)(buffer + i) = val;
|
len_rounded / sizeof(u32));
|
||||||
}
|
|
||||||
|
|
||||||
*num_dumped_bytes = len_rounded;
|
*num_dumped_bytes = len_rounded;
|
||||||
|
|
||||||
|
@ -95,7 +95,7 @@ qed_sp_fcoe_func_start(struct qed_hwfn *p_hwfn,
|
|||||||
struct qed_cxt_info cxt_info;
|
struct qed_cxt_info cxt_info;
|
||||||
u32 dummy_cid;
|
u32 dummy_cid;
|
||||||
int rc = 0;
|
int rc = 0;
|
||||||
u16 tmp;
|
__le16 tmp;
|
||||||
u8 i;
|
u8 i;
|
||||||
|
|
||||||
/* Get SPQ entry */
|
/* Get SPQ entry */
|
||||||
@ -162,17 +162,13 @@ qed_sp_fcoe_func_start(struct qed_hwfn *p_hwfn,
|
|||||||
tmp = cpu_to_le16(fcoe_pf_params->cmdq_num_entries);
|
tmp = cpu_to_le16(fcoe_pf_params->cmdq_num_entries);
|
||||||
p_data->q_params.cmdq_num_entries = tmp;
|
p_data->q_params.cmdq_num_entries = tmp;
|
||||||
|
|
||||||
tmp = fcoe_pf_params->num_cqs;
|
p_data->q_params.num_queues = fcoe_pf_params->num_cqs;
|
||||||
p_data->q_params.num_queues = (u8)tmp;
|
|
||||||
|
|
||||||
tmp = (u16)p_hwfn->hw_info.resc_start[QED_CMDQS_CQS];
|
tmp = (__force __le16)p_hwfn->hw_info.resc_start[QED_CMDQS_CQS];
|
||||||
p_data->q_params.queue_relative_offset = (u8)tmp;
|
p_data->q_params.queue_relative_offset = (__force u8)tmp;
|
||||||
|
|
||||||
for (i = 0; i < fcoe_pf_params->num_cqs; i++) {
|
for (i = 0; i < fcoe_pf_params->num_cqs; i++) {
|
||||||
u16 igu_sb_id;
|
tmp = cpu_to_le16(qed_get_igu_sb_id(p_hwfn, i));
|
||||||
|
|
||||||
igu_sb_id = qed_get_igu_sb_id(p_hwfn, i);
|
|
||||||
tmp = cpu_to_le16(igu_sb_id);
|
|
||||||
p_data->q_params.cq_cmdq_sb_num_arr[i] = tmp;
|
p_data->q_params.cq_cmdq_sb_num_arr[i] = tmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -185,21 +181,21 @@ qed_sp_fcoe_func_start(struct qed_hwfn *p_hwfn,
|
|||||||
fcoe_pf_params->bdq_pbl_base_addr[BDQ_ID_RQ]);
|
fcoe_pf_params->bdq_pbl_base_addr[BDQ_ID_RQ]);
|
||||||
p_data->q_params.bdq_pbl_num_entries[BDQ_ID_RQ] =
|
p_data->q_params.bdq_pbl_num_entries[BDQ_ID_RQ] =
|
||||||
fcoe_pf_params->bdq_pbl_num_entries[BDQ_ID_RQ];
|
fcoe_pf_params->bdq_pbl_num_entries[BDQ_ID_RQ];
|
||||||
tmp = fcoe_pf_params->bdq_xoff_threshold[BDQ_ID_RQ];
|
tmp = cpu_to_le16(fcoe_pf_params->bdq_xoff_threshold[BDQ_ID_RQ]);
|
||||||
p_data->q_params.bdq_xoff_threshold[BDQ_ID_RQ] = cpu_to_le16(tmp);
|
p_data->q_params.bdq_xoff_threshold[BDQ_ID_RQ] = tmp;
|
||||||
tmp = fcoe_pf_params->bdq_xon_threshold[BDQ_ID_RQ];
|
tmp = cpu_to_le16(fcoe_pf_params->bdq_xon_threshold[BDQ_ID_RQ]);
|
||||||
p_data->q_params.bdq_xon_threshold[BDQ_ID_RQ] = cpu_to_le16(tmp);
|
p_data->q_params.bdq_xon_threshold[BDQ_ID_RQ] = tmp;
|
||||||
|
|
||||||
DMA_REGPAIR_LE(p_data->q_params.bdq_pbl_base_address[BDQ_ID_IMM_DATA],
|
DMA_REGPAIR_LE(p_data->q_params.bdq_pbl_base_address[BDQ_ID_IMM_DATA],
|
||||||
fcoe_pf_params->bdq_pbl_base_addr[BDQ_ID_IMM_DATA]);
|
fcoe_pf_params->bdq_pbl_base_addr[BDQ_ID_IMM_DATA]);
|
||||||
p_data->q_params.bdq_pbl_num_entries[BDQ_ID_IMM_DATA] =
|
p_data->q_params.bdq_pbl_num_entries[BDQ_ID_IMM_DATA] =
|
||||||
fcoe_pf_params->bdq_pbl_num_entries[BDQ_ID_IMM_DATA];
|
fcoe_pf_params->bdq_pbl_num_entries[BDQ_ID_IMM_DATA];
|
||||||
tmp = fcoe_pf_params->bdq_xoff_threshold[BDQ_ID_IMM_DATA];
|
tmp = cpu_to_le16(fcoe_pf_params->bdq_xoff_threshold[BDQ_ID_IMM_DATA]);
|
||||||
p_data->q_params.bdq_xoff_threshold[BDQ_ID_IMM_DATA] = cpu_to_le16(tmp);
|
p_data->q_params.bdq_xoff_threshold[BDQ_ID_IMM_DATA] = tmp;
|
||||||
tmp = fcoe_pf_params->bdq_xon_threshold[BDQ_ID_IMM_DATA];
|
tmp = cpu_to_le16(fcoe_pf_params->bdq_xon_threshold[BDQ_ID_IMM_DATA]);
|
||||||
p_data->q_params.bdq_xon_threshold[BDQ_ID_IMM_DATA] = cpu_to_le16(tmp);
|
p_data->q_params.bdq_xon_threshold[BDQ_ID_IMM_DATA] = tmp;
|
||||||
tmp = fcoe_pf_params->rq_buffer_size;
|
tmp = cpu_to_le16(fcoe_pf_params->rq_buffer_size);
|
||||||
p_data->q_params.rq_buffer_size = cpu_to_le16(tmp);
|
p_data->q_params.rq_buffer_size = tmp;
|
||||||
|
|
||||||
if (fcoe_pf_params->is_target) {
|
if (fcoe_pf_params->is_target) {
|
||||||
SET_FIELD(p_data->q_params.q_validity,
|
SET_FIELD(p_data->q_params.q_validity,
|
||||||
@ -233,7 +229,8 @@ qed_sp_fcoe_conn_offload(struct qed_hwfn *p_hwfn,
|
|||||||
struct fcoe_conn_offload_ramrod_data *p_data;
|
struct fcoe_conn_offload_ramrod_data *p_data;
|
||||||
struct qed_spq_entry *p_ent = NULL;
|
struct qed_spq_entry *p_ent = NULL;
|
||||||
struct qed_sp_init_data init_data;
|
struct qed_sp_init_data init_data;
|
||||||
u16 physical_q0, tmp;
|
u16 physical_q0;
|
||||||
|
__le16 tmp;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
/* Get SPQ entry */
|
/* Get SPQ entry */
|
||||||
@ -254,7 +251,7 @@ qed_sp_fcoe_conn_offload(struct qed_hwfn *p_hwfn,
|
|||||||
|
|
||||||
/* Transmission PQ is the first of the PF */
|
/* Transmission PQ is the first of the PF */
|
||||||
physical_q0 = qed_get_cm_pq_idx(p_hwfn, PQ_FLAGS_OFLD);
|
physical_q0 = qed_get_cm_pq_idx(p_hwfn, PQ_FLAGS_OFLD);
|
||||||
p_conn->physical_q0 = cpu_to_le16(physical_q0);
|
p_conn->physical_q0 = physical_q0;
|
||||||
p_data->physical_q0 = cpu_to_le16(physical_q0);
|
p_data->physical_q0 = cpu_to_le16(physical_q0);
|
||||||
|
|
||||||
p_data->conn_id = cpu_to_le16(p_conn->conn_id);
|
p_data->conn_id = cpu_to_le16(p_conn->conn_id);
|
||||||
@ -553,8 +550,8 @@ int qed_fcoe_alloc(struct qed_hwfn *p_hwfn)
|
|||||||
void qed_fcoe_setup(struct qed_hwfn *p_hwfn)
|
void qed_fcoe_setup(struct qed_hwfn *p_hwfn)
|
||||||
{
|
{
|
||||||
struct e4_fcoe_task_context *p_task_ctx = NULL;
|
struct e4_fcoe_task_context *p_task_ctx = NULL;
|
||||||
|
u32 i, lc;
|
||||||
int rc;
|
int rc;
|
||||||
u32 i;
|
|
||||||
|
|
||||||
spin_lock_init(&p_hwfn->p_fcoe_info->lock);
|
spin_lock_init(&p_hwfn->p_fcoe_info->lock);
|
||||||
for (i = 0; i < p_hwfn->pf_params.fcoe_pf_params.num_tasks; i++) {
|
for (i = 0; i < p_hwfn->pf_params.fcoe_pf_params.num_tasks; i++) {
|
||||||
@ -565,10 +562,15 @@ void qed_fcoe_setup(struct qed_hwfn *p_hwfn)
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
memset(p_task_ctx, 0, sizeof(struct e4_fcoe_task_context));
|
memset(p_task_ctx, 0, sizeof(struct e4_fcoe_task_context));
|
||||||
SET_FIELD(p_task_ctx->timer_context.logical_client_0,
|
|
||||||
TIMERS_CONTEXT_VALIDLC0, 1);
|
lc = 0;
|
||||||
SET_FIELD(p_task_ctx->timer_context.logical_client_1,
|
SET_FIELD(lc, TIMERS_CONTEXT_VALIDLC0, 1);
|
||||||
TIMERS_CONTEXT_VALIDLC1, 1);
|
p_task_ctx->timer_context.logical_client_0 = cpu_to_le32(lc);
|
||||||
|
|
||||||
|
lc = 0;
|
||||||
|
SET_FIELD(lc, TIMERS_CONTEXT_VALIDLC1, 1);
|
||||||
|
p_task_ctx->timer_context.logical_client_1 = cpu_to_le32(lc);
|
||||||
|
|
||||||
SET_FIELD(p_task_ctx->tstorm_ag_context.flags0,
|
SET_FIELD(p_task_ctx->tstorm_ag_context.flags0,
|
||||||
E4_TSTORM_FCOE_TASK_AG_CTX_CONNECTION_TYPE, 1);
|
E4_TSTORM_FCOE_TASK_AG_CTX_CONNECTION_TYPE, 1);
|
||||||
}
|
}
|
||||||
|
@ -45,9 +45,4 @@ static inline void qed_get_protocol_stats_fcoe(struct qed_dev *cdev,
|
|||||||
}
|
}
|
||||||
#endif /* CONFIG_QED_FCOE */
|
#endif /* CONFIG_QED_FCOE */
|
||||||
|
|
||||||
#ifdef CONFIG_QED_LL2
|
|
||||||
extern const struct qed_common_ops qed_common_ops_pass;
|
|
||||||
extern const struct qed_ll2_ops qed_ll2_ops_pass;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* _QED_FCOE_H */
|
#endif /* _QED_FCOE_H */
|
||||||
|
@ -2793,34 +2793,34 @@ struct fw_overlay_buf_hdr {
|
|||||||
|
|
||||||
/* init array header: raw */
|
/* init array header: raw */
|
||||||
struct init_array_raw_hdr {
|
struct init_array_raw_hdr {
|
||||||
u32 data;
|
__le32 data;
|
||||||
#define INIT_ARRAY_RAW_HDR_TYPE_MASK 0xF
|
#define INIT_ARRAY_RAW_HDR_TYPE_MASK 0xF
|
||||||
#define INIT_ARRAY_RAW_HDR_TYPE_SHIFT 0
|
#define INIT_ARRAY_RAW_HDR_TYPE_SHIFT 0
|
||||||
#define INIT_ARRAY_RAW_HDR_PARAMS_MASK 0xFFFFFFF
|
#define INIT_ARRAY_RAW_HDR_PARAMS_MASK 0xFFFFFFF
|
||||||
#define INIT_ARRAY_RAW_HDR_PARAMS_SHIFT 4
|
#define INIT_ARRAY_RAW_HDR_PARAMS_SHIFT 4
|
||||||
};
|
};
|
||||||
|
|
||||||
/* init array header: standard */
|
/* init array header: standard */
|
||||||
struct init_array_standard_hdr {
|
struct init_array_standard_hdr {
|
||||||
u32 data;
|
__le32 data;
|
||||||
#define INIT_ARRAY_STANDARD_HDR_TYPE_MASK 0xF
|
#define INIT_ARRAY_STANDARD_HDR_TYPE_MASK 0xF
|
||||||
#define INIT_ARRAY_STANDARD_HDR_TYPE_SHIFT 0
|
#define INIT_ARRAY_STANDARD_HDR_TYPE_SHIFT 0
|
||||||
#define INIT_ARRAY_STANDARD_HDR_SIZE_MASK 0xFFFFFFF
|
#define INIT_ARRAY_STANDARD_HDR_SIZE_MASK 0xFFFFFFF
|
||||||
#define INIT_ARRAY_STANDARD_HDR_SIZE_SHIFT 4
|
#define INIT_ARRAY_STANDARD_HDR_SIZE_SHIFT 4
|
||||||
};
|
};
|
||||||
|
|
||||||
/* init array header: zipped */
|
/* init array header: zipped */
|
||||||
struct init_array_zipped_hdr {
|
struct init_array_zipped_hdr {
|
||||||
u32 data;
|
__le32 data;
|
||||||
#define INIT_ARRAY_ZIPPED_HDR_TYPE_MASK 0xF
|
#define INIT_ARRAY_ZIPPED_HDR_TYPE_MASK 0xF
|
||||||
#define INIT_ARRAY_ZIPPED_HDR_TYPE_SHIFT 0
|
#define INIT_ARRAY_ZIPPED_HDR_TYPE_SHIFT 0
|
||||||
#define INIT_ARRAY_ZIPPED_HDR_ZIPPED_SIZE_MASK 0xFFFFFFF
|
#define INIT_ARRAY_ZIPPED_HDR_ZIPPED_SIZE_MASK 0xFFFFFFF
|
||||||
#define INIT_ARRAY_ZIPPED_HDR_ZIPPED_SIZE_SHIFT 4
|
#define INIT_ARRAY_ZIPPED_HDR_ZIPPED_SIZE_SHIFT 4
|
||||||
};
|
};
|
||||||
|
|
||||||
/* init array header: pattern */
|
/* init array header: pattern */
|
||||||
struct init_array_pattern_hdr {
|
struct init_array_pattern_hdr {
|
||||||
u32 data;
|
__le32 data;
|
||||||
#define INIT_ARRAY_PATTERN_HDR_TYPE_MASK 0xF
|
#define INIT_ARRAY_PATTERN_HDR_TYPE_MASK 0xF
|
||||||
#define INIT_ARRAY_PATTERN_HDR_TYPE_SHIFT 0
|
#define INIT_ARRAY_PATTERN_HDR_TYPE_SHIFT 0
|
||||||
#define INIT_ARRAY_PATTERN_HDR_PATTERN_SIZE_MASK 0xF
|
#define INIT_ARRAY_PATTERN_HDR_PATTERN_SIZE_MASK 0xF
|
||||||
@ -2831,10 +2831,10 @@ struct init_array_pattern_hdr {
|
|||||||
|
|
||||||
/* init array header union */
|
/* init array header union */
|
||||||
union init_array_hdr {
|
union init_array_hdr {
|
||||||
struct init_array_raw_hdr raw;
|
struct init_array_raw_hdr raw;
|
||||||
struct init_array_standard_hdr standard;
|
struct init_array_standard_hdr standard;
|
||||||
struct init_array_zipped_hdr zipped;
|
struct init_array_zipped_hdr zipped;
|
||||||
struct init_array_pattern_hdr pattern;
|
struct init_array_pattern_hdr pattern;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* init array types */
|
/* init array types */
|
||||||
@ -2847,54 +2847,54 @@ enum init_array_types {
|
|||||||
|
|
||||||
/* init operation: callback */
|
/* init operation: callback */
|
||||||
struct init_callback_op {
|
struct init_callback_op {
|
||||||
u32 op_data;
|
__le32 op_data;
|
||||||
#define INIT_CALLBACK_OP_OP_MASK 0xF
|
#define INIT_CALLBACK_OP_OP_MASK 0xF
|
||||||
#define INIT_CALLBACK_OP_OP_SHIFT 0
|
#define INIT_CALLBACK_OP_OP_SHIFT 0
|
||||||
#define INIT_CALLBACK_OP_RESERVED_MASK 0xFFFFFFF
|
#define INIT_CALLBACK_OP_RESERVED_MASK 0xFFFFFFF
|
||||||
#define INIT_CALLBACK_OP_RESERVED_SHIFT 4
|
#define INIT_CALLBACK_OP_RESERVED_SHIFT 4
|
||||||
u16 callback_id;
|
__le16 callback_id;
|
||||||
u16 block_id;
|
__le16 block_id;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* init operation: delay */
|
/* init operation: delay */
|
||||||
struct init_delay_op {
|
struct init_delay_op {
|
||||||
u32 op_data;
|
__le32 op_data;
|
||||||
#define INIT_DELAY_OP_OP_MASK 0xF
|
#define INIT_DELAY_OP_OP_MASK 0xF
|
||||||
#define INIT_DELAY_OP_OP_SHIFT 0
|
#define INIT_DELAY_OP_OP_SHIFT 0
|
||||||
#define INIT_DELAY_OP_RESERVED_MASK 0xFFFFFFF
|
#define INIT_DELAY_OP_RESERVED_MASK 0xFFFFFFF
|
||||||
#define INIT_DELAY_OP_RESERVED_SHIFT 4
|
#define INIT_DELAY_OP_RESERVED_SHIFT 4
|
||||||
u32 delay;
|
__le32 delay;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* init operation: if_mode */
|
/* init operation: if_mode */
|
||||||
struct init_if_mode_op {
|
struct init_if_mode_op {
|
||||||
u32 op_data;
|
__le32 op_data;
|
||||||
#define INIT_IF_MODE_OP_OP_MASK 0xF
|
#define INIT_IF_MODE_OP_OP_MASK 0xF
|
||||||
#define INIT_IF_MODE_OP_OP_SHIFT 0
|
#define INIT_IF_MODE_OP_OP_SHIFT 0
|
||||||
#define INIT_IF_MODE_OP_RESERVED1_MASK 0xFFF
|
#define INIT_IF_MODE_OP_RESERVED1_MASK 0xFFF
|
||||||
#define INIT_IF_MODE_OP_RESERVED1_SHIFT 4
|
#define INIT_IF_MODE_OP_RESERVED1_SHIFT 4
|
||||||
#define INIT_IF_MODE_OP_CMD_OFFSET_MASK 0xFFFF
|
#define INIT_IF_MODE_OP_CMD_OFFSET_MASK 0xFFFF
|
||||||
#define INIT_IF_MODE_OP_CMD_OFFSET_SHIFT 16
|
#define INIT_IF_MODE_OP_CMD_OFFSET_SHIFT 16
|
||||||
u16 reserved2;
|
__le16 reserved2;
|
||||||
u16 modes_buf_offset;
|
__le16 modes_buf_offset;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* init operation: if_phase */
|
/* init operation: if_phase */
|
||||||
struct init_if_phase_op {
|
struct init_if_phase_op {
|
||||||
u32 op_data;
|
__le32 op_data;
|
||||||
#define INIT_IF_PHASE_OP_OP_MASK 0xF
|
#define INIT_IF_PHASE_OP_OP_MASK 0xF
|
||||||
#define INIT_IF_PHASE_OP_OP_SHIFT 0
|
#define INIT_IF_PHASE_OP_OP_SHIFT 0
|
||||||
#define INIT_IF_PHASE_OP_RESERVED1_MASK 0xFFF
|
#define INIT_IF_PHASE_OP_RESERVED1_MASK 0xFFF
|
||||||
#define INIT_IF_PHASE_OP_RESERVED1_SHIFT 4
|
#define INIT_IF_PHASE_OP_RESERVED1_SHIFT 4
|
||||||
#define INIT_IF_PHASE_OP_CMD_OFFSET_MASK 0xFFFF
|
#define INIT_IF_PHASE_OP_CMD_OFFSET_MASK 0xFFFF
|
||||||
#define INIT_IF_PHASE_OP_CMD_OFFSET_SHIFT 16
|
#define INIT_IF_PHASE_OP_CMD_OFFSET_SHIFT 16
|
||||||
u32 phase_data;
|
__le32 phase_data;
|
||||||
#define INIT_IF_PHASE_OP_PHASE_MASK 0xFF
|
#define INIT_IF_PHASE_OP_PHASE_MASK 0xFF
|
||||||
#define INIT_IF_PHASE_OP_PHASE_SHIFT 0
|
#define INIT_IF_PHASE_OP_PHASE_SHIFT 0
|
||||||
#define INIT_IF_PHASE_OP_RESERVED2_MASK 0xFF
|
#define INIT_IF_PHASE_OP_RESERVED2_MASK 0xFF
|
||||||
#define INIT_IF_PHASE_OP_RESERVED2_SHIFT 8
|
#define INIT_IF_PHASE_OP_RESERVED2_SHIFT 8
|
||||||
#define INIT_IF_PHASE_OP_PHASE_ID_MASK 0xFFFF
|
#define INIT_IF_PHASE_OP_PHASE_ID_MASK 0xFFFF
|
||||||
#define INIT_IF_PHASE_OP_PHASE_ID_SHIFT 16
|
#define INIT_IF_PHASE_OP_PHASE_ID_SHIFT 16
|
||||||
};
|
};
|
||||||
|
|
||||||
/* init mode operators */
|
/* init mode operators */
|
||||||
@ -2907,67 +2907,67 @@ enum init_mode_ops {
|
|||||||
|
|
||||||
/* init operation: raw */
|
/* init operation: raw */
|
||||||
struct init_raw_op {
|
struct init_raw_op {
|
||||||
u32 op_data;
|
__le32 op_data;
|
||||||
#define INIT_RAW_OP_OP_MASK 0xF
|
#define INIT_RAW_OP_OP_MASK 0xF
|
||||||
#define INIT_RAW_OP_OP_SHIFT 0
|
#define INIT_RAW_OP_OP_SHIFT 0
|
||||||
#define INIT_RAW_OP_PARAM1_MASK 0xFFFFFFF
|
#define INIT_RAW_OP_PARAM1_MASK 0xFFFFFFF
|
||||||
#define INIT_RAW_OP_PARAM1_SHIFT 4
|
#define INIT_RAW_OP_PARAM1_SHIFT 4
|
||||||
u32 param2;
|
__le32 param2;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* init array params */
|
/* init array params */
|
||||||
struct init_op_array_params {
|
struct init_op_array_params {
|
||||||
u16 size;
|
__le16 size;
|
||||||
u16 offset;
|
__le16 offset;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Write init operation arguments */
|
/* Write init operation arguments */
|
||||||
union init_write_args {
|
union init_write_args {
|
||||||
u32 inline_val;
|
__le32 inline_val;
|
||||||
u32 zeros_count;
|
__le32 zeros_count;
|
||||||
u32 array_offset;
|
__le32 array_offset;
|
||||||
struct init_op_array_params runtime;
|
struct init_op_array_params runtime;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* init operation: write */
|
/* init operation: write */
|
||||||
struct init_write_op {
|
struct init_write_op {
|
||||||
u32 data;
|
__le32 data;
|
||||||
#define INIT_WRITE_OP_OP_MASK 0xF
|
#define INIT_WRITE_OP_OP_MASK 0xF
|
||||||
#define INIT_WRITE_OP_OP_SHIFT 0
|
#define INIT_WRITE_OP_OP_SHIFT 0
|
||||||
#define INIT_WRITE_OP_SOURCE_MASK 0x7
|
#define INIT_WRITE_OP_SOURCE_MASK 0x7
|
||||||
#define INIT_WRITE_OP_SOURCE_SHIFT 4
|
#define INIT_WRITE_OP_SOURCE_SHIFT 4
|
||||||
#define INIT_WRITE_OP_RESERVED_MASK 0x1
|
#define INIT_WRITE_OP_RESERVED_MASK 0x1
|
||||||
#define INIT_WRITE_OP_RESERVED_SHIFT 7
|
#define INIT_WRITE_OP_RESERVED_SHIFT 7
|
||||||
#define INIT_WRITE_OP_WIDE_BUS_MASK 0x1
|
#define INIT_WRITE_OP_WIDE_BUS_MASK 0x1
|
||||||
#define INIT_WRITE_OP_WIDE_BUS_SHIFT 8
|
#define INIT_WRITE_OP_WIDE_BUS_SHIFT 8
|
||||||
#define INIT_WRITE_OP_ADDRESS_MASK 0x7FFFFF
|
#define INIT_WRITE_OP_ADDRESS_MASK 0x7FFFFF
|
||||||
#define INIT_WRITE_OP_ADDRESS_SHIFT 9
|
#define INIT_WRITE_OP_ADDRESS_SHIFT 9
|
||||||
union init_write_args args;
|
union init_write_args args;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* init operation: read */
|
/* init operation: read */
|
||||||
struct init_read_op {
|
struct init_read_op {
|
||||||
u32 op_data;
|
__le32 op_data;
|
||||||
#define INIT_READ_OP_OP_MASK 0xF
|
#define INIT_READ_OP_OP_MASK 0xF
|
||||||
#define INIT_READ_OP_OP_SHIFT 0
|
#define INIT_READ_OP_OP_SHIFT 0
|
||||||
#define INIT_READ_OP_POLL_TYPE_MASK 0xF
|
#define INIT_READ_OP_POLL_TYPE_MASK 0xF
|
||||||
#define INIT_READ_OP_POLL_TYPE_SHIFT 4
|
#define INIT_READ_OP_POLL_TYPE_SHIFT 4
|
||||||
#define INIT_READ_OP_RESERVED_MASK 0x1
|
#define INIT_READ_OP_RESERVED_MASK 0x1
|
||||||
#define INIT_READ_OP_RESERVED_SHIFT 8
|
#define INIT_READ_OP_RESERVED_SHIFT 8
|
||||||
#define INIT_READ_OP_ADDRESS_MASK 0x7FFFFF
|
#define INIT_READ_OP_ADDRESS_MASK 0x7FFFFF
|
||||||
#define INIT_READ_OP_ADDRESS_SHIFT 9
|
#define INIT_READ_OP_ADDRESS_SHIFT 9
|
||||||
u32 expected_val;
|
__le32 expected_val;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Init operations union */
|
/* Init operations union */
|
||||||
union init_op {
|
union init_op {
|
||||||
struct init_raw_op raw;
|
struct init_raw_op raw;
|
||||||
struct init_write_op write;
|
struct init_write_op write;
|
||||||
struct init_read_op read;
|
struct init_read_op read;
|
||||||
struct init_if_mode_op if_mode;
|
struct init_if_mode_op if_mode;
|
||||||
struct init_if_phase_op if_phase;
|
struct init_if_phase_op if_phase;
|
||||||
struct init_callback_op callback;
|
struct init_callback_op callback;
|
||||||
struct init_delay_op delay;
|
struct init_delay_op delay;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Init command operation types */
|
/* Init command operation types */
|
||||||
@ -4391,79 +4391,6 @@ void qed_fw_overlay_mem_free(struct qed_hwfn *p_hwfn,
|
|||||||
(IRO[66].base + ((roce_pf_id) * IRO[66].m1))
|
(IRO[66].base + ((roce_pf_id) * IRO[66].m1))
|
||||||
#define USTORM_ROCE_CQE_STATS_SIZE (IRO[66].size)
|
#define USTORM_ROCE_CQE_STATS_SIZE (IRO[66].size)
|
||||||
|
|
||||||
/* IRO Array */
|
|
||||||
static const u32 iro_arr[] = {
|
|
||||||
0x00000000, 0x00000000, 0x00080000,
|
|
||||||
0x00003288, 0x00000088, 0x00880000,
|
|
||||||
0x000058e8, 0x00000020, 0x00200000,
|
|
||||||
0x00000b00, 0x00000008, 0x00040000,
|
|
||||||
0x00000a80, 0x00000008, 0x00040000,
|
|
||||||
0x00000000, 0x00000008, 0x00020000,
|
|
||||||
0x00000080, 0x00000008, 0x00040000,
|
|
||||||
0x00000084, 0x00000008, 0x00020000,
|
|
||||||
0x00005718, 0x00000004, 0x00040000,
|
|
||||||
0x00004dd0, 0x00000000, 0x00780000,
|
|
||||||
0x00003e40, 0x00000000, 0x00780000,
|
|
||||||
0x00004480, 0x00000000, 0x00780000,
|
|
||||||
0x00003210, 0x00000000, 0x00780000,
|
|
||||||
0x00003b50, 0x00000000, 0x00780000,
|
|
||||||
0x00007f58, 0x00000000, 0x00780000,
|
|
||||||
0x00005f58, 0x00000000, 0x00080000,
|
|
||||||
0x00007100, 0x00000000, 0x00080000,
|
|
||||||
0x0000aea0, 0x00000000, 0x00080000,
|
|
||||||
0x00004398, 0x00000000, 0x00080000,
|
|
||||||
0x0000a5a0, 0x00000000, 0x00080000,
|
|
||||||
0x0000bde8, 0x00000000, 0x00080000,
|
|
||||||
0x00000020, 0x00000004, 0x00040000,
|
|
||||||
0x000056c8, 0x00000010, 0x00100000,
|
|
||||||
0x0000c210, 0x00000030, 0x00300000,
|
|
||||||
0x0000b088, 0x00000038, 0x00380000,
|
|
||||||
0x00003d20, 0x00000080, 0x00400000,
|
|
||||||
0x0000bf60, 0x00000000, 0x00040000,
|
|
||||||
0x00004560, 0x00040080, 0x00040000,
|
|
||||||
0x000001f8, 0x00000004, 0x00040000,
|
|
||||||
0x00003d60, 0x00000080, 0x00200000,
|
|
||||||
0x00008960, 0x00000040, 0x00300000,
|
|
||||||
0x0000e840, 0x00000060, 0x00600000,
|
|
||||||
0x00004618, 0x00000080, 0x00380000,
|
|
||||||
0x00010738, 0x000000c0, 0x00c00000,
|
|
||||||
0x000001f8, 0x00000002, 0x00020000,
|
|
||||||
0x0000a2a0, 0x00000000, 0x01080000,
|
|
||||||
0x0000a3a8, 0x00000008, 0x00080000,
|
|
||||||
0x000001c0, 0x00000008, 0x00080000,
|
|
||||||
0x000001f8, 0x00000008, 0x00080000,
|
|
||||||
0x00000ac0, 0x00000008, 0x00080000,
|
|
||||||
0x00002578, 0x00000008, 0x00080000,
|
|
||||||
0x000024f8, 0x00000008, 0x00080000,
|
|
||||||
0x00000280, 0x00000008, 0x00080000,
|
|
||||||
0x00000680, 0x00080018, 0x00080000,
|
|
||||||
0x00000b78, 0x00080018, 0x00020000,
|
|
||||||
0x0000c640, 0x00000050, 0x003c0000,
|
|
||||||
0x00012038, 0x00000018, 0x00100000,
|
|
||||||
0x00011b00, 0x00000040, 0x00180000,
|
|
||||||
0x000095d0, 0x00000050, 0x00200000,
|
|
||||||
0x00008b10, 0x00000040, 0x00280000,
|
|
||||||
0x00011640, 0x00000018, 0x00100000,
|
|
||||||
0x0000c828, 0x00000048, 0x00380000,
|
|
||||||
0x00011710, 0x00000020, 0x00200000,
|
|
||||||
0x00004650, 0x00000080, 0x00100000,
|
|
||||||
0x00003618, 0x00000010, 0x00100000,
|
|
||||||
0x0000a968, 0x00000008, 0x00010000,
|
|
||||||
0x000097a0, 0x00000008, 0x00010000,
|
|
||||||
0x00011990, 0x00000008, 0x00010000,
|
|
||||||
0x0000f018, 0x00000008, 0x00010000,
|
|
||||||
0x00012628, 0x00000008, 0x00010000,
|
|
||||||
0x00011da8, 0x00000008, 0x00010000,
|
|
||||||
0x0000aa78, 0x00000030, 0x00100000,
|
|
||||||
0x0000d768, 0x00000028, 0x00280000,
|
|
||||||
0x00009a58, 0x00000018, 0x00180000,
|
|
||||||
0x00009bd8, 0x00000008, 0x00080000,
|
|
||||||
0x00013a18, 0x00000008, 0x00080000,
|
|
||||||
0x000126e8, 0x00000018, 0x00180000,
|
|
||||||
0x0000e608, 0x00500288, 0x00100000,
|
|
||||||
0x00012970, 0x00000138, 0x00280000,
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Runtime array offsets */
|
/* Runtime array offsets */
|
||||||
#define DORQ_REG_PF_MAX_ICID_0_RT_OFFSET 0
|
#define DORQ_REG_PF_MAX_ICID_0_RT_OFFSET 0
|
||||||
#define DORQ_REG_PF_MAX_ICID_1_RT_OFFSET 1
|
#define DORQ_REG_PF_MAX_ICID_1_RT_OFFSET 1
|
||||||
|
@ -812,9 +812,8 @@ int qed_dmae_host2host(struct qed_hwfn *p_hwfn,
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
void qed_hw_err_notify(struct qed_hwfn *p_hwfn,
|
void qed_hw_err_notify(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt,
|
||||||
struct qed_ptt *p_ptt,
|
enum qed_hw_err_type err_type, const char *fmt, ...)
|
||||||
enum qed_hw_err_type err_type, char *fmt, ...)
|
|
||||||
{
|
{
|
||||||
char buf[QED_HW_ERR_MAX_STR_SIZE];
|
char buf[QED_HW_ERR_MAX_STR_SIZE];
|
||||||
va_list vl;
|
va_list vl;
|
||||||
|
@ -301,7 +301,8 @@ int qed_dmae_sanity(struct qed_hwfn *p_hwfn,
|
|||||||
* @param fmt - debug data buffer to send to the MFW
|
* @param fmt - debug data buffer to send to the MFW
|
||||||
* @param ... - buffer format args
|
* @param ... - buffer format args
|
||||||
*/
|
*/
|
||||||
void qed_hw_err_notify(struct qed_hwfn *p_hwfn,
|
void __printf(4, 5) __cold qed_hw_err_notify(struct qed_hwfn *p_hwfn,
|
||||||
struct qed_ptt *p_ptt,
|
struct qed_ptt *p_ptt,
|
||||||
enum qed_hw_err_type err_type, char *fmt, ...);
|
enum qed_hw_err_type err_type,
|
||||||
|
const char *fmt, ...);
|
||||||
#endif
|
#endif
|
||||||
|
@ -156,23 +156,25 @@ static u16 task_region_offsets[1][NUM_OF_CONNECTION_TYPES_E4] = {
|
|||||||
cmd ## _ ## field, \
|
cmd ## _ ## field, \
|
||||||
value)
|
value)
|
||||||
|
|
||||||
#define QM_INIT_TX_PQ_MAP(p_hwfn, map, chip, pq_id, vp_pq_id, rl_valid, rl_id, \
|
#define QM_INIT_TX_PQ_MAP(p_hwfn, map, chip, pq_id, vp_pq_id, rl_valid, \
|
||||||
ext_voq, wrr) \
|
rl_id, ext_voq, wrr) \
|
||||||
do { \
|
do { \
|
||||||
typeof(map) __map; \
|
u32 __reg = 0; \
|
||||||
memset(&__map, 0, sizeof(__map)); \
|
\
|
||||||
SET_FIELD(__map.reg, QM_RF_PQ_MAP_ ## chip ## _PQ_VALID, 1); \
|
BUILD_BUG_ON(sizeof((map).reg) != sizeof(__reg)); \
|
||||||
SET_FIELD(__map.reg, QM_RF_PQ_MAP_ ## chip ## _RL_VALID, \
|
\
|
||||||
rl_valid ? 1 : 0);\
|
SET_FIELD(__reg, QM_RF_PQ_MAP_##chip##_PQ_VALID, 1); \
|
||||||
SET_FIELD(__map.reg, QM_RF_PQ_MAP_ ## chip ## _VP_PQ_ID, \
|
SET_FIELD(__reg, QM_RF_PQ_MAP_##chip##_RL_VALID, \
|
||||||
vp_pq_id); \
|
!!(rl_valid)); \
|
||||||
SET_FIELD(__map.reg, QM_RF_PQ_MAP_ ## chip ## _RL_ID, rl_id); \
|
SET_FIELD(__reg, QM_RF_PQ_MAP_##chip##_VP_PQ_ID, (vp_pq_id)); \
|
||||||
SET_FIELD(__map.reg, QM_RF_PQ_MAP_ ## chip ## _VOQ, ext_voq); \
|
SET_FIELD(__reg, QM_RF_PQ_MAP_##chip##_RL_ID, (rl_id)); \
|
||||||
SET_FIELD(__map.reg, \
|
SET_FIELD(__reg, QM_RF_PQ_MAP_##chip##_VOQ, (ext_voq)); \
|
||||||
QM_RF_PQ_MAP_ ## chip ## _WRR_WEIGHT_GROUP, wrr); \
|
SET_FIELD(__reg, QM_RF_PQ_MAP_##chip##_WRR_WEIGHT_GROUP, \
|
||||||
STORE_RT_REG(p_hwfn, QM_REG_TXPQMAP_RT_OFFSET + (pq_id), \
|
(wrr)); \
|
||||||
*((u32 *)&__map)); \
|
\
|
||||||
(map) = __map; \
|
STORE_RT_REG((p_hwfn), QM_REG_TXPQMAP_RT_OFFSET + (pq_id), \
|
||||||
|
__reg); \
|
||||||
|
(map).reg = cpu_to_le32(__reg); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define WRITE_PQ_INFO_TO_RAM 1
|
#define WRITE_PQ_INFO_TO_RAM 1
|
||||||
@ -996,20 +998,23 @@ bool qed_send_qm_stop_cmd(struct qed_hwfn *p_hwfn,
|
|||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief qed_dmae_to_grc - is an internal function - writes from host to
|
* qed_dmae_to_grc() - Internal function for writing from host to
|
||||||
* wide-bus registers (split registers are not supported yet)
|
* wide-bus registers (split registers are not supported yet).
|
||||||
*
|
*
|
||||||
* @param p_hwfn - HW device data
|
* @p_hwfn: HW device data.
|
||||||
* @param p_ptt - ptt window used for writing the registers.
|
* @p_ptt: PTT window used for writing the registers.
|
||||||
* @param p_data - pointer to source data.
|
* @p_data: Pointer to source data.
|
||||||
* @param addr - Destination register address.
|
* @addr: Destination register address.
|
||||||
* @param len_in_dwords - data length in DWARDS (u32)
|
* @len_in_dwords: Data length in dwords (u32).
|
||||||
|
*
|
||||||
|
* Return: Length of the written data in dwords (u32) or -1 on invalid
|
||||||
|
* input.
|
||||||
*/
|
*/
|
||||||
static int qed_dmae_to_grc(struct qed_hwfn *p_hwfn,
|
static int qed_dmae_to_grc(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt,
|
||||||
struct qed_ptt *p_ptt,
|
__le32 *p_data, u32 addr, u32 len_in_dwords)
|
||||||
u32 *p_data, u32 addr, u32 len_in_dwords)
|
|
||||||
{
|
{
|
||||||
struct qed_dmae_params params = {};
|
struct qed_dmae_params params = {};
|
||||||
|
u32 *data_cpu;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
if (!p_data)
|
if (!p_data)
|
||||||
@ -1028,8 +1033,13 @@ static int qed_dmae_to_grc(struct qed_hwfn *p_hwfn,
|
|||||||
DP_VERBOSE(p_hwfn,
|
DP_VERBOSE(p_hwfn,
|
||||||
QED_MSG_DEBUG,
|
QED_MSG_DEBUG,
|
||||||
"Failed writing to chip using DMAE, using GRC instead\n");
|
"Failed writing to chip using DMAE, using GRC instead\n");
|
||||||
/* write to registers using GRC */
|
|
||||||
ARR_REG_WR(p_hwfn, p_ptt, addr, p_data, len_in_dwords);
|
/* Swap to CPU byteorder and write to registers using GRC */
|
||||||
|
data_cpu = (__force u32 *)p_data;
|
||||||
|
le32_to_cpu_array(data_cpu, len_in_dwords);
|
||||||
|
|
||||||
|
ARR_REG_WR(p_hwfn, p_ptt, addr, data_cpu, len_in_dwords);
|
||||||
|
cpu_to_le32_array(data_cpu, len_in_dwords);
|
||||||
}
|
}
|
||||||
|
|
||||||
return len_in_dwords;
|
return len_in_dwords;
|
||||||
@ -1230,7 +1240,7 @@ void qed_gft_disable(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt, u16 pf_id)
|
|||||||
qed_wr(p_hwfn, p_ptt, PRS_REG_GFT_CAM + CAM_LINE_SIZE * pf_id, 0);
|
qed_wr(p_hwfn, p_ptt, PRS_REG_GFT_CAM + CAM_LINE_SIZE * pf_id, 0);
|
||||||
|
|
||||||
/* Zero ramline */
|
/* Zero ramline */
|
||||||
qed_dmae_to_grc(p_hwfn, p_ptt, (u32 *)&ram_line,
|
qed_dmae_to_grc(p_hwfn, p_ptt, &ram_line.lo,
|
||||||
PRS_REG_GFT_PROFILE_MASK_RAM + RAM_LINE_SIZE * pf_id,
|
PRS_REG_GFT_PROFILE_MASK_RAM + RAM_LINE_SIZE * pf_id,
|
||||||
sizeof(ram_line) / REG_SIZE);
|
sizeof(ram_line) / REG_SIZE);
|
||||||
}
|
}
|
||||||
@ -1242,8 +1252,10 @@ void qed_gft_config(struct qed_hwfn *p_hwfn,
|
|||||||
bool udp,
|
bool udp,
|
||||||
bool ipv4, bool ipv6, enum gft_profile_type profile_type)
|
bool ipv4, bool ipv6, enum gft_profile_type profile_type)
|
||||||
{
|
{
|
||||||
u32 reg_val, cam_line, search_non_ip_as_gft;
|
struct regpair ram_line;
|
||||||
struct regpair ram_line = { };
|
u32 search_non_ip_as_gft;
|
||||||
|
u32 reg_val, cam_line;
|
||||||
|
u32 lo = 0, hi = 0;
|
||||||
|
|
||||||
if (!ipv6 && !ipv4)
|
if (!ipv6 && !ipv4)
|
||||||
DP_NOTICE(p_hwfn,
|
DP_NOTICE(p_hwfn,
|
||||||
@ -1314,43 +1326,46 @@ void qed_gft_config(struct qed_hwfn *p_hwfn,
|
|||||||
search_non_ip_as_gft = 0;
|
search_non_ip_as_gft = 0;
|
||||||
|
|
||||||
/* Tunnel type */
|
/* Tunnel type */
|
||||||
SET_FIELD(ram_line.lo, GFT_RAM_LINE_TUNNEL_DST_PORT, 1);
|
SET_FIELD(lo, GFT_RAM_LINE_TUNNEL_DST_PORT, 1);
|
||||||
SET_FIELD(ram_line.lo, GFT_RAM_LINE_TUNNEL_OVER_IP_PROTOCOL, 1);
|
SET_FIELD(lo, GFT_RAM_LINE_TUNNEL_OVER_IP_PROTOCOL, 1);
|
||||||
|
|
||||||
if (profile_type == GFT_PROFILE_TYPE_4_TUPLE) {
|
if (profile_type == GFT_PROFILE_TYPE_4_TUPLE) {
|
||||||
SET_FIELD(ram_line.hi, GFT_RAM_LINE_DST_IP, 1);
|
SET_FIELD(hi, GFT_RAM_LINE_DST_IP, 1);
|
||||||
SET_FIELD(ram_line.hi, GFT_RAM_LINE_SRC_IP, 1);
|
SET_FIELD(hi, GFT_RAM_LINE_SRC_IP, 1);
|
||||||
SET_FIELD(ram_line.hi, GFT_RAM_LINE_OVER_IP_PROTOCOL, 1);
|
SET_FIELD(hi, GFT_RAM_LINE_OVER_IP_PROTOCOL, 1);
|
||||||
SET_FIELD(ram_line.lo, GFT_RAM_LINE_ETHERTYPE, 1);
|
SET_FIELD(lo, GFT_RAM_LINE_ETHERTYPE, 1);
|
||||||
SET_FIELD(ram_line.lo, GFT_RAM_LINE_SRC_PORT, 1);
|
SET_FIELD(lo, GFT_RAM_LINE_SRC_PORT, 1);
|
||||||
SET_FIELD(ram_line.lo, GFT_RAM_LINE_DST_PORT, 1);
|
SET_FIELD(lo, GFT_RAM_LINE_DST_PORT, 1);
|
||||||
} else if (profile_type == GFT_PROFILE_TYPE_L4_DST_PORT) {
|
} else if (profile_type == GFT_PROFILE_TYPE_L4_DST_PORT) {
|
||||||
SET_FIELD(ram_line.hi, GFT_RAM_LINE_OVER_IP_PROTOCOL, 1);
|
SET_FIELD(hi, GFT_RAM_LINE_OVER_IP_PROTOCOL, 1);
|
||||||
SET_FIELD(ram_line.lo, GFT_RAM_LINE_ETHERTYPE, 1);
|
SET_FIELD(lo, GFT_RAM_LINE_ETHERTYPE, 1);
|
||||||
SET_FIELD(ram_line.lo, GFT_RAM_LINE_DST_PORT, 1);
|
SET_FIELD(lo, GFT_RAM_LINE_DST_PORT, 1);
|
||||||
} else if (profile_type == GFT_PROFILE_TYPE_IP_DST_ADDR) {
|
} else if (profile_type == GFT_PROFILE_TYPE_IP_DST_ADDR) {
|
||||||
SET_FIELD(ram_line.hi, GFT_RAM_LINE_DST_IP, 1);
|
SET_FIELD(hi, GFT_RAM_LINE_DST_IP, 1);
|
||||||
SET_FIELD(ram_line.lo, GFT_RAM_LINE_ETHERTYPE, 1);
|
SET_FIELD(lo, GFT_RAM_LINE_ETHERTYPE, 1);
|
||||||
} else if (profile_type == GFT_PROFILE_TYPE_IP_SRC_ADDR) {
|
} else if (profile_type == GFT_PROFILE_TYPE_IP_SRC_ADDR) {
|
||||||
SET_FIELD(ram_line.hi, GFT_RAM_LINE_SRC_IP, 1);
|
SET_FIELD(hi, GFT_RAM_LINE_SRC_IP, 1);
|
||||||
SET_FIELD(ram_line.lo, GFT_RAM_LINE_ETHERTYPE, 1);
|
SET_FIELD(lo, GFT_RAM_LINE_ETHERTYPE, 1);
|
||||||
} else if (profile_type == GFT_PROFILE_TYPE_TUNNEL_TYPE) {
|
} else if (profile_type == GFT_PROFILE_TYPE_TUNNEL_TYPE) {
|
||||||
SET_FIELD(ram_line.lo, GFT_RAM_LINE_TUNNEL_ETHERTYPE, 1);
|
SET_FIELD(lo, GFT_RAM_LINE_TUNNEL_ETHERTYPE, 1);
|
||||||
|
|
||||||
/* Allow tunneled traffic without inner IP */
|
/* Allow tunneled traffic without inner IP */
|
||||||
search_non_ip_as_gft = 1;
|
search_non_ip_as_gft = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ram_line.lo = cpu_to_le32(lo);
|
||||||
|
ram_line.hi = cpu_to_le32(hi);
|
||||||
|
|
||||||
qed_wr(p_hwfn,
|
qed_wr(p_hwfn,
|
||||||
p_ptt, PRS_REG_SEARCH_NON_IP_AS_GFT, search_non_ip_as_gft);
|
p_ptt, PRS_REG_SEARCH_NON_IP_AS_GFT, search_non_ip_as_gft);
|
||||||
qed_dmae_to_grc(p_hwfn, p_ptt, (u32 *)&ram_line,
|
qed_dmae_to_grc(p_hwfn, p_ptt, &ram_line.lo,
|
||||||
PRS_REG_GFT_PROFILE_MASK_RAM + RAM_LINE_SIZE * pf_id,
|
PRS_REG_GFT_PROFILE_MASK_RAM + RAM_LINE_SIZE * pf_id,
|
||||||
sizeof(ram_line) / REG_SIZE);
|
sizeof(ram_line) / REG_SIZE);
|
||||||
|
|
||||||
/* Set default profile so that no filter match will happen */
|
/* Set default profile so that no filter match will happen */
|
||||||
ram_line.lo = 0xffffffff;
|
ram_line.lo = cpu_to_le32(0xffffffff);
|
||||||
ram_line.hi = 0x3ff;
|
ram_line.hi = cpu_to_le32(0x3ff);
|
||||||
qed_dmae_to_grc(p_hwfn, p_ptt, (u32 *)&ram_line,
|
qed_dmae_to_grc(p_hwfn, p_ptt, &ram_line.lo,
|
||||||
PRS_REG_GFT_PROFILE_MASK_RAM + RAM_LINE_SIZE *
|
PRS_REG_GFT_PROFILE_MASK_RAM + RAM_LINE_SIZE *
|
||||||
PRS_GFT_CAM_LINES_NO_MATCH,
|
PRS_GFT_CAM_LINES_NO_MATCH,
|
||||||
sizeof(ram_line) / REG_SIZE);
|
sizeof(ram_line) / REG_SIZE);
|
||||||
@ -1368,7 +1383,7 @@ static u8 qed_calc_cdu_validation_byte(u8 conn_type, u8 region, u32 cid)
|
|||||||
u8 crc, validation_byte = 0;
|
u8 crc, validation_byte = 0;
|
||||||
static u8 crc8_table_valid; /* automatically initialized to 0 */
|
static u8 crc8_table_valid; /* automatically initialized to 0 */
|
||||||
u32 validation_string = 0;
|
u32 validation_string = 0;
|
||||||
u32 data_to_crc;
|
__be32 data_to_crc;
|
||||||
|
|
||||||
if (!crc8_table_valid) {
|
if (!crc8_table_valid) {
|
||||||
crc8_populate_msb(cdu_crc8_table, 0x07);
|
crc8_populate_msb(cdu_crc8_table, 0x07);
|
||||||
@ -1390,10 +1405,9 @@ static u8 qed_calc_cdu_validation_byte(u8 conn_type, u8 region, u32 cid)
|
|||||||
validation_string |= (conn_type & 0xF);
|
validation_string |= (conn_type & 0xF);
|
||||||
|
|
||||||
/* Convert to big-endian and calculate CRC8 */
|
/* Convert to big-endian and calculate CRC8 */
|
||||||
data_to_crc = be32_to_cpu(validation_string);
|
data_to_crc = cpu_to_be32(validation_string);
|
||||||
|
crc = crc8(cdu_crc8_table, (u8 *)&data_to_crc, sizeof(data_to_crc),
|
||||||
crc = crc8(cdu_crc8_table,
|
CRC8_INIT_VALUE);
|
||||||
(u8 *)&data_to_crc, sizeof(data_to_crc), CRC8_INIT_VALUE);
|
|
||||||
|
|
||||||
/* The validation byte [7:0] is composed:
|
/* The validation byte [7:0] is composed:
|
||||||
* for type A validation
|
* for type A validation
|
||||||
|
@ -43,6 +43,79 @@ static u32 pxp_global_win[] = {
|
|||||||
0,
|
0,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* IRO Array */
|
||||||
|
static const u32 iro_arr[] = {
|
||||||
|
0x00000000, 0x00000000, 0x00080000,
|
||||||
|
0x00003288, 0x00000088, 0x00880000,
|
||||||
|
0x000058e8, 0x00000020, 0x00200000,
|
||||||
|
0x00000b00, 0x00000008, 0x00040000,
|
||||||
|
0x00000a80, 0x00000008, 0x00040000,
|
||||||
|
0x00000000, 0x00000008, 0x00020000,
|
||||||
|
0x00000080, 0x00000008, 0x00040000,
|
||||||
|
0x00000084, 0x00000008, 0x00020000,
|
||||||
|
0x00005718, 0x00000004, 0x00040000,
|
||||||
|
0x00004dd0, 0x00000000, 0x00780000,
|
||||||
|
0x00003e40, 0x00000000, 0x00780000,
|
||||||
|
0x00004480, 0x00000000, 0x00780000,
|
||||||
|
0x00003210, 0x00000000, 0x00780000,
|
||||||
|
0x00003b50, 0x00000000, 0x00780000,
|
||||||
|
0x00007f58, 0x00000000, 0x00780000,
|
||||||
|
0x00005f58, 0x00000000, 0x00080000,
|
||||||
|
0x00007100, 0x00000000, 0x00080000,
|
||||||
|
0x0000aea0, 0x00000000, 0x00080000,
|
||||||
|
0x00004398, 0x00000000, 0x00080000,
|
||||||
|
0x0000a5a0, 0x00000000, 0x00080000,
|
||||||
|
0x0000bde8, 0x00000000, 0x00080000,
|
||||||
|
0x00000020, 0x00000004, 0x00040000,
|
||||||
|
0x000056c8, 0x00000010, 0x00100000,
|
||||||
|
0x0000c210, 0x00000030, 0x00300000,
|
||||||
|
0x0000b088, 0x00000038, 0x00380000,
|
||||||
|
0x00003d20, 0x00000080, 0x00400000,
|
||||||
|
0x0000bf60, 0x00000000, 0x00040000,
|
||||||
|
0x00004560, 0x00040080, 0x00040000,
|
||||||
|
0x000001f8, 0x00000004, 0x00040000,
|
||||||
|
0x00003d60, 0x00000080, 0x00200000,
|
||||||
|
0x00008960, 0x00000040, 0x00300000,
|
||||||
|
0x0000e840, 0x00000060, 0x00600000,
|
||||||
|
0x00004618, 0x00000080, 0x00380000,
|
||||||
|
0x00010738, 0x000000c0, 0x00c00000,
|
||||||
|
0x000001f8, 0x00000002, 0x00020000,
|
||||||
|
0x0000a2a0, 0x00000000, 0x01080000,
|
||||||
|
0x0000a3a8, 0x00000008, 0x00080000,
|
||||||
|
0x000001c0, 0x00000008, 0x00080000,
|
||||||
|
0x000001f8, 0x00000008, 0x00080000,
|
||||||
|
0x00000ac0, 0x00000008, 0x00080000,
|
||||||
|
0x00002578, 0x00000008, 0x00080000,
|
||||||
|
0x000024f8, 0x00000008, 0x00080000,
|
||||||
|
0x00000280, 0x00000008, 0x00080000,
|
||||||
|
0x00000680, 0x00080018, 0x00080000,
|
||||||
|
0x00000b78, 0x00080018, 0x00020000,
|
||||||
|
0x0000c640, 0x00000050, 0x003c0000,
|
||||||
|
0x00012038, 0x00000018, 0x00100000,
|
||||||
|
0x00011b00, 0x00000040, 0x00180000,
|
||||||
|
0x000095d0, 0x00000050, 0x00200000,
|
||||||
|
0x00008b10, 0x00000040, 0x00280000,
|
||||||
|
0x00011640, 0x00000018, 0x00100000,
|
||||||
|
0x0000c828, 0x00000048, 0x00380000,
|
||||||
|
0x00011710, 0x00000020, 0x00200000,
|
||||||
|
0x00004650, 0x00000080, 0x00100000,
|
||||||
|
0x00003618, 0x00000010, 0x00100000,
|
||||||
|
0x0000a968, 0x00000008, 0x00010000,
|
||||||
|
0x000097a0, 0x00000008, 0x00010000,
|
||||||
|
0x00011990, 0x00000008, 0x00010000,
|
||||||
|
0x0000f018, 0x00000008, 0x00010000,
|
||||||
|
0x00012628, 0x00000008, 0x00010000,
|
||||||
|
0x00011da8, 0x00000008, 0x00010000,
|
||||||
|
0x0000aa78, 0x00000030, 0x00100000,
|
||||||
|
0x0000d768, 0x00000028, 0x00280000,
|
||||||
|
0x00009a58, 0x00000018, 0x00180000,
|
||||||
|
0x00009bd8, 0x00000008, 0x00080000,
|
||||||
|
0x00013a18, 0x00000008, 0x00080000,
|
||||||
|
0x000126e8, 0x00000018, 0x00180000,
|
||||||
|
0x0000e608, 0x00500288, 0x00100000,
|
||||||
|
0x00012970, 0x00000138, 0x00280000,
|
||||||
|
};
|
||||||
|
|
||||||
void qed_init_iro_array(struct qed_dev *cdev)
|
void qed_init_iro_array(struct qed_dev *cdev)
|
||||||
{
|
{
|
||||||
cdev->iro_arr = iro_arr;
|
cdev->iro_arr = iro_arr;
|
||||||
|
@ -816,11 +816,12 @@ static inline u16 qed_attn_update_idx(struct qed_hwfn *p_hwfn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief qed_int_assertion - handles asserted attention bits
|
* qed_int_assertion() - Handle asserted attention bits.
|
||||||
*
|
*
|
||||||
* @param p_hwfn
|
* @p_hwfn: HW device data.
|
||||||
* @param asserted_bits newly asserted bits
|
* @asserted_bits: Newly asserted bits.
|
||||||
* @return int
|
*
|
||||||
|
* Return: Zero value.
|
||||||
*/
|
*/
|
||||||
static int qed_int_assertion(struct qed_hwfn *p_hwfn, u16 asserted_bits)
|
static int qed_int_assertion(struct qed_hwfn *p_hwfn, u16 asserted_bits)
|
||||||
{
|
{
|
||||||
@ -880,16 +881,17 @@ static void qed_int_attn_print(struct qed_hwfn *p_hwfn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief qed_int_deassertion_aeu_bit - handles the effects of a single
|
* qed_int_deassertion_aeu_bit() - Handles the effects of a single
|
||||||
* cause of the attention
|
* cause of the attention.
|
||||||
*
|
*
|
||||||
* @param p_hwfn
|
* @p_hwfn: HW device data.
|
||||||
* @param p_aeu - descriptor of an AEU bit which caused the attention
|
* @p_aeu: Descriptor of an AEU bit which caused the attention.
|
||||||
* @param aeu_en_reg - register offset of the AEU enable reg. which configured
|
* @aeu_en_reg: Register offset of the AEU enable reg. which configured
|
||||||
* this bit to this group.
|
* this bit to this group.
|
||||||
* @param bit_index - index of this bit in the aeu_en_reg
|
* @p_bit_name: AEU bit description for logging purposes.
|
||||||
|
* @bitmask: Index of this bit in the aeu_en_reg.
|
||||||
*
|
*
|
||||||
* @return int
|
* Return: Zero on success, negative errno otherwise.
|
||||||
*/
|
*/
|
||||||
static int
|
static int
|
||||||
qed_int_deassertion_aeu_bit(struct qed_hwfn *p_hwfn,
|
qed_int_deassertion_aeu_bit(struct qed_hwfn *p_hwfn,
|
||||||
@ -938,12 +940,12 @@ qed_int_deassertion_aeu_bit(struct qed_hwfn *p_hwfn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief qed_int_deassertion_parity - handle a single parity AEU source
|
* qed_int_deassertion_parity() - Handle a single parity AEU source.
|
||||||
*
|
*
|
||||||
* @param p_hwfn
|
* @p_hwfn: HW device data.
|
||||||
* @param p_aeu - descriptor of an AEU bit which caused the parity
|
* @p_aeu: Descriptor of an AEU bit which caused the parity.
|
||||||
* @param aeu_en_reg - address of the AEU enable register
|
* @aeu_en_reg: Address of the AEU enable register.
|
||||||
* @param bit_index
|
* @bit_index: Index (0-31) of an AEU bit.
|
||||||
*/
|
*/
|
||||||
static void qed_int_deassertion_parity(struct qed_hwfn *p_hwfn,
|
static void qed_int_deassertion_parity(struct qed_hwfn *p_hwfn,
|
||||||
struct aeu_invert_reg_bit *p_aeu,
|
struct aeu_invert_reg_bit *p_aeu,
|
||||||
@ -976,12 +978,13 @@ static void qed_int_deassertion_parity(struct qed_hwfn *p_hwfn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief - handles deassertion of previously asserted attentions.
|
* qed_int_deassertion() - Handle deassertion of previously asserted
|
||||||
|
* attentions.
|
||||||
*
|
*
|
||||||
* @param p_hwfn
|
* @p_hwfn: HW device data.
|
||||||
* @param deasserted_bits - newly deasserted bits
|
* @deasserted_bits: newly deasserted bits.
|
||||||
* @return int
|
|
||||||
*
|
*
|
||||||
|
* Return: Zero value.
|
||||||
*/
|
*/
|
||||||
static int qed_int_deassertion(struct qed_hwfn *p_hwfn,
|
static int qed_int_deassertion(struct qed_hwfn *p_hwfn,
|
||||||
u16 deasserted_bits)
|
u16 deasserted_bits)
|
||||||
@ -1188,16 +1191,15 @@ static int qed_int_attentions(struct qed_hwfn *p_hwfn)
|
|||||||
static void qed_sb_ack_attn(struct qed_hwfn *p_hwfn,
|
static void qed_sb_ack_attn(struct qed_hwfn *p_hwfn,
|
||||||
void __iomem *igu_addr, u32 ack_cons)
|
void __iomem *igu_addr, u32 ack_cons)
|
||||||
{
|
{
|
||||||
struct igu_prod_cons_update igu_ack = { 0 };
|
u32 igu_ack;
|
||||||
|
|
||||||
igu_ack.sb_id_and_flags =
|
igu_ack = ((ack_cons << IGU_PROD_CONS_UPDATE_SB_INDEX_SHIFT) |
|
||||||
((ack_cons << IGU_PROD_CONS_UPDATE_SB_INDEX_SHIFT) |
|
(1 << IGU_PROD_CONS_UPDATE_UPDATE_FLAG_SHIFT) |
|
||||||
(1 << IGU_PROD_CONS_UPDATE_UPDATE_FLAG_SHIFT) |
|
(IGU_INT_NOP << IGU_PROD_CONS_UPDATE_ENABLE_INT_SHIFT) |
|
||||||
(IGU_INT_NOP << IGU_PROD_CONS_UPDATE_ENABLE_INT_SHIFT) |
|
(IGU_SEG_ACCESS_ATTN <<
|
||||||
(IGU_SEG_ACCESS_ATTN <<
|
IGU_PROD_CONS_UPDATE_SEGMENT_ACCESS_SHIFT));
|
||||||
IGU_PROD_CONS_UPDATE_SEGMENT_ACCESS_SHIFT));
|
|
||||||
|
|
||||||
DIRECT_REG_WR(igu_addr, igu_ack.sb_id_and_flags);
|
DIRECT_REG_WR(igu_addr, igu_ack);
|
||||||
|
|
||||||
/* Both segments (interrupts & acks) are written to same place address;
|
/* Both segments (interrupts & acks) are written to same place address;
|
||||||
* Need to guarantee all commands will be received (in-order) by HW.
|
* Need to guarantee all commands will be received (in-order) by HW.
|
||||||
@ -1411,16 +1413,16 @@ void qed_init_cau_sb_entry(struct qed_hwfn *p_hwfn,
|
|||||||
u8 pf_id, u16 vf_number, u8 vf_valid)
|
u8 pf_id, u16 vf_number, u8 vf_valid)
|
||||||
{
|
{
|
||||||
struct qed_dev *cdev = p_hwfn->cdev;
|
struct qed_dev *cdev = p_hwfn->cdev;
|
||||||
u32 cau_state;
|
u32 cau_state, params = 0, data = 0;
|
||||||
u8 timer_res;
|
u8 timer_res;
|
||||||
|
|
||||||
memset(p_sb_entry, 0, sizeof(*p_sb_entry));
|
memset(p_sb_entry, 0, sizeof(*p_sb_entry));
|
||||||
|
|
||||||
SET_FIELD(p_sb_entry->params, CAU_SB_ENTRY_PF_NUMBER, pf_id);
|
SET_FIELD(params, CAU_SB_ENTRY_PF_NUMBER, pf_id);
|
||||||
SET_FIELD(p_sb_entry->params, CAU_SB_ENTRY_VF_NUMBER, vf_number);
|
SET_FIELD(params, CAU_SB_ENTRY_VF_NUMBER, vf_number);
|
||||||
SET_FIELD(p_sb_entry->params, CAU_SB_ENTRY_VF_VALID, vf_valid);
|
SET_FIELD(params, CAU_SB_ENTRY_VF_VALID, vf_valid);
|
||||||
SET_FIELD(p_sb_entry->params, CAU_SB_ENTRY_SB_TIMESET0, 0x7F);
|
SET_FIELD(params, CAU_SB_ENTRY_SB_TIMESET0, 0x7F);
|
||||||
SET_FIELD(p_sb_entry->params, CAU_SB_ENTRY_SB_TIMESET1, 0x7F);
|
SET_FIELD(params, CAU_SB_ENTRY_SB_TIMESET1, 0x7F);
|
||||||
|
|
||||||
cau_state = CAU_HC_DISABLE_STATE;
|
cau_state = CAU_HC_DISABLE_STATE;
|
||||||
|
|
||||||
@ -1439,7 +1441,8 @@ void qed_init_cau_sb_entry(struct qed_hwfn *p_hwfn,
|
|||||||
timer_res = 1;
|
timer_res = 1;
|
||||||
else
|
else
|
||||||
timer_res = 2;
|
timer_res = 2;
|
||||||
SET_FIELD(p_sb_entry->params, CAU_SB_ENTRY_TIMER_RES0, timer_res);
|
|
||||||
|
SET_FIELD(params, CAU_SB_ENTRY_TIMER_RES0, timer_res);
|
||||||
|
|
||||||
if (cdev->tx_coalesce_usecs <= 0x7F)
|
if (cdev->tx_coalesce_usecs <= 0x7F)
|
||||||
timer_res = 0;
|
timer_res = 0;
|
||||||
@ -1447,10 +1450,13 @@ void qed_init_cau_sb_entry(struct qed_hwfn *p_hwfn,
|
|||||||
timer_res = 1;
|
timer_res = 1;
|
||||||
else
|
else
|
||||||
timer_res = 2;
|
timer_res = 2;
|
||||||
SET_FIELD(p_sb_entry->params, CAU_SB_ENTRY_TIMER_RES1, timer_res);
|
|
||||||
|
|
||||||
SET_FIELD(p_sb_entry->data, CAU_SB_ENTRY_STATE0, cau_state);
|
SET_FIELD(params, CAU_SB_ENTRY_TIMER_RES1, timer_res);
|
||||||
SET_FIELD(p_sb_entry->data, CAU_SB_ENTRY_STATE1, cau_state);
|
p_sb_entry->params = cpu_to_le32(params);
|
||||||
|
|
||||||
|
SET_FIELD(data, CAU_SB_ENTRY_STATE0, cau_state);
|
||||||
|
SET_FIELD(data, CAU_SB_ENTRY_STATE1, cau_state);
|
||||||
|
p_sb_entry->data = cpu_to_le32(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void qed_int_cau_conf_pi(struct qed_hwfn *p_hwfn,
|
static void qed_int_cau_conf_pi(struct qed_hwfn *p_hwfn,
|
||||||
@ -1460,31 +1466,27 @@ static void qed_int_cau_conf_pi(struct qed_hwfn *p_hwfn,
|
|||||||
enum qed_coalescing_fsm coalescing_fsm,
|
enum qed_coalescing_fsm coalescing_fsm,
|
||||||
u8 timeset)
|
u8 timeset)
|
||||||
{
|
{
|
||||||
struct cau_pi_entry pi_entry;
|
|
||||||
u32 sb_offset, pi_offset;
|
u32 sb_offset, pi_offset;
|
||||||
|
u32 prod = 0;
|
||||||
|
|
||||||
if (IS_VF(p_hwfn->cdev))
|
if (IS_VF(p_hwfn->cdev))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
sb_offset = igu_sb_id * PIS_PER_SB_E4;
|
SET_FIELD(prod, CAU_PI_ENTRY_PI_TIMESET, timeset);
|
||||||
memset(&pi_entry, 0, sizeof(struct cau_pi_entry));
|
|
||||||
|
|
||||||
SET_FIELD(pi_entry.prod, CAU_PI_ENTRY_PI_TIMESET, timeset);
|
|
||||||
if (coalescing_fsm == QED_COAL_RX_STATE_MACHINE)
|
if (coalescing_fsm == QED_COAL_RX_STATE_MACHINE)
|
||||||
SET_FIELD(pi_entry.prod, CAU_PI_ENTRY_FSM_SEL, 0);
|
SET_FIELD(prod, CAU_PI_ENTRY_FSM_SEL, 0);
|
||||||
else
|
else
|
||||||
SET_FIELD(pi_entry.prod, CAU_PI_ENTRY_FSM_SEL, 1);
|
SET_FIELD(prod, CAU_PI_ENTRY_FSM_SEL, 1);
|
||||||
|
|
||||||
|
sb_offset = igu_sb_id * PIS_PER_SB_E4;
|
||||||
pi_offset = sb_offset + pi_index;
|
pi_offset = sb_offset + pi_index;
|
||||||
if (p_hwfn->hw_init_done) {
|
|
||||||
|
if (p_hwfn->hw_init_done)
|
||||||
qed_wr(p_hwfn, p_ptt,
|
qed_wr(p_hwfn, p_ptt,
|
||||||
CAU_REG_PI_MEMORY + pi_offset * sizeof(u32),
|
CAU_REG_PI_MEMORY + pi_offset * sizeof(u32), prod);
|
||||||
*((u32 *)&(pi_entry)));
|
else
|
||||||
} else {
|
STORE_RT_REG(p_hwfn, CAU_REG_PI_MEMORY_RT_OFFSET + pi_offset,
|
||||||
STORE_RT_REG(p_hwfn,
|
prod);
|
||||||
CAU_REG_PI_MEMORY_RT_OFFSET + pi_offset,
|
|
||||||
*((u32 *)&(pi_entry)));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void qed_int_cau_conf_sb(struct qed_hwfn *p_hwfn,
|
void qed_int_cau_conf_sb(struct qed_hwfn *p_hwfn,
|
||||||
@ -2241,9 +2243,9 @@ int qed_int_igu_read_cam(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Initialize igu runtime registers
|
* qed_int_igu_init_rt() - Initialize IGU runtime registers.
|
||||||
*
|
*
|
||||||
* @param p_hwfn
|
* @p_hwfn: HW device data.
|
||||||
*/
|
*/
|
||||||
void qed_int_igu_init_rt(struct qed_hwfn *p_hwfn)
|
void qed_int_igu_init_rt(struct qed_hwfn *p_hwfn)
|
||||||
{
|
{
|
||||||
@ -2353,6 +2355,7 @@ int qed_int_set_timer_res(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt,
|
|||||||
u8 timer_res, u16 sb_id, bool tx)
|
u8 timer_res, u16 sb_id, bool tx)
|
||||||
{
|
{
|
||||||
struct cau_sb_entry sb_entry;
|
struct cau_sb_entry sb_entry;
|
||||||
|
u32 params;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
if (!p_hwfn->hw_init_done) {
|
if (!p_hwfn->hw_init_done) {
|
||||||
@ -2368,10 +2371,14 @@ int qed_int_set_timer_res(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt,
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
params = le32_to_cpu(sb_entry.params);
|
||||||
|
|
||||||
if (tx)
|
if (tx)
|
||||||
SET_FIELD(sb_entry.params, CAU_SB_ENTRY_TIMER_RES1, timer_res);
|
SET_FIELD(params, CAU_SB_ENTRY_TIMER_RES1, timer_res);
|
||||||
else
|
else
|
||||||
SET_FIELD(sb_entry.params, CAU_SB_ENTRY_TIMER_RES0, timer_res);
|
SET_FIELD(params, CAU_SB_ENTRY_TIMER_RES0, timer_res);
|
||||||
|
|
||||||
|
sb_entry.params = cpu_to_le32(params);
|
||||||
|
|
||||||
rc = qed_dmae_host2grc(p_hwfn, p_ptt,
|
rc = qed_dmae_host2grc(p_hwfn, p_ptt,
|
||||||
(u64)(uintptr_t)&sb_entry,
|
(u64)(uintptr_t)&sb_entry,
|
||||||
|
@ -117,10 +117,9 @@ struct qed_iscsi_conn {
|
|||||||
u8 abortive_dsconnect;
|
u8 abortive_dsconnect;
|
||||||
};
|
};
|
||||||
|
|
||||||
static int
|
static int qed_iscsi_async_event(struct qed_hwfn *p_hwfn, u8 fw_event_code,
|
||||||
qed_iscsi_async_event(struct qed_hwfn *p_hwfn,
|
__le16 echo, union event_ring_data *data,
|
||||||
u8 fw_event_code,
|
u8 fw_return_code)
|
||||||
u16 echo, union event_ring_data *data, u8 fw_return_code)
|
|
||||||
{
|
{
|
||||||
if (p_hwfn->p_iscsi_info->event_cb) {
|
if (p_hwfn->p_iscsi_info->event_cb) {
|
||||||
struct qed_iscsi_info *p_iscsi = p_hwfn->p_iscsi_info;
|
struct qed_iscsi_info *p_iscsi = p_hwfn->p_iscsi_info;
|
||||||
@ -271,6 +270,7 @@ static int qed_sp_iscsi_conn_offload(struct qed_hwfn *p_hwfn,
|
|||||||
dma_addr_t xhq_pbl_addr;
|
dma_addr_t xhq_pbl_addr;
|
||||||
dma_addr_t uhq_pbl_addr;
|
dma_addr_t uhq_pbl_addr;
|
||||||
u16 physical_q;
|
u16 physical_q;
|
||||||
|
__le16 tmp;
|
||||||
int rc = 0;
|
int rc = 0;
|
||||||
u32 dval;
|
u32 dval;
|
||||||
u16 wval;
|
u16 wval;
|
||||||
@ -294,12 +294,12 @@ static int qed_sp_iscsi_conn_offload(struct qed_hwfn *p_hwfn,
|
|||||||
|
|
||||||
/* Transmission PQ is the first of the PF */
|
/* Transmission PQ is the first of the PF */
|
||||||
physical_q = qed_get_cm_pq_idx(p_hwfn, PQ_FLAGS_OFLD);
|
physical_q = qed_get_cm_pq_idx(p_hwfn, PQ_FLAGS_OFLD);
|
||||||
p_conn->physical_q0 = cpu_to_le16(physical_q);
|
p_conn->physical_q0 = physical_q;
|
||||||
p_ramrod->iscsi.physical_q0 = cpu_to_le16(physical_q);
|
p_ramrod->iscsi.physical_q0 = cpu_to_le16(physical_q);
|
||||||
|
|
||||||
/* iSCSI Pure-ACK PQ */
|
/* iSCSI Pure-ACK PQ */
|
||||||
physical_q = qed_get_cm_pq_idx(p_hwfn, PQ_FLAGS_ACK);
|
physical_q = qed_get_cm_pq_idx(p_hwfn, PQ_FLAGS_ACK);
|
||||||
p_conn->physical_q1 = cpu_to_le16(physical_q);
|
p_conn->physical_q1 = physical_q;
|
||||||
p_ramrod->iscsi.physical_q1 = cpu_to_le16(physical_q);
|
p_ramrod->iscsi.physical_q1 = cpu_to_le16(physical_q);
|
||||||
|
|
||||||
p_ramrod->conn_id = cpu_to_le16(p_conn->conn_id);
|
p_ramrod->conn_id = cpu_to_le16(p_conn->conn_id);
|
||||||
@ -325,14 +325,20 @@ static int qed_sp_iscsi_conn_offload(struct qed_hwfn *p_hwfn,
|
|||||||
p_tcp = &p_ramrod->tcp;
|
p_tcp = &p_ramrod->tcp;
|
||||||
|
|
||||||
p = (u16 *)p_conn->local_mac;
|
p = (u16 *)p_conn->local_mac;
|
||||||
p_tcp->local_mac_addr_hi = swab16(get_unaligned(p));
|
tmp = cpu_to_le16(get_unaligned_be16(p));
|
||||||
p_tcp->local_mac_addr_mid = swab16(get_unaligned(p + 1));
|
p_tcp->local_mac_addr_hi = tmp;
|
||||||
p_tcp->local_mac_addr_lo = swab16(get_unaligned(p + 2));
|
tmp = cpu_to_le16(get_unaligned_be16(p + 1));
|
||||||
|
p_tcp->local_mac_addr_mid = tmp;
|
||||||
|
tmp = cpu_to_le16(get_unaligned_be16(p + 2));
|
||||||
|
p_tcp->local_mac_addr_lo = tmp;
|
||||||
|
|
||||||
p = (u16 *)p_conn->remote_mac;
|
p = (u16 *)p_conn->remote_mac;
|
||||||
p_tcp->remote_mac_addr_hi = swab16(get_unaligned(p));
|
tmp = cpu_to_le16(get_unaligned_be16(p));
|
||||||
p_tcp->remote_mac_addr_mid = swab16(get_unaligned(p + 1));
|
p_tcp->remote_mac_addr_hi = tmp;
|
||||||
p_tcp->remote_mac_addr_lo = swab16(get_unaligned(p + 2));
|
tmp = cpu_to_le16(get_unaligned_be16(p + 1));
|
||||||
|
p_tcp->remote_mac_addr_mid = tmp;
|
||||||
|
tmp = cpu_to_le16(get_unaligned_be16(p + 2));
|
||||||
|
p_tcp->remote_mac_addr_lo = tmp;
|
||||||
|
|
||||||
p_tcp->vlan_id = cpu_to_le16(p_conn->vlan_id);
|
p_tcp->vlan_id = cpu_to_le16(p_conn->vlan_id);
|
||||||
|
|
||||||
@ -391,14 +397,20 @@ static int qed_sp_iscsi_conn_offload(struct qed_hwfn *p_hwfn,
|
|||||||
&((struct iscsi_spe_conn_offload_option2 *)p_ramrod)->tcp;
|
&((struct iscsi_spe_conn_offload_option2 *)p_ramrod)->tcp;
|
||||||
|
|
||||||
p = (u16 *)p_conn->local_mac;
|
p = (u16 *)p_conn->local_mac;
|
||||||
p_tcp2->local_mac_addr_hi = swab16(get_unaligned(p));
|
tmp = cpu_to_le16(get_unaligned_be16(p));
|
||||||
p_tcp2->local_mac_addr_mid = swab16(get_unaligned(p + 1));
|
p_tcp2->local_mac_addr_hi = tmp;
|
||||||
p_tcp2->local_mac_addr_lo = swab16(get_unaligned(p + 2));
|
tmp = cpu_to_le16(get_unaligned_be16(p + 1));
|
||||||
|
p_tcp2->local_mac_addr_mid = tmp;
|
||||||
|
tmp = cpu_to_le16(get_unaligned_be16(p + 2));
|
||||||
|
p_tcp2->local_mac_addr_lo = tmp;
|
||||||
|
|
||||||
p = (u16 *)p_conn->remote_mac;
|
p = (u16 *)p_conn->remote_mac;
|
||||||
p_tcp2->remote_mac_addr_hi = swab16(get_unaligned(p));
|
tmp = cpu_to_le16(get_unaligned_be16(p));
|
||||||
p_tcp2->remote_mac_addr_mid = swab16(get_unaligned(p + 1));
|
p_tcp2->remote_mac_addr_hi = tmp;
|
||||||
p_tcp2->remote_mac_addr_lo = swab16(get_unaligned(p + 2));
|
tmp = cpu_to_le16(get_unaligned_be16(p + 1));
|
||||||
|
p_tcp2->remote_mac_addr_mid = tmp;
|
||||||
|
tmp = cpu_to_le16(get_unaligned_be16(p + 2));
|
||||||
|
p_tcp2->remote_mac_addr_lo = tmp;
|
||||||
|
|
||||||
p_tcp2->vlan_id = cpu_to_le16(p_conn->vlan_id);
|
p_tcp2->vlan_id = cpu_to_le16(p_conn->vlan_id);
|
||||||
p_tcp2->flags = cpu_to_le16(p_conn->tcp_flags);
|
p_tcp2->flags = cpu_to_le16(p_conn->tcp_flags);
|
||||||
|
@ -26,10 +26,6 @@ struct qed_iscsi_info {
|
|||||||
iscsi_event_cb_t event_cb;
|
iscsi_event_cb_t event_cb;
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef CONFIG_QED_LL2
|
|
||||||
extern const struct qed_ll2_ops qed_ll2_ops_pass;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if IS_ENABLED(CONFIG_QED_ISCSI)
|
#if IS_ENABLED(CONFIG_QED_ISCSI)
|
||||||
int qed_iscsi_alloc(struct qed_hwfn *p_hwfn);
|
int qed_iscsi_alloc(struct qed_hwfn *p_hwfn);
|
||||||
|
|
||||||
|
@ -59,9 +59,8 @@ struct mpa_v2_hdr {
|
|||||||
#define QED_IWARP_DEF_KA_TIMEOUT (1200000) /* 20 min */
|
#define QED_IWARP_DEF_KA_TIMEOUT (1200000) /* 20 min */
|
||||||
#define QED_IWARP_DEF_KA_INTERVAL (1000) /* 1 sec */
|
#define QED_IWARP_DEF_KA_INTERVAL (1000) /* 1 sec */
|
||||||
|
|
||||||
static int qed_iwarp_async_event(struct qed_hwfn *p_hwfn,
|
static int qed_iwarp_async_event(struct qed_hwfn *p_hwfn, u8 fw_event_code,
|
||||||
u8 fw_event_code, u16 echo,
|
__le16 echo, union event_ring_data *data,
|
||||||
union event_ring_data *data,
|
|
||||||
u8 fw_return_code);
|
u8 fw_return_code);
|
||||||
|
|
||||||
/* Override devinfo with iWARP specific values */
|
/* Override devinfo with iWARP specific values */
|
||||||
@ -247,14 +246,14 @@ int qed_iwarp_create_qp(struct qed_hwfn *p_hwfn,
|
|||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(p_ramrod->flags,
|
||||||
IWARP_CREATE_QP_RAMROD_DATA_SRQ_FLG, qp->use_srq);
|
IWARP_CREATE_QP_RAMROD_DATA_SRQ_FLG, qp->use_srq);
|
||||||
|
|
||||||
p_ramrod->pd = qp->pd;
|
p_ramrod->pd = cpu_to_le16(qp->pd);
|
||||||
p_ramrod->sq_num_pages = qp->sq_num_pages;
|
p_ramrod->sq_num_pages = cpu_to_le16(qp->sq_num_pages);
|
||||||
p_ramrod->rq_num_pages = qp->rq_num_pages;
|
p_ramrod->rq_num_pages = cpu_to_le16(qp->rq_num_pages);
|
||||||
|
|
||||||
p_ramrod->srq_id.srq_idx = cpu_to_le16(qp->srq_id);
|
p_ramrod->srq_id.srq_idx = cpu_to_le16(qp->srq_id);
|
||||||
p_ramrod->srq_id.opaque_fid = cpu_to_le16(p_hwfn->hw_info.opaque_fid);
|
p_ramrod->srq_id.opaque_fid = cpu_to_le16(p_hwfn->hw_info.opaque_fid);
|
||||||
p_ramrod->qp_handle_for_cqe.hi = cpu_to_le32(qp->qp_handle.hi);
|
p_ramrod->qp_handle_for_cqe.hi = qp->qp_handle.hi;
|
||||||
p_ramrod->qp_handle_for_cqe.lo = cpu_to_le32(qp->qp_handle.lo);
|
p_ramrod->qp_handle_for_cqe.lo = qp->qp_handle.lo;
|
||||||
|
|
||||||
p_ramrod->cq_cid_for_sq =
|
p_ramrod->cq_cid_for_sq =
|
||||||
cpu_to_le32((p_hwfn->hw_info.opaque_fid << 16) | qp->sq_cq_id);
|
cpu_to_le32((p_hwfn->hw_info.opaque_fid << 16) | qp->sq_cq_id);
|
||||||
@ -289,6 +288,7 @@ static int qed_iwarp_modify_fw(struct qed_hwfn *p_hwfn, struct qed_rdma_qp *qp)
|
|||||||
struct iwarp_modify_qp_ramrod_data *p_ramrod;
|
struct iwarp_modify_qp_ramrod_data *p_ramrod;
|
||||||
struct qed_sp_init_data init_data;
|
struct qed_sp_init_data init_data;
|
||||||
struct qed_spq_entry *p_ent;
|
struct qed_spq_entry *p_ent;
|
||||||
|
u16 flags, trans_to_state;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
/* Get SPQ entry */
|
/* Get SPQ entry */
|
||||||
@ -304,12 +304,17 @@ static int qed_iwarp_modify_fw(struct qed_hwfn *p_hwfn, struct qed_rdma_qp *qp)
|
|||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
p_ramrod = &p_ent->ramrod.iwarp_modify_qp;
|
p_ramrod = &p_ent->ramrod.iwarp_modify_qp;
|
||||||
SET_FIELD(p_ramrod->flags, IWARP_MODIFY_QP_RAMROD_DATA_STATE_TRANS_EN,
|
|
||||||
0x1);
|
flags = le16_to_cpu(p_ramrod->flags);
|
||||||
|
SET_FIELD(flags, IWARP_MODIFY_QP_RAMROD_DATA_STATE_TRANS_EN, 0x1);
|
||||||
|
p_ramrod->flags = cpu_to_le16(flags);
|
||||||
|
|
||||||
if (qp->iwarp_state == QED_IWARP_QP_STATE_CLOSING)
|
if (qp->iwarp_state == QED_IWARP_QP_STATE_CLOSING)
|
||||||
p_ramrod->transition_to_state = IWARP_MODIFY_QP_STATE_CLOSING;
|
trans_to_state = IWARP_MODIFY_QP_STATE_CLOSING;
|
||||||
else
|
else
|
||||||
p_ramrod->transition_to_state = IWARP_MODIFY_QP_STATE_ERROR;
|
trans_to_state = IWARP_MODIFY_QP_STATE_ERROR;
|
||||||
|
|
||||||
|
p_ramrod->transition_to_state = cpu_to_le16(trans_to_state);
|
||||||
|
|
||||||
rc = qed_spq_post(p_hwfn, p_ent, NULL);
|
rc = qed_spq_post(p_hwfn, p_ent, NULL);
|
||||||
|
|
||||||
@ -622,6 +627,7 @@ qed_iwarp_tcp_offload(struct qed_hwfn *p_hwfn, struct qed_iwarp_ep *ep)
|
|||||||
dma_addr_t async_output_phys;
|
dma_addr_t async_output_phys;
|
||||||
dma_addr_t in_pdata_phys;
|
dma_addr_t in_pdata_phys;
|
||||||
u16 physical_q;
|
u16 physical_q;
|
||||||
|
u16 flags = 0;
|
||||||
u8 tcp_flags;
|
u8 tcp_flags;
|
||||||
int rc;
|
int rc;
|
||||||
int i;
|
int i;
|
||||||
@ -674,13 +680,14 @@ qed_iwarp_tcp_offload(struct qed_hwfn *p_hwfn, struct qed_iwarp_ep *ep)
|
|||||||
tcp->vlan_id = cpu_to_le16(ep->cm_info.vlan);
|
tcp->vlan_id = cpu_to_le16(ep->cm_info.vlan);
|
||||||
|
|
||||||
tcp_flags = p_hwfn->p_rdma_info->iwarp.tcp_flags;
|
tcp_flags = p_hwfn->p_rdma_info->iwarp.tcp_flags;
|
||||||
tcp->flags = 0;
|
|
||||||
SET_FIELD(tcp->flags, TCP_OFFLOAD_PARAMS_OPT2_TS_EN,
|
SET_FIELD(flags, TCP_OFFLOAD_PARAMS_OPT2_TS_EN,
|
||||||
!!(tcp_flags & QED_IWARP_TS_EN));
|
!!(tcp_flags & QED_IWARP_TS_EN));
|
||||||
|
|
||||||
SET_FIELD(tcp->flags, TCP_OFFLOAD_PARAMS_OPT2_DA_EN,
|
SET_FIELD(flags, TCP_OFFLOAD_PARAMS_OPT2_DA_EN,
|
||||||
!!(tcp_flags & QED_IWARP_DA_EN));
|
!!(tcp_flags & QED_IWARP_DA_EN));
|
||||||
|
|
||||||
|
tcp->flags = cpu_to_le16(flags);
|
||||||
tcp->ip_version = ep->cm_info.ip_version;
|
tcp->ip_version = ep->cm_info.ip_version;
|
||||||
|
|
||||||
for (i = 0; i < 4; i++) {
|
for (i = 0; i < 4; i++) {
|
||||||
@ -696,10 +703,10 @@ qed_iwarp_tcp_offload(struct qed_hwfn *p_hwfn, struct qed_iwarp_ep *ep)
|
|||||||
tcp->tos_or_tc = 0;
|
tcp->tos_or_tc = 0;
|
||||||
|
|
||||||
tcp->max_rt_time = QED_IWARP_DEF_MAX_RT_TIME;
|
tcp->max_rt_time = QED_IWARP_DEF_MAX_RT_TIME;
|
||||||
tcp->cwnd = QED_IWARP_DEF_CWND_FACTOR * tcp->mss;
|
tcp->cwnd = cpu_to_le32(QED_IWARP_DEF_CWND_FACTOR * ep->mss);
|
||||||
tcp->ka_max_probe_cnt = QED_IWARP_DEF_KA_MAX_PROBE_CNT;
|
tcp->ka_max_probe_cnt = QED_IWARP_DEF_KA_MAX_PROBE_CNT;
|
||||||
tcp->ka_timeout = QED_IWARP_DEF_KA_TIMEOUT;
|
tcp->ka_timeout = cpu_to_le32(QED_IWARP_DEF_KA_TIMEOUT);
|
||||||
tcp->ka_interval = QED_IWARP_DEF_KA_INTERVAL;
|
tcp->ka_interval = cpu_to_le32(QED_IWARP_DEF_KA_INTERVAL);
|
||||||
|
|
||||||
tcp->rcv_wnd_scale = (u8)p_hwfn->p_rdma_info->iwarp.rcv_wnd_scale;
|
tcp->rcv_wnd_scale = (u8)p_hwfn->p_rdma_info->iwarp.rcv_wnd_scale;
|
||||||
tcp->connect_mode = ep->connect_mode;
|
tcp->connect_mode = ep->connect_mode;
|
||||||
@ -730,6 +737,7 @@ qed_iwarp_mpa_received(struct qed_hwfn *p_hwfn, struct qed_iwarp_ep *ep)
|
|||||||
union async_output *async_data;
|
union async_output *async_data;
|
||||||
u16 mpa_ord, mpa_ird;
|
u16 mpa_ord, mpa_ird;
|
||||||
u8 mpa_hdr_size = 0;
|
u8 mpa_hdr_size = 0;
|
||||||
|
u16 ulp_data_len;
|
||||||
u8 mpa_rev;
|
u8 mpa_rev;
|
||||||
|
|
||||||
async_data = &ep->ep_buffer_virt->async_output;
|
async_data = &ep->ep_buffer_virt->async_output;
|
||||||
@ -793,8 +801,8 @@ qed_iwarp_mpa_received(struct qed_hwfn *p_hwfn, struct qed_iwarp_ep *ep)
|
|||||||
/* Strip mpa v2 hdr from private data before sending to upper layer */
|
/* Strip mpa v2 hdr from private data before sending to upper layer */
|
||||||
ep->cm_info.private_data = ep->ep_buffer_virt->in_pdata + mpa_hdr_size;
|
ep->cm_info.private_data = ep->ep_buffer_virt->in_pdata + mpa_hdr_size;
|
||||||
|
|
||||||
ep->cm_info.private_data_len = async_data->mpa_request.ulp_data_len -
|
ulp_data_len = le16_to_cpu(async_data->mpa_request.ulp_data_len);
|
||||||
mpa_hdr_size;
|
ep->cm_info.private_data_len = ulp_data_len - mpa_hdr_size;
|
||||||
|
|
||||||
params.event = QED_IWARP_EVENT_MPA_REQUEST;
|
params.event = QED_IWARP_EVENT_MPA_REQUEST;
|
||||||
params.cm_info = &ep->cm_info;
|
params.cm_info = &ep->cm_info;
|
||||||
@ -809,6 +817,7 @@ static int
|
|||||||
qed_iwarp_mpa_offload(struct qed_hwfn *p_hwfn, struct qed_iwarp_ep *ep)
|
qed_iwarp_mpa_offload(struct qed_hwfn *p_hwfn, struct qed_iwarp_ep *ep)
|
||||||
{
|
{
|
||||||
struct iwarp_mpa_offload_ramrod_data *p_mpa_ramrod;
|
struct iwarp_mpa_offload_ramrod_data *p_mpa_ramrod;
|
||||||
|
struct mpa_outgoing_params *common;
|
||||||
struct qed_iwarp_info *iwarp_info;
|
struct qed_iwarp_info *iwarp_info;
|
||||||
struct qed_sp_init_data init_data;
|
struct qed_sp_init_data init_data;
|
||||||
dma_addr_t async_output_phys;
|
dma_addr_t async_output_phys;
|
||||||
@ -817,6 +826,7 @@ qed_iwarp_mpa_offload(struct qed_hwfn *p_hwfn, struct qed_iwarp_ep *ep)
|
|||||||
dma_addr_t in_pdata_phys;
|
dma_addr_t in_pdata_phys;
|
||||||
struct qed_rdma_qp *qp;
|
struct qed_rdma_qp *qp;
|
||||||
bool reject;
|
bool reject;
|
||||||
|
u32 val;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
if (!ep)
|
if (!ep)
|
||||||
@ -841,18 +851,21 @@ qed_iwarp_mpa_offload(struct qed_hwfn *p_hwfn, struct qed_iwarp_ep *ep)
|
|||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
p_mpa_ramrod = &p_ent->ramrod.iwarp_mpa_offload;
|
p_mpa_ramrod = &p_ent->ramrod.iwarp_mpa_offload;
|
||||||
|
common = &p_mpa_ramrod->common;
|
||||||
|
|
||||||
out_pdata_phys = ep->ep_buffer_phys +
|
out_pdata_phys = ep->ep_buffer_phys +
|
||||||
offsetof(struct qed_iwarp_ep_memory, out_pdata);
|
offsetof(struct qed_iwarp_ep_memory, out_pdata);
|
||||||
DMA_REGPAIR_LE(p_mpa_ramrod->common.outgoing_ulp_buffer.addr,
|
DMA_REGPAIR_LE(common->outgoing_ulp_buffer.addr, out_pdata_phys);
|
||||||
out_pdata_phys);
|
|
||||||
p_mpa_ramrod->common.outgoing_ulp_buffer.len =
|
|
||||||
ep->cm_info.private_data_len;
|
|
||||||
p_mpa_ramrod->common.crc_needed = p_hwfn->p_rdma_info->iwarp.crc_needed;
|
|
||||||
|
|
||||||
p_mpa_ramrod->common.out_rq.ord = ep->cm_info.ord;
|
val = ep->cm_info.private_data_len;
|
||||||
p_mpa_ramrod->common.out_rq.ird = ep->cm_info.ird;
|
common->outgoing_ulp_buffer.len = cpu_to_le16(val);
|
||||||
|
common->crc_needed = p_hwfn->p_rdma_info->iwarp.crc_needed;
|
||||||
|
|
||||||
p_mpa_ramrod->tcp_cid = p_hwfn->hw_info.opaque_fid << 16 | ep->tcp_cid;
|
common->out_rq.ord = cpu_to_le32(ep->cm_info.ord);
|
||||||
|
common->out_rq.ird = cpu_to_le32(ep->cm_info.ird);
|
||||||
|
|
||||||
|
val = p_hwfn->hw_info.opaque_fid << 16 | ep->tcp_cid;
|
||||||
|
p_mpa_ramrod->tcp_cid = cpu_to_le32(val);
|
||||||
|
|
||||||
in_pdata_phys = ep->ep_buffer_phys +
|
in_pdata_phys = ep->ep_buffer_phys +
|
||||||
offsetof(struct qed_iwarp_ep_memory, in_pdata);
|
offsetof(struct qed_iwarp_ep_memory, in_pdata);
|
||||||
@ -874,11 +887,11 @@ qed_iwarp_mpa_offload(struct qed_hwfn *p_hwfn, struct qed_iwarp_ep *ep)
|
|||||||
p_mpa_ramrod->stats_counter_id =
|
p_mpa_ramrod->stats_counter_id =
|
||||||
RESC_START(p_hwfn, QED_RDMA_STATS_QUEUE) + qp->stats_queue;
|
RESC_START(p_hwfn, QED_RDMA_STATS_QUEUE) + qp->stats_queue;
|
||||||
} else {
|
} else {
|
||||||
p_mpa_ramrod->common.reject = 1;
|
common->reject = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
iwarp_info = &p_hwfn->p_rdma_info->iwarp;
|
iwarp_info = &p_hwfn->p_rdma_info->iwarp;
|
||||||
p_mpa_ramrod->rcv_wnd = iwarp_info->rcv_wnd_size;
|
p_mpa_ramrod->rcv_wnd = cpu_to_le16(iwarp_info->rcv_wnd_size);
|
||||||
p_mpa_ramrod->mode = ep->mpa_rev;
|
p_mpa_ramrod->mode = ep->mpa_rev;
|
||||||
SET_FIELD(p_mpa_ramrod->rtr_pref,
|
SET_FIELD(p_mpa_ramrod->rtr_pref,
|
||||||
IWARP_MPA_OFFLOAD_RAMROD_DATA_RTR_SUPPORTED, ep->rtr_type);
|
IWARP_MPA_OFFLOAD_RAMROD_DATA_RTR_SUPPORTED, ep->rtr_type);
|
||||||
@ -929,6 +942,7 @@ qed_iwarp_parse_private_data(struct qed_hwfn *p_hwfn, struct qed_iwarp_ep *ep)
|
|||||||
union async_output *async_data;
|
union async_output *async_data;
|
||||||
u16 mpa_ird, mpa_ord;
|
u16 mpa_ird, mpa_ord;
|
||||||
u8 mpa_data_size = 0;
|
u8 mpa_data_size = 0;
|
||||||
|
u16 ulp_data_len;
|
||||||
|
|
||||||
if (MPA_REV2(p_hwfn->p_rdma_info->iwarp.mpa_rev)) {
|
if (MPA_REV2(p_hwfn->p_rdma_info->iwarp.mpa_rev)) {
|
||||||
mpa_v2_params =
|
mpa_v2_params =
|
||||||
@ -940,11 +954,12 @@ qed_iwarp_parse_private_data(struct qed_hwfn *p_hwfn, struct qed_iwarp_ep *ep)
|
|||||||
ep->cm_info.ird = (u8)(mpa_ord & MPA_V2_IRD_ORD_MASK);
|
ep->cm_info.ird = (u8)(mpa_ord & MPA_V2_IRD_ORD_MASK);
|
||||||
ep->cm_info.ord = (u8)(mpa_ird & MPA_V2_IRD_ORD_MASK);
|
ep->cm_info.ord = (u8)(mpa_ird & MPA_V2_IRD_ORD_MASK);
|
||||||
}
|
}
|
||||||
async_data = &ep->ep_buffer_virt->async_output;
|
|
||||||
|
|
||||||
|
async_data = &ep->ep_buffer_virt->async_output;
|
||||||
ep->cm_info.private_data = ep->ep_buffer_virt->in_pdata + mpa_data_size;
|
ep->cm_info.private_data = ep->ep_buffer_virt->in_pdata + mpa_data_size;
|
||||||
ep->cm_info.private_data_len = async_data->mpa_response.ulp_data_len -
|
|
||||||
mpa_data_size;
|
ulp_data_len = le16_to_cpu(async_data->mpa_response.ulp_data_len);
|
||||||
|
ep->cm_info.private_data_len = ulp_data_len - mpa_data_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -1821,7 +1836,7 @@ qed_iwarp_mpa_classify(struct qed_hwfn *p_hwfn,
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
mpa_len = ntohs(*((u16 *)(mpa_data)));
|
mpa_len = ntohs(*(__force __be16 *)mpa_data);
|
||||||
fpdu->fpdu_length = QED_IWARP_FPDU_LEN_WITH_PAD(mpa_len);
|
fpdu->fpdu_length = QED_IWARP_FPDU_LEN_WITH_PAD(mpa_len);
|
||||||
|
|
||||||
if (fpdu->fpdu_length <= tcp_payload_len)
|
if (fpdu->fpdu_length <= tcp_payload_len)
|
||||||
@ -1843,11 +1858,13 @@ qed_iwarp_init_fpdu(struct qed_iwarp_ll2_buff *buf,
|
|||||||
struct unaligned_opaque_data *pkt_data,
|
struct unaligned_opaque_data *pkt_data,
|
||||||
u16 tcp_payload_size, u8 placement_offset)
|
u16 tcp_payload_size, u8 placement_offset)
|
||||||
{
|
{
|
||||||
|
u16 first_mpa_offset = le16_to_cpu(pkt_data->first_mpa_offset);
|
||||||
|
|
||||||
fpdu->mpa_buf = buf;
|
fpdu->mpa_buf = buf;
|
||||||
fpdu->pkt_hdr = buf->data_phys_addr + placement_offset;
|
fpdu->pkt_hdr = buf->data_phys_addr + placement_offset;
|
||||||
fpdu->pkt_hdr_size = pkt_data->tcp_payload_offset;
|
fpdu->pkt_hdr_size = pkt_data->tcp_payload_offset;
|
||||||
fpdu->mpa_frag = buf->data_phys_addr + pkt_data->first_mpa_offset;
|
fpdu->mpa_frag = buf->data_phys_addr + first_mpa_offset;
|
||||||
fpdu->mpa_frag_virt = (u8 *)(buf->data) + pkt_data->first_mpa_offset;
|
fpdu->mpa_frag_virt = (u8 *)(buf->data) + first_mpa_offset;
|
||||||
|
|
||||||
if (tcp_payload_size == 1)
|
if (tcp_payload_size == 1)
|
||||||
fpdu->incomplete_bytes = QED_IWARP_INVALID_FPDU_LENGTH;
|
fpdu->incomplete_bytes = QED_IWARP_INVALID_FPDU_LENGTH;
|
||||||
@ -1865,6 +1882,7 @@ qed_iwarp_cp_pkt(struct qed_hwfn *p_hwfn,
|
|||||||
struct unaligned_opaque_data *pkt_data,
|
struct unaligned_opaque_data *pkt_data,
|
||||||
struct qed_iwarp_ll2_buff *buf, u16 tcp_payload_size)
|
struct qed_iwarp_ll2_buff *buf, u16 tcp_payload_size)
|
||||||
{
|
{
|
||||||
|
u16 first_mpa_offset = le16_to_cpu(pkt_data->first_mpa_offset);
|
||||||
u8 *tmp_buf = p_hwfn->p_rdma_info->iwarp.mpa_intermediate_buf;
|
u8 *tmp_buf = p_hwfn->p_rdma_info->iwarp.mpa_intermediate_buf;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
@ -1885,13 +1903,11 @@ qed_iwarp_cp_pkt(struct qed_hwfn *p_hwfn,
|
|||||||
DP_VERBOSE(p_hwfn, QED_MSG_RDMA,
|
DP_VERBOSE(p_hwfn, QED_MSG_RDMA,
|
||||||
"MPA ALIGN Copying fpdu: [%p, %d] [%p, %d]\n",
|
"MPA ALIGN Copying fpdu: [%p, %d] [%p, %d]\n",
|
||||||
fpdu->mpa_frag_virt, fpdu->mpa_frag_len,
|
fpdu->mpa_frag_virt, fpdu->mpa_frag_len,
|
||||||
(u8 *)(buf->data) + pkt_data->first_mpa_offset,
|
(u8 *)(buf->data) + first_mpa_offset, tcp_payload_size);
|
||||||
tcp_payload_size);
|
|
||||||
|
|
||||||
memcpy(tmp_buf, fpdu->mpa_frag_virt, fpdu->mpa_frag_len);
|
memcpy(tmp_buf, fpdu->mpa_frag_virt, fpdu->mpa_frag_len);
|
||||||
memcpy(tmp_buf + fpdu->mpa_frag_len,
|
memcpy(tmp_buf + fpdu->mpa_frag_len,
|
||||||
(u8 *)(buf->data) + pkt_data->first_mpa_offset,
|
(u8 *)(buf->data) + first_mpa_offset, tcp_payload_size);
|
||||||
tcp_payload_size);
|
|
||||||
|
|
||||||
rc = qed_iwarp_recycle_pkt(p_hwfn, fpdu, fpdu->mpa_buf);
|
rc = qed_iwarp_recycle_pkt(p_hwfn, fpdu, fpdu->mpa_buf);
|
||||||
if (rc)
|
if (rc)
|
||||||
@ -2034,6 +2050,7 @@ qed_iwarp_send_fpdu(struct qed_hwfn *p_hwfn,
|
|||||||
u16 tcp_payload_size, enum qed_iwarp_mpa_pkt_type pkt_type)
|
u16 tcp_payload_size, enum qed_iwarp_mpa_pkt_type pkt_type)
|
||||||
{
|
{
|
||||||
struct qed_ll2_tx_pkt_info tx_pkt;
|
struct qed_ll2_tx_pkt_info tx_pkt;
|
||||||
|
u16 first_mpa_offset;
|
||||||
u8 ll2_handle;
|
u8 ll2_handle;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
@ -2085,11 +2102,13 @@ qed_iwarp_send_fpdu(struct qed_hwfn *p_hwfn,
|
|||||||
if (!fpdu->incomplete_bytes)
|
if (!fpdu->incomplete_bytes)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
first_mpa_offset = le16_to_cpu(curr_pkt->first_mpa_offset);
|
||||||
|
|
||||||
/* Set third fragment to second part of the packet */
|
/* Set third fragment to second part of the packet */
|
||||||
rc = qed_ll2_set_fragment_of_tx_packet(p_hwfn,
|
rc = qed_ll2_set_fragment_of_tx_packet(p_hwfn,
|
||||||
ll2_handle,
|
ll2_handle,
|
||||||
buf->data_phys_addr +
|
buf->data_phys_addr +
|
||||||
curr_pkt->first_mpa_offset,
|
first_mpa_offset,
|
||||||
fpdu->incomplete_bytes);
|
fpdu->incomplete_bytes);
|
||||||
out:
|
out:
|
||||||
DP_VERBOSE(p_hwfn,
|
DP_VERBOSE(p_hwfn,
|
||||||
@ -2110,12 +2129,12 @@ qed_iwarp_mpa_get_data(struct qed_hwfn *p_hwfn,
|
|||||||
{
|
{
|
||||||
u64 opaque_data;
|
u64 opaque_data;
|
||||||
|
|
||||||
opaque_data = HILO_64(opaque_data1, opaque_data0);
|
opaque_data = HILO_64(cpu_to_le32(opaque_data1),
|
||||||
|
cpu_to_le32(opaque_data0));
|
||||||
*curr_pkt = *((struct unaligned_opaque_data *)&opaque_data);
|
*curr_pkt = *((struct unaligned_opaque_data *)&opaque_data);
|
||||||
|
|
||||||
curr_pkt->first_mpa_offset = curr_pkt->tcp_payload_offset +
|
le16_add_cpu(&curr_pkt->first_mpa_offset,
|
||||||
le16_to_cpu(curr_pkt->first_mpa_offset);
|
curr_pkt->tcp_payload_offset);
|
||||||
curr_pkt->cid = le32_to_cpu(curr_pkt->cid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* This function is called when an unaligned or incomplete MPA packet arrives
|
/* This function is called when an unaligned or incomplete MPA packet arrives
|
||||||
@ -2130,18 +2149,22 @@ qed_iwarp_process_mpa_pkt(struct qed_hwfn *p_hwfn,
|
|||||||
struct qed_iwarp_ll2_buff *buf = mpa_buf->ll2_buf;
|
struct qed_iwarp_ll2_buff *buf = mpa_buf->ll2_buf;
|
||||||
enum qed_iwarp_mpa_pkt_type pkt_type;
|
enum qed_iwarp_mpa_pkt_type pkt_type;
|
||||||
struct qed_iwarp_fpdu *fpdu;
|
struct qed_iwarp_fpdu *fpdu;
|
||||||
|
u16 cid, first_mpa_offset;
|
||||||
int rc = -EINVAL;
|
int rc = -EINVAL;
|
||||||
u8 *mpa_data;
|
u8 *mpa_data;
|
||||||
|
|
||||||
fpdu = qed_iwarp_get_curr_fpdu(p_hwfn, curr_pkt->cid & 0xffff);
|
cid = le32_to_cpu(curr_pkt->cid);
|
||||||
|
|
||||||
|
fpdu = qed_iwarp_get_curr_fpdu(p_hwfn, (u16)cid);
|
||||||
if (!fpdu) { /* something corrupt with cid, post rx back */
|
if (!fpdu) { /* something corrupt with cid, post rx back */
|
||||||
DP_ERR(p_hwfn, "Invalid cid, drop and post back to rx cid=%x\n",
|
DP_ERR(p_hwfn, "Invalid cid, drop and post back to rx cid=%x\n",
|
||||||
curr_pkt->cid);
|
cid);
|
||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
do {
|
do {
|
||||||
mpa_data = ((u8 *)(buf->data) + curr_pkt->first_mpa_offset);
|
first_mpa_offset = le16_to_cpu(curr_pkt->first_mpa_offset);
|
||||||
|
mpa_data = ((u8 *)(buf->data) + first_mpa_offset);
|
||||||
|
|
||||||
pkt_type = qed_iwarp_mpa_classify(p_hwfn, fpdu,
|
pkt_type = qed_iwarp_mpa_classify(p_hwfn, fpdu,
|
||||||
mpa_buf->tcp_payload_len,
|
mpa_buf->tcp_payload_len,
|
||||||
@ -2187,7 +2210,8 @@ qed_iwarp_process_mpa_pkt(struct qed_hwfn *p_hwfn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
mpa_buf->tcp_payload_len -= fpdu->fpdu_length;
|
mpa_buf->tcp_payload_len -= fpdu->fpdu_length;
|
||||||
curr_pkt->first_mpa_offset += fpdu->fpdu_length;
|
le16_add_cpu(&curr_pkt->first_mpa_offset,
|
||||||
|
fpdu->fpdu_length);
|
||||||
break;
|
break;
|
||||||
case QED_IWARP_MPA_PKT_UNALIGNED:
|
case QED_IWARP_MPA_PKT_UNALIGNED:
|
||||||
qed_iwarp_update_fpdu_length(p_hwfn, fpdu, mpa_data);
|
qed_iwarp_update_fpdu_length(p_hwfn, fpdu, mpa_data);
|
||||||
@ -2226,7 +2250,9 @@ qed_iwarp_process_mpa_pkt(struct qed_hwfn *p_hwfn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
mpa_buf->tcp_payload_len -= fpdu->incomplete_bytes;
|
mpa_buf->tcp_payload_len -= fpdu->incomplete_bytes;
|
||||||
curr_pkt->first_mpa_offset += fpdu->incomplete_bytes;
|
le16_add_cpu(&curr_pkt->first_mpa_offset,
|
||||||
|
fpdu->incomplete_bytes);
|
||||||
|
|
||||||
/* The framed PDU was sent - no more incomplete bytes */
|
/* The framed PDU was sent - no more incomplete bytes */
|
||||||
fpdu->incomplete_bytes = 0;
|
fpdu->incomplete_bytes = 0;
|
||||||
break;
|
break;
|
||||||
@ -2277,6 +2303,7 @@ qed_iwarp_ll2_comp_mpa_pkt(void *cxt, struct qed_ll2_comp_rx_data *data)
|
|||||||
struct qed_iwarp_ll2_mpa_buf *mpa_buf;
|
struct qed_iwarp_ll2_mpa_buf *mpa_buf;
|
||||||
struct qed_iwarp_info *iwarp_info;
|
struct qed_iwarp_info *iwarp_info;
|
||||||
struct qed_hwfn *p_hwfn = cxt;
|
struct qed_hwfn *p_hwfn = cxt;
|
||||||
|
u16 first_mpa_offset;
|
||||||
|
|
||||||
iwarp_info = &p_hwfn->p_rdma_info->iwarp;
|
iwarp_info = &p_hwfn->p_rdma_info->iwarp;
|
||||||
mpa_buf = list_first_entry(&iwarp_info->mpa_buf_list,
|
mpa_buf = list_first_entry(&iwarp_info->mpa_buf_list,
|
||||||
@ -2290,17 +2317,21 @@ qed_iwarp_ll2_comp_mpa_pkt(void *cxt, struct qed_ll2_comp_rx_data *data)
|
|||||||
qed_iwarp_mpa_get_data(p_hwfn, &mpa_buf->data,
|
qed_iwarp_mpa_get_data(p_hwfn, &mpa_buf->data,
|
||||||
data->opaque_data_0, data->opaque_data_1);
|
data->opaque_data_0, data->opaque_data_1);
|
||||||
|
|
||||||
|
first_mpa_offset = le16_to_cpu(mpa_buf->data.first_mpa_offset);
|
||||||
|
|
||||||
DP_VERBOSE(p_hwfn,
|
DP_VERBOSE(p_hwfn,
|
||||||
QED_MSG_RDMA,
|
QED_MSG_RDMA,
|
||||||
"LL2 MPA CompRx payload_len:0x%x\tfirst_mpa_offset:0x%x\ttcp_payload_offset:0x%x\tflags:0x%x\tcid:0x%x\n",
|
"LL2 MPA CompRx payload_len:0x%x\tfirst_mpa_offset:0x%x\ttcp_payload_offset:0x%x\tflags:0x%x\tcid:0x%x\n",
|
||||||
data->length.packet_length, mpa_buf->data.first_mpa_offset,
|
data->length.packet_length, first_mpa_offset,
|
||||||
mpa_buf->data.tcp_payload_offset, mpa_buf->data.flags,
|
mpa_buf->data.tcp_payload_offset, mpa_buf->data.flags,
|
||||||
mpa_buf->data.cid);
|
mpa_buf->data.cid);
|
||||||
|
|
||||||
mpa_buf->ll2_buf = data->cookie;
|
mpa_buf->ll2_buf = data->cookie;
|
||||||
mpa_buf->tcp_payload_len = data->length.packet_length -
|
mpa_buf->tcp_payload_len = data->length.packet_length -
|
||||||
mpa_buf->data.first_mpa_offset;
|
first_mpa_offset;
|
||||||
mpa_buf->data.first_mpa_offset += data->u.placement_offset;
|
|
||||||
|
first_mpa_offset += data->u.placement_offset;
|
||||||
|
mpa_buf->data.first_mpa_offset = cpu_to_le16(first_mpa_offset);
|
||||||
mpa_buf->placement_offset = data->u.placement_offset;
|
mpa_buf->placement_offset = data->u.placement_offset;
|
||||||
|
|
||||||
list_add_tail(&mpa_buf->list_entry, &iwarp_info->mpa_buf_pending_list);
|
list_add_tail(&mpa_buf->list_entry, &iwarp_info->mpa_buf_pending_list);
|
||||||
@ -2499,14 +2530,16 @@ qed_iwarp_ll2_slowpath(void *cxt,
|
|||||||
struct unaligned_opaque_data unalign_data;
|
struct unaligned_opaque_data unalign_data;
|
||||||
struct qed_hwfn *p_hwfn = cxt;
|
struct qed_hwfn *p_hwfn = cxt;
|
||||||
struct qed_iwarp_fpdu *fpdu;
|
struct qed_iwarp_fpdu *fpdu;
|
||||||
|
u32 cid;
|
||||||
|
|
||||||
qed_iwarp_mpa_get_data(p_hwfn, &unalign_data,
|
qed_iwarp_mpa_get_data(p_hwfn, &unalign_data,
|
||||||
opaque_data_0, opaque_data_1);
|
opaque_data_0, opaque_data_1);
|
||||||
|
|
||||||
DP_VERBOSE(p_hwfn, QED_MSG_RDMA, "(0x%x) Flush fpdu\n",
|
cid = le32_to_cpu(unalign_data.cid);
|
||||||
unalign_data.cid);
|
|
||||||
|
|
||||||
fpdu = qed_iwarp_get_curr_fpdu(p_hwfn, (u16)unalign_data.cid);
|
DP_VERBOSE(p_hwfn, QED_MSG_RDMA, "(0x%x) Flush fpdu\n", cid);
|
||||||
|
|
||||||
|
fpdu = qed_iwarp_get_curr_fpdu(p_hwfn, (u16)cid);
|
||||||
if (fpdu)
|
if (fpdu)
|
||||||
memset(fpdu, 0, sizeof(*fpdu));
|
memset(fpdu, 0, sizeof(*fpdu));
|
||||||
}
|
}
|
||||||
@ -3008,9 +3041,8 @@ qed_iwarp_check_ep_ok(struct qed_hwfn *p_hwfn, struct qed_iwarp_ep *ep)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qed_iwarp_async_event(struct qed_hwfn *p_hwfn,
|
static int qed_iwarp_async_event(struct qed_hwfn *p_hwfn, u8 fw_event_code,
|
||||||
u8 fw_event_code, u16 echo,
|
__le16 echo, union event_ring_data *data,
|
||||||
union event_ring_data *data,
|
|
||||||
u8 fw_return_code)
|
u8 fw_return_code)
|
||||||
{
|
{
|
||||||
struct qed_rdma_events events = p_hwfn->p_rdma_info->events;
|
struct qed_rdma_events events = p_hwfn->p_rdma_info->events;
|
||||||
|
@ -24,6 +24,7 @@
|
|||||||
#include "qed.h"
|
#include "qed.h"
|
||||||
#include <linux/qed/qed_chain.h>
|
#include <linux/qed/qed_chain.h>
|
||||||
#include "qed_cxt.h"
|
#include "qed_cxt.h"
|
||||||
|
#include "qed_dcbx.h"
|
||||||
#include "qed_dev_api.h"
|
#include "qed_dev_api.h"
|
||||||
#include <linux/qed/qed_eth_if.h>
|
#include <linux/qed/qed_eth_if.h>
|
||||||
#include "qed_hsi.h"
|
#include "qed_hsi.h"
|
||||||
@ -31,6 +32,7 @@
|
|||||||
#include "qed_int.h"
|
#include "qed_int.h"
|
||||||
#include "qed_l2.h"
|
#include "qed_l2.h"
|
||||||
#include "qed_mcp.h"
|
#include "qed_mcp.h"
|
||||||
|
#include "qed_ptp.h"
|
||||||
#include "qed_reg_addr.h"
|
#include "qed_reg_addr.h"
|
||||||
#include "qed_sp.h"
|
#include "qed_sp.h"
|
||||||
#include "qed_sriov.h"
|
#include "qed_sriov.h"
|
||||||
@ -340,10 +342,11 @@ int qed_sp_eth_vport_start(struct qed_hwfn *p_hwfn,
|
|||||||
struct qed_sp_vport_start_params *p_params)
|
struct qed_sp_vport_start_params *p_params)
|
||||||
{
|
{
|
||||||
struct vport_start_ramrod_data *p_ramrod = NULL;
|
struct vport_start_ramrod_data *p_ramrod = NULL;
|
||||||
|
struct eth_vport_tpa_param *tpa_param;
|
||||||
struct qed_spq_entry *p_ent = NULL;
|
struct qed_spq_entry *p_ent = NULL;
|
||||||
struct qed_sp_init_data init_data;
|
struct qed_sp_init_data init_data;
|
||||||
|
u16 min_size, rx_mode = 0;
|
||||||
u8 abs_vport_id = 0;
|
u8 abs_vport_id = 0;
|
||||||
u16 rx_mode = 0;
|
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
rc = qed_fw_vport(p_hwfn, p_params->vport_id, &abs_vport_id);
|
rc = qed_fw_vport(p_hwfn, p_params->vport_id, &abs_vport_id);
|
||||||
@ -376,21 +379,23 @@ int qed_sp_eth_vport_start(struct qed_hwfn *p_hwfn,
|
|||||||
p_ramrod->rx_mode.state = cpu_to_le16(rx_mode);
|
p_ramrod->rx_mode.state = cpu_to_le16(rx_mode);
|
||||||
|
|
||||||
/* TPA related fields */
|
/* TPA related fields */
|
||||||
memset(&p_ramrod->tpa_param, 0, sizeof(struct eth_vport_tpa_param));
|
tpa_param = &p_ramrod->tpa_param;
|
||||||
|
memset(tpa_param, 0, sizeof(*tpa_param));
|
||||||
|
|
||||||
p_ramrod->tpa_param.max_buff_num = p_params->max_buffers_per_cqe;
|
tpa_param->max_buff_num = p_params->max_buffers_per_cqe;
|
||||||
|
|
||||||
switch (p_params->tpa_mode) {
|
switch (p_params->tpa_mode) {
|
||||||
case QED_TPA_MODE_GRO:
|
case QED_TPA_MODE_GRO:
|
||||||
p_ramrod->tpa_param.tpa_max_aggs_num = ETH_TPA_MAX_AGGS_NUM;
|
min_size = p_params->mtu / 2;
|
||||||
p_ramrod->tpa_param.tpa_max_size = (u16)-1;
|
|
||||||
p_ramrod->tpa_param.tpa_min_size_to_cont = p_params->mtu / 2;
|
tpa_param->tpa_max_aggs_num = ETH_TPA_MAX_AGGS_NUM;
|
||||||
p_ramrod->tpa_param.tpa_min_size_to_start = p_params->mtu / 2;
|
tpa_param->tpa_max_size = cpu_to_le16(U16_MAX);
|
||||||
p_ramrod->tpa_param.tpa_ipv4_en_flg = 1;
|
tpa_param->tpa_min_size_to_cont = cpu_to_le16(min_size);
|
||||||
p_ramrod->tpa_param.tpa_ipv6_en_flg = 1;
|
tpa_param->tpa_min_size_to_start = cpu_to_le16(min_size);
|
||||||
p_ramrod->tpa_param.tpa_pkt_split_flg = 1;
|
tpa_param->tpa_ipv4_en_flg = 1;
|
||||||
p_ramrod->tpa_param.tpa_gro_consistent_flg = 1;
|
tpa_param->tpa_ipv6_en_flg = 1;
|
||||||
break;
|
tpa_param->tpa_pkt_split_flg = 1;
|
||||||
|
tpa_param->tpa_gro_consistent_flg = 1;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -599,33 +604,33 @@ qed_sp_update_accept_mode(struct qed_hwfn *p_hwfn,
|
|||||||
static void
|
static void
|
||||||
qed_sp_vport_update_sge_tpa(struct qed_hwfn *p_hwfn,
|
qed_sp_vport_update_sge_tpa(struct qed_hwfn *p_hwfn,
|
||||||
struct vport_update_ramrod_data *p_ramrod,
|
struct vport_update_ramrod_data *p_ramrod,
|
||||||
struct qed_sge_tpa_params *p_params)
|
const struct qed_sge_tpa_params *param)
|
||||||
{
|
{
|
||||||
struct eth_vport_tpa_param *p_tpa;
|
struct eth_vport_tpa_param *tpa;
|
||||||
|
|
||||||
if (!p_params) {
|
if (!param) {
|
||||||
p_ramrod->common.update_tpa_param_flg = 0;
|
p_ramrod->common.update_tpa_param_flg = 0;
|
||||||
p_ramrod->common.update_tpa_en_flg = 0;
|
p_ramrod->common.update_tpa_en_flg = 0;
|
||||||
p_ramrod->common.update_tpa_param_flg = 0;
|
p_ramrod->common.update_tpa_param_flg = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
p_ramrod->common.update_tpa_en_flg = p_params->update_tpa_en_flg;
|
p_ramrod->common.update_tpa_en_flg = param->update_tpa_en_flg;
|
||||||
p_tpa = &p_ramrod->tpa_param;
|
tpa = &p_ramrod->tpa_param;
|
||||||
p_tpa->tpa_ipv4_en_flg = p_params->tpa_ipv4_en_flg;
|
tpa->tpa_ipv4_en_flg = param->tpa_ipv4_en_flg;
|
||||||
p_tpa->tpa_ipv6_en_flg = p_params->tpa_ipv6_en_flg;
|
tpa->tpa_ipv6_en_flg = param->tpa_ipv6_en_flg;
|
||||||
p_tpa->tpa_ipv4_tunn_en_flg = p_params->tpa_ipv4_tunn_en_flg;
|
tpa->tpa_ipv4_tunn_en_flg = param->tpa_ipv4_tunn_en_flg;
|
||||||
p_tpa->tpa_ipv6_tunn_en_flg = p_params->tpa_ipv6_tunn_en_flg;
|
tpa->tpa_ipv6_tunn_en_flg = param->tpa_ipv6_tunn_en_flg;
|
||||||
|
|
||||||
p_ramrod->common.update_tpa_param_flg = p_params->update_tpa_param_flg;
|
p_ramrod->common.update_tpa_param_flg = param->update_tpa_param_flg;
|
||||||
p_tpa->max_buff_num = p_params->max_buffers_per_cqe;
|
tpa->max_buff_num = param->max_buffers_per_cqe;
|
||||||
p_tpa->tpa_pkt_split_flg = p_params->tpa_pkt_split_flg;
|
tpa->tpa_pkt_split_flg = param->tpa_pkt_split_flg;
|
||||||
p_tpa->tpa_hdr_data_split_flg = p_params->tpa_hdr_data_split_flg;
|
tpa->tpa_hdr_data_split_flg = param->tpa_hdr_data_split_flg;
|
||||||
p_tpa->tpa_gro_consistent_flg = p_params->tpa_gro_consistent_flg;
|
tpa->tpa_gro_consistent_flg = param->tpa_gro_consistent_flg;
|
||||||
p_tpa->tpa_max_aggs_num = p_params->tpa_max_aggs_num;
|
tpa->tpa_max_aggs_num = param->tpa_max_aggs_num;
|
||||||
p_tpa->tpa_max_size = p_params->tpa_max_size;
|
tpa->tpa_max_size = cpu_to_le16(param->tpa_max_size);
|
||||||
p_tpa->tpa_min_size_to_start = p_params->tpa_min_size_to_start;
|
tpa->tpa_min_size_to_start = cpu_to_le16(param->tpa_min_size_to_start);
|
||||||
p_tpa->tpa_min_size_to_cont = p_params->tpa_min_size_to_cont;
|
tpa->tpa_min_size_to_cont = cpu_to_le16(param->tpa_min_size_to_cont);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -2087,7 +2092,8 @@ int qed_get_rxq_coalesce(struct qed_hwfn *p_hwfn,
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
timer_res = GET_FIELD(sb_entry.params, CAU_SB_ENTRY_TIMER_RES0);
|
timer_res = GET_FIELD(le32_to_cpu(sb_entry.params),
|
||||||
|
CAU_SB_ENTRY_TIMER_RES0);
|
||||||
|
|
||||||
address = BAR0_MAP_REG_USDM_RAM +
|
address = BAR0_MAP_REG_USDM_RAM +
|
||||||
USTORM_ETH_QUEUE_ZONE_OFFSET(p_cid->abs.queue_id);
|
USTORM_ETH_QUEUE_ZONE_OFFSET(p_cid->abs.queue_id);
|
||||||
@ -2120,7 +2126,8 @@ int qed_get_txq_coalesce(struct qed_hwfn *p_hwfn,
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
timer_res = GET_FIELD(sb_entry.params, CAU_SB_ENTRY_TIMER_RES1);
|
timer_res = GET_FIELD(le32_to_cpu(sb_entry.params),
|
||||||
|
CAU_SB_ENTRY_TIMER_RES1);
|
||||||
|
|
||||||
address = BAR0_MAP_REG_XSDM_RAM +
|
address = BAR0_MAP_REG_XSDM_RAM +
|
||||||
XSTORM_ETH_QUEUE_ZONE_OFFSET(p_cid->abs.queue_id);
|
XSTORM_ETH_QUEUE_ZONE_OFFSET(p_cid->abs.queue_id);
|
||||||
@ -2874,16 +2881,6 @@ static int qed_req_bulletin_update_mac(struct qed_dev *cdev, u8 *mac)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_QED_SRIOV
|
|
||||||
extern const struct qed_iov_hv_ops qed_iov_ops_pass;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef CONFIG_DCB
|
|
||||||
extern const struct qed_eth_dcbnl_ops qed_dcbnl_ops_pass;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
extern const struct qed_eth_ptp_ops qed_ptp_ops_pass;
|
|
||||||
|
|
||||||
static const struct qed_eth_ops qed_eth_ops_pass = {
|
static const struct qed_eth_ops qed_eth_ops_pass = {
|
||||||
.common = &qed_common_ops_pass,
|
.common = &qed_common_ops_pass,
|
||||||
#ifdef CONFIG_QED_SRIOV
|
#ifdef CONFIG_QED_SRIOV
|
||||||
|
@ -1798,6 +1798,7 @@ qed_ll2_prepare_tx_packet_set_bd(struct qed_hwfn *p_hwfn,
|
|||||||
enum core_roce_flavor_type roce_flavor;
|
enum core_roce_flavor_type roce_flavor;
|
||||||
enum core_tx_dest tx_dest;
|
enum core_tx_dest tx_dest;
|
||||||
u16 bd_data = 0, frag_idx;
|
u16 bd_data = 0, frag_idx;
|
||||||
|
u16 bitfield1;
|
||||||
|
|
||||||
roce_flavor = (pkt->qed_roce_flavor == QED_LL2_ROCE) ? CORE_ROCE
|
roce_flavor = (pkt->qed_roce_flavor == QED_LL2_ROCE) ? CORE_ROCE
|
||||||
: CORE_RROCE;
|
: CORE_RROCE;
|
||||||
@ -1829,9 +1830,11 @@ qed_ll2_prepare_tx_packet_set_bd(struct qed_hwfn *p_hwfn,
|
|||||||
pkt->remove_stag = true;
|
pkt->remove_stag = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
SET_FIELD(start_bd->bitfield1, CORE_TX_BD_L4_HDR_OFFSET_W,
|
bitfield1 = le16_to_cpu(start_bd->bitfield1);
|
||||||
cpu_to_le16(pkt->l4_hdr_offset_w));
|
SET_FIELD(bitfield1, CORE_TX_BD_L4_HDR_OFFSET_W, pkt->l4_hdr_offset_w);
|
||||||
SET_FIELD(start_bd->bitfield1, CORE_TX_BD_TX_DST, tx_dest);
|
SET_FIELD(bitfield1, CORE_TX_BD_TX_DST, tx_dest);
|
||||||
|
start_bd->bitfield1 = cpu_to_le16(bitfield1);
|
||||||
|
|
||||||
bd_data |= pkt->bd_flags;
|
bd_data |= pkt->bd_flags;
|
||||||
SET_FIELD(bd_data, CORE_TX_BD_DATA_START_BD, 0x1);
|
SET_FIELD(bd_data, CORE_TX_BD_DATA_START_BD, 0x1);
|
||||||
SET_FIELD(bd_data, CORE_TX_BD_DATA_NBDS, pkt->num_of_bds);
|
SET_FIELD(bd_data, CORE_TX_BD_DATA_NBDS, pkt->num_of_bds);
|
||||||
|
@ -116,6 +116,8 @@ struct qed_ll2_info {
|
|||||||
struct qed_ll2_cbs cbs;
|
struct qed_ll2_cbs cbs;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
extern const struct qed_ll2_ops qed_ll2_ops_pass;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief qed_ll2_acquire_connection - allocate resources,
|
* @brief qed_ll2_acquire_connection - allocate resources,
|
||||||
* starts rx & tx (if relevant) queues pair. Provides
|
* starts rx & tx (if relevant) queues pair. Provides
|
||||||
|
@ -1962,8 +1962,7 @@ static u32 qed_nvm_flash_image_access_crc(struct qed_dev *cdev,
|
|||||||
u32 *crc)
|
u32 *crc)
|
||||||
{
|
{
|
||||||
u8 *buf = NULL;
|
u8 *buf = NULL;
|
||||||
int rc, j;
|
int rc;
|
||||||
u32 val;
|
|
||||||
|
|
||||||
/* Allocate a buffer for holding the nvram image */
|
/* Allocate a buffer for holding the nvram image */
|
||||||
buf = kzalloc(nvm_image->length, GFP_KERNEL);
|
buf = kzalloc(nvm_image->length, GFP_KERNEL);
|
||||||
@ -1981,15 +1980,14 @@ static u32 qed_nvm_flash_image_access_crc(struct qed_dev *cdev,
|
|||||||
/* Convert the buffer into big-endian format (excluding the
|
/* Convert the buffer into big-endian format (excluding the
|
||||||
* closing 4 bytes of CRC).
|
* closing 4 bytes of CRC).
|
||||||
*/
|
*/
|
||||||
for (j = 0; j < nvm_image->length - 4; j += 4) {
|
cpu_to_be32_array((__force __be32 *)buf, (const u32 *)buf,
|
||||||
val = cpu_to_be32(*(u32 *)&buf[j]);
|
DIV_ROUND_UP(nvm_image->length - 4, 4));
|
||||||
*(u32 *)&buf[j] = val;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Calc CRC for the "actual" image buffer, i.e. not including
|
/* Calc CRC for the "actual" image buffer, i.e. not including
|
||||||
* the last 4 CRC bytes.
|
* the last 4 CRC bytes.
|
||||||
*/
|
*/
|
||||||
*crc = (~cpu_to_be32(crc32(0xffffffff, buf, nvm_image->length - 4)));
|
*crc = ~crc32(~0U, buf, nvm_image->length - 4);
|
||||||
|
*crc = (__force u32)cpu_to_be32p(crc);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
kfree(buf);
|
kfree(buf);
|
||||||
@ -2451,7 +2449,7 @@ void qed_schedule_recovery_handler(struct qed_hwfn *p_hwfn)
|
|||||||
ops->schedule_recovery_handler(cookie);
|
ops->schedule_recovery_handler(cookie);
|
||||||
}
|
}
|
||||||
|
|
||||||
static char *qed_hw_err_type_descr[] = {
|
static const char * const qed_hw_err_type_descr[] = {
|
||||||
[QED_HW_ERR_FAN_FAIL] = "Fan Failure",
|
[QED_HW_ERR_FAN_FAIL] = "Fan Failure",
|
||||||
[QED_HW_ERR_MFW_RESP_FAIL] = "MFW Response Failure",
|
[QED_HW_ERR_MFW_RESP_FAIL] = "MFW Response Failure",
|
||||||
[QED_HW_ERR_HW_ATTN] = "HW Attention",
|
[QED_HW_ERR_HW_ATTN] = "HW Attention",
|
||||||
@ -2466,7 +2464,7 @@ void qed_hw_error_occurred(struct qed_hwfn *p_hwfn,
|
|||||||
{
|
{
|
||||||
struct qed_common_cb_ops *ops = p_hwfn->cdev->protocol_ops.common;
|
struct qed_common_cb_ops *ops = p_hwfn->cdev->protocol_ops.common;
|
||||||
void *cookie = p_hwfn->cdev->ops_cookie;
|
void *cookie = p_hwfn->cdev->ops_cookie;
|
||||||
char *err_str;
|
const char *err_str;
|
||||||
|
|
||||||
if (err_type > QED_HW_ERR_LAST)
|
if (err_type > QED_HW_ERR_LAST)
|
||||||
err_type = QED_HW_ERR_LAST;
|
err_type = QED_HW_ERR_LAST;
|
||||||
|
@ -1276,7 +1276,7 @@ int qed_mfw_process_tlv_req(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt)
|
|||||||
*/
|
*/
|
||||||
for (offset = 0; offset < size; offset += sizeof(u32)) {
|
for (offset = 0; offset < size; offset += sizeof(u32)) {
|
||||||
val = qed_rd(p_hwfn, p_ptt, addr + offset);
|
val = qed_rd(p_hwfn, p_ptt, addr + offset);
|
||||||
val = be32_to_cpu(val);
|
val = be32_to_cpu((__force __be32)val);
|
||||||
memcpy(&p_mfw_buf[offset], &val, sizeof(u32));
|
memcpy(&p_mfw_buf[offset], &val, sizeof(u32));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1325,7 +1325,7 @@ int qed_mfw_process_tlv_req(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt)
|
|||||||
*/
|
*/
|
||||||
for (offset = 0; offset < size; offset += sizeof(u32)) {
|
for (offset = 0; offset < size; offset += sizeof(u32)) {
|
||||||
memcpy(&val, &p_mfw_buf[offset], sizeof(u32));
|
memcpy(&val, &p_mfw_buf[offset], sizeof(u32));
|
||||||
val = cpu_to_be32(val);
|
val = (__force u32)cpu_to_be32(val);
|
||||||
qed_wr(p_hwfn, p_ptt, addr + offset, val);
|
qed_wr(p_hwfn, p_ptt, addr + offset, val);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#include "qed_hw.h"
|
#include "qed_hw.h"
|
||||||
#include "qed_l2.h"
|
#include "qed_l2.h"
|
||||||
#include "qed_mcp.h"
|
#include "qed_mcp.h"
|
||||||
|
#include "qed_ptp.h"
|
||||||
#include "qed_reg_addr.h"
|
#include "qed_reg_addr.h"
|
||||||
|
|
||||||
/* 16 nano second time quantas to wait before making a Drift adjustment */
|
/* 16 nano second time quantas to wait before making a Drift adjustment */
|
||||||
|
9
drivers/net/ethernet/qlogic/qed/qed_ptp.h
Normal file
9
drivers/net/ethernet/qlogic/qed/qed_ptp.h
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause) */
|
||||||
|
/* Copyright (c) 2020 Marvell International Ltd. */
|
||||||
|
|
||||||
|
#ifndef __QED_PTP_H
|
||||||
|
#define __QED_PTP_H
|
||||||
|
|
||||||
|
extern const struct qed_eth_ptp_ops qed_ptp_ops_pass;
|
||||||
|
|
||||||
|
#endif /* __QED_PTP_H */
|
@ -1106,7 +1106,7 @@ static int qed_rdma_create_cq(void *rdma_cxt,
|
|||||||
p_ramrod->pbl_num_pages = cpu_to_le16(params->pbl_num_pages);
|
p_ramrod->pbl_num_pages = cpu_to_le16(params->pbl_num_pages);
|
||||||
p_ramrod->cnq_id = (u8)RESC_START(p_hwfn, QED_RDMA_CNQ_RAM) +
|
p_ramrod->cnq_id = (u8)RESC_START(p_hwfn, QED_RDMA_CNQ_RAM) +
|
||||||
params->cnq_id;
|
params->cnq_id;
|
||||||
p_ramrod->int_timeout = params->int_timeout;
|
p_ramrod->int_timeout = cpu_to_le16(params->int_timeout);
|
||||||
|
|
||||||
/* toggle the bit for every resize or create cq for a given icid */
|
/* toggle the bit for every resize or create cq for a given icid */
|
||||||
toggle_bit = qed_rdma_toggle_bit_create_resize_cq(p_hwfn, *icid);
|
toggle_bit = qed_rdma_toggle_bit_create_resize_cq(p_hwfn, *icid);
|
||||||
@ -1206,7 +1206,7 @@ err: dma_free_coherent(&p_hwfn->cdev->pdev->dev,
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
void qed_rdma_set_fw_mac(u16 *p_fw_mac, u8 *p_qed_mac)
|
void qed_rdma_set_fw_mac(__le16 *p_fw_mac, const u8 *p_qed_mac)
|
||||||
{
|
{
|
||||||
p_fw_mac[0] = cpu_to_le16((p_qed_mac[0] << 8) + p_qed_mac[1]);
|
p_fw_mac[0] = cpu_to_le16((p_qed_mac[0] << 8) + p_qed_mac[1]);
|
||||||
p_fw_mac[1] = cpu_to_le16((p_qed_mac[2] << 8) + p_qed_mac[3]);
|
p_fw_mac[1] = cpu_to_le16((p_qed_mac[2] << 8) + p_qed_mac[3]);
|
||||||
@ -1495,6 +1495,7 @@ qed_rdma_register_tid(void *rdma_cxt,
|
|||||||
struct qed_spq_entry *p_ent;
|
struct qed_spq_entry *p_ent;
|
||||||
enum rdma_tid_type tid_type;
|
enum rdma_tid_type tid_type;
|
||||||
u8 fw_return_code;
|
u8 fw_return_code;
|
||||||
|
u16 flags = 0;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
DP_VERBOSE(p_hwfn, QED_MSG_RDMA, "itid = %08x\n", params->itid);
|
DP_VERBOSE(p_hwfn, QED_MSG_RDMA, "itid = %08x\n", params->itid);
|
||||||
@ -1514,54 +1515,46 @@ qed_rdma_register_tid(void *rdma_cxt,
|
|||||||
if (p_hwfn->p_rdma_info->last_tid < params->itid)
|
if (p_hwfn->p_rdma_info->last_tid < params->itid)
|
||||||
p_hwfn->p_rdma_info->last_tid = params->itid;
|
p_hwfn->p_rdma_info->last_tid = params->itid;
|
||||||
|
|
||||||
p_ramrod = &p_ent->ramrod.rdma_register_tid;
|
SET_FIELD(flags, RDMA_REGISTER_TID_RAMROD_DATA_TWO_LEVEL_PBL,
|
||||||
|
|
||||||
p_ramrod->flags = 0;
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
|
||||||
RDMA_REGISTER_TID_RAMROD_DATA_TWO_LEVEL_PBL,
|
|
||||||
params->pbl_two_level);
|
params->pbl_two_level);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, RDMA_REGISTER_TID_RAMROD_DATA_ZERO_BASED,
|
||||||
RDMA_REGISTER_TID_RAMROD_DATA_ZERO_BASED, params->zbva);
|
params->zbva);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, RDMA_REGISTER_TID_RAMROD_DATA_PHY_MR, params->phy_mr);
|
||||||
RDMA_REGISTER_TID_RAMROD_DATA_PHY_MR, params->phy_mr);
|
|
||||||
|
|
||||||
/* Don't initialize D/C field, as it may override other bits. */
|
/* Don't initialize D/C field, as it may override other bits. */
|
||||||
if (!(params->tid_type == QED_RDMA_TID_FMR) && !(params->dma_mr))
|
if (!(params->tid_type == QED_RDMA_TID_FMR) && !(params->dma_mr))
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, 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,
|
SET_FIELD(flags, RDMA_REGISTER_TID_RAMROD_DATA_REMOTE_READ,
|
||||||
RDMA_REGISTER_TID_RAMROD_DATA_REMOTE_READ,
|
|
||||||
params->remote_read);
|
params->remote_read);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, RDMA_REGISTER_TID_RAMROD_DATA_REMOTE_WRITE,
|
||||||
RDMA_REGISTER_TID_RAMROD_DATA_REMOTE_WRITE,
|
|
||||||
params->remote_write);
|
params->remote_write);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, RDMA_REGISTER_TID_RAMROD_DATA_REMOTE_ATOMIC,
|
||||||
RDMA_REGISTER_TID_RAMROD_DATA_REMOTE_ATOMIC,
|
|
||||||
params->remote_atomic);
|
params->remote_atomic);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, RDMA_REGISTER_TID_RAMROD_DATA_LOCAL_WRITE,
|
||||||
RDMA_REGISTER_TID_RAMROD_DATA_LOCAL_WRITE,
|
|
||||||
params->local_write);
|
params->local_write);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, RDMA_REGISTER_TID_RAMROD_DATA_LOCAL_READ,
|
||||||
RDMA_REGISTER_TID_RAMROD_DATA_LOCAL_READ, params->local_read);
|
params->local_read);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, RDMA_REGISTER_TID_RAMROD_DATA_ENABLE_MW_BIND,
|
||||||
RDMA_REGISTER_TID_RAMROD_DATA_ENABLE_MW_BIND,
|
|
||||||
params->mw_bind);
|
params->mw_bind);
|
||||||
|
|
||||||
|
p_ramrod = &p_ent->ramrod.rdma_register_tid;
|
||||||
|
p_ramrod->flags = cpu_to_le16(flags);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags1,
|
SET_FIELD(p_ramrod->flags1,
|
||||||
RDMA_REGISTER_TID_RAMROD_DATA_PBL_PAGE_SIZE_LOG,
|
RDMA_REGISTER_TID_RAMROD_DATA_PBL_PAGE_SIZE_LOG,
|
||||||
params->pbl_page_size_log - 12);
|
params->pbl_page_size_log - 12);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags2,
|
SET_FIELD(p_ramrod->flags2, RDMA_REGISTER_TID_RAMROD_DATA_DMA_MR,
|
||||||
RDMA_REGISTER_TID_RAMROD_DATA_DMA_MR, params->dma_mr);
|
params->dma_mr);
|
||||||
|
|
||||||
switch (params->tid_type) {
|
switch (params->tid_type) {
|
||||||
case QED_RDMA_TID_REGISTERED_MR:
|
case QED_RDMA_TID_REGISTERED_MR:
|
||||||
@ -1579,8 +1572,9 @@ qed_rdma_register_tid(void *rdma_cxt,
|
|||||||
qed_sp_destroy_request(p_hwfn, p_ent);
|
qed_sp_destroy_request(p_hwfn, p_ent);
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
SET_FIELD(p_ramrod->flags1,
|
|
||||||
RDMA_REGISTER_TID_RAMROD_DATA_TID_TYPE, tid_type);
|
SET_FIELD(p_ramrod->flags1, RDMA_REGISTER_TID_RAMROD_DATA_TID_TYPE,
|
||||||
|
tid_type);
|
||||||
|
|
||||||
p_ramrod->itid = cpu_to_le32(params->itid);
|
p_ramrod->itid = cpu_to_le32(params->itid);
|
||||||
p_ramrod->key = params->key;
|
p_ramrod->key = params->key;
|
||||||
|
@ -201,7 +201,7 @@ qed_bmap_release_id(struct qed_hwfn *p_hwfn, struct qed_bmap *bmap, u32 id_num);
|
|||||||
int
|
int
|
||||||
qed_bmap_test_id(struct qed_hwfn *p_hwfn, struct qed_bmap *bmap, u32 id_num);
|
qed_bmap_test_id(struct qed_hwfn *p_hwfn, struct qed_bmap *bmap, u32 id_num);
|
||||||
|
|
||||||
void qed_rdma_set_fw_mac(u16 *p_fw_mac, u8 *p_qed_mac);
|
void qed_rdma_set_fw_mac(__le16 *p_fw_mac, const u8 *p_qed_mac);
|
||||||
|
|
||||||
bool qed_rdma_allocated_qps(struct qed_hwfn *p_hwfn);
|
bool qed_rdma_allocated_qps(struct qed_hwfn *p_hwfn);
|
||||||
#endif
|
#endif
|
||||||
|
@ -37,35 +37,30 @@
|
|||||||
|
|
||||||
static void qed_roce_free_real_icid(struct qed_hwfn *p_hwfn, u16 icid);
|
static void qed_roce_free_real_icid(struct qed_hwfn *p_hwfn, u16 icid);
|
||||||
|
|
||||||
static int
|
static int qed_roce_async_event(struct qed_hwfn *p_hwfn, u8 fw_event_code,
|
||||||
qed_roce_async_event(struct qed_hwfn *p_hwfn,
|
__le16 echo, union event_ring_data *data,
|
||||||
u8 fw_event_code,
|
u8 fw_return_code)
|
||||||
u16 echo, union event_ring_data *data, u8 fw_return_code)
|
|
||||||
{
|
{
|
||||||
struct qed_rdma_events events = p_hwfn->p_rdma_info->events;
|
struct qed_rdma_events events = p_hwfn->p_rdma_info->events;
|
||||||
|
union rdma_eqe_data *rdata = &data->rdma_data;
|
||||||
|
|
||||||
if (fw_event_code == ROCE_ASYNC_EVENT_DESTROY_QP_DONE) {
|
if (fw_event_code == ROCE_ASYNC_EVENT_DESTROY_QP_DONE) {
|
||||||
u16 icid =
|
u16 icid = (u16)le32_to_cpu(rdata->rdma_destroy_qp_data.cid);
|
||||||
(u16)le32_to_cpu(data->rdma_data.rdma_destroy_qp_data.cid);
|
|
||||||
|
|
||||||
/* icid release in this async event can occur only if the icid
|
/* icid release in this async event can occur only if the icid
|
||||||
* was offloaded to the FW. In case it wasn't offloaded this is
|
* was offloaded to the FW. In case it wasn't offloaded this is
|
||||||
* handled in qed_roce_sp_destroy_qp.
|
* handled in qed_roce_sp_destroy_qp.
|
||||||
*/
|
*/
|
||||||
qed_roce_free_real_icid(p_hwfn, icid);
|
qed_roce_free_real_icid(p_hwfn, icid);
|
||||||
|
} else if (fw_event_code == ROCE_ASYNC_EVENT_SRQ_EMPTY ||
|
||||||
|
fw_event_code == ROCE_ASYNC_EVENT_SRQ_LIMIT) {
|
||||||
|
u16 srq_id = (u16)le32_to_cpu(rdata->async_handle.lo);
|
||||||
|
|
||||||
|
events.affiliated_event(events.context, fw_event_code,
|
||||||
|
&srq_id);
|
||||||
} else {
|
} else {
|
||||||
if (fw_event_code == ROCE_ASYNC_EVENT_SRQ_EMPTY ||
|
events.affiliated_event(events.context, fw_event_code,
|
||||||
fw_event_code == ROCE_ASYNC_EVENT_SRQ_LIMIT) {
|
(void *)&rdata->async_handle);
|
||||||
u16 srq_id = (u16)data->rdma_data.async_handle.lo;
|
|
||||||
|
|
||||||
events.affiliated_event(events.context, fw_event_code,
|
|
||||||
&srq_id);
|
|
||||||
} else {
|
|
||||||
union rdma_eqe_data rdata = data->rdma_data;
|
|
||||||
|
|
||||||
events.affiliated_event(events.context, fw_event_code,
|
|
||||||
(void *)&rdata.async_handle);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -222,9 +217,9 @@ static int qed_roce_sp_create_responder(struct qed_hwfn *p_hwfn,
|
|||||||
struct roce_create_qp_resp_ramrod_data *p_ramrod;
|
struct roce_create_qp_resp_ramrod_data *p_ramrod;
|
||||||
u16 regular_latency_queue, low_latency_queue;
|
u16 regular_latency_queue, low_latency_queue;
|
||||||
struct qed_sp_init_data init_data;
|
struct qed_sp_init_data init_data;
|
||||||
enum roce_flavor roce_flavor;
|
|
||||||
struct qed_spq_entry *p_ent;
|
struct qed_spq_entry *p_ent;
|
||||||
enum protocol_type proto;
|
enum protocol_type proto;
|
||||||
|
u32 flags = 0;
|
||||||
int rc;
|
int rc;
|
||||||
u8 tc;
|
u8 tc;
|
||||||
|
|
||||||
@ -257,45 +252,34 @@ static int qed_roce_sp_create_responder(struct qed_hwfn *p_hwfn,
|
|||||||
if (rc)
|
if (rc)
|
||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
p_ramrod = &p_ent->ramrod.roce_create_qp_resp;
|
SET_FIELD(flags, ROCE_CREATE_QP_RESP_RAMROD_DATA_ROCE_FLAVOR,
|
||||||
|
qed_roce_mode_to_flavor(qp->roce_mode));
|
||||||
|
|
||||||
p_ramrod->flags = 0;
|
SET_FIELD(flags, ROCE_CREATE_QP_RESP_RAMROD_DATA_RDMA_RD_EN,
|
||||||
|
|
||||||
roce_flavor = qed_roce_mode_to_flavor(qp->roce_mode);
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
|
||||||
ROCE_CREATE_QP_RESP_RAMROD_DATA_ROCE_FLAVOR, roce_flavor);
|
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
|
||||||
ROCE_CREATE_QP_RESP_RAMROD_DATA_RDMA_RD_EN,
|
|
||||||
qp->incoming_rdma_read_en);
|
qp->incoming_rdma_read_en);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_CREATE_QP_RESP_RAMROD_DATA_RDMA_WR_EN,
|
||||||
ROCE_CREATE_QP_RESP_RAMROD_DATA_RDMA_WR_EN,
|
|
||||||
qp->incoming_rdma_write_en);
|
qp->incoming_rdma_write_en);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_CREATE_QP_RESP_RAMROD_DATA_ATOMIC_EN,
|
||||||
ROCE_CREATE_QP_RESP_RAMROD_DATA_ATOMIC_EN,
|
|
||||||
qp->incoming_atomic_en);
|
qp->incoming_atomic_en);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_CREATE_QP_RESP_RAMROD_DATA_E2E_FLOW_CONTROL_EN,
|
||||||
ROCE_CREATE_QP_RESP_RAMROD_DATA_E2E_FLOW_CONTROL_EN,
|
|
||||||
qp->e2e_flow_control_en);
|
qp->e2e_flow_control_en);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_CREATE_QP_RESP_RAMROD_DATA_SRQ_FLG, qp->use_srq);
|
||||||
ROCE_CREATE_QP_RESP_RAMROD_DATA_SRQ_FLG, qp->use_srq);
|
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_CREATE_QP_RESP_RAMROD_DATA_RESERVED_KEY_EN,
|
||||||
ROCE_CREATE_QP_RESP_RAMROD_DATA_RESERVED_KEY_EN,
|
|
||||||
qp->fmr_and_reserved_lkey);
|
qp->fmr_and_reserved_lkey);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_CREATE_QP_RESP_RAMROD_DATA_MIN_RNR_NAK_TIMER,
|
||||||
ROCE_CREATE_QP_RESP_RAMROD_DATA_MIN_RNR_NAK_TIMER,
|
|
||||||
qp->min_rnr_nak_timer);
|
qp->min_rnr_nak_timer);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_CREATE_QP_RESP_RAMROD_DATA_XRC_FLAG,
|
||||||
ROCE_CREATE_QP_RESP_RAMROD_DATA_XRC_FLAG,
|
|
||||||
qed_rdma_is_xrc_qp(qp));
|
qed_rdma_is_xrc_qp(qp));
|
||||||
|
|
||||||
|
p_ramrod = &p_ent->ramrod.roce_create_qp_resp;
|
||||||
|
p_ramrod->flags = cpu_to_le32(flags);
|
||||||
p_ramrod->max_ird = qp->max_rd_atomic_resp;
|
p_ramrod->max_ird = qp->max_rd_atomic_resp;
|
||||||
p_ramrod->traffic_class = qp->traffic_class_tos;
|
p_ramrod->traffic_class = qp->traffic_class_tos;
|
||||||
p_ramrod->hop_limit = qp->hop_limit_ttl;
|
p_ramrod->hop_limit = qp->hop_limit_ttl;
|
||||||
@ -310,10 +294,10 @@ static int qed_roce_sp_create_responder(struct qed_hwfn *p_hwfn,
|
|||||||
DMA_REGPAIR_LE(p_ramrod->rq_pbl_addr, qp->rq_pbl_ptr);
|
DMA_REGPAIR_LE(p_ramrod->rq_pbl_addr, qp->rq_pbl_ptr);
|
||||||
DMA_REGPAIR_LE(p_ramrod->irq_pbl_addr, qp->irq_phys_addr);
|
DMA_REGPAIR_LE(p_ramrod->irq_pbl_addr, qp->irq_phys_addr);
|
||||||
qed_rdma_copy_gids(qp, p_ramrod->src_gid, p_ramrod->dst_gid);
|
qed_rdma_copy_gids(qp, p_ramrod->src_gid, p_ramrod->dst_gid);
|
||||||
p_ramrod->qp_handle_for_async.hi = cpu_to_le32(qp->qp_handle_async.hi);
|
p_ramrod->qp_handle_for_async.hi = qp->qp_handle_async.hi;
|
||||||
p_ramrod->qp_handle_for_async.lo = cpu_to_le32(qp->qp_handle_async.lo);
|
p_ramrod->qp_handle_for_async.lo = qp->qp_handle_async.lo;
|
||||||
p_ramrod->qp_handle_for_cqe.hi = cpu_to_le32(qp->qp_handle.hi);
|
p_ramrod->qp_handle_for_cqe.hi = qp->qp_handle.hi;
|
||||||
p_ramrod->qp_handle_for_cqe.lo = cpu_to_le32(qp->qp_handle.lo);
|
p_ramrod->qp_handle_for_cqe.lo = qp->qp_handle.lo;
|
||||||
p_ramrod->cq_cid = cpu_to_le32((p_hwfn->hw_info.opaque_fid << 16) |
|
p_ramrod->cq_cid = cpu_to_le32((p_hwfn->hw_info.opaque_fid << 16) |
|
||||||
qp->rq_cq_id);
|
qp->rq_cq_id);
|
||||||
p_ramrod->xrc_domain = cpu_to_le16(qp->xrcd_id);
|
p_ramrod->xrc_domain = cpu_to_le16(qp->xrcd_id);
|
||||||
@ -335,7 +319,7 @@ static int qed_roce_sp_create_responder(struct qed_hwfn *p_hwfn,
|
|||||||
qed_rdma_set_fw_mac(p_ramrod->remote_mac_addr, qp->remote_mac_addr);
|
qed_rdma_set_fw_mac(p_ramrod->remote_mac_addr, qp->remote_mac_addr);
|
||||||
qed_rdma_set_fw_mac(p_ramrod->local_mac_addr, qp->local_mac_addr);
|
qed_rdma_set_fw_mac(p_ramrod->local_mac_addr, qp->local_mac_addr);
|
||||||
|
|
||||||
p_ramrod->udp_src_port = qp->udp_src_port;
|
p_ramrod->udp_src_port = cpu_to_le16(qp->udp_src_port);
|
||||||
p_ramrod->vlan_id = cpu_to_le16(qp->vlan_id);
|
p_ramrod->vlan_id = cpu_to_le16(qp->vlan_id);
|
||||||
p_ramrod->srq_id.srq_idx = cpu_to_le16(qp->srq_id);
|
p_ramrod->srq_id.srq_idx = cpu_to_le16(qp->srq_id);
|
||||||
p_ramrod->srq_id.opaque_fid = cpu_to_le16(p_hwfn->hw_info.opaque_fid);
|
p_ramrod->srq_id.opaque_fid = cpu_to_le16(p_hwfn->hw_info.opaque_fid);
|
||||||
@ -371,9 +355,9 @@ static int qed_roce_sp_create_requester(struct qed_hwfn *p_hwfn,
|
|||||||
struct roce_create_qp_req_ramrod_data *p_ramrod;
|
struct roce_create_qp_req_ramrod_data *p_ramrod;
|
||||||
u16 regular_latency_queue, low_latency_queue;
|
u16 regular_latency_queue, low_latency_queue;
|
||||||
struct qed_sp_init_data init_data;
|
struct qed_sp_init_data init_data;
|
||||||
enum roce_flavor roce_flavor;
|
|
||||||
struct qed_spq_entry *p_ent;
|
struct qed_spq_entry *p_ent;
|
||||||
enum protocol_type proto;
|
enum protocol_type proto;
|
||||||
|
u16 flags = 0;
|
||||||
int rc;
|
int rc;
|
||||||
u8 tc;
|
u8 tc;
|
||||||
|
|
||||||
@ -407,34 +391,29 @@ static int qed_roce_sp_create_requester(struct qed_hwfn *p_hwfn,
|
|||||||
if (rc)
|
if (rc)
|
||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
p_ramrod = &p_ent->ramrod.roce_create_qp_req;
|
SET_FIELD(flags, ROCE_CREATE_QP_REQ_RAMROD_DATA_ROCE_FLAVOR,
|
||||||
|
qed_roce_mode_to_flavor(qp->roce_mode));
|
||||||
|
|
||||||
p_ramrod->flags = 0;
|
SET_FIELD(flags, ROCE_CREATE_QP_REQ_RAMROD_DATA_FMR_AND_RESERVED_EN,
|
||||||
|
|
||||||
roce_flavor = qed_roce_mode_to_flavor(qp->roce_mode);
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
|
||||||
ROCE_CREATE_QP_REQ_RAMROD_DATA_ROCE_FLAVOR, roce_flavor);
|
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
|
||||||
ROCE_CREATE_QP_REQ_RAMROD_DATA_FMR_AND_RESERVED_EN,
|
|
||||||
qp->fmr_and_reserved_lkey);
|
qp->fmr_and_reserved_lkey);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_CREATE_QP_REQ_RAMROD_DATA_SIGNALED_COMP,
|
||||||
ROCE_CREATE_QP_REQ_RAMROD_DATA_SIGNALED_COMP, qp->signal_all);
|
qp->signal_all);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_CREATE_QP_REQ_RAMROD_DATA_ERR_RETRY_CNT,
|
||||||
ROCE_CREATE_QP_REQ_RAMROD_DATA_ERR_RETRY_CNT, qp->retry_cnt);
|
qp->retry_cnt);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_CREATE_QP_REQ_RAMROD_DATA_RNR_NAK_CNT,
|
||||||
ROCE_CREATE_QP_REQ_RAMROD_DATA_RNR_NAK_CNT,
|
|
||||||
qp->rnr_retry_cnt);
|
qp->rnr_retry_cnt);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_CREATE_QP_REQ_RAMROD_DATA_XRC_FLAG,
|
||||||
ROCE_CREATE_QP_REQ_RAMROD_DATA_XRC_FLAG,
|
|
||||||
qed_rdma_is_xrc_qp(qp));
|
qed_rdma_is_xrc_qp(qp));
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags2,
|
p_ramrod = &p_ent->ramrod.roce_create_qp_req;
|
||||||
ROCE_CREATE_QP_REQ_RAMROD_DATA_EDPM_MODE, qp->edpm_mode);
|
p_ramrod->flags = cpu_to_le16(flags);
|
||||||
|
|
||||||
|
SET_FIELD(p_ramrod->flags2, ROCE_CREATE_QP_REQ_RAMROD_DATA_EDPM_MODE,
|
||||||
|
qp->edpm_mode);
|
||||||
|
|
||||||
p_ramrod->max_ord = qp->max_rd_atomic_req;
|
p_ramrod->max_ord = qp->max_rd_atomic_req;
|
||||||
p_ramrod->traffic_class = qp->traffic_class_tos;
|
p_ramrod->traffic_class = qp->traffic_class_tos;
|
||||||
@ -451,10 +430,10 @@ static int qed_roce_sp_create_requester(struct qed_hwfn *p_hwfn,
|
|||||||
DMA_REGPAIR_LE(p_ramrod->sq_pbl_addr, qp->sq_pbl_ptr);
|
DMA_REGPAIR_LE(p_ramrod->sq_pbl_addr, qp->sq_pbl_ptr);
|
||||||
DMA_REGPAIR_LE(p_ramrod->orq_pbl_addr, qp->orq_phys_addr);
|
DMA_REGPAIR_LE(p_ramrod->orq_pbl_addr, qp->orq_phys_addr);
|
||||||
qed_rdma_copy_gids(qp, p_ramrod->src_gid, p_ramrod->dst_gid);
|
qed_rdma_copy_gids(qp, p_ramrod->src_gid, p_ramrod->dst_gid);
|
||||||
p_ramrod->qp_handle_for_async.hi = cpu_to_le32(qp->qp_handle_async.hi);
|
p_ramrod->qp_handle_for_async.hi = qp->qp_handle_async.hi;
|
||||||
p_ramrod->qp_handle_for_async.lo = cpu_to_le32(qp->qp_handle_async.lo);
|
p_ramrod->qp_handle_for_async.lo = qp->qp_handle_async.lo;
|
||||||
p_ramrod->qp_handle_for_cqe.hi = cpu_to_le32(qp->qp_handle.hi);
|
p_ramrod->qp_handle_for_cqe.hi = qp->qp_handle.hi;
|
||||||
p_ramrod->qp_handle_for_cqe.lo = cpu_to_le32(qp->qp_handle.lo);
|
p_ramrod->qp_handle_for_cqe.lo = qp->qp_handle.lo;
|
||||||
p_ramrod->cq_cid =
|
p_ramrod->cq_cid =
|
||||||
cpu_to_le32((p_hwfn->hw_info.opaque_fid << 16) | qp->sq_cq_id);
|
cpu_to_le32((p_hwfn->hw_info.opaque_fid << 16) | qp->sq_cq_id);
|
||||||
|
|
||||||
@ -475,7 +454,7 @@ static int qed_roce_sp_create_requester(struct qed_hwfn *p_hwfn,
|
|||||||
qed_rdma_set_fw_mac(p_ramrod->remote_mac_addr, qp->remote_mac_addr);
|
qed_rdma_set_fw_mac(p_ramrod->remote_mac_addr, qp->remote_mac_addr);
|
||||||
qed_rdma_set_fw_mac(p_ramrod->local_mac_addr, qp->local_mac_addr);
|
qed_rdma_set_fw_mac(p_ramrod->local_mac_addr, qp->local_mac_addr);
|
||||||
|
|
||||||
p_ramrod->udp_src_port = qp->udp_src_port;
|
p_ramrod->udp_src_port = cpu_to_le16(qp->udp_src_port);
|
||||||
p_ramrod->vlan_id = cpu_to_le16(qp->vlan_id);
|
p_ramrod->vlan_id = cpu_to_le16(qp->vlan_id);
|
||||||
p_ramrod->stats_counter_id = RESC_START(p_hwfn, QED_RDMA_STATS_QUEUE) +
|
p_ramrod->stats_counter_id = RESC_START(p_hwfn, QED_RDMA_STATS_QUEUE) +
|
||||||
qp->stats_queue;
|
qp->stats_queue;
|
||||||
@ -507,6 +486,7 @@ static int qed_roce_sp_modify_responder(struct qed_hwfn *p_hwfn,
|
|||||||
struct roce_modify_qp_resp_ramrod_data *p_ramrod;
|
struct roce_modify_qp_resp_ramrod_data *p_ramrod;
|
||||||
struct qed_sp_init_data init_data;
|
struct qed_sp_init_data init_data;
|
||||||
struct qed_spq_entry *p_ent;
|
struct qed_spq_entry *p_ent;
|
||||||
|
u16 flags = 0;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
if (!qp->has_resp)
|
if (!qp->has_resp)
|
||||||
@ -531,53 +511,43 @@ static int qed_roce_sp_modify_responder(struct qed_hwfn *p_hwfn,
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
p_ramrod = &p_ent->ramrod.roce_modify_qp_resp;
|
SET_FIELD(flags, ROCE_MODIFY_QP_RESP_RAMROD_DATA_MOVE_TO_ERR_FLG,
|
||||||
|
!!move_to_err);
|
||||||
|
|
||||||
p_ramrod->flags = 0;
|
SET_FIELD(flags, ROCE_MODIFY_QP_RESP_RAMROD_DATA_RDMA_RD_EN,
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
|
||||||
ROCE_MODIFY_QP_RESP_RAMROD_DATA_MOVE_TO_ERR_FLG, move_to_err);
|
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
|
||||||
ROCE_MODIFY_QP_RESP_RAMROD_DATA_RDMA_RD_EN,
|
|
||||||
qp->incoming_rdma_read_en);
|
qp->incoming_rdma_read_en);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_RESP_RAMROD_DATA_RDMA_WR_EN,
|
||||||
ROCE_MODIFY_QP_RESP_RAMROD_DATA_RDMA_WR_EN,
|
|
||||||
qp->incoming_rdma_write_en);
|
qp->incoming_rdma_write_en);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_RESP_RAMROD_DATA_ATOMIC_EN,
|
||||||
ROCE_MODIFY_QP_RESP_RAMROD_DATA_ATOMIC_EN,
|
|
||||||
qp->incoming_atomic_en);
|
qp->incoming_atomic_en);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_CREATE_QP_RESP_RAMROD_DATA_E2E_FLOW_CONTROL_EN,
|
||||||
ROCE_CREATE_QP_RESP_RAMROD_DATA_E2E_FLOW_CONTROL_EN,
|
|
||||||
qp->e2e_flow_control_en);
|
qp->e2e_flow_control_en);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_RESP_RAMROD_DATA_RDMA_OPS_EN_FLG,
|
||||||
ROCE_MODIFY_QP_RESP_RAMROD_DATA_RDMA_OPS_EN_FLG,
|
|
||||||
GET_FIELD(modify_flags,
|
GET_FIELD(modify_flags,
|
||||||
QED_RDMA_MODIFY_QP_VALID_RDMA_OPS_EN));
|
QED_RDMA_MODIFY_QP_VALID_RDMA_OPS_EN));
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_RESP_RAMROD_DATA_P_KEY_FLG,
|
||||||
ROCE_MODIFY_QP_RESP_RAMROD_DATA_P_KEY_FLG,
|
|
||||||
GET_FIELD(modify_flags, QED_ROCE_MODIFY_QP_VALID_PKEY));
|
GET_FIELD(modify_flags, QED_ROCE_MODIFY_QP_VALID_PKEY));
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_RESP_RAMROD_DATA_ADDRESS_VECTOR_FLG,
|
||||||
ROCE_MODIFY_QP_RESP_RAMROD_DATA_ADDRESS_VECTOR_FLG,
|
|
||||||
GET_FIELD(modify_flags,
|
GET_FIELD(modify_flags,
|
||||||
QED_ROCE_MODIFY_QP_VALID_ADDRESS_VECTOR));
|
QED_ROCE_MODIFY_QP_VALID_ADDRESS_VECTOR));
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_RESP_RAMROD_DATA_MAX_IRD_FLG,
|
||||||
ROCE_MODIFY_QP_RESP_RAMROD_DATA_MAX_IRD_FLG,
|
|
||||||
GET_FIELD(modify_flags,
|
GET_FIELD(modify_flags,
|
||||||
QED_RDMA_MODIFY_QP_VALID_MAX_RD_ATOMIC_RESP));
|
QED_RDMA_MODIFY_QP_VALID_MAX_RD_ATOMIC_RESP));
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_RESP_RAMROD_DATA_MIN_RNR_NAK_TIMER_FLG,
|
||||||
ROCE_MODIFY_QP_RESP_RAMROD_DATA_MIN_RNR_NAK_TIMER_FLG,
|
|
||||||
GET_FIELD(modify_flags,
|
GET_FIELD(modify_flags,
|
||||||
QED_ROCE_MODIFY_QP_VALID_MIN_RNR_NAK_TIMER));
|
QED_ROCE_MODIFY_QP_VALID_MIN_RNR_NAK_TIMER));
|
||||||
|
|
||||||
|
p_ramrod = &p_ent->ramrod.roce_modify_qp_resp;
|
||||||
|
p_ramrod->flags = cpu_to_le16(flags);
|
||||||
|
|
||||||
p_ramrod->fields = 0;
|
p_ramrod->fields = 0;
|
||||||
SET_FIELD(p_ramrod->fields,
|
SET_FIELD(p_ramrod->fields,
|
||||||
ROCE_MODIFY_QP_RESP_RAMROD_DATA_MIN_RNR_NAK_TIMER,
|
ROCE_MODIFY_QP_RESP_RAMROD_DATA_MIN_RNR_NAK_TIMER,
|
||||||
@ -604,6 +574,7 @@ static int qed_roce_sp_modify_requester(struct qed_hwfn *p_hwfn,
|
|||||||
struct roce_modify_qp_req_ramrod_data *p_ramrod;
|
struct roce_modify_qp_req_ramrod_data *p_ramrod;
|
||||||
struct qed_sp_init_data init_data;
|
struct qed_sp_init_data init_data;
|
||||||
struct qed_spq_entry *p_ent;
|
struct qed_spq_entry *p_ent;
|
||||||
|
u16 flags = 0;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
if (!qp->has_req)
|
if (!qp->has_req)
|
||||||
@ -628,54 +599,44 @@ static int qed_roce_sp_modify_requester(struct qed_hwfn *p_hwfn,
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
p_ramrod = &p_ent->ramrod.roce_modify_qp_req;
|
SET_FIELD(flags, ROCE_MODIFY_QP_REQ_RAMROD_DATA_MOVE_TO_ERR_FLG,
|
||||||
|
!!move_to_err);
|
||||||
|
|
||||||
p_ramrod->flags = 0;
|
SET_FIELD(flags, ROCE_MODIFY_QP_REQ_RAMROD_DATA_MOVE_TO_SQD_FLG,
|
||||||
|
!!move_to_sqd);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_REQ_RAMROD_DATA_EN_SQD_ASYNC_NOTIFY,
|
||||||
ROCE_MODIFY_QP_REQ_RAMROD_DATA_MOVE_TO_ERR_FLG, move_to_err);
|
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
|
||||||
ROCE_MODIFY_QP_REQ_RAMROD_DATA_MOVE_TO_SQD_FLG, move_to_sqd);
|
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
|
||||||
ROCE_MODIFY_QP_REQ_RAMROD_DATA_EN_SQD_ASYNC_NOTIFY,
|
|
||||||
qp->sqd_async);
|
qp->sqd_async);
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_REQ_RAMROD_DATA_P_KEY_FLG,
|
||||||
ROCE_MODIFY_QP_REQ_RAMROD_DATA_P_KEY_FLG,
|
|
||||||
GET_FIELD(modify_flags, QED_ROCE_MODIFY_QP_VALID_PKEY));
|
GET_FIELD(modify_flags, QED_ROCE_MODIFY_QP_VALID_PKEY));
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_REQ_RAMROD_DATA_ADDRESS_VECTOR_FLG,
|
||||||
ROCE_MODIFY_QP_REQ_RAMROD_DATA_ADDRESS_VECTOR_FLG,
|
|
||||||
GET_FIELD(modify_flags,
|
GET_FIELD(modify_flags,
|
||||||
QED_ROCE_MODIFY_QP_VALID_ADDRESS_VECTOR));
|
QED_ROCE_MODIFY_QP_VALID_ADDRESS_VECTOR));
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_REQ_RAMROD_DATA_MAX_ORD_FLG,
|
||||||
ROCE_MODIFY_QP_REQ_RAMROD_DATA_MAX_ORD_FLG,
|
|
||||||
GET_FIELD(modify_flags,
|
GET_FIELD(modify_flags,
|
||||||
QED_RDMA_MODIFY_QP_VALID_MAX_RD_ATOMIC_REQ));
|
QED_RDMA_MODIFY_QP_VALID_MAX_RD_ATOMIC_REQ));
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_REQ_RAMROD_DATA_RNR_NAK_CNT_FLG,
|
||||||
ROCE_MODIFY_QP_REQ_RAMROD_DATA_RNR_NAK_CNT_FLG,
|
|
||||||
GET_FIELD(modify_flags,
|
GET_FIELD(modify_flags,
|
||||||
QED_ROCE_MODIFY_QP_VALID_RNR_RETRY_CNT));
|
QED_ROCE_MODIFY_QP_VALID_RNR_RETRY_CNT));
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_REQ_RAMROD_DATA_ERR_RETRY_CNT_FLG,
|
||||||
ROCE_MODIFY_QP_REQ_RAMROD_DATA_ERR_RETRY_CNT_FLG,
|
|
||||||
GET_FIELD(modify_flags, QED_ROCE_MODIFY_QP_VALID_RETRY_CNT));
|
GET_FIELD(modify_flags, QED_ROCE_MODIFY_QP_VALID_RETRY_CNT));
|
||||||
|
|
||||||
SET_FIELD(p_ramrod->flags,
|
SET_FIELD(flags, ROCE_MODIFY_QP_REQ_RAMROD_DATA_ACK_TIMEOUT_FLG,
|
||||||
ROCE_MODIFY_QP_REQ_RAMROD_DATA_ACK_TIMEOUT_FLG,
|
|
||||||
GET_FIELD(modify_flags,
|
GET_FIELD(modify_flags,
|
||||||
QED_ROCE_MODIFY_QP_VALID_ACK_TIMEOUT));
|
QED_ROCE_MODIFY_QP_VALID_ACK_TIMEOUT));
|
||||||
|
|
||||||
|
p_ramrod = &p_ent->ramrod.roce_modify_qp_req;
|
||||||
|
p_ramrod->flags = cpu_to_le16(flags);
|
||||||
|
|
||||||
p_ramrod->fields = 0;
|
p_ramrod->fields = 0;
|
||||||
SET_FIELD(p_ramrod->fields,
|
SET_FIELD(p_ramrod->fields,
|
||||||
ROCE_MODIFY_QP_REQ_RAMROD_DATA_ERR_RETRY_CNT, qp->retry_cnt);
|
ROCE_MODIFY_QP_REQ_RAMROD_DATA_ERR_RETRY_CNT, qp->retry_cnt);
|
||||||
|
SET_FIELD(p_ramrod->fields, ROCE_MODIFY_QP_REQ_RAMROD_DATA_RNR_NAK_CNT,
|
||||||
SET_FIELD(p_ramrod->fields,
|
|
||||||
ROCE_MODIFY_QP_REQ_RAMROD_DATA_RNR_NAK_CNT,
|
|
||||||
qp->rnr_retry_cnt);
|
qp->rnr_retry_cnt);
|
||||||
|
|
||||||
p_ramrod->max_ord = qp->max_rd_atomic_req;
|
p_ramrod->max_ord = qp->max_rd_atomic_req;
|
||||||
|
@ -154,12 +154,9 @@ struct qed_consq {
|
|||||||
struct qed_chain chain;
|
struct qed_chain chain;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef int
|
typedef int (*qed_spq_async_comp_cb)(struct qed_hwfn *p_hwfn, u8 opcode,
|
||||||
(*qed_spq_async_comp_cb)(struct qed_hwfn *p_hwfn,
|
__le16 echo, union event_ring_data *data,
|
||||||
u8 opcode,
|
u8 fw_return_code);
|
||||||
u16 echo,
|
|
||||||
union event_ring_data *data,
|
|
||||||
u8 fw_return_code);
|
|
||||||
|
|
||||||
int
|
int
|
||||||
qed_spq_register_async_cb(struct qed_hwfn *p_hwfn,
|
qed_spq_register_async_cb(struct qed_hwfn *p_hwfn,
|
||||||
|
@ -300,6 +300,7 @@ int qed_sp_pf_start(struct qed_hwfn *p_hwfn,
|
|||||||
struct qed_tunnel_info *p_tunn,
|
struct qed_tunnel_info *p_tunn,
|
||||||
bool allow_npar_tx_switch)
|
bool allow_npar_tx_switch)
|
||||||
{
|
{
|
||||||
|
struct outer_tag_config_struct *outer_tag_config;
|
||||||
struct pf_start_ramrod_data *p_ramrod = NULL;
|
struct pf_start_ramrod_data *p_ramrod = NULL;
|
||||||
u16 sb = qed_int_get_sp_sb_id(p_hwfn);
|
u16 sb = qed_int_get_sp_sb_id(p_hwfn);
|
||||||
u8 sb_index = p_hwfn->p_eq->eq_sb_index;
|
u8 sb_index = p_hwfn->p_eq->eq_sb_index;
|
||||||
@ -336,29 +337,30 @@ int qed_sp_pf_start(struct qed_hwfn *p_hwfn,
|
|||||||
else
|
else
|
||||||
p_ramrod->mf_mode = MF_NPAR;
|
p_ramrod->mf_mode = MF_NPAR;
|
||||||
|
|
||||||
p_ramrod->outer_tag_config.outer_tag.tci =
|
outer_tag_config = &p_ramrod->outer_tag_config;
|
||||||
cpu_to_le16(p_hwfn->hw_info.ovlan);
|
outer_tag_config->outer_tag.tci = cpu_to_le16(p_hwfn->hw_info.ovlan);
|
||||||
|
|
||||||
if (test_bit(QED_MF_8021Q_TAGGING, &p_hwfn->cdev->mf_bits)) {
|
if (test_bit(QED_MF_8021Q_TAGGING, &p_hwfn->cdev->mf_bits)) {
|
||||||
p_ramrod->outer_tag_config.outer_tag.tpid = ETH_P_8021Q;
|
outer_tag_config->outer_tag.tpid = cpu_to_le16(ETH_P_8021Q);
|
||||||
} else if (test_bit(QED_MF_8021AD_TAGGING, &p_hwfn->cdev->mf_bits)) {
|
} else if (test_bit(QED_MF_8021AD_TAGGING, &p_hwfn->cdev->mf_bits)) {
|
||||||
p_ramrod->outer_tag_config.outer_tag.tpid = ETH_P_8021AD;
|
outer_tag_config->outer_tag.tpid = cpu_to_le16(ETH_P_8021AD);
|
||||||
p_ramrod->outer_tag_config.enable_stag_pri_change = 1;
|
outer_tag_config->enable_stag_pri_change = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
p_ramrod->outer_tag_config.pri_map_valid = 1;
|
outer_tag_config->pri_map_valid = 1;
|
||||||
for (i = 0; i < QED_MAX_PFC_PRIORITIES; i++)
|
for (i = 0; i < QED_MAX_PFC_PRIORITIES; i++)
|
||||||
p_ramrod->outer_tag_config.inner_to_outer_pri_map[i] = i;
|
outer_tag_config->inner_to_outer_pri_map[i] = i;
|
||||||
|
|
||||||
/* enable_stag_pri_change should be set if port is in BD mode or,
|
/* enable_stag_pri_change should be set if port is in BD mode or,
|
||||||
* UFP with Host Control mode.
|
* UFP with Host Control mode.
|
||||||
*/
|
*/
|
||||||
if (test_bit(QED_MF_UFP_SPECIFIC, &p_hwfn->cdev->mf_bits)) {
|
if (test_bit(QED_MF_UFP_SPECIFIC, &p_hwfn->cdev->mf_bits)) {
|
||||||
if (p_hwfn->ufp_info.pri_type == QED_UFP_PRI_OS)
|
if (p_hwfn->ufp_info.pri_type == QED_UFP_PRI_OS)
|
||||||
p_ramrod->outer_tag_config.enable_stag_pri_change = 1;
|
outer_tag_config->enable_stag_pri_change = 1;
|
||||||
else
|
else
|
||||||
p_ramrod->outer_tag_config.enable_stag_pri_change = 0;
|
outer_tag_config->enable_stag_pri_change = 0;
|
||||||
|
|
||||||
p_ramrod->outer_tag_config.outer_tag.tci |=
|
outer_tag_config->outer_tag.tci |=
|
||||||
cpu_to_le16(((u16)p_hwfn->ufp_info.tc << 13));
|
cpu_to_le16(((u16)p_hwfn->ufp_info.tc << 13));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -406,7 +408,7 @@ int qed_sp_pf_start(struct qed_hwfn *p_hwfn,
|
|||||||
|
|
||||||
DP_VERBOSE(p_hwfn, QED_MSG_SPQ,
|
DP_VERBOSE(p_hwfn, QED_MSG_SPQ,
|
||||||
"Setting event_ring_sb [id %04x index %02x], outer_tag.tci [%d]\n",
|
"Setting event_ring_sb [id %04x index %02x], outer_tag.tci [%d]\n",
|
||||||
sb, sb_index, p_ramrod->outer_tag_config.outer_tag.tci);
|
sb, sb_index, outer_tag_config->outer_tag.tci);
|
||||||
|
|
||||||
rc = qed_spq_post(p_hwfn, p_ent, NULL);
|
rc = qed_spq_post(p_hwfn, p_ent, NULL);
|
||||||
|
|
||||||
|
@ -642,18 +642,18 @@ void qed_spq_return_entry(struct qed_hwfn *p_hwfn, struct qed_spq_entry *p_ent)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief qed_spq_add_entry - adds a new entry to the pending
|
* qed_spq_add_entry() - Add a new entry to the pending list.
|
||||||
* list. Should be used while lock is being held.
|
* Should be used while lock is being held.
|
||||||
*
|
*
|
||||||
* Addes an entry to the pending list is there is room (en empty
|
* @p_hwfn: HW device data.
|
||||||
|
* @p_ent: An entry to add.
|
||||||
|
* @priority: Desired priority.
|
||||||
|
*
|
||||||
|
* Adds an entry to the pending list is there is room (an empty
|
||||||
* element is available in the free_pool), or else places the
|
* element is available in the free_pool), or else places the
|
||||||
* entry in the unlimited_pending pool.
|
* entry in the unlimited_pending pool.
|
||||||
*
|
*
|
||||||
* @param p_hwfn
|
* Return: zero on success, -EINVAL on invalid @priority.
|
||||||
* @param p_ent
|
|
||||||
* @param priority
|
|
||||||
*
|
|
||||||
* @return int
|
|
||||||
*/
|
*/
|
||||||
static int qed_spq_add_entry(struct qed_hwfn *p_hwfn,
|
static int qed_spq_add_entry(struct qed_hwfn *p_hwfn,
|
||||||
struct qed_spq_entry *p_ent,
|
struct qed_spq_entry *p_ent,
|
||||||
|
@ -823,16 +823,17 @@ static int qed_iov_enable_vf_access(struct qed_hwfn *p_hwfn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief qed_iov_config_perm_table - configure the permission
|
* qed_iov_config_perm_table() - Configure the permission zone table.
|
||||||
* zone table.
|
*
|
||||||
* In E4, queue zone permission table size is 320x9. There
|
* @p_hwfn: HW device data.
|
||||||
* are 320 VF queues for single engine device (256 for dual
|
* @p_ptt: PTT window for writing the registers.
|
||||||
* engine device), and each entry has the following format:
|
* @vf: VF info data.
|
||||||
* {Valid, VF[7:0]}
|
* @enable: The actual permision for this VF.
|
||||||
* @param p_hwfn
|
*
|
||||||
* @param p_ptt
|
* In E4, queue zone permission table size is 320x9. There
|
||||||
* @param vf
|
* are 320 VF queues for single engine device (256 for dual
|
||||||
* @param enable
|
* engine device), and each entry has the following format:
|
||||||
|
* {Valid, VF[7:0]}
|
||||||
*/
|
*/
|
||||||
static void qed_iov_config_perm_table(struct qed_hwfn *p_hwfn,
|
static void qed_iov_config_perm_table(struct qed_hwfn *p_hwfn,
|
||||||
struct qed_ptt *p_ptt,
|
struct qed_ptt *p_ptt,
|
||||||
@ -4004,7 +4005,7 @@ static int qed_sriov_vfpf_msg(struct qed_hwfn *p_hwfn,
|
|||||||
/* List the physical address of the request so that handler
|
/* List the physical address of the request so that handler
|
||||||
* could later on copy the message from it.
|
* could later on copy the message from it.
|
||||||
*/
|
*/
|
||||||
p_vf->vf_mbx.pending_req = (((u64)vf_msg->hi) << 32) | vf_msg->lo;
|
p_vf->vf_mbx.pending_req = HILO_64(vf_msg->hi, vf_msg->lo);
|
||||||
|
|
||||||
/* Mark the event and schedule the workqueue */
|
/* Mark the event and schedule the workqueue */
|
||||||
p_vf->vf_mbx.b_pending_msg = true;
|
p_vf->vf_mbx.b_pending_msg = true;
|
||||||
@ -4036,9 +4037,7 @@ static void qed_sriov_vfpf_malicious(struct qed_hwfn *p_hwfn,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qed_sriov_eqe_event(struct qed_hwfn *p_hwfn,
|
static int qed_sriov_eqe_event(struct qed_hwfn *p_hwfn, u8 opcode, __le16 echo,
|
||||||
u8 opcode,
|
|
||||||
__le16 echo,
|
|
||||||
union event_ring_data *data, u8 fw_return_code)
|
union event_ring_data *data, u8 fw_return_code)
|
||||||
{
|
{
|
||||||
switch (opcode) {
|
switch (opcode) {
|
||||||
|
@ -246,6 +246,8 @@ enum qed_iov_wq_flag {
|
|||||||
QED_IOV_WQ_VF_FORCE_LINK_QUERY_FLAG,
|
QED_IOV_WQ_VF_FORCE_LINK_QUERY_FLAG,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
extern const struct qed_iov_hv_ops qed_iov_ops_pass;
|
||||||
|
|
||||||
#ifdef CONFIG_QED_SRIOV
|
#ifdef CONFIG_QED_SRIOV
|
||||||
/**
|
/**
|
||||||
* @brief Check if given VF ID @vfid is valid
|
* @brief Check if given VF ID @vfid is valid
|
||||||
|
@ -1764,8 +1764,8 @@ qede_flow_parse_ports(struct qede_dev *edev, struct flow_rule *rule,
|
|||||||
struct flow_match_ports match;
|
struct flow_match_ports match;
|
||||||
|
|
||||||
flow_rule_match_ports(rule, &match);
|
flow_rule_match_ports(rule, &match);
|
||||||
if ((match.key->src && match.mask->src != U16_MAX) ||
|
if ((match.key->src && match.mask->src != htons(U16_MAX)) ||
|
||||||
(match.key->dst && match.mask->dst != U16_MAX)) {
|
(match.key->dst && match.mask->dst != htons(U16_MAX))) {
|
||||||
DP_NOTICE(edev, "Do not support ports masks\n");
|
DP_NOTICE(edev, "Do not support ports masks\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
@ -1817,8 +1817,8 @@ qede_flow_parse_v4_common(struct qede_dev *edev, struct flow_rule *rule,
|
|||||||
struct flow_match_ipv4_addrs match;
|
struct flow_match_ipv4_addrs match;
|
||||||
|
|
||||||
flow_rule_match_ipv4_addrs(rule, &match);
|
flow_rule_match_ipv4_addrs(rule, &match);
|
||||||
if ((match.key->src && match.mask->src != U32_MAX) ||
|
if ((match.key->src && match.mask->src != htonl(U32_MAX)) ||
|
||||||
(match.key->dst && match.mask->dst != U32_MAX)) {
|
(match.key->dst && match.mask->dst != htonl(U32_MAX))) {
|
||||||
DP_NOTICE(edev, "Do not support ipv4 prefix/masks\n");
|
DP_NOTICE(edev, "Do not support ipv4 prefix/masks\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
@ -28,12 +28,12 @@ struct qede_ptp {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* qede_ptp_adjfreq
|
* qede_ptp_adjfreq() - Adjust the frequency of the PTP cycle counter.
|
||||||
* @ptp: the ptp clock structure
|
|
||||||
* @ppb: parts per billion adjustment from base
|
|
||||||
*
|
*
|
||||||
* Adjust the frequency of the ptp cycle counter by the
|
* @info: The PTP clock info structure.
|
||||||
* indicated ppb from the base frequency.
|
* @ppb: Parts per billion adjustment from base.
|
||||||
|
*
|
||||||
|
* Return: Zero on success, negative errno otherwise.
|
||||||
*/
|
*/
|
||||||
static int qede_ptp_adjfreq(struct ptp_clock_info *info, s32 ppb)
|
static int qede_ptp_adjfreq(struct ptp_clock_info *info, s32 ppb)
|
||||||
{
|
{
|
||||||
|
@ -1403,16 +1403,15 @@ static inline void qed_sb_ack(struct qed_sb_info *sb_info,
|
|||||||
enum igu_int_cmd int_cmd,
|
enum igu_int_cmd int_cmd,
|
||||||
u8 upd_flg)
|
u8 upd_flg)
|
||||||
{
|
{
|
||||||
struct igu_prod_cons_update igu_ack = { 0 };
|
u32 igu_ack;
|
||||||
|
|
||||||
igu_ack.sb_id_and_flags =
|
igu_ack = ((sb_info->sb_ack << IGU_PROD_CONS_UPDATE_SB_INDEX_SHIFT) |
|
||||||
((sb_info->sb_ack << IGU_PROD_CONS_UPDATE_SB_INDEX_SHIFT) |
|
(upd_flg << IGU_PROD_CONS_UPDATE_UPDATE_FLAG_SHIFT) |
|
||||||
(upd_flg << IGU_PROD_CONS_UPDATE_UPDATE_FLAG_SHIFT) |
|
(int_cmd << IGU_PROD_CONS_UPDATE_ENABLE_INT_SHIFT) |
|
||||||
(int_cmd << IGU_PROD_CONS_UPDATE_ENABLE_INT_SHIFT) |
|
(IGU_SEG_ACCESS_REG <<
|
||||||
(IGU_SEG_ACCESS_REG <<
|
IGU_PROD_CONS_UPDATE_SEGMENT_ACCESS_SHIFT));
|
||||||
IGU_PROD_CONS_UPDATE_SEGMENT_ACCESS_SHIFT));
|
|
||||||
|
|
||||||
DIRECT_REG_WR(sb_info->igu_addr, igu_ack.sb_id_and_flags);
|
DIRECT_REG_WR(sb_info->igu_addr, igu_ack);
|
||||||
|
|
||||||
/* Both segments (interrupts & acks) are written to same place address;
|
/* Both segments (interrupts & acks) are written to same place address;
|
||||||
* Need to guarantee all commands will be received (in-order) by HW.
|
* Need to guarantee all commands will be received (in-order) by HW.
|
||||||
|
Loading…
Reference in New Issue
Block a user