Commit 8c97ab54 authored by Suman Ghosh's avatar Suman Ghosh Committed by David S. Miller

octeontx2-pf: Fix graceful exit during PFC configuration failure

During PFC configuration failure the code was not handling a graceful
exit. This patch fixes the same and add proper code for a graceful exit.

Fixes: 99c969a8 ("octeontx2-pf: Add egress PFC support")
Signed-off-by: default avatarSuman Ghosh <sumang@marvell.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 738b54b9
...@@ -399,9 +399,10 @@ static int otx2_dcbnl_ieee_getpfc(struct net_device *dev, struct ieee_pfc *pfc) ...@@ -399,9 +399,10 @@ static int otx2_dcbnl_ieee_getpfc(struct net_device *dev, struct ieee_pfc *pfc)
static int otx2_dcbnl_ieee_setpfc(struct net_device *dev, struct ieee_pfc *pfc) static int otx2_dcbnl_ieee_setpfc(struct net_device *dev, struct ieee_pfc *pfc)
{ {
struct otx2_nic *pfvf = netdev_priv(dev); struct otx2_nic *pfvf = netdev_priv(dev);
u8 old_pfc_en;
int err; int err;
/* Save PFC configuration to interface */ old_pfc_en = pfvf->pfc_en;
pfvf->pfc_en = pfc->pfc_en; pfvf->pfc_en = pfc->pfc_en;
if (pfvf->hw.tx_queues >= NIX_PF_PFC_PRIO_MAX) if (pfvf->hw.tx_queues >= NIX_PF_PFC_PRIO_MAX)
...@@ -411,13 +412,17 @@ static int otx2_dcbnl_ieee_setpfc(struct net_device *dev, struct ieee_pfc *pfc) ...@@ -411,13 +412,17 @@ static int otx2_dcbnl_ieee_setpfc(struct net_device *dev, struct ieee_pfc *pfc)
* supported by the tx queue configuration * supported by the tx queue configuration
*/ */
err = otx2_check_pfc_config(pfvf); err = otx2_check_pfc_config(pfvf);
if (err) if (err) {
pfvf->pfc_en = old_pfc_en;
return err; return err;
}
process_pfc: process_pfc:
err = otx2_config_priority_flow_ctrl(pfvf); err = otx2_config_priority_flow_ctrl(pfvf);
if (err) if (err) {
pfvf->pfc_en = old_pfc_en;
return err; return err;
}
/* Request Per channel Bpids */ /* Request Per channel Bpids */
if (pfc->pfc_en) if (pfc->pfc_en)
...@@ -425,6 +430,12 @@ static int otx2_dcbnl_ieee_setpfc(struct net_device *dev, struct ieee_pfc *pfc) ...@@ -425,6 +430,12 @@ static int otx2_dcbnl_ieee_setpfc(struct net_device *dev, struct ieee_pfc *pfc)
err = otx2_pfc_txschq_update(pfvf); err = otx2_pfc_txschq_update(pfvf);
if (err) { if (err) {
if (pfc->pfc_en)
otx2_nix_config_bp(pfvf, false);
otx2_pfc_txschq_stop(pfvf);
pfvf->pfc_en = old_pfc_en;
otx2_config_priority_flow_ctrl(pfvf);
dev_err(pfvf->dev, "%s failed to update TX schedulers\n", __func__); dev_err(pfvf->dev, "%s failed to update TX schedulers\n", __func__);
return err; return err;
} }
......
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