Commit 4c85e575 authored by Hariprasad Kelam's avatar Hariprasad Kelam Committed by David S. Miller

octeontx2-pf: Dont enable backpressure on LBK links

Avoid configure backpressure for LBK links as they
don't support it and enable lmacs before configuration
pause frames.

Fixes: 75f36270 ("octeontx2-pf: Support to enable/disable pause frames via ethtool")
Signed-off-by: default avatarGeetha sowjanya <gakula@marvell.com>
Signed-off-by: default avatarHariprasad Kelam <hkelam@marvell.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 69f0aeb1
...@@ -1504,8 +1504,8 @@ static int cgx_lmac_init(struct cgx *cgx) ...@@ -1504,8 +1504,8 @@ static int cgx_lmac_init(struct cgx *cgx)
/* Add reference */ /* Add reference */
cgx->lmac_idmap[lmac->lmac_id] = lmac; cgx->lmac_idmap[lmac->lmac_id] = lmac;
cgx->mac_ops->mac_pause_frm_config(cgx, lmac->lmac_id, true);
set_bit(lmac->lmac_id, &cgx->lmac_bmap); set_bit(lmac->lmac_id, &cgx->lmac_bmap);
cgx->mac_ops->mac_pause_frm_config(cgx, lmac->lmac_id, true);
} }
return cgx_lmac_verify_fwi_version(cgx); return cgx_lmac_verify_fwi_version(cgx);
......
...@@ -924,6 +924,7 @@ static int otx2_cq_init(struct otx2_nic *pfvf, u16 qidx) ...@@ -924,6 +924,7 @@ static int otx2_cq_init(struct otx2_nic *pfvf, u16 qidx)
aq->cq.drop = RQ_DROP_LVL_CQ(pfvf->hw.rq_skid, cq->cqe_cnt); aq->cq.drop = RQ_DROP_LVL_CQ(pfvf->hw.rq_skid, cq->cqe_cnt);
aq->cq.drop_ena = 1; aq->cq.drop_ena = 1;
if (!is_otx2_lbkvf(pfvf->pdev)) {
/* Enable receive CQ backpressure */ /* Enable receive CQ backpressure */
aq->cq.bp_ena = 1; aq->cq.bp_ena = 1;
aq->cq.bpid = pfvf->bpid[0]; aq->cq.bpid = pfvf->bpid[0];
...@@ -931,6 +932,7 @@ static int otx2_cq_init(struct otx2_nic *pfvf, u16 qidx) ...@@ -931,6 +932,7 @@ static int otx2_cq_init(struct otx2_nic *pfvf, u16 qidx)
/* Set backpressure level is same as cq pass level */ /* Set backpressure level is same as cq pass level */
aq->cq.bp = RQ_PASS_LVL_CQ(pfvf->hw.rq_skid, qset->rqe_cnt); aq->cq.bp = RQ_PASS_LVL_CQ(pfvf->hw.rq_skid, qset->rqe_cnt);
} }
}
/* Fill AQ info */ /* Fill AQ info */
aq->qidx = qidx; aq->qidx = qidx;
...@@ -1186,7 +1188,7 @@ static int otx2_aura_init(struct otx2_nic *pfvf, int aura_id, ...@@ -1186,7 +1188,7 @@ static int otx2_aura_init(struct otx2_nic *pfvf, int aura_id,
aq->aura.fc_hyst_bits = 0; /* Store count on all updates */ aq->aura.fc_hyst_bits = 0; /* Store count on all updates */
/* Enable backpressure for RQ aura */ /* Enable backpressure for RQ aura */
if (aura_id < pfvf->hw.rqpool_cnt) { if (aura_id < pfvf->hw.rqpool_cnt && !is_otx2_lbkvf(pfvf->pdev)) {
aq->aura.bp_ena = 0; aq->aura.bp_ena = 0;
aq->aura.nix0_bpid = pfvf->bpid[0]; aq->aura.nix0_bpid = pfvf->bpid[0];
/* Set backpressure level for RQ's Aura */ /* Set backpressure level for RQ's Aura */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment