qed: Initialize hardware for new protocols
RoCE and iSCSI would require some added/changed hw configuration in order to properly run; The biggest single change being the requirement of allocating and mapping host memory for several HW blocks that aren't being used by qede [SRC, QM, TM, etc.]. In addition, whereas qede is only using context memory for HW blocks, the new protocol would also require task memories to be added. Signed-off-by: Yuval Mintz <Yuval.Mintz@qlogic.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
c5ac93191d
commit
dbb799c397
@ -187,6 +187,8 @@ struct qed_hw_info {
|
|||||||
|
|
||||||
#define RESC_START(_p_hwfn, resc) ((_p_hwfn)->hw_info.resc_start[resc])
|
#define RESC_START(_p_hwfn, resc) ((_p_hwfn)->hw_info.resc_start[resc])
|
||||||
#define RESC_NUM(_p_hwfn, resc) ((_p_hwfn)->hw_info.resc_num[resc])
|
#define RESC_NUM(_p_hwfn, resc) ((_p_hwfn)->hw_info.resc_num[resc])
|
||||||
|
#define RESC_END(_p_hwfn, resc) (RESC_START(_p_hwfn, resc) + \
|
||||||
|
RESC_NUM(_p_hwfn, resc))
|
||||||
#define FEAT_NUM(_p_hwfn, resc) ((_p_hwfn)->hw_info.feat_num[resc])
|
#define FEAT_NUM(_p_hwfn, resc) ((_p_hwfn)->hw_info.feat_num[resc])
|
||||||
|
|
||||||
u8 num_tc;
|
u8 num_tc;
|
||||||
@ -259,6 +261,7 @@ struct qed_qm_info {
|
|||||||
u8 pure_lb_pq;
|
u8 pure_lb_pq;
|
||||||
u8 offload_pq;
|
u8 offload_pq;
|
||||||
u8 pure_ack_pq;
|
u8 pure_ack_pq;
|
||||||
|
u8 ooo_pq;
|
||||||
u8 vf_queues_offset;
|
u8 vf_queues_offset;
|
||||||
u16 num_pqs;
|
u16 num_pqs;
|
||||||
u16 num_vf_pqs;
|
u16 num_vf_pqs;
|
||||||
@ -271,6 +274,7 @@ struct qed_qm_info {
|
|||||||
u8 pf_wfq;
|
u8 pf_wfq;
|
||||||
u32 pf_rl;
|
u32 pf_rl;
|
||||||
struct qed_wfq_data *wfq_data;
|
struct qed_wfq_data *wfq_data;
|
||||||
|
u8 num_pf_rls;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct storm_stats {
|
struct storm_stats {
|
||||||
@ -316,6 +320,7 @@ struct qed_hwfn {
|
|||||||
bool hw_init_done;
|
bool hw_init_done;
|
||||||
|
|
||||||
u8 num_funcs_on_engine;
|
u8 num_funcs_on_engine;
|
||||||
|
u8 enabled_func_idx;
|
||||||
|
|
||||||
/* BAR access */
|
/* BAR access */
|
||||||
void __iomem *regview;
|
void __iomem *regview;
|
||||||
@ -354,6 +359,9 @@ struct qed_hwfn {
|
|||||||
/* Protocol related */
|
/* Protocol related */
|
||||||
struct qed_pf_params pf_params;
|
struct qed_pf_params pf_params;
|
||||||
|
|
||||||
|
bool b_rdma_enabled_in_prs;
|
||||||
|
u32 rdma_prs_search_reg;
|
||||||
|
|
||||||
/* Array of sb_info of all status blocks */
|
/* Array of sb_info of all status blocks */
|
||||||
struct qed_sb_info *sbs_info[MAX_SB_PER_PF_MIMD];
|
struct qed_sb_info *sbs_info[MAX_SB_PER_PF_MIMD];
|
||||||
u16 num_sbs;
|
u16 num_sbs;
|
||||||
@ -559,6 +567,7 @@ static inline u8 qed_concrete_to_sw_fid(struct qed_dev *cdev,
|
|||||||
}
|
}
|
||||||
|
|
||||||
#define PURE_LB_TC 8
|
#define PURE_LB_TC 8
|
||||||
|
#define OOO_LB_TC 9
|
||||||
|
|
||||||
int qed_configure_vport_wfq(struct qed_dev *cdev, u16 vp_id, u32 rate);
|
int qed_configure_vport_wfq(struct qed_dev *cdev, u16 vp_id, u32 rate);
|
||||||
void qed_configure_vp_wfq_on_link_change(struct qed_dev *cdev, u32 min_pf_rate);
|
void qed_configure_vp_wfq_on_link_change(struct qed_dev *cdev, u32 min_pf_rate);
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -21,6 +21,14 @@ struct qed_cxt_info {
|
|||||||
enum protocol_type type;
|
enum protocol_type type;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define MAX_TID_BLOCKS 512
|
||||||
|
struct qed_tid_mem {
|
||||||
|
u32 tid_size;
|
||||||
|
u32 num_tids_per_block;
|
||||||
|
u32 waste;
|
||||||
|
u8 *blocks[MAX_TID_BLOCKS]; /* 4K */
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief qed_cxt_acquire - Acquire a new cid of a specific protocol type
|
* @brief qed_cxt_acquire - Acquire a new cid of a specific protocol type
|
||||||
*
|
*
|
||||||
@ -46,8 +54,22 @@ int qed_cxt_acquire_cid(struct qed_hwfn *p_hwfn,
|
|||||||
int qed_cxt_get_cid_info(struct qed_hwfn *p_hwfn,
|
int qed_cxt_get_cid_info(struct qed_hwfn *p_hwfn,
|
||||||
struct qed_cxt_info *p_info);
|
struct qed_cxt_info *p_info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief qed_cxt_get_tid_mem_info
|
||||||
|
*
|
||||||
|
* @param p_hwfn
|
||||||
|
* @param p_info
|
||||||
|
*
|
||||||
|
* @return int
|
||||||
|
*/
|
||||||
|
int qed_cxt_get_tid_mem_info(struct qed_hwfn *p_hwfn,
|
||||||
|
struct qed_tid_mem *p_info);
|
||||||
|
|
||||||
|
#define QED_CXT_ISCSI_TID_SEG PROTOCOLID_ISCSI
|
||||||
|
#define QED_CXT_ROCE_TID_SEG PROTOCOLID_ROCE
|
||||||
enum qed_cxt_elem_type {
|
enum qed_cxt_elem_type {
|
||||||
QED_ELEM_CXT,
|
QED_ELEM_CXT,
|
||||||
|
QED_ELEM_SRQ,
|
||||||
QED_ELEM_TASK
|
QED_ELEM_TASK
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -149,4 +171,6 @@ int qed_qm_reconf(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt);
|
|||||||
void qed_cxt_release_cid(struct qed_hwfn *p_hwfn,
|
void qed_cxt_release_cid(struct qed_hwfn *p_hwfn,
|
||||||
u32 cid);
|
u32 cid);
|
||||||
|
|
||||||
|
#define QED_CTX_WORKING_MEM 0
|
||||||
|
#define QED_CTX_FL_MEM 1
|
||||||
#endif
|
#endif
|
||||||
|
@ -161,9 +161,13 @@ static int qed_init_qm_info(struct qed_hwfn *p_hwfn, bool b_sleepable)
|
|||||||
u8 num_vports, vf_offset = 0, i, vport_id, num_ports, curr_queue = 0;
|
u8 num_vports, vf_offset = 0, i, vport_id, num_ports, curr_queue = 0;
|
||||||
struct qed_qm_info *qm_info = &p_hwfn->qm_info;
|
struct qed_qm_info *qm_info = &p_hwfn->qm_info;
|
||||||
struct init_qm_port_params *p_qm_port;
|
struct init_qm_port_params *p_qm_port;
|
||||||
|
bool init_rdma_offload_pq = false;
|
||||||
|
bool init_pure_ack_pq = false;
|
||||||
|
bool init_ooo_pq = false;
|
||||||
u16 num_pqs, multi_cos_tcs = 1;
|
u16 num_pqs, multi_cos_tcs = 1;
|
||||||
u8 pf_wfq = qm_info->pf_wfq;
|
u8 pf_wfq = qm_info->pf_wfq;
|
||||||
u32 pf_rl = qm_info->pf_rl;
|
u32 pf_rl = qm_info->pf_rl;
|
||||||
|
u16 num_pf_rls = 0;
|
||||||
u16 num_vfs = 0;
|
u16 num_vfs = 0;
|
||||||
|
|
||||||
#ifdef CONFIG_QED_SRIOV
|
#ifdef CONFIG_QED_SRIOV
|
||||||
@ -175,6 +179,25 @@ static int qed_init_qm_info(struct qed_hwfn *p_hwfn, bool b_sleepable)
|
|||||||
num_pqs = multi_cos_tcs + num_vfs + 1; /* The '1' is for pure-LB */
|
num_pqs = multi_cos_tcs + num_vfs + 1; /* The '1' is for pure-LB */
|
||||||
num_vports = (u8)RESC_NUM(p_hwfn, QED_VPORT);
|
num_vports = (u8)RESC_NUM(p_hwfn, QED_VPORT);
|
||||||
|
|
||||||
|
if (p_hwfn->hw_info.personality == QED_PCI_ETH_ROCE) {
|
||||||
|
num_pqs++; /* for RoCE queue */
|
||||||
|
init_rdma_offload_pq = true;
|
||||||
|
/* we subtract num_vfs because each require a rate limiter,
|
||||||
|
* and one default rate limiter
|
||||||
|
*/
|
||||||
|
if (p_hwfn->pf_params.rdma_pf_params.enable_dcqcn)
|
||||||
|
num_pf_rls = RESC_NUM(p_hwfn, QED_RL) - num_vfs - 1;
|
||||||
|
|
||||||
|
num_pqs += num_pf_rls;
|
||||||
|
qm_info->num_pf_rls = (u8) num_pf_rls;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (p_hwfn->hw_info.personality == QED_PCI_ISCSI) {
|
||||||
|
num_pqs += 2; /* for iSCSI pure-ACK / OOO queue */
|
||||||
|
init_pure_ack_pq = true;
|
||||||
|
init_ooo_pq = true;
|
||||||
|
}
|
||||||
|
|
||||||
/* Sanity checking that setup requires legal number of resources */
|
/* Sanity checking that setup requires legal number of resources */
|
||||||
if (num_pqs > RESC_NUM(p_hwfn, QED_PQ)) {
|
if (num_pqs > RESC_NUM(p_hwfn, QED_PQ)) {
|
||||||
DP_ERR(p_hwfn,
|
DP_ERR(p_hwfn,
|
||||||
@ -212,12 +235,22 @@ static int qed_init_qm_info(struct qed_hwfn *p_hwfn, bool b_sleepable)
|
|||||||
|
|
||||||
vport_id = (u8)RESC_START(p_hwfn, QED_VPORT);
|
vport_id = (u8)RESC_START(p_hwfn, QED_VPORT);
|
||||||
|
|
||||||
|
/* First init rate limited queues */
|
||||||
|
for (curr_queue = 0; curr_queue < num_pf_rls; curr_queue++) {
|
||||||
|
qm_info->qm_pq_params[curr_queue].vport_id = vport_id++;
|
||||||
|
qm_info->qm_pq_params[curr_queue].tc_id =
|
||||||
|
p_hwfn->hw_info.non_offload_tc;
|
||||||
|
qm_info->qm_pq_params[curr_queue].wrr_group = 1;
|
||||||
|
qm_info->qm_pq_params[curr_queue].rl_valid = 1;
|
||||||
|
}
|
||||||
|
|
||||||
/* First init per-TC PQs */
|
/* First init per-TC PQs */
|
||||||
for (i = 0; i < multi_cos_tcs; i++) {
|
for (i = 0; i < multi_cos_tcs; i++) {
|
||||||
struct init_qm_pq_params *params =
|
struct init_qm_pq_params *params =
|
||||||
&qm_info->qm_pq_params[curr_queue++];
|
&qm_info->qm_pq_params[curr_queue++];
|
||||||
|
|
||||||
if (p_hwfn->hw_info.personality == QED_PCI_ETH) {
|
if (p_hwfn->hw_info.personality == QED_PCI_ETH_ROCE ||
|
||||||
|
p_hwfn->hw_info.personality == QED_PCI_ETH) {
|
||||||
params->vport_id = vport_id;
|
params->vport_id = vport_id;
|
||||||
params->tc_id = p_hwfn->hw_info.non_offload_tc;
|
params->tc_id = p_hwfn->hw_info.non_offload_tc;
|
||||||
params->wrr_group = 1;
|
params->wrr_group = 1;
|
||||||
@ -237,6 +270,32 @@ static int qed_init_qm_info(struct qed_hwfn *p_hwfn, bool b_sleepable)
|
|||||||
curr_queue++;
|
curr_queue++;
|
||||||
|
|
||||||
qm_info->offload_pq = 0;
|
qm_info->offload_pq = 0;
|
||||||
|
if (init_rdma_offload_pq) {
|
||||||
|
qm_info->offload_pq = curr_queue;
|
||||||
|
qm_info->qm_pq_params[curr_queue].vport_id = vport_id;
|
||||||
|
qm_info->qm_pq_params[curr_queue].tc_id =
|
||||||
|
p_hwfn->hw_info.offload_tc;
|
||||||
|
qm_info->qm_pq_params[curr_queue].wrr_group = 1;
|
||||||
|
curr_queue++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (init_pure_ack_pq) {
|
||||||
|
qm_info->pure_ack_pq = curr_queue;
|
||||||
|
qm_info->qm_pq_params[curr_queue].vport_id = vport_id;
|
||||||
|
qm_info->qm_pq_params[curr_queue].tc_id =
|
||||||
|
p_hwfn->hw_info.offload_tc;
|
||||||
|
qm_info->qm_pq_params[curr_queue].wrr_group = 1;
|
||||||
|
curr_queue++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (init_ooo_pq) {
|
||||||
|
qm_info->ooo_pq = curr_queue;
|
||||||
|
qm_info->qm_pq_params[curr_queue].vport_id = vport_id;
|
||||||
|
qm_info->qm_pq_params[curr_queue].tc_id = DCBX_ISCSI_OOO_TC;
|
||||||
|
qm_info->qm_pq_params[curr_queue].wrr_group = 1;
|
||||||
|
curr_queue++;
|
||||||
|
}
|
||||||
|
|
||||||
/* Then init per-VF PQs */
|
/* Then init per-VF PQs */
|
||||||
vf_offset = curr_queue;
|
vf_offset = curr_queue;
|
||||||
for (i = 0; i < num_vfs; i++) {
|
for (i = 0; i < num_vfs; i++) {
|
||||||
@ -371,21 +430,20 @@ int qed_resc_alloc(struct qed_dev *cdev)
|
|||||||
if (!p_hwfn->p_tx_cids) {
|
if (!p_hwfn->p_tx_cids) {
|
||||||
DP_NOTICE(p_hwfn,
|
DP_NOTICE(p_hwfn,
|
||||||
"Failed to allocate memory for Tx Cids\n");
|
"Failed to allocate memory for Tx Cids\n");
|
||||||
rc = -ENOMEM;
|
goto alloc_no_mem;
|
||||||
goto alloc_err;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
p_hwfn->p_rx_cids = kzalloc(rx_size, GFP_KERNEL);
|
p_hwfn->p_rx_cids = kzalloc(rx_size, GFP_KERNEL);
|
||||||
if (!p_hwfn->p_rx_cids) {
|
if (!p_hwfn->p_rx_cids) {
|
||||||
DP_NOTICE(p_hwfn,
|
DP_NOTICE(p_hwfn,
|
||||||
"Failed to allocate memory for Rx Cids\n");
|
"Failed to allocate memory for Rx Cids\n");
|
||||||
rc = -ENOMEM;
|
goto alloc_no_mem;
|
||||||
goto alloc_err;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for_each_hwfn(cdev, i) {
|
for_each_hwfn(cdev, i) {
|
||||||
struct qed_hwfn *p_hwfn = &cdev->hwfns[i];
|
struct qed_hwfn *p_hwfn = &cdev->hwfns[i];
|
||||||
|
u32 n_eqes, num_cons;
|
||||||
|
|
||||||
/* First allocate the context manager structure */
|
/* First allocate the context manager structure */
|
||||||
rc = qed_cxt_mngr_alloc(p_hwfn);
|
rc = qed_cxt_mngr_alloc(p_hwfn);
|
||||||
@ -434,18 +492,34 @@ int qed_resc_alloc(struct qed_dev *cdev)
|
|||||||
goto alloc_err;
|
goto alloc_err;
|
||||||
|
|
||||||
/* EQ */
|
/* EQ */
|
||||||
p_eq = qed_eq_alloc(p_hwfn, 256);
|
n_eqes = qed_chain_get_capacity(&p_hwfn->p_spq->chain);
|
||||||
if (!p_eq) {
|
if (p_hwfn->hw_info.personality == QED_PCI_ETH_ROCE) {
|
||||||
rc = -ENOMEM;
|
num_cons = qed_cxt_get_proto_cid_count(p_hwfn,
|
||||||
|
PROTOCOLID_ROCE,
|
||||||
|
0) * 2;
|
||||||
|
n_eqes += num_cons + 2 * MAX_NUM_VFS_BB;
|
||||||
|
} else if (p_hwfn->hw_info.personality == QED_PCI_ISCSI) {
|
||||||
|
num_cons =
|
||||||
|
qed_cxt_get_proto_cid_count(p_hwfn,
|
||||||
|
PROTOCOLID_ISCSI, 0);
|
||||||
|
n_eqes += 2 * num_cons;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (n_eqes > 0xFFFF) {
|
||||||
|
DP_ERR(p_hwfn,
|
||||||
|
"Cannot allocate 0x%x EQ elements. The maximum of a u16 chain is 0x%x\n",
|
||||||
|
n_eqes, 0xFFFF);
|
||||||
goto alloc_err;
|
goto alloc_err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
p_eq = qed_eq_alloc(p_hwfn, (u16) n_eqes);
|
||||||
|
if (!p_eq)
|
||||||
|
goto alloc_no_mem;
|
||||||
p_hwfn->p_eq = p_eq;
|
p_hwfn->p_eq = p_eq;
|
||||||
|
|
||||||
p_consq = qed_consq_alloc(p_hwfn);
|
p_consq = qed_consq_alloc(p_hwfn);
|
||||||
if (!p_consq) {
|
if (!p_consq)
|
||||||
rc = -ENOMEM;
|
goto alloc_no_mem;
|
||||||
goto alloc_err;
|
|
||||||
}
|
|
||||||
p_hwfn->p_consq = p_consq;
|
p_hwfn->p_consq = p_consq;
|
||||||
|
|
||||||
/* DMA info initialization */
|
/* DMA info initialization */
|
||||||
@ -474,6 +548,8 @@ int qed_resc_alloc(struct qed_dev *cdev)
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
alloc_no_mem:
|
||||||
|
rc = -ENOMEM;
|
||||||
alloc_err:
|
alloc_err:
|
||||||
qed_resc_free(cdev);
|
qed_resc_free(cdev);
|
||||||
return rc;
|
return rc;
|
||||||
@ -639,6 +715,7 @@ static int qed_hw_init_common(struct qed_hwfn *p_hwfn,
|
|||||||
struct qed_qm_info *qm_info = &p_hwfn->qm_info;
|
struct qed_qm_info *qm_info = &p_hwfn->qm_info;
|
||||||
struct qed_qm_common_rt_init_params params;
|
struct qed_qm_common_rt_init_params params;
|
||||||
struct qed_dev *cdev = p_hwfn->cdev;
|
struct qed_dev *cdev = p_hwfn->cdev;
|
||||||
|
u16 num_pfs, pf_id;
|
||||||
u32 concrete_fid;
|
u32 concrete_fid;
|
||||||
int rc = 0;
|
int rc = 0;
|
||||||
u8 vf_id;
|
u8 vf_id;
|
||||||
@ -687,9 +764,16 @@ static int qed_hw_init_common(struct qed_hwfn *p_hwfn,
|
|||||||
qed_wr(p_hwfn, p_ptt, PSWRQ2_REG_L2P_VALIDATE_VFID, 0);
|
qed_wr(p_hwfn, p_ptt, PSWRQ2_REG_L2P_VALIDATE_VFID, 0);
|
||||||
qed_wr(p_hwfn, p_ptt, PGLUE_B_REG_USE_CLIENTID_IN_TAG, 1);
|
qed_wr(p_hwfn, p_ptt, PGLUE_B_REG_USE_CLIENTID_IN_TAG, 1);
|
||||||
|
|
||||||
/* Disable relaxed ordering in the PCI config space */
|
if (QED_IS_BB(p_hwfn->cdev)) {
|
||||||
qed_wr(p_hwfn, p_ptt, 0x20b4,
|
num_pfs = NUM_OF_ENG_PFS(p_hwfn->cdev);
|
||||||
qed_rd(p_hwfn, p_ptt, 0x20b4) & ~0x10);
|
for (pf_id = 0; pf_id < num_pfs; pf_id++) {
|
||||||
|
qed_fid_pretend(p_hwfn, p_ptt, pf_id);
|
||||||
|
qed_wr(p_hwfn, p_ptt, PRS_REG_SEARCH_ROCE, 0x0);
|
||||||
|
qed_wr(p_hwfn, p_ptt, PRS_REG_SEARCH_TCP, 0x0);
|
||||||
|
}
|
||||||
|
/* pretend to original PF */
|
||||||
|
qed_fid_pretend(p_hwfn, p_ptt, p_hwfn->rel_pf_id);
|
||||||
|
}
|
||||||
|
|
||||||
for (vf_id = 0; vf_id < MAX_NUM_VFS_BB; vf_id++) {
|
for (vf_id = 0; vf_id < MAX_NUM_VFS_BB; vf_id++) {
|
||||||
concrete_fid = qed_vfid_to_concrete(p_hwfn, vf_id);
|
concrete_fid = qed_vfid_to_concrete(p_hwfn, vf_id);
|
||||||
@ -779,7 +863,8 @@ static int qed_hw_init_pf(struct qed_hwfn *p_hwfn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Protocl Configuration */
|
/* Protocl Configuration */
|
||||||
STORE_RT_REG(p_hwfn, PRS_REG_SEARCH_TCP_RT_OFFSET, 0);
|
STORE_RT_REG(p_hwfn, PRS_REG_SEARCH_TCP_RT_OFFSET,
|
||||||
|
(p_hwfn->hw_info.personality == QED_PCI_ISCSI) ? 1 : 0);
|
||||||
STORE_RT_REG(p_hwfn, PRS_REG_SEARCH_FCOE_RT_OFFSET, 0);
|
STORE_RT_REG(p_hwfn, PRS_REG_SEARCH_FCOE_RT_OFFSET, 0);
|
||||||
STORE_RT_REG(p_hwfn, PRS_REG_SEARCH_ROCE_RT_OFFSET, 0);
|
STORE_RT_REG(p_hwfn, PRS_REG_SEARCH_ROCE_RT_OFFSET, 0);
|
||||||
|
|
||||||
@ -1256,8 +1341,9 @@ static void qed_hw_set_feat(struct qed_hwfn *p_hwfn)
|
|||||||
num_features);
|
num_features);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void qed_hw_get_resc(struct qed_hwfn *p_hwfn)
|
static int qed_hw_get_resc(struct qed_hwfn *p_hwfn)
|
||||||
{
|
{
|
||||||
|
u8 enabled_func_idx = p_hwfn->enabled_func_idx;
|
||||||
u32 *resc_start = p_hwfn->hw_info.resc_start;
|
u32 *resc_start = p_hwfn->hw_info.resc_start;
|
||||||
u8 num_funcs = p_hwfn->num_funcs_on_engine;
|
u8 num_funcs = p_hwfn->num_funcs_on_engine;
|
||||||
u32 *resc_num = p_hwfn->hw_info.resc_num;
|
u32 *resc_num = p_hwfn->hw_info.resc_num;
|
||||||
@ -1281,14 +1367,22 @@ static void qed_hw_get_resc(struct qed_hwfn *p_hwfn)
|
|||||||
resc_num[QED_VPORT] = MAX_NUM_VPORTS_BB / num_funcs;
|
resc_num[QED_VPORT] = MAX_NUM_VPORTS_BB / num_funcs;
|
||||||
resc_num[QED_RSS_ENG] = ETH_RSS_ENGINE_NUM_BB / num_funcs;
|
resc_num[QED_RSS_ENG] = ETH_RSS_ENGINE_NUM_BB / num_funcs;
|
||||||
resc_num[QED_PQ] = MAX_QM_TX_QUEUES_BB / num_funcs;
|
resc_num[QED_PQ] = MAX_QM_TX_QUEUES_BB / num_funcs;
|
||||||
resc_num[QED_RL] = 8;
|
resc_num[QED_RL] = min_t(u32, 64, resc_num[QED_VPORT]);
|
||||||
resc_num[QED_MAC] = ETH_NUM_MAC_FILTERS / num_funcs;
|
resc_num[QED_MAC] = ETH_NUM_MAC_FILTERS / num_funcs;
|
||||||
resc_num[QED_VLAN] = (ETH_NUM_VLAN_FILTERS - 1 /*For vlan0*/) /
|
resc_num[QED_VLAN] = (ETH_NUM_VLAN_FILTERS - 1 /*For vlan0*/) /
|
||||||
num_funcs;
|
num_funcs;
|
||||||
resc_num[QED_ILT] = 950;
|
resc_num[QED_ILT] = PXP_NUM_ILT_RECORDS_BB / num_funcs;
|
||||||
|
|
||||||
for (i = 0; i < QED_MAX_RESC; i++)
|
for (i = 0; i < QED_MAX_RESC; i++)
|
||||||
resc_start[i] = resc_num[i] * p_hwfn->rel_pf_id;
|
resc_start[i] = resc_num[i] * enabled_func_idx;
|
||||||
|
|
||||||
|
/* Sanity for ILT */
|
||||||
|
if (RESC_END(p_hwfn, QED_ILT) > PXP_NUM_ILT_RECORDS_BB) {
|
||||||
|
DP_NOTICE(p_hwfn, "Can't assign ILT pages [%08x,...,%08x]\n",
|
||||||
|
RESC_START(p_hwfn, QED_ILT),
|
||||||
|
RESC_END(p_hwfn, QED_ILT) - 1);
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
qed_hw_set_feat(p_hwfn);
|
qed_hw_set_feat(p_hwfn);
|
||||||
|
|
||||||
@ -1318,6 +1412,8 @@ static void qed_hw_get_resc(struct qed_hwfn *p_hwfn)
|
|||||||
p_hwfn->hw_info.resc_start[QED_VLAN],
|
p_hwfn->hw_info.resc_start[QED_VLAN],
|
||||||
p_hwfn->hw_info.resc_num[QED_ILT],
|
p_hwfn->hw_info.resc_num[QED_ILT],
|
||||||
p_hwfn->hw_info.resc_start[QED_ILT]);
|
p_hwfn->hw_info.resc_start[QED_ILT]);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qed_hw_get_nvm_info(struct qed_hwfn *p_hwfn,
|
static int qed_hw_get_nvm_info(struct qed_hwfn *p_hwfn,
|
||||||
@ -1484,8 +1580,8 @@ static int qed_hw_get_nvm_info(struct qed_hwfn *p_hwfn,
|
|||||||
|
|
||||||
static void qed_get_num_funcs(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt)
|
static void qed_get_num_funcs(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt)
|
||||||
{
|
{
|
||||||
u32 reg_function_hide, tmp, eng_mask;
|
u8 num_funcs, enabled_func_idx = p_hwfn->rel_pf_id;
|
||||||
u8 num_funcs;
|
u32 reg_function_hide, tmp, eng_mask, low_pfs_mask;
|
||||||
|
|
||||||
num_funcs = MAX_NUM_PFS_BB;
|
num_funcs = MAX_NUM_PFS_BB;
|
||||||
|
|
||||||
@ -1515,9 +1611,19 @@ static void qed_get_num_funcs(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt)
|
|||||||
num_funcs++;
|
num_funcs++;
|
||||||
tmp >>= 0x1;
|
tmp >>= 0x1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Get the PF index within the enabled functions */
|
||||||
|
low_pfs_mask = (0x1 << p_hwfn->abs_pf_id) - 1;
|
||||||
|
tmp = reg_function_hide & eng_mask & low_pfs_mask;
|
||||||
|
while (tmp) {
|
||||||
|
if (tmp & 0x1)
|
||||||
|
enabled_func_idx--;
|
||||||
|
tmp >>= 0x1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p_hwfn->num_funcs_on_engine = num_funcs;
|
p_hwfn->num_funcs_on_engine = num_funcs;
|
||||||
|
p_hwfn->enabled_func_idx = enabled_func_idx;
|
||||||
|
|
||||||
DP_VERBOSE(p_hwfn,
|
DP_VERBOSE(p_hwfn,
|
||||||
NETIF_MSG_PROBE,
|
NETIF_MSG_PROBE,
|
||||||
@ -1587,9 +1693,7 @@ qed_get_hw_info(struct qed_hwfn *p_hwfn,
|
|||||||
|
|
||||||
qed_get_num_funcs(p_hwfn, p_ptt);
|
qed_get_num_funcs(p_hwfn, p_ptt);
|
||||||
|
|
||||||
qed_hw_get_resc(p_hwfn);
|
return qed_hw_get_resc(p_hwfn);
|
||||||
|
|
||||||
return rc;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qed_get_dev_info(struct qed_dev *cdev)
|
static int qed_get_dev_info(struct qed_dev *cdev)
|
||||||
|
@ -791,16 +791,16 @@ qed_dmae_host2host(struct qed_hwfn *p_hwfn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
u16 qed_get_qm_pq(struct qed_hwfn *p_hwfn,
|
u16 qed_get_qm_pq(struct qed_hwfn *p_hwfn,
|
||||||
enum protocol_type proto,
|
enum protocol_type proto, union qed_qm_pq_params *p_params)
|
||||||
union qed_qm_pq_params *p_params)
|
|
||||||
{
|
{
|
||||||
u16 pq_id = 0;
|
u16 pq_id = 0;
|
||||||
|
|
||||||
if ((proto == PROTOCOLID_CORE || proto == PROTOCOLID_ETH) &&
|
if ((proto == PROTOCOLID_CORE ||
|
||||||
!p_params) {
|
proto == PROTOCOLID_ETH ||
|
||||||
|
proto == PROTOCOLID_ISCSI ||
|
||||||
|
proto == PROTOCOLID_ROCE) && !p_params) {
|
||||||
DP_NOTICE(p_hwfn,
|
DP_NOTICE(p_hwfn,
|
||||||
"Protocol %d received NULL PQ params\n",
|
"Protocol %d received NULL PQ params\n", proto);
|
||||||
proto);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -808,6 +808,8 @@ u16 qed_get_qm_pq(struct qed_hwfn *p_hwfn,
|
|||||||
case PROTOCOLID_CORE:
|
case PROTOCOLID_CORE:
|
||||||
if (p_params->core.tc == LB_TC)
|
if (p_params->core.tc == LB_TC)
|
||||||
pq_id = p_hwfn->qm_info.pure_lb_pq;
|
pq_id = p_hwfn->qm_info.pure_lb_pq;
|
||||||
|
else if (p_params->core.tc == OOO_LB_TC)
|
||||||
|
pq_id = p_hwfn->qm_info.ooo_pq;
|
||||||
else
|
else
|
||||||
pq_id = p_hwfn->qm_info.offload_pq;
|
pq_id = p_hwfn->qm_info.offload_pq;
|
||||||
break;
|
break;
|
||||||
@ -817,6 +819,18 @@ u16 qed_get_qm_pq(struct qed_hwfn *p_hwfn,
|
|||||||
pq_id += p_hwfn->qm_info.vf_queues_offset +
|
pq_id += p_hwfn->qm_info.vf_queues_offset +
|
||||||
p_params->eth.vf_id;
|
p_params->eth.vf_id;
|
||||||
break;
|
break;
|
||||||
|
case PROTOCOLID_ISCSI:
|
||||||
|
if (p_params->iscsi.q_idx == 1)
|
||||||
|
pq_id = p_hwfn->qm_info.pure_ack_pq;
|
||||||
|
break;
|
||||||
|
case PROTOCOLID_ROCE:
|
||||||
|
if (p_params->roce.dcqcn)
|
||||||
|
pq_id = p_params->roce.qpid;
|
||||||
|
else
|
||||||
|
pq_id = p_hwfn->qm_info.offload_pq;
|
||||||
|
if (pq_id > p_hwfn->qm_info.num_pf_rls)
|
||||||
|
pq_id = p_hwfn->qm_info.offload_pq;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
pq_id = 0;
|
pq_id = 0;
|
||||||
}
|
}
|
||||||
|
@ -253,6 +253,10 @@ int qed_dmae_info_alloc(struct qed_hwfn *p_hwfn);
|
|||||||
void qed_dmae_info_free(struct qed_hwfn *p_hwfn);
|
void qed_dmae_info_free(struct qed_hwfn *p_hwfn);
|
||||||
|
|
||||||
union qed_qm_pq_params {
|
union qed_qm_pq_params {
|
||||||
|
struct {
|
||||||
|
u8 q_idx;
|
||||||
|
} iscsi;
|
||||||
|
|
||||||
struct {
|
struct {
|
||||||
u8 tc;
|
u8 tc;
|
||||||
} core;
|
} core;
|
||||||
@ -262,11 +266,15 @@ union qed_qm_pq_params {
|
|||||||
u8 vf_id;
|
u8 vf_id;
|
||||||
u8 tc;
|
u8 tc;
|
||||||
} eth;
|
} eth;
|
||||||
|
|
||||||
|
struct {
|
||||||
|
u8 dcqcn;
|
||||||
|
u8 qpid; /* roce relative */
|
||||||
|
} roce;
|
||||||
};
|
};
|
||||||
|
|
||||||
u16 qed_get_qm_pq(struct qed_hwfn *p_hwfn,
|
u16 qed_get_qm_pq(struct qed_hwfn *p_hwfn,
|
||||||
enum protocol_type proto,
|
enum protocol_type proto, union qed_qm_pq_params *params);
|
||||||
union qed_qm_pq_params *params);
|
|
||||||
|
|
||||||
int qed_init_fw_data(struct qed_dev *cdev,
|
int qed_init_fw_data(struct qed_dev *cdev,
|
||||||
const u8 *fw_data);
|
const u8 *fw_data);
|
||||||
|
@ -27,6 +27,35 @@
|
|||||||
#define CDU_REG_CID_ADDR_PARAMS_NCIB ( \
|
#define CDU_REG_CID_ADDR_PARAMS_NCIB ( \
|
||||||
0xff << 24)
|
0xff << 24)
|
||||||
|
|
||||||
|
#define CDU_REG_SEGMENT0_PARAMS \
|
||||||
|
0x580904UL
|
||||||
|
#define CDU_REG_SEGMENT0_PARAMS_T0_NUM_TIDS_IN_BLOCK \
|
||||||
|
(0xfff << 0)
|
||||||
|
#define CDU_REG_SEGMENT0_PARAMS_T0_NUM_TIDS_IN_BLOCK_SHIFT \
|
||||||
|
0
|
||||||
|
#define CDU_REG_SEGMENT0_PARAMS_T0_TID_BLOCK_WASTE \
|
||||||
|
(0xff << 16)
|
||||||
|
#define CDU_REG_SEGMENT0_PARAMS_T0_TID_BLOCK_WASTE_SHIFT \
|
||||||
|
16
|
||||||
|
#define CDU_REG_SEGMENT0_PARAMS_T0_TID_SIZE \
|
||||||
|
(0xff << 24)
|
||||||
|
#define CDU_REG_SEGMENT0_PARAMS_T0_TID_SIZE_SHIFT \
|
||||||
|
24
|
||||||
|
#define CDU_REG_SEGMENT1_PARAMS \
|
||||||
|
0x580908UL
|
||||||
|
#define CDU_REG_SEGMENT1_PARAMS_T1_NUM_TIDS_IN_BLOCK \
|
||||||
|
(0xfff << 0)
|
||||||
|
#define CDU_REG_SEGMENT1_PARAMS_T1_NUM_TIDS_IN_BLOCK_SHIFT \
|
||||||
|
0
|
||||||
|
#define CDU_REG_SEGMENT1_PARAMS_T1_TID_BLOCK_WASTE \
|
||||||
|
(0xff << 16)
|
||||||
|
#define CDU_REG_SEGMENT1_PARAMS_T1_TID_BLOCK_WASTE_SHIFT \
|
||||||
|
16
|
||||||
|
#define CDU_REG_SEGMENT1_PARAMS_T1_TID_SIZE \
|
||||||
|
(0xff << 24)
|
||||||
|
#define CDU_REG_SEGMENT1_PARAMS_T1_TID_SIZE_SHIFT \
|
||||||
|
24
|
||||||
|
|
||||||
#define XSDM_REG_OPERATION_GEN \
|
#define XSDM_REG_OPERATION_GEN \
|
||||||
0xf80408UL
|
0xf80408UL
|
||||||
#define NIG_REG_RX_BRB_OUT_EN \
|
#define NIG_REG_RX_BRB_OUT_EN \
|
||||||
@ -225,6 +254,8 @@
|
|||||||
0x1f0000UL
|
0x1f0000UL
|
||||||
#define PRS_REG_MSG_INFO \
|
#define PRS_REG_MSG_INFO \
|
||||||
0x1f0a1cUL
|
0x1f0a1cUL
|
||||||
|
#define PRS_REG_ROCE_DEST_QP_MAX_PF \
|
||||||
|
0x1f0430UL
|
||||||
#define PSDM_REG_ENABLE_IN1 \
|
#define PSDM_REG_ENABLE_IN1 \
|
||||||
0xfa0004UL
|
0xfa0004UL
|
||||||
#define PSEM_REG_ENABLE_IN \
|
#define PSEM_REG_ENABLE_IN \
|
||||||
@ -233,6 +264,8 @@
|
|||||||
0x280020UL
|
0x280020UL
|
||||||
#define PSWRQ2_REG_CDUT_P_SIZE \
|
#define PSWRQ2_REG_CDUT_P_SIZE \
|
||||||
0x24000cUL
|
0x24000cUL
|
||||||
|
#define PSWRQ2_REG_ILT_MEMORY \
|
||||||
|
0x260000UL
|
||||||
#define PSWHST_REG_DISCARD_INTERNAL_WRITES \
|
#define PSWHST_REG_DISCARD_INTERNAL_WRITES \
|
||||||
0x2a0040UL
|
0x2a0040UL
|
||||||
#define PSWHST2_REG_DBGSYN_ALMOST_FULL_THR \
|
#define PSWHST2_REG_DBGSYN_ALMOST_FULL_THR \
|
||||||
|
Loading…
x
Reference in New Issue
Block a user